Webhooks
A webhook allows your application to receive real-time notifications when specific events occur. Webhooks can be configured through the PORTOS BackOffice application. For each webhook, you can define the following options:
URL: address where the events will be delivered
Secret: optional string that is used to create JSON payload signature.
Resource filter: specifies list of resources (e.g. tickets, article categories, ...) for which notification will be sent.
When an event is triggered, the PORTOS API sends an HTTP POST request to the specified URL, carrying the event data as a JSON payload. It is essential that the external application hosting the URL can handle these HTTP POST requests to process the event data effectively.
Testing Webhook Deliveries
In your browser, navigate to https://smee.io
Click Start a new channel. Smee.io will generate a unique Webhook Proxy URL for you.
Copy the full URL under "Webhook Proxy URL".
Open PORTOS BackOffice application.
Navigate to System > Extensions > Webhooks (or Systรฉm > Rozลกรญrenia > Webhooky if using the Slovak version).
Create a new webhook and paste the copied URL from Smee.io into the Address (Adresa) field.
Press the Save (Uloลพiลฅ) button
In PORTOS BackOffice, perform an action such as creating, editing, or deleting a resource (e.g., an article category).
Check your Smee.io channel; the event should appear, confirming that the webhook is working correctly.
Validating Webhook Deliveries
To ensure the security and authenticity of webhook deliveries, users have the option to specify a "secret" when setting up a webhook. If a secret is defined, every webhook request from your app will include an HTTP header named X-PORTOS-WEBHOOK-SIGNATURE
. This header contains an HMACSHA256 signature of the JSON payload, generated using the secret. External applications can use this signature to validate that the webhook requests are genuinely from your app and have not been tampered with.
Example Implementations
To implement HMAC verification in your app, please refer to examples below. Examples are using following variables:
jsonPayload
: The content of the HTTP request body that contains the event data in JSON format.receivedSignature
: The value of theX-PORTOS-WEBHOOK-SIGNATURE
HTTP header, which contains the HMACSHA256 signature sent by the PORTOS API.secret
: The secret key specified in webhook settings, used to generate the signature.
Example Hash calculation
Hereโs an example of how to calculate the SHA256 hash for a webhook using the provided secret and JSON content:
Secret: my-secret-key
JSON content:
Resulting SHA256 hash: 06324bd73f157373a4a678320a014d8c3db4c2e07d8a6177ecdf233b9f07d3f0
Webhook payload
Data models
The webhook content follows this data structure:
WebhookPayloadDto
WebhookPayloadDto
Name | Type | Description |
---|---|---|
|
| Unique webhook identifier (GUID v4 format), generated by PORTOS API. |
|
| Indicates version of webhook payload. Currently fixed to "1.0" |
|
| Name of event. Currently, only resource changed events are delivered, so values is fixed to "portos.resources.changed" |
| Based on value of "event" field, content may vary. |
WebhookResourceChangedContentDto
WebhookResourceChangedContentDto
Name | Type | Description |
---|---|---|
| Information about user that triggers the resource change. | |
|
| Name of action that represents the resource change. Supported values: created, updated or deleted. |
|
| Name of resource, e.g. ticket, articleCategory, ... |
|
| The resource that has been created/updated/deleted. Based on value of "resourceName" field, content may vary (e.g. for "ticket", content is |
UserInfoIdentity
UserInfoIdentity
Name | Type | Description |
---|---|---|
|
| Display name of user. |
|
| Unique user identifier. |
|
| Name of feature (specified for "virtual" users only, e.g. user representing some Portos extension). |
|
| Unique name of the device on which the user operates. |
Webhook Payload Example
Please note that the actual payload does not include JSON indentation.
Last updated