Shopkit Webhooks
Webhooks allow you to build or set up integrations which subscribe to certain events on Shopkit stores.
The webhooks can be used to integrate with third-party services, for example invoicing systems, CRM services or even create notifications and alerts. You're only limited by your imagination.
If you find a bug or something worth fixing, create an issue or a pull request on the Github repo.
Workflow
When one of the events is triggered, we'll send a HTTP POST payload to the webhook's configured URL.
We expect a 2xx
status code when requesting your URL.
Creating a webhook
- Login into your store.
- Navigate to the Webhooks section under the Account settings > Developers.
- Create a webhook by inserting the url and select an event.
Events
When configuring a webhook, you can choose which events you would like to receive payloads for:
Name | Description |
---|---|
order_canceled |
When an order status is changed to canceled |
order_payment_failed |
When an order payment failes (expired, canceled, other) |
order_change_payment |
When an order payment method is changed |
order_delivered |
When an order status is changed to delivered |
order_shipping |
When an order shipping is requested |
order_returned |
When an order status is changed to returned |
order_invoice |
When an order invoice is requested |
order_change_status |
When an order status is changed |
order_sent |
When an order status is changed to sent |
order_paid |
When an order is set to paid |
order_updated |
When an order is updated (any change is made to an order) |
order_created |
When an order is created |
order_deleted |
When an order is deleted |
order_pickup_available |
When an order status is changed to pickup_available |
order_waiting_shipment |
When an order status is changed to waiting_shipment |
order_invoiced |
when an order is invoiced |
shipping_expedited |
when an order is shipped |
order_tag_added |
When a tag is added to an order |
client_created |
When a client is created |
client_updated |
When a client is updated |
client_deleted |
When a client is deleted |
client_tag_added |
When a tag is added to a client |
client_wholesale_accepted |
When a client wholesale is accpepted |
client_wholesale_revoked |
When a client wholesale wholesale is revoked |
client_wholesale_requested |
When a client apply for wholesale |
newsletter_subscribed |
When a client subscribe the newsletter |
newsletter_unsubscribed |
When a client unsubscribe the newsletter |
product_created |
When a product is created |
product_updated |
When a product is updates |
product_deleted |
When a product is deleted |
product_updated_stock |
When a product stock is changed |
cart_abandoned |
When an abandoned cart is notified |
Payloads
All webhooks deliver the payload in application/json
as the body of the HTTP POST request.
Headers
The HTTP requests to your webhook's URL will contain a special headers.
We also send the User-Agent
for all requests as Shopkit-Webhook
.
Name | Description |
---|---|
X-Platform |
Plaform identifier. Shopkit |
X-Shopkit-Environment |
Plaform Environment. Production |
X-Shopkit-Event |
The name of the event that was triggered |
X-Webhook-Resource-Origin |
The origin that triggered the event |
The header X-Webhook-Resource-Origin
, possible values are:
Name | Description |
---|---|
api |
When origin is the api |
import |
When origin is an import (ex: product csv import) |
backoffice |
When origin is the backoffice |
storefront |
When origin is the store front |
duplicate |
When origin is a duplicate action (ex: product duplicate) |
process |
When origin is processed by a background action (ex: a callback) |
Orders
POST /webhook HTTP/2
Host: localhost
User-Agent: Shopkit-Webhook
Content-Type: application/json
X-Shopkit-Event: order_updated
X-Webhook-Signature: 6d5a75b42956154a7da8843f56c272428fd43967be1a5474821940b377d061fe
X-Webhook-Resource-Origin: backoffice
X-Platform: Shopkit
X-Shopkit-Environment: production
Content-Length: 4632
{
"order":{
"id":1337,
"hash":"a77e38d0b16ba62f32361331774324904278edcf",
"total":157.03,
"subtotal":148.64,
"product_tax":16.0052,
"total_tax":16.0052,
"discount":14.864,
"shipping":{
"value":7.25,
"tax":0,
"tax_percent":"",
"discount":0,
"discount_percent":0
},
"created_at":"2017-05-17T10:45:05+01:00",
"update_at":"2024-09-20T16:31:02+01:00",
"sent_at":"2017-05-17T11:23:21+01:00",
"paid_at":"2017-05-17T11:23:21+01:00",
"currency":"EUR",
"status":3,
"paid":true,
"is_new":false,
"invoice_url":"https://www.invoicexpress.com/invoice/permalink",
"weight":0,
"observations":"",
"note":"",
"client_note":"",
"custom_field":"",
"tracking_code":"",
"tracking_carrier":"",
"tracking_created_at":"",
"tracking_url":"",
"expected_arrival_from":null,
"expected_arrival_until":null,
"shipping_url":"",
"at_code":"",
"tax_exemption":null,
"tax_settings":null,
"wholesale":false,
"billing_info_same_delivery":"1",
"is_digital":false,
"payment":{
"data":{
"entity":88888,
"reference":888888888,
"value":157.03
},
"value":0,
"tax":0,
"tax_percent":"",
"title":"Multibanco",
"method":"multibanco",
"type":"multibanco",
"gateway":"gateway"
},
"status_alias":"sent",
"status_description":"Enviada",
"coupon":{
"code":"bajevolp",
"type":"percent",
"value":10
},
"shipment_method":"Transportadora",
"shipment_method_id":492,
"shipment_type":null,
"tracking_status":{
"event_alias":null,
"event_description":null
},
"permalink":"https://parallax.shopk.it/order/a77e38d0b16ba62f32361331774324904278edcf",
"client":{
"id":"731068",
"hash":"cfc1c614870f7033bb0a033b6e7cd18e",
"name":"Shopkit",
"email":"info@shopk.it",
"company":"Shopkit",
"fiscal_id":"PT999999990",
"is_registered":true,
"picture":null,
"delivery":{
"name":"Shopkit",
"phone":"+351969057993",
"address":"Avenida do Empresário, 1",
"address_extra":"Centro de Empresas Inovadoras",
"country_code":"PRT",
"country_code_alpha_2":"PT",
"zip_code":"6000-767",
"city":"Castelo Branco",
"country":"Portugal - Continental"
},
"billing":{
"same_as_delivery":true,
"name":"Shopkit",
"phone":"+351969057993",
"address":"Avenida do Empresário, 1",
"address_extra":"Centro de Empresas Inovadoras",
"country_code":"PRT",
"country_code_alpha_2":"PT",
"zip_code":"6000-767",
"city":"Castelo Branco",
"country":"Portugal - Continental"
},
"address":"Avenida do Empresário, 1 Centro de Empresas Inovadoras",
"postcode":"6000-767",
"town":"Castelo Branco",
"country":"Portugal - Continental",
"country_code":"PRT",
"phone":"+351969057993"
},
"tags":[
{
"id":2800420,
"title":"shopkit",
"handle":"shopkit",
"total_items":1,
"created_at":"2024-09-20T16:31:02+01:00"
}
],
"l10n":{
"tax_id_abbr":"NIF/NIPC/VAT ID",
"tax_name":"IVA"
},
"products_count":2,
"products_quantity":2,
"products":[
{
"id":44753,
"title":"Shelving Tree with Birds",
"option":"Azul / Small",
"reference":"STHFBF7574",
"barcode":null,
"price":77.32,
"price_with_tax":95.1036,
"price_without_tax":77.32,
"tax":23,
"quantity":1,
"discount":7.731999999999999,
"subtotal":85.5932,
"subtotal_with_tax":85.5932,
"subtotal_without_tax":77.32,
"discount_percent":10,
"weight":0,
"origin_country":null,
"origin_country_alpha_2":null,
"harmonized_code":null,
"type":"physical",
"url":"https://parallax.shopk.it/product/shelving-tree-with-birds",
"description_short":"This is a tree decal that is created to work with standard 24\" wall shelves that you…",
"image":{
"thumb":"https://cdn.shopk.it/usercontent/parallax/media/images/thumb/0c0014c3ddd01f19933ce97e2041acd3.jpg",
"square":"https://cdn.shopk.it/usercontent/parallax/media/images/square/0c0014c3ddd01f19933ce97e2041acd3.jpg",
"full":"https://cdn.shopk.it/usercontent/parallax/media/images/0c0014c3ddd01f19933ce97e2041acd3.jpg"
},
"is_product":true
},
{
"id":44752,
"title":"Hanging Succulent Planter",
"option":null,
"reference":"",
"barcode":null,
"price":71.32,
"price_with_tax":71.32,
"price_without_tax":71.32,
"tax":0,
"quantity":1,
"discount":7.132,
"subtotal":64.188,
"subtotal_with_tax":64.188,
"subtotal_without_tax":71.32,
"discount_percent":10,
"weight":0,
"origin_country":null,
"origin_country_alpha_2":null,
"harmonized_code":null,
"type":"physical",
"url":"https://parallax.shopk.it/product/hanging-succulent-planter",
"description_short":"This stoneware planter/pot has been hand made by me from earthy textured, speckled clay…",
"image":{
"thumb":"https://cdn.shopk.it/usercontent/parallax/media/images/thumb/eacc633fe509af083776db911a5f02b9.jpg",
"square":"https://cdn.shopk.it/usercontent/parallax/media/images/square/eacc633fe509af083776db911a5f02b9.jpg",
"full":"https://cdn.shopk.it/usercontent/parallax/media/images/eacc633fe509af083776db911a5f02b9.jpg"
},
"is_product":true
}
]
}
}
Client
POST /webhook HTTP/2
Host: localhost
User-Agent: Shopkit-Webhook
Content-Type: application/json
X-Shopkit-Event: client_updated
X-Webhook-Signature: 6d5a75b42956154a7da8843f56c272428fd43967be1a5474821940b377d061fe
X-Webhook-Resource-Origin: backoffice
X-Platform: Shopkit
X-Shopkit-Environment: production
Content-Length: 681
{
"client":{
"name":"Shopkit",
"email":"info@shopk.it",
"company":null,
"fiscal_id":null,
"locale":"pt_PT",
"gender":null,
"birthday":null,
"picture":null,
"subscribe_newsletter":false,
"wholesale":false,
"created_at":1572289289,
"last_seen_at":1572289289,
"ip_address":null,
"is_banned":false,
"internal_notes":null,
"tags":[],
"delivery":{
"name":"Shopkit",
"phone":"+351969057993",
"address":"Avenida do Empresário, 1",
"address_extra":"Centro de Empresas Inovadoras",
"country_code":"PRT",
"country_code_alpha_2":"PT",
"zip_code":"6000-767",
"city":"Castelo Branco",
"country":"Portugal - Continental"
},
"billing":{
"name":"Shopkit",
"phone":"+351969057993",
"address":"Avenida do Empresário, 1",
"address_extra":"Centro de Empresas Inovadoras",
"country_code":"PRT",
"country_code_alpha_2":"PT",
"zip_code":"6000-767",
"city":"Castelo Branco",
"country":"Portugal - Continental"
},
}
}
Newsletter
POST /webhook HTTP/2
Host: localhost
User-Agent: Shopkit-Webhook
Content-Type: application/json
X-Shopkit-Event: newsletter_subscribed
X-Webhook-Signature: 6d5a75b42956154a7da8843f56c272428fd43967be1a5474821940b377d061fe
X-Webhook-Resource-Origin: backoffice
X-Platform: Shopkit
X-Shopkit-Environment: production
Content-Length: 107
{
"client":{
"name":"Shopkit",
"email":"info@shopk.it",
"hash":"a77e38d0b16ba62f32361331774324904278edcf"
}
}
Verifying webhooks
In order to ensure the webhook you received is legit, we suggest you verify its signature. To do that, create an HMAC signed using the SHA256 hash algorithm, using your application’s client_secret and the body of the webhook request as keys, and make sure it matches the webhook’s X-Webhook-Signature header.
hash_hmac('sha256', payload, client_secret);
Testing
We provide a tool for testing payloads. It's located in the Webhooks section (under the Account settings menu).
This will post a dummy payload to your URL, so you don't need to simulate order events in your store to develop, test and debug.
Last Modified 2025-04-08T15:37:35+01:00