Webhook Events
These are example payloads of all webhook event you can receive from Unidy.
User
user.created
{
"event_type": "user.created",
"user": {
"first_name": null,
"last_name": null,
"email": "admin@example.com",
"created_at": "2021-05-28T13:13:06.361Z",
"updated_at": "2021-06-01T09:40:27.779Z",
"confirmed_at": "2021-06-01T09:40:27.779Z",
"salutation": null,
"gender": null,
"phone_number": null,
"date_of_birth": null,
"company_name": null,
"address_line_1": null,
"address_line_2": null,
"city": null,
"postal_code": null,
"country_code": null,
"unidy_id": "eb7a4199-de25-515a-991e-2e721b24728e"
},
"occurred_at": "2021-06-01T09:44:17.073Z",
"occured_at": "2021-06-01T09:44:17.073Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "b05a6dcd-472f-4930-ab0b-836f4435fa62"
}
user.updated
{
"event_type": "user.updated",
"user": {
"first_name": null,
"last_name": null,
"email": "admin@example.com",
"created_at": "2021-05-28T13:13:06.361Z",
"updated_at": "2021-06-01T09:40:27.779Z",
"confirmed_at": "2021-06-01T09:40:27.779Z",
"salutation": null,
"gender": null,
"phone_number": null,
"date_of_birth": null,
"company_name": null,
"address_line_1": null,
"address_line_2": null,
"city": null,
"postal_code": null,
"country_code": null,
"unidy_id": "eb7a4199-de25-515a-991e-2e721b24728e"
},
"occurred_at": "2021-06-01T09:44:17.073Z",
"occured_at": "2021-06-01T09:44:17.073Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "b05a6dcd-472f-4930-ab0b-836f4435fa62"
}
user.deleted
{
"event_type": "user.updated",
"user": {
"first_name": null,
"last_name": null,
"email": "admin@example.com",
"created_at": "2021-05-28T13:13:06.361Z",
"updated_at": "2021-06-01T09:40:27.779Z",
"confirmed_at": "2021-06-01T09:40:27.779Z",
"salutation": null,
"gender": null,
"phone_number": null,
"date_of_birth": null,
"company_name": null,
"address_line_1": null,
"address_line_2": null,
"city": null,
"postal_code": null,
"country_code": null,
"unidy_id": "eb7a4199-de25-515a-991e-2e721b24728e"
},
"occurred_at": "2021-06-01T09:44:17.073Z",
"occured_at": "2021-06-01T09:44:17.073Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "b05a6dcd-472f-4930-ab0b-836f4435fa62"
}
Newsletter Subscription
newsletter_subscription.created
{
"event_type": "newsletter_subscription.created",
"occurred_at": "2021-09-22T16:05:20.486Z",
"occured_at": "2021-09-22T16:05:20.486Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "f71970b6-d162-4ed2-9910-c8b7f48106ab",
"newsletter_subscription": {
"id": 43,
"email": "admin@example.com",
"topics": ["club_news", "player_news"], // OLD DEPRECATED KEY, WILL BE REMOVED
"preferences": ["club_news", "player_news"],
"internal_name": "default_newsletter",
"confirmed_at": "2021-09-22T16:05:20.486Z",
"preference_token": "ihg3nJfrE6M572TEpbUisZ3G"
}
}
newsletter_subscription.updated
{
"event_type": "newsletter_subscription.updated",
"occurred_at": "2021-09-22T16:05:20.486Z",
"occured_at": "2021-09-22T16:05:20.486Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "f71970b6-d162-4ed2-9910-c8b7f48106ab",
"newsletter_subscription": {
"id": 43,
"email": "admin@example.com",
"topics": ["club_news", "player_news"], // OLD DEPRECATED KEY, WILL BE REMOVED
"preferences": ["club_news", "player_news"],
"internal_name": "default_newsletter",
"confirmed_at": "2021-09-22T16:05:20.486Z",
"preference_token": "ihg3nJfrE6M572TEpbUisZ3G"
}
}
newsletter_subscription.deleted
{
"event_type": "newsletter_subscription.deleted",
"occurred_at": "2021-09-22T16:05:20.486Z",
"occured_at": "2021-09-22T16:05:20.486Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "f71970b6-d162-4ed2-9910-c8b7f48106ab",
"newsletter_subscription": {
"id": 43,
"email": "admin@example.com",
"topics": ["club_news", "player_news"], // OLD DEPRECATED KEY, WILL BE REMOVED
"preferences": ["club_news", "player_news"],
"internal_name": "default_newsletter",
"confirmed_at": "2021-09-22T16:05:20.486Z",
"preference_token": "ihg3nJfrE6M572TEpbUisZ3G"
}
}
Topic
topic.deleted
{
"event_type": "topic.deleted",
"occurred_at": "2021-09-22T16:05:20.486Z",
"occured_at": "2021-09-22T16:05:20.486Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "f71970b6-d162-4ed2-9910-c8b7f48106ab",
"topic": { "topic": "player_news" }
}
Subscription
Content of metadata is not always present and it can vary depending on subscription.
subscription.created
{
"event_type": "subscription.created",
"occurred_at": "2023-03-24T10:05:21.801Z",
"occured_at": "2023-03-24T10:05:21.801Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "300646f5-e14b-452a-a3cb-df9e9e1b933f",
"subscription": {
"id": "a2472716-9062-41e8-b002-4a0320a70fbf",
"reference": "987654321",
"user_id": "02f4b82d-f992-4ebf-b69c-a79422142992",
"created_at": "2023-03-24T10:04:38.430Z",
"updated_at": "2023-03-24T10:04:38.430Z",
"title": "factory title",
"text": "factory test text which descirbes the subscription",
"ends_at": "2023-03-24T10:04:38.430Z",
"starts_at": "2023-03-24T10:04:38.430Z",
"price": 100.99,
"subscription_category_id": "5ea34525-34f3-4f6e-a7c1-4c1c10342f71",
"payment_frequency": "yearly", //daily,weekly,monthly,quarterly,six_monthly,yearly,onetime
"payment_state": "payed", // payed,not_payed
"state": "active", // active,inactive,passive
"next_payment_at": "2023-03-24T10:04:38.430Z",
"metadata": {
"name": {
"label": "Name",
"value": "Max Mustermann"
},
"test": {
"label": "added info",
"value": "some additional wallet information"
}
},
"wallet_export": {
"qr_code": "2222",
"additional_attributes": [
"name",
"test"
],
"further_information": "Lorem ipsum dolor sit amet, https://google.de"
}
}
}
subscription.updated
{
"event_type": "subscription.updated",
"occurred_at": "2023-03-24T10:06:03.748Z",
"occured_at": "2023-03-24T10:06:03.748Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "811d2ed8-4ac7-4c0e-88c4-ee8d0f8041f7",
"subscription": {
"id": "a2472716-9062-41e8-b002-4a0320a70fbf",
"reference": "987654321",
"user_id": "02f4b82d-f992-4ebf-b69c-a79422142992",
"created_at": "2023-03-24T10:04:38.430Z",
"updated_at": "2023-03-24T10:04:38.430Z",
"title": "factory title",
"text": "factory test text which descirbes the subscription",
"ends_at": "2023-03-24T10:04:38.430Z",
"starts_at": "2023-03-24T10:04:38.430Z",
"price": 100.99,
"subscription_category_id": "5ea34525-34f3-4f6e-a7c1-4c1c10342f71",
"payment_frequency": "yearly", //daily,weekly,monthly,quarterly,six_monthly,yearly,onetime
"payment_state": "payed", // payed,not_payed
"state": "active", // active,inactive,passive
"next_payment_at": "2023-03-24T10:04:38.430Z",
"metadata": {
"name": {
"label": "Name",
"value": "Max Mustermann"
},
"test": {
"label": "added info",
"value": "some additional wallet information"
}
},
"wallet_export": {
"qr_code": "2222",
"additional_attributes": [
"name",
"test"
],
"further_information": "Lorem ipsum dolor sit amet, https://google.de"
}
}
}
subscription.deleted
{
"event_type": "subscription.deleted",
"occurred_at": "2023-03-24T10:08:36.279Z",
"occured_at": "2023-03-24T10:08:36.279Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "389b1db8-7c9a-4074-8e8f-84f7344abcd2",
"subscription": {
"id": "a2472716-9062-41e8-b002-4a0320a70fbf",
"user_id": "02f4b82d-f992-4ebf-b69c-a79422142992"
}
}
Custom Attributes
If you defined custom attributes for your users, they will be injected into the regular user data.
See example
{
"event_type": "user.updated",
"user": {
"membership_number": "12345aaa",
"vip_user": true,
"birth_year": 2000,
"description": "Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.",
"first_name": null,
"last_name": null,
"email": "admin@example.com",
"created_at": "2021-05-28T13:13:06.361Z",
"updated_at": "2021-06-01T09:40:27.779Z",
"confirmed_at": "2021-06-01T09:40:27.779Z",
"salutation": null,
"gender": null,
"phone_number": null,
"date_of_birth": null,
"company_name": null,
"address_line_1": null,
"address_line_2": null,
"city": null,
"postal_code": null,
"country_code": null,
"unidy_id": "eb7a4199-de25-515a-991e-2e721b24728e"
},
"occurred_at": "2021-06-01T09:44:17.073Z",
"occured_at": "2021-06-01T09:44:17.073Z", // OLD DEPRECATED KEY, WILL BE REMOVED
"event_id": "b05a6dcd-472f-4930-ab0b-836f4435fa62"
}
Handling Update Loops
You might run in the situation, where your system is updating data in Unidy via the API and then receive the resulting webhooks. You can identify those webhooks by comparing the creator of the update. E.g.:
{
...
"source": "api",
"event_id": "470d0a20-0da3-4d5e-9da6-7bac5c230670",
"client_id": "V_6L5h7bi8sbt8z3JcQFfa2zasdfd321NGS5qIC0GN_Q",
"event_type": "user.updated",
"occurred_at": "2025-03-03T09:59:26.630Z"
}
If you updated a user via API and your client ID is V_6L5h7bi8sbt8z3JcQFfa2zasdfd321NGS5qIC0GN_Q
, then you can ignore this webhook, because you caused the change.
Did this answer your question?
π
π
π€©