Best Practices
Prompt response to webhooks
When you receive our webhook events, please respond to the request with 200 OK
as soon as possible. Your response time and response status will be kept monitoring. If your endpoints are deteriorating ( slow response, too many 500 Internal server error
), we might turn off your endpoint automatically.
For more details, please refer to Circuit breaker section
Replay events
Sometimes if you need to replay webhook events that failed, you can go to developer center > your App > Deploy & release > webhook > webhook log to replay the failed webhook event
Missing Webhook & reconcilliation job
Generally speaking, webhook is a very reliable system. However, it is recommended that your app should not rely entirely on receiving data from webhooks, especially if your app and usecases require to maintaining 100% data integrity and always stay synchronised with SHOPLINE events. Because the delivery of webhooks is not always guaranteed due to various reasons. For example, network problems and upstream services downtime.
In this case, the app should implement resampling jobs to fetch data from us from time to time, so as to improve the stability of your app.
Our OpenAPI supports queries for a specific timeframe, like created_after
, created_before
, updated_after
, updated_befored
, and in another syntax created_at=lt:{timestamp}
etc. We recommend you make use of it.
For details, please refer to OpenAPI documentation.
Understand why missing webhook may happen
Understanding the reasons is crucial for effectively managing and mitigating their impact. Below are some reasons and examples for reference.
Reasons | Details | Example |
---|---|---|
Network issues | Interruptions or failures in network connectivity can prevent webhook delivery. This could be due to issues with the internet service provider, network congestion, etc | If a webhook is sent during a period of network instability at one of the network layers, the webhook might not reach the external inventory management system. |
Server Downtime or Overload | If the receiving server is down for maintenance or overloaded with requests, it may not be able to accept incoming webhooks. | An accounting application's server is undergoing maintenance when SHOPLINE tries to send a webhook about a new transaction, leading to a missed webhook |
Webhook Handling Errors from App | If the external application fails to properly handle and acknowledge the receipt of a webhook, may eventually lead to circuit break. | An external shipping update system fails to send a 200 OK response due to an internal error, leading to circuit break and result in stop sending webhook to the app. |
Payload Size Limits | Webhooks have payload size limits. If the data exceeds this limit, the webhook may not be sent or may be truncated. | A webhook containing an unusual large amount of order data might exceed SHOPLINE’s payload size limit and fail to deliver. |
Security and Firewall Settings | Strict security protocols or firewall settings at the receiver's end can block incoming webhooks | A firewall misconfiguration in the merchant’s system could inadvertently block incoming webhooks from SHOPLINE |
Authorization and Permission Changes | Changes in authorization for the app can lead to missed webhooks | If a SHOPLINE store mistakenly uninstall and revoke permissions to an app for a certain period of time, webhooks will no longer be sent to that app. |
SHOPLINE platform issues | Although very rare, issues on SHOPLINE's end, such as system outages or bugs, can prevent webhooks from being dispatched | A temporary glitch in SHOPLINE’s webhook dispatch system could result in missed webhooks for order updates |
General Considerations if reconciliation job needed
Below are some general rules of thumb to consider when deciding if a reconciliation job is needed
- Data sensitivity & Impact evaluation
- Highly sensitive data, particularly data involving financial impacts like transactions (which could lead to financial loss), usually warrants more stringent reconciliation measures
- Evaluate the impact of potential missing data or desynchronization on your application's functionality, as well as its potential impact on the business and customer experience
- Resource Allocation: Consider the resources needed for implementing and maintaining reconciliation jobs. For some use cases, the effort may outweigh the benefits
In summary, whether to implement reconciliation jobs for handling missing data should be determined based on the criticality of data accuracy and timeliness in your specific use case.
Example on app use cases that require data 100% stay synchronised
Scenario: SHOPLINE stores selling shirts with an integrated external accounting application
(example for illustration the concept only)
In this usecase, App think it is crucial for keeping app's data 100% in sync with the store. The end-of-day balance computations must be accurate. Reconciliation jobs will be vital under this assumption.
How to do?
- Schedule a reconciliation job to run regularly / shortly before your app need to compute balances
- Using the App token to request corresponding APIs to fetch and validate all purchase information
- Update the records in your accounting application if there is any missing pieces
Below are some more examples for demonstration the decision process. Please be aware that App should review and justify base on their own situations.
App usecases | Justification | Reconciliation jobs needed? |
---|---|---|
Financial & accounting App | External accounting applications must accurately match transactions with SHOPLINE store sales to maintain financial integrity | Best practice is to implement reconciliation jobs for regular validation |
Inventory management | Applications managing stock levels need to avoid discrepancies due to missing data, which can lead to issues like overselling | Best practice is to implement reconciliation jobs for regular / frequent validation |
Order Processing and Fulfillment | Systems that handle order processing, where missing data can lead to unfulfilled orders | Best practice is to implement reconciliation jobs for regular validation |
Marketing applications | Marketing applications, where missing some data points does not significantly impact overall performance, such as promotional widgets (e.g, smart recommendations) | Not necessary, as the effort may outweigh the benefits. Occasional missing data does not critically affect overall performance |
Understanding Webhook Sequence & Delays
Webhook Sequence
Sequence of triggering webhook events is not the same as the sequence of receiving the webhook events. For example, a set of webhook events are triggered in the following sequence: A -> B -> C
, you might receive the webhook events in the following sequence: B -> A -> C
.
Webhooks delayed
Sometimes you might find delays in receiving our webhook events. Yet, webhook events always reflects the latest attributes of the given resources. We recommend you to compare updated_at
in the resource payload with the current time or ts
in the event payload.
ts
represents the time that the event is triggered, if the event is triggered in the following sequence A --> B --> C
, then the timestamp for A would be the earliest, followed by B, then C (i.e., A's ts < B's ts < C's ts).
Implications for Sequence-Sensitive Applications
Example | Order webhook usecase 1
Webhook with Different Order Status Payloads may receive in different sequence occasionally
i. Sequence Based on Timestamp: A -> B = Order pending -> Order confirmed
ii. Sequence Based on Receiving Time: B -> A = Order confirmed -> Order pending
In this scenario, the sequence of events based on receiving time may misrepresent the actual order of events. If the application does not account for the timestamp, it will inevitably encounter logical errors.
Example | Order webhook usecase 2
Different Order Webhook Topics may receive in different sequence occasionally
i. Sequence Based on Timestamp: A -> B = Order created -> Order payment complete
ii. Sequence Based on Receiving Time: B -> A = Order payment complete -> Order created
In this scenario, the 'Order Payment Complete' webhook is received first, but lacks order details because the 'Order Created' event has not yet arrived, the application might encounter significant logic issues.
Solving Sequence Issues:
If your application's use case is sensitive to the sequence of events, it's essential to incorporate the timestamp from each webhook event into your application logic. This approach ensures that actions are processed in the correct chronological order, based on when events were actually triggered, rather than when they were received. Furthermore, applications may need to develop custom logic to effectively manage dependencies between different webhook topics.
For example, it might be necessary to cache the details of an order payment confirmation and then incorporate them only after the corresponding 'order create' event has been received. This method allows for the accurate assembly of information in the proper sequence, ensuring data integrity and consistency.
Webhook Idempotence Concept (may receive webhook more than once)
SHOPLINE aims to ensure webhook events to be delivered to endpoints a minimum of once, a feature known as "at least once" delivery. This also mean an endpoint may also receive same webhook event more than once. To recognize and manage these duplicate events, you can compare the 'trace id' of incoming events with those of previously received events.
Implementing Deduplication
To maintain the efficiency and accuracy of your application, it is crucial to incorporate a deduplication process (dedup) to avoid processing duplicate webhook events. This process should occur before the events are passed on to the application layer.
Possible steps for Deduplication (for ref. only)
- Trace ID Check: On receiving a webhook event, check its 'trace_id' against a list or database of 'trace_id(s)' from previously processed events.
- Duplicate Identification: If the 'trace_id' is found in your records, identify the event as a duplicate and prevent it from proceeding further.
- Processing Unique Events: Only allow events with unique 'trace_id' to move forward to the application layer for processing.
- Record Keeping: Maintain a record of 'trace ids' from processed webhook events to ensure ongoing accuracy in duplication checks.
Updated 5 months ago