Webhooks
Webhooks allow your applications to receive real-time notifications whenever important events occur within VDSapps.
Setting Up Webhooks in RapIDadmin
To start receiving webhook notifications, you first need to configure them in the RapIDadmin interface.
Navigate to RapIDadmin > API > Webhooks
Click the Create button
(Optional) Select an Application from the dropdown menu
Note: The application selector allows you to link webhooks to a specific application.
Enter the notification URL where you want to receive the webhooks
Generate a Signing Secret by clicking the Generate Secret button
Note: Store this secret securely as it will be used to verify the authenticity of incoming webhooks
Select the events you want to subscribe to by checking the corresponding boxes
Click the Save button
Important Considerations
Ensure your notification URL is publicly accessible and can handle POST requests
Keep your Signing Secret confidential to maintain the security of your webhook system
You can create multiple webhook configurations for different purposes or applications
Event Types
Each webhook notification includes:
A header called
x-event-name
that shows what type of event occurredA JSON body containing the event details
The notifications differ based on the source:
EliteID notifications: Provide detailed updates about changes to person records and credentials
RapIDadmin notifications: Include information about print job status and details
x-event-name | Description |
EliteId.Person.Created | New person record creation |
EliteId.Person.Updated | Existing person record modification |
EliteId.Person.Deleted | Person record removal |
EliteId.PersonCredential.Created | Initial card issuance |
EliteId.PersonCredential.Updated | Card reprint and smart card update |
RapIDAdmin.PrintJob.Started | Print process initiation |
RapIDAdmin.PrintJob.Complete | Successful print job completion |
RapIDAdmin.PrintJob.Failed | Print job failure |
JSON Payload Examples
EliteID Person Events
x-event-name: EliteID.Person.Created
{
"Id": " aff5ff4a-7775-4895-b999-99c9e70e1495",
"IdNumber": "20020",
"SecondaryId": null,
"FirstName": "Jones",
"FirstNamePreferred": null,
"MiddleName": null,
"LastName": "Kevin",
"ModifiedTime": null,
"Note": null,
"NoteTime": null,
"NoteCreatedBy": null,
"SignatureId": null,
"SignatureTime": null,
"SignatureUri": null,
"PhotoId": null,
"PhotoTime": null,
"PhotoUri": null,
"CreationTime": "2024-10-04T15:38:53Z",
"LastImportTime": null,
"FieldValues": {
"735ff460-00e5-4810-b7f4-1125a2418b00": "Student",
"2ec1180e-1fbc-4b18-ba93-666041698261": "09",
"c36a046f-3194-45a9-8889-b6ff7f1b80c6": ""
}
}
x-event-name: EliteID.Person.Updated
{
"Id": "aff5ff4a-7775-4895-b999-99c9e70e1495",
"IdNumber": "20020",
"SecondaryId": null,
"FirstName": "KEVIN",
"FirstNamePreferred": null,
"MiddleName": null,
"LastName": "JONES",
"ModifiedTime": "2024-10-11T18:11:42Z",
"Note": null,
"NoteTime": null,
"NoteCreatedBy": null,
"SignatureId": null,
"SignatureTime": null,
"SignatureUri": null,
"PhotoId": "0e92f9f0-e88e-4d67-9f2d-0b8c4f299046",
"PhotoTime": "2024-10-04T15:40:21Z",
"PhotoUri": "https://PHOTO_URI",
"CreationTime": "2024-10-04T15:38:53Z",
"LastImportTime": "2024-10-04T15:40:21Z",
"FieldValues": {
"2ec1180e-1fbc-4b18-ba93-666041698261": "09",
"c36a046f-3194-45a9-8889-b6ff7f1b80c6": "kjones@email.com",
"735ff460-00e5-4810-b7f4-1125a2418b00": "Student",
}
}
x-event-name: EliteId.Person.Deleted
{
"Id": "aff5ff4a-7775-4895-b999-99c9e70e1495",
"IdNumber": "20020",
"SecondaryId": null,
"FirstName": "KEVIN",
"FirstNamePreferred": null,
"MiddleName": null,
"LastName": "JONES",
"ModifiedTime": "2024-10-11T18:11:42Z",
"Note": null,
"NoteTime": null,
"NoteCreatedBy": null,
"SignatureId": null,
"SignatureTime": null,
"SignatureUri": null,
"PhotoId": "0e92f9f0-e88e-4d67-9f2d-0b8c4f299046",
"PhotoTime": "2024-10-04T15:40:21Z",
"PhotoUri": "https://PHOTO_URI",
"CreationTime": "2024-10-04T15:38:53Z",
"LastImportTime": null,
"FieldValues": {
"2ec1180e-1fbc-4b18-ba93-666041698261": "09",
"c36a046f-3194-45a9-8889-b6ff7f1b80c6": "kjones@email.com",
"735ff460-00e5-4810-b7f4-1125a2418b00": "Student"
}
}
EliteID Credential Events
x-event-name: EliteId.PersonCredential.Created
x-event-name: EliteId.PersonCredential.Updated
RapIDadmin Print Events
x-event-name: RapIDAdmin.PrintJob.Started
x-event-name: RapIDAdmin.PrintJob.Completed
x-event-name: RapIDAdmin.PrintJob.Failed
Field Descriptions
EliteID.Person Field Descriptions
The following table describes the fields that are included in Person webhook’s response body.
Field Name | Description |
---|---|
Id | Unique identifier for the person (UUID format) |
IdNumber | Assigned identification number for the person |
SecondaryId | Assigned secondary identification number for the person |
FirstName | Person's first name |
FirstNamePreferred | Person's preferred first name (if different from FirstName) |
MiddleName | Person's middle name |
LastName | Person's last name |
ModifiedTime | Timestamp of the last modification to the person's record |
Note | Any additional notes about the person |
NoteTime | Timestamp of when the note was last updated |
NoteCreatedBy | Identifier of the user who created or last updated the note |
SignatureId | Unique identifier for the person's signature |
SignatureTime | Timestamp of when the signature was last updated |
SignatureUri | URI to access the person's signature image |
PhotoId | Unique identifier for the person's photo |
PhotoTime | Timestamp of when the photo was last updated |
PhotoUri | URI to access the person's photo. The link does not expire. |
CreationTime | Timestamp of when the person's record was created |
LastImportTime | Timestamp of the last time the person's data was bulk imported from an external system |
FieldValues | Object containing custom field values, where the key is the field's UUID and the value is the field's content |
Notes on FieldValues
The FieldValues
object contains custom fields that may vary depending on your specific EliteID configuration.
The exact meaning and use of these custom fields will depend on your organization's setup.
EliteId.PersonCredential Field Descriptions
The following table describes the fields that are included in PersonCredential webhook’s response body.
Field Name | Description |
---|---|
PersonId | Unique identifier for the person (UUID format) |
CardTemplateId | Unique identifier for the card template |
CardTemplateName | Name of the card template |
Created | Timestamp of the event |
ExpirationDate | Card expiration date (if applicable) |
IdNumber | Assigned ID number |
Iso | Current ISO number (if applicable) |
PreviousIso | Previous ISO number (if applicable) |
ProxNumber | Current proximity card number (if applicable) |
PreviousProxNumber | Previous proximity card number (if applicable) |
ProxFacility | Current proximity facility code (if applicable) |
PreviousProxFacility | Previous proximity facility code (if applicable) |
Library | Current library number (if applicable) |
Signature Verification
The webhook notification includes an x-signature
header that contains a signature. The signature is generated server-side by creating an HMAC of the raw request body using SHA-256 and the Signing Secret as the key. To authenticate webhooks using signature verification, follow these steps:
Retrieve the raw body of the request
Extract the value from the
x-signature
headerCompute the HMAC of the raw body using the SHA-256 hash function and the Signing Secret
Compare the computed HMAC with the one provided in the
x-signature
header
The following is an example using ASP.NET
Expected Webhook Events for Common Scenarios
This section outlines the sequence of webhook events you can expect for common operations within EliteID.
Note: Smart Card printing will generate two PersonCredential notifications. The second notification contains the updated smart card number.
EliteID API operations and bulk data imports do not generate webhook alerts.
A new person is added to the system
When a new person record is created:
EliteId.Person.Created
A person's information is updated
When a person's information is modified in the system (Edits, Photos, Signatures, Notes):
EliteId.Person.Updated
A person is deleted
When a person record is deleted in the system:
EliteId.Person.Deleted
A person's first card is printed successfully
When a new card is printed for a person for the first time:
EliteId.PersonCredential.Created
RapIDAdmin.PrintJob.Started
RapIDAdmin.PrintJob.Complete
A person's card is reprinted successfully
When an existing card is reprinted:
EliteId.PersonCredential.Updated
RapIDAdmin.PrintJob.Started
RapIDAdmin.PrintJob.Complete
A person’s card fails to print
When a card does not print:
EliteId.PersonCredential.Updated
RapIDAdmin.PrintJob.Failed
A (Smart) card is printed successfully
When a card associated with a Smart template is printed:
EliteId.PersonCredential.Created
RapIDAdmin.PrintJob.Started
EliteId.PersonCredential.Updated
RapIDAdmin.PrintJob.Complete
A (Smart) card is reprinted successfully
When a card associated with a Smart template is reprinted:
EliteId.PersonCredential.Updated
RapIDAdmin.PrintJob.Started
EliteId.PersonCredential.Updated
RapIDAdmin.PrintJob.Complete