Participants

Webhook events related to participants.

Webhooks are a powerful tool for receiving real-time notifications about your payment updates from Zero Hash's systems. By configuring webhooks, you can streamline your workflow and stay informed about events related to your payments.

Configuring Webhooks

  • Contact Zero Hash: Reach out to Zero Hash directly to initiate the webhook configuration process. You can do this via the platform Slack channel or by contacting your Zero Hash relationship manager.
  • Provide URLs: Provide the URLs for your production (Prod) and certification (Cert) webhooks to Zero Hash. These URLs will be where Zero Hash sends the webhook payloads.
  • Wait for Configuration: Zero Hash will configure the webhooks within 2 business days of receiving the URLs. Once configured, you will start receiving webhook notifications according to your participant events.

Webhook URLs

Ensure that you provide separate URLs for production and certification environments. This helps in distinguishing between live and test data, allowing you to safely test webhook integrations without affecting your production environment.

Handling Webhook Payloads

Upon receiving webhook payloads, your system should be capable of processing and interpreting the data. Parse the payload according to the provided documentation and handle events appropriately based on your application logic.

Retry Policy

  • Upon failure to send a webhook notification, Zero Hash will up to 5 more attempts to POST the notification.
  • Each retry will have a 250 millisecond delay between each attempt to your webhook listener.

Sequencing and order

The client should interpret event sequence not by the order of each webhook message, but instead by the timestamp field.

📘

Order of webhooks

When sorting webhooks to determine the sequence by which they happened, use the timestamp field. This field determines when the event associated with the webhook took place. Conversely, you should not rely on the order by which you receive the webhook to determine the sequence.


Participant Status Definitions

StatusDefinition
submittedSuccessfully submitted to <POST /participants/customers/new> and given a participant code, but has not yet been approved to transact.
pending_approvalParticipant requires manual review by Zero Hash before moving to an approved or rejected status.
approvedParticipant code and relationships created and the participant passes necessary approvals to transact.
rejectedParticipant who was rejected from becoming an active user; most often due to customer verification declines.
lockedInvestigative state for the Zero Hash compliance team.
pending_unlockInvestigations conclude the participant may remain active on Zero Hash. Only available via GET /participants, and not via webhook.
pending_disableInvestigations conclude the participant should be indefinitely banned from Zero Hash. Only available via GET /participants, and not via webhook.
disabledIndefinitely banned from Zero Hash, but balances may exist in the participant account. Zero Hash settlement team will divest existing balances.
divestedIndefinitely banned from Zero Hash and participant balances were moved back to the platform float.
closedIndefinitely banned from Zero Hash and no balances remained at the time of ban

Participant Reason Codes and Request Availability

Reason CodeDefinitionRequest Availability
compliance_issuelockedNone
compliance_issuepending_disableNone
compliance_issuedisabledNone
compliance_issueclosedNone
compliance_issuedivestedNone
user_requestlockedClosing only (sell/withdraw)
user_requestpending_disableClosing only (sell/withdraw)
user_requestdisabledNone
user_requestclosedNone
user_requestdivestedNone
risk_clearedpending_unlockNone - the cleared risk still needs to be approved
risk_clearedapprovedAll