Credentials
Introduction
Credentials are used to identify individual users of an access control system. PDK supports a wide variety of credentials, including digital credentials that can be distributed through the ProdataKey app or a custom mobile app.
There are three types of credentials:
- Card: a physical credential, such as a proximity card, key fob, sticker, wristband, or QR code.
- Bluetooth: a digital credential that allows users to gain access by presenting a mobile device to a Bluetooth reader.
- Mobile: a digital credential that allows users to gain access by pressing a button in the ProdataKey app or a custom mobile app.
The credential object
- Physical
- Digital
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": 1234567,
"facilityCode": null,
"description": null,
"types": ["card"]
}
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": null,
"facilityCode": null,
"description": null,
"types": ["touch", "token"]
}
Property | Type | Description |
---|---|---|
id | String | The credential ID. |
holderId | String | The holder ID. |
credentialNumber | Integer | The credential number. |
facilityCode | Integer | The facility code number. This only applies to card credentials. |
description | String | The credential description. For digital credentials, this value is initially set to Pending until the credential is activated. Once a digital credential is activated, the description is set to the model name of the associated device (e.g. iPhone , SM-A256U ). |
types | String[] | A list of credential types. Possible values include card for physical credentials, touch for Bluetooth credentials, and token for mobile credentials. Credentials can only be physical or digital, so if card is present in the list, touch and token are ignored. |
Basic Endpoints
Create a credential
Request
- Physical
- Digital
POST https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials HTTP/1.1
Authorization: Bearer {{system_token}}
Content-Type: application/json
{
"types": ["card"],
"credentialNumber": 1234567
}
POST https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials HTTP/1.1
Authorization: Bearer {{system_token}}
Content-Type: application/json
{
"types": ["touch", "token"],
"sendEmail": false
}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
holder_id | Path | String | Yes | The holder ID. |
system_token | Header | String | Yes | A valid system token. |
types | Body | String[] | Yes | A list of credential types. Possible values include card for physical credentials, touch for Bluetooth credentials, and token for mobile credentials. Credentials can only be physical or digital, so if card is present in the list, touch and token are ignored. |
credentialNumber | Body | Integer | Sometimes | The credential number. This value is required for card credentials and must be omitted for digital credentials, since it will be set automatically once a digital credential is accepted. This value must be unique among all other credential numbers on the cloud node. |
facilityCode | Body | Integer | No | The facility code number. This only applies to card credentials. |
description | Body | String | No | The credential description. This value is only configurable for card credentials. The maximum length is 255 characters. |
sendEmail | Body | Boolean | No | Whether or not to send a ProdataKey app activation email. This only applies to digital credentials. The default value is true . If set to false , the partner application must implement a custom activation workflow using the inviteId provided in the response. |
Response
- Physical
- Digital
The response contains the ID of the newly created credential object.
HTTP/1.1 201 OK
Content-Type: application/json
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b"
}
The response contains the ID of the newly created credential object along with an inviteId
, which can be used for custom activation workflows. Invitations expire after 72 hours and can be renewed at any time.
HTTP/1.1 200 OK
Content-Type: application/json
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"inviteId": "651da6b9340a24e82b824a2a"
}
If you'd like your custom activation workflow to launch the ProdataKey app, use the following deep link format.
https:/invite/{{inviteId}}
If you'd like your custom activation workflow to launch your custom app, be sure to include the inviteId
in your deep link. The inviteId
can then be passed to the iOS SDK or Android SDK for activation.
https:/activate?inviteId={{inviteId}}
Retrieve a credential
Request
GET https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials/{{credential_id}} HTTP/1.1
Authorization: Bearer {{system_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
holder_id | Path | String | Yes | The holder ID. |
credential_id | Path | String | Yes | The credential ID. |
system_token | Header | String | Yes | A valid system token. |
Response
The response contains a credential object.
- Physical
- Digital
HTTP/1.1 200 OK
Content-Type: application/json
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": 1234567,
"facilityCode": null,
"description": null,
"types": ["card"]
}
HTTP/1.1 200 OK
Content-Type: application/json
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": null,
"facilityCode": null,
"description": null,
"types": ["touch", "token"]
}
Update a credential
Once a credential is created, its properties can't be updated, with the exception of the types
property of a digital credential.
Request
PUT https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials/{{credential_id}} HTTP/1.1
Authorization: Bearer {{system_token}}
Content-Type: application/json
{
"types": ["touch", "token"]
}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
holder_id | Path | String | Yes | The holder ID. |
credential_id | Path | String | Yes | The credential ID. |
system_token | Header | String | Yes | A valid system token. |
types | Body | String[] | Yes | A list of credential types. Possible values include touch for Bluetooth credentials and token for mobile credentials. |
Response
The response contains the ID of the updated credential object.
HTTP/1.1 200 OK
Content-Type: application/json
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b"
}
Delete a credential
Request
DELETE https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials/{{credential_id}} HTTP/1.1
Authorization: Bearer {{system_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
holder_id | Path | String | Yes | The holder ID. |
credential_id | Path | String | Yes | The credential ID. |
system_token | Header | String | Yes | A valid system token. |
Response
HTTP/1.1 204 No Content
List all credentials
Request
GET https://systems.pdk.io/{{system_id}}/credentials HTTP/1.1
Authorization: Bearer {{system_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
page | Query | Integer | No | The zero-based page number used for pagination. The default value is 0. |
per_page | Query | Integer | No | The number of items per page used for pagination. The default value is 10 and the maximum value is 100. |
system_token | Header | String | Yes | A valid system token. |
Response
The response contains an array of credential objects.
HTTP/1.1 200 OK
Content-Type: application/json
[
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": 1234567,
"facilityCode": null,
"description": null,
"types": [
"card"
]
},
{
"id": "07a462bd-d633-4506-a753-2f878d6b6e61",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": null,
"facilityCode": null,
"description": null,
"types": [
"touch",
"token"
]
}
]
List all credentials for a holder
Request
GET https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials HTTP/1.1
Authorization: Bearer {{system_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
holder_id | Path | String | Yes | The holder ID. |
page | Query | Integer | No | The zero-based page number used for pagination. The default value is 0. |
per_page | Query | Integer | No | The number of items per page used for pagination. The default value is 10 and the maximum value is 100. |
system_token | Header | String | Yes | A valid system token. |
Response
The response contains an array of credential objects.
HTTP/1.1 200 OK
Content-Type: application/json
[
{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": 1234567,
"facilityCode": null,
"description": null,
"types": [
"card"
]
},
{
"id": "07a462bd-d633-4506-a753-2f878d6b6e61",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": null,
"facilityCode": null,
"description": null,
"types": [
"touch",
"token"
]
}
]
List all facility codes
Request
GET https://systems.pdk.io/{{system_id}}/credentials/facility-codes HTTP/1.1
Authorization: Bearer {{system_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
system_id | Path | String | Yes | The system ID. |
page | Query | Integer | No | The zero-based page number used for pagination. The default value is 0. |
per_page | Query | Integer | No | The number of items per page used for pagination. The default value is 10 and the maximum value is 100. |
system_token | Header | String | Yes | A valid system token. |
Response
The response includes an array of strings representing all facility codes in the system.
HTTP/1.1 200 OK
Content-Type: application/json
["123", "456"]
Renew a digital credential invitation
Request
POST https://accounts.pdk.io/api/credentials/holders/invite HTTP/1.1
Authorization: Bearer {{id_token}}
Content-Type: application/json
{
"systemId": "0738b8df-329a-4d50-88e7-7a48928c4d6f",
"holderId": "db49d19d-6f76-4c1f-9939-567c2af827ad",
"credentialId": "bbea08dd-7e74-441c-97d3-fc137016b38f",
"types": ["touch", "token"],
"sendEmail": true,
"email": "john@example.com"
}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
id_token | Header | String | Yes | A valid ID token. |
systemId | Body | String | Yes | The system ID. |
holderId | Body | String | Yes | The holder ID. |
credentialId | Body | String | Yes | The credential ID. |
types | Body | String[] | Yes | A list of digital credential types. Possible values include touch for Bluetooth credentials and token for mobile credentials. |
sendEmail | Body | boolean | Yes | Whether or not to send a ProdataKey app activation email. The default value is true . If set to false , the partner application must implement a custom activation workflow using the inviteId provided in the response. |
email | Body | String | Sometimes | The email address to which the ProdataKey app activation email should be sent. This value is required if sendEmail is set to true . |
Response
The response contains the same inviteId
that was returned when the credential was initially created. The inviteId
can be used for custom activation workflows.
HTTP/1.1 200 OK
Content-Type: application/json
{
"inviteId": "677e990a10aa4992e5cf13ff"
}
Credential Self-Help
Organizations can reduce administrative load by enabling credential self-help, which allows users to reset their digital credentials on a new mobile device (e.g. when they get a new phone). However, in order to prevent abuse, the ability to reset credentials is restricted after a certain number of requests (the default limit is 1 request per month). The endpoints below allow you to manage any self-help restrictions that are currently in force.
List all credential self-help restrictions
Request
GET https://accounts.pdk.io/api/credentials/holders/restrictions HTTP/1.1
Authorization: Bearer {{id_token}}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
id_token | Header | String | Yes | A valid ID token. |
systemId | Query | String | Yes | The system ID. |
holderId | Query | String | Yes | The holder ID. |
Response
HTTP/1.1 200 OK
Content-Type: application/json
[
{
"holderId": "asefsef-58bf-4513-a5c2-58d352cf7fc3",
"systemId": "asdfsef-68e9-4718-ab64-cd9dd64338bc",
"credentialId": "fe5f3wefasef-8263-4a3a-b508-dc56813e0seff"
}
]
Clear all credential self-help restrictions
Request
POST https://accounts.pdk.io/api/credentials/holders/restrictions/clear HTTP/1.1
Authorization: Bearer {{id_token}}
Content-Type: application/json
{
"systemId": "{{system_id}}",
"holderId": "{{holder_id}}",
"credentialId": "{{credential_id}}"
}
Parameter | Location | Type | Required | Description |
---|---|---|---|---|
id_token | Header | String | Yes | A valid id token. |
systemId | Body | String | Yes | The system ID. |
holderId | Body | String | Yes | The holder ID. |
credentialId | Body | String | No | The credential ID. |
Response
HTTP/1.1 204 No Content