Skip to main content
Version: 2.0

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

{
"id": "83481691-680a-4d8d-9352-9651d3f1753b",
"holderId": "3a1d8a29-efb3-44cf-94f2-8acbb4acf728",
"credentialNumber": 1234567,
"facilityCode": null,
"description": null,
"types": ["card"]
}
PropertyTypeDescription
idStringThe credential ID.
holderIdStringThe holder ID.
credentialNumberIntegerThe credential number.
facilityCodeIntegerThe facility code number. This only applies to card credentials.
descriptionStringThe 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).
typesString[]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

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
}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
holder_idPathStringYesThe holder ID.
system_tokenHeaderStringYesA valid system token.
typesBodyString[]YesA 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.
credentialNumberBodyIntegerSometimesThe 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.
facilityCodeBodyIntegerNoThe facility code number. This only applies to card credentials.
descriptionBodyStringNoThe credential description. This value is only configurable for card credentials. The maximum length is 255 characters.
sendEmailBodyBooleanNoWhether 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

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"
}

Retrieve a credential

Request

GET https://systems.pdk.io/{{system_id}}/holders/{{holder_id}}/credentials/{{credential_id}} HTTP/1.1
Authorization: Bearer {{system_token}}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
holder_idPathStringYesThe holder ID.
credential_idPathStringYesThe credential ID.
system_tokenHeaderStringYesA valid system token.

Response

The response contains a credential object.

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"]
}

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"]
}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
holder_idPathStringYesThe holder ID.
credential_idPathStringYesThe credential ID.
system_tokenHeaderStringYesA valid system token.
typesBodyString[]YesA 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}}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
holder_idPathStringYesThe holder ID.
credential_idPathStringYesThe credential ID.
system_tokenHeaderStringYesA 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}}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
pageQueryIntegerNoThe zero-based page number used for pagination. The default value is 0.
per_pageQueryIntegerNoThe number of items per page used for pagination. The default value is 10 and the maximum value is 100.
system_tokenHeaderStringYesA 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}}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
holder_idPathStringYesThe holder ID.
pageQueryIntegerNoThe zero-based page number used for pagination. The default value is 0.
per_pageQueryIntegerNoThe number of items per page used for pagination. The default value is 10 and the maximum value is 100.
system_tokenHeaderStringYesA 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}}
ParameterLocationTypeRequiredDescription
system_idPathStringYesThe system ID.
pageQueryIntegerNoThe zero-based page number used for pagination. The default value is 0.
per_pageQueryIntegerNoThe number of items per page used for pagination. The default value is 10 and the maximum value is 100.
system_tokenHeaderStringYesA 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"
}
ParameterLocationTypeRequiredDescription
id_tokenHeaderStringYesA valid ID token.
systemIdBodyStringYesThe system ID.
holderIdBodyStringYesThe holder ID.
credentialIdBodyStringYesThe credential ID.
typesBodyString[]YesA list of digital credential types. Possible values include touch for Bluetooth credentials and token for mobile credentials.
sendEmailBodybooleanYesWhether 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.
emailBodyStringSometimesThe 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}}
ParameterLocationTypeRequiredDescription
id_tokenHeaderStringYesA valid ID token.
systemIdQueryStringYesThe system ID.
holderIdQueryStringYesThe 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}}"
}
ParameterLocationTypeRequiredDescription
id_tokenHeaderStringYesA valid id token.
systemIdBodyStringYesThe system ID.
holderIdBodyStringYesThe holder ID.
credentialIdBodyStringNoThe credential ID.

Response

HTTP/1.1 204 No Content