Using Webhooks

You can leverage webhooks to track pass updates in your own service. To get set up, follow the instructions below.

Registering Your Endpoint

Under the Webhooks section, add your endpoint, and click Update to save your changes.

Register webhook graphic

Adding Authorization

For additional security, we recommend generating a project secret, and saving it as the Authorization Header.

Check against this header in your endpoint to ensure you are processing requests from a trusted source.

Implementation Details

List of Events

A registered endpoint will receive all of the following events:

EventValueDescription
PassCreatedpass:createUser created a pass.
PassRegisterpass:registerUser installed a pass onto their device.
PassUnregisterpass:unregisterUser removed a pass from their device.
PassExpiredpass:expireUser's pass expired (see all possible expiration reasons here).
PassScanpass:scanUser’s pass was scanned with ethpass.

Payload Schema

All payloads will include an event field describing the update, and a result field containing the updated pass.

The result field will have the same body and specifications as GET /v0/passes/{passId}.

An example payload for an expired pass might look like the below.

{
  "event": "pass:expire",
  "result": {
    "id": "2f8210ee-4f02-4966-9529-745d80116718",
    "barcodeSignature": "0x02c954980025cfc61a0f78b938173c0eda776103c896f44fc5ba5941933dd9c96891e0fef78f1aecf0eb09ec34d0bd74f2f1627329d6afa88dfadeac8ae049871c",
    "platform": "google",
    "ownerAddress": "0xF888f4fAad70F542a80176f8b63438402C937473",
    "createdAt": "2022-10-27T21:57:38.520137+00:00",
    "expiredAt": "2022-10-27T21:58:03.158+00:00",
    "expireAction": "USER_REVOKE",
    "lastScannedAt": "2022-10-27T21:58:01.822+00:00",
    "chain": {
      "name": "evm",
      "network": "1"
    },
    "registrations": [
      {
        "id": "07a39167-6484-4ce8-b485-84eb41a5cd5b",
        "createdAt": "2022-10-27T21:56:30.026695+00:00",
        "deletedAt": null
      }
    ],
    "nfts": [
      {
        "contractAddress": "0x25ed58c027921e14d86380ea2646e3a1b5c55a8b",
        "contractInterface": "0x80ac58cd",
        "tokenId": "5946"
      }
    ]
  }
}

Testing Webhooks

Once your endpoint is registered in the dashboard, you can quickly trigger an event by using the dashboard to revoke an existing pass, or creating a new pass with your app.

To preview webhook activity without implementing your own endpoint, we recommend using webhook.site.