Webhook Service Tutorials
The Emporix Webhook Event Publishing works in the following way:
- When an event takes place and you subscribed to receiving notifications about this event, a message is sent to the Webhook Service.
- The Webhook Service forwards the message to the Event Gateway.
- The Event Gateway passes the event to your earlier configured endpoint for this particular event.
info
For example, if you create a catalog in the Emporix environment, a notification is sent to the Webhook service. The service passes the message to the Event Gateway. If you configured the "Create a new catalog" endpoint beforehand, you will receive the notification that a new catalog has been created.
How to configure webhook notifications
To receive notifications from Emporix API services, you need to subscribe to specific events by following the process below:
- Retrieve all subscriptions to the Emporix API events.
- Subscribe to specific events generated in the Emporix API.
- Connect the tenant with their consumer application by following the link to the Event Gateway.
- Configure endpoints in the Event Gateway.
attention
By default, the maximum number of events per tenant is limited to 5000/month. The limit resets on the first day of each month. If you want to publish more events, contact Emporix Support.
Retrieve all subscriptions
Before you subscribe to events, you need to check for any active subscriptions by sending a request to theattention
metadata.version
value. You will need it to call the Subscribing and unsubscribing from events
endpoint further in the tutorial.If there is no prior subscription to the event of your choice, the metadata.version
is empty. It is automatically set to 1
when you send a request to the Subscribe to events
To receive notifications about events, for example creating or updating a catalog in the Catalog Service, you need to subscribe to them by using the Webhook Service.
To subscribe to an event, you need to send a request to thecatalog.created
and catalog.updated
.note
Learn about the index.item-updated
event's specific behavior
The
index.item-updated
webhook event is emitted whenever there is a change on an item in the system - the index is updated with the new information.
For the event to be triggered, a product must have at least one defined price, as it is the price that determines products indexing on a specific site.
Bear in mind all the events are site-specific, which means that they are linked to activities happening on particular sites.
The prices are also site-specific, and a single price can be associated with multiple sites.
The number of events triggered in the system depends on the number of sites assigned to a specific product’s prices, with one event emitted per each site. Example:
productid | price with associated sites | number of emitted events | sites the event was emitted to |
123 | $10 - sites A, B | 2 | A, B |
234 | $10 - site A, $15 - sites A, B, C | 3 | A, B, C |
345 | no price | 0 | none |
- A product 123 has one assigned price of $10, associated with two sites A and B. When you update the product 123, the number of emitted
index.item-updated
events is 2 as there are two sites associated with the product price. - A product 234 has two assigned prices: $10 associated with site A and $15 associated with site A, B, and C. So when you update the product 234, the
index.item-updated
event runs 3 times, as there are three sites affected. - A product 345 has no defined price. So when you update the 345 product, the
index.item-updated
is not emitted as no site is associated with the product.
Connect to the Event Gateway
You need to have access to the Event Gateway to connect the tenant with their consumer application.
When you subscribe to events, you will receive an email with an automatically generated link to the application portal.
To generate the login link with the authentication token needed to connect a tenant to their consumer application portal, you need to send a request to theinfo
You can use your Emporix tenant ID as application ID in Svix.
Configure your endpoints
To receive notifications about the events you subscribed to in Subscribe to events, on the Event Gateway, you need to configure endpoints that relate to those events.
To configure endpoints by using the APIs, since we are currently using the Svix platform for this purpose, check out the "Add webhook endpoints/Using the API" section in the official Svix documentation.