Biometric Services
Overview
Biometric Services is intended to be used by service providers to build identity proofing services for their end-users.
- Biometric Services exposes a simple REST API to detect and recognize faces from still images.
- WebCapture SDK (Face Autocapture and Liveness) provides face and liveness detection from video streams.
Service Provider
A service provider is an entity that develops apps and use cases on top of the BioServer.
The service provider:
- Owns a client ID and a secret that gives access to Biometric Services for either the service provider itself or a third party
- Can eventually be billed according to the use of Biometric Services (see: Billing System)
User
The user is a person whose face images are sent to Biometric Services in the context of use cases that are implemented by the service provider.
Typical Use Cases
The most common use cases are described below.
Reference Image Verification
This use case flow allows the verification and storage of a user's face image.
Process Steps
The primary process steps are:
Note: The known user has already been authenticated by the Service Provider.
- The Service Provider (SP) app asks the known user for an image of their face,
- The face image is sent to the BioServer.
- The BioServer creates the face resource.
- An 'OK' notification is returned to the user.
- The SP app is notified that the operation is done.
- The SP app gets the face resource from the BioServer.
- The BioServer returns the face resource to the SP app.
- The face image is verified by Biometric Services and becomes a reference face image.
- The back end stores the user's reference image.
- The SP app notifies the user that registration is complete.
One-to-One Verification
This use case allows one-to-one face image recognition. A user is asked for a face biometric authentication. Biometric Services checks it against a reference face (previously stored by the back end).
Process Steps
The primary process steps are:
- The Service Provider (SP) app asks the user for a face biometric authentication.
- The user sends their face image to the BioServer.
- The BioServer creates the face resource.
- The face resource is returned to the user who OKs it.
- The SP app is notified that the operation is complete.
- The SP app reads the reference face image.
- The SP app sends the reference face image to the BioServer.
- Biometric Services checks if a reference face matches another image of the user's face, and creates the face resource.
- 'OK' is returned to the SP app.
- The SP app returns the matches resource to the BioServer.
- The BioServer computes the matches.
- The matches resource is returned to the SP app.
- The SP app makes a decision about the match.
- The SP app notifies the user if the authentication is 'OK' or not.
Note: Only authentication via the
APIkey
is required. The Biometric Services session is not used. Images and verification results are not stored in the session.
Web Services
The following web services are involved in this scenario:
- Direct Create Face: Returns the Face result in JSON format
- Direct Match Image vs. Template: Returns the Match result in JSON format
API Workflow Diagram
A diagram of the one-to-one verification process is shown below.
One-to-Few Identification
This use case allows the service provider to find matches of a reference face among a small number of face images:
- Biometric Services checks a face from a photo (“selfie”) and matches a face extracted from an identity document.
- The result is signed by Biometric Services and can be added to the decision proof.
Note: All face images must be provided. No user database is involved.
The primary process steps are:
- The Service Provider (SP) app sends the reference face image of a known user to the BioServer.
- The BioServer creates the face resource.
- An 'OK' notification is returned to the SP app.
- The face image is sent to the BioServer.
- The face resource is created.
- An 'OK' response is returned to the SP app.
- The SP app gets the matches resource from the BioServer.
- The BioServer computes matches.
- The BioServer returns the matches resource to the SP app.
- The SP app verifies that the faces match.
Web Services
The following web services are involved in this scenario:
CreateBioSession
: Contains aSESSION_ID
inside location header.GetBioSession
(Optional): RetrievesSESSION
information.CreateFaceFromImage
(Multiple times): Encodes each face image and stores the template within distributed cache. Returns thefaceid
in response header(Location).GetFace
: (Optional): Retrieves each face information.Matches
: Retrieves a list of ordered matches (best scores come first) for a given face.
API Workflow Diagram
A diagram of the one-to-few verification process is shown below.
Replay Challenge using NativeSDK
This functionality enables the service to confirm a user's liveness through a Biometric challenge, conducted on a user's mobile device via an iOS or Android app integrated with NativeSDK. Termed as hybrid liveness, this process unfolds in two separate stages: the initial phase takes place on the mobile device, while the validation phase proceeds on the backend.
The primary process steps are:
- The Service Provider (SP) asks the enduser to proceed to an offline liveness check on iOS or Android App.
- The NativeSDK integration within the app connects with Bioserver to retrieve capture parameters.
- The enduser proceed to the offline check.
- Result from the check is sent automatically to Bioserver.
- Bioserver replays the liveness scenario on backend and validates the liveness.
- The liveness response is returned to the SP app.
Web Services
The following web services are involved in this scenario:
CreateBioSession
: Contains aSESSION_ID
inside location headerGetBioSession
(Optional): RetrievesSESSION
informationinitLivenessParameters
: Posts liveness settings that will be used to run the challengegetLivenessParameters
(Optional): Retrieves liveness settings that will be used to run the challenge on the mobile side
API Workflow Diagram
A diagram of the Replay challenge process is shown below.
API Errors
Calls to the API may return errors. When this happens, an HTTP error code is returned along with an error object.
Error objects include the following:
- An ID attribute which is used to identify the error
- An optional message attribute which gives more information about the error
Sample Error Object
The object containing the id
error and the message
describing the error are shown in the snippet:
JSON1{2 "id": "a5ac0455-8d99-4d73-835c-c656b5aba41e",3 "message": "Session not found"4}
Managing Backpressure During High Demand
When our platform experiences peak traffic, attempts to process a replay liveness or coding/matching operation might result in a 429 Too Many Requests
HTTP response. This indicates our current request volume exceeds the server's processing capacity. Our system automatically scales to increase capacity, but this scaling requires a brief period to complete.
Key Advice for Handling 429 Responses :
- Prompt User Notification: Inform users of the high demand affecting the system and suggest they retry their request after a brief interval.
Recommended Message for Users :
"We're currently managing increased traffic and are working to accommodate all requests. Please try again shortly. Thank you for your patience."
This approach helps navigate the challenges of backpressure, ensuring users are aware of the current state and know to retry their requests after a short pause.
REST APIs
Overview
This section provides details about the REST APIs used for user identity proofing in Biometric Services. These REST APIs accept JSON for the request payload, and send responses as JSON.
HealthCheck / Monitoring / Capabilities API
This section describes the GetCapabilities
API that requests some capabilities of the bio-session, along with the version number and the supported algorithm.
This API retrieves various capabilities of the bio-session, along with the algorithm used, the version used, and the supported algorithms.
Endpoint
The GET
and curl
commands are used to make the HTTP request to the URL for the bio-session capabilities.
The header data is specified with the -H
option as shown in the snippet:
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/capabilities \3 -H 'Authorization: [APIKEY_VALUE]'
Header Fields
The HTTP header fields containing metadata associated with the API request and response fields is shown below.
Field | Description |
---|---|
apikey (optional) | APIkey value |
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields below.
Field | Type | Description |
---|---|---|
version | String | The Biometric Services version. |
currentMode | Array | The available modes used for face creation. |
Response Example
The 200
status code will be returned with a description in the event of success, as shown below.
The sample code response for the version and modes is shown in the snippet:
JSON1{2 "currentMode": ["F5_1_VID60"],3 "version": "3.21.0"4}
HTTP Error Codes
Below are the status codes and descriptions that will be returned if the getCapabilities
request generates an error.
Name | Description |
---|---|
401 | Authentication is required |
404 | The instance is not working properly. |
500 | The instance is not working properly. |
Bio-Sessions APIs
This section describes the APIs used to create and retrieve bio-sessions.
A bio-session is a sequence of Biometric Services interactions related to the same user. A bio-session is explicitly created, but ends automatically after a configured number of seconds has elapsed.
CreateBioSession API
The CreateBioSession
API creates a bio-session. This API will return a 201 HTTP code with a location header that contains the SESSION_ID
to use in every requests related to this bio-session.
Endpoint
A sample request to create the bio-session is shown in the snippet:
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions \3 -H 'Content-Type: application/json' \4 -H 'apikey: [APIKEY_VALUE]' \5 -d '[{6"correlationId": "891a6728-1ac4-11e7-93ae-92361f002671",7"callbackURL": "https://service/callback"8}]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields containing metadata associated with the API request and response fields are shown in the table.
Field | Description |
---|---|
apikey (optional) | APIkey value |
Content-Type | Allowed values: application/json |
Request Body Fields
The request body is the data that you send to the server when you request the API. It is used to create the resource information returned by the API, and contains the representation of the resource to be created as shown in the following fields.
Field | Type | Description |
---|---|---|
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
imageStorageEnabled (optional) | Boolean | This specifies if images need to be stored for this bio-session; if this parameter is set to true , then the image used to create a face resource can be retrieved using GetFaceImage . The default value is false . |
ttlSeconds (optional) | Number | This specifies a time-to-live value in seconds after which this bio-session is automatically ended. If it is not specified by CreateBioSession , the ttlSeconds will be set to the configured default. An error will occur if ttlSeconds is set higher than the configured max. |
callbackURL (optional) | String | This specifies the URL used to notify a service provider that liveness check/replay-metadata results are available. |
Response Example
The 201
status code indicates that the bio-session was successfully created. It also return a Location
header of the URI to use for future requests related to the created session. This URI contains the created SESSION_ID
.
Field | Type | Description |
---|---|---|
Location | String | Header containing the URI of created the bio-session. SESSION_ID can be extracted alone if needed from location value. |
An example success snippet is shown below:
HTTP1HTTP/1.1 201 Created2get3Location: /v2/bio-sessions/0991cedc-9111-4b9d-9e4e-8d6eb4db488f
In order to extract SESSION_ID
, we can use a regex to remove the everything before the uuid (example of regex : "^.*/(.*)").
On the previous example, we have SESSION_ID
= 0991cedc-9111-4b9d-9e4e-8d6eb4db488f
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The status code indicates the specific error type and the issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the bio-session |
429 | Server is currently experiencing high demand. Request can be sent again after a few seconds. |
500 | Internal error |
GetBioSession API
The GetBioSession
API retrieves information about the bio-session.
Endpoint
The requested bioSessionID
field and apikey
header value (specified with the -H
option) are shown in the snippet:
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId} \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields containing metadata associated with the API request and response fields is shown below.
Field | Description |
---|---|
apikey (optional) | APIkey value |
URI Field
The URI field that provides the HTTP address where the bioSessionID
string identifier for the bio-session resource can be retrieved is shown below.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session resource to retrieve |
Response Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created, as shown in the fields below.
Field | Type | Description |
---|---|---|
id | String | The bio-session unique identifier generated by Biometric Services |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
imageStorageEnabled (optional) | Boolean | If images will be stored for this bio-session |
created | Datetime | The date on which the bio-session is created |
expires | Datetime | The date after which the bio-session will expire and will be removed from the server |
signature (optional) | String | The digital signature (JWS) of the response. Authentication and integrity can be verified afterward using the Biometric Services public certificate |
Response Example
This response sample returns the requested parameters with the bio-session information as shown in the snippet:
JSON1{2 "id": "0991cedc-9111-4b9d-9e4e-8d6eb4db488f",3 "correlationId": "891a6728-1ac4-11e7-93ae-92361f002671",4 "imageStorageEnabled": false,5 "created": "2017-05-18T10:14:39.587Z",6 "expires": "2017-05-18T10:19:39.587Z",7 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KICAiaWQiIDogIjA5OTFjZ…vtmiJGc"8}
HTTP Error Codes
The error status code indicates the specific error type and the error code issue. If an error occurs, one of the 4xx
status codes will be returned as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to retrieve the bio-session |
404 | Unable to find a bio-session for the given identifier |
500 | Internal error |
DeleteBioSession API
This function deletes a session
Shell1curl -X DELETE \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId} \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
URI Field
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session |
Response Example
The 204
status code will be returned when the face image has been successfully deleted.
Name | Description |
---|---|
204 | The session has been successfully deleted. |
The sample response for the 204
status code is shown in the snippet:
HTTP1HTTP/1.1 204 No Content
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
401 | Authentication is required |
404 | Unable to find a bio-session for the given identifier |
409 | There is replay liveness in progress |
500 | Internal error |
Faces APIs
This section describes the APIs that handle face functions.
The CreateFaceFromImage
function creates a face resource from a known user's image by processing the face image on the server.
Note: No more than one face can be detected per image.
Image Requirements
- There should be at least 60 pixels between the eyes.
- When an image is compressed using JPEG (.jpeg/.jpg), the image quality should be 80% or higher.
Endpoint
The POST
and curl
commands are used to create the face image resource.
The header data is specified with the -H
option, and the paths to the multi-form images are flagged with the -F
option, as shown in the snippet:
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces \3 -H 'Content-Type: multipart/mixed' \4 -H 'apikey: [APIKEY_VALUE]' \5 -F 'face=@[ABSOLUTE_LOCAL_PATH_TO_face]' \6 -F 'image=@[ABSOLUTE_LOCAL_PATH_TO_image]'
A JSON image object for the API is shown in the snippet:
JSON1{2 "imageType": "SELFIE",3 "friendlyName": "Presidential portrait of Barack Obama",4 "imageRotationEnabled": false5}
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contain metadata associated with the API request and response fields are shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
Content-Type | Allowed values: multipart/mixed , multipart/form-data |
URI Field
The URI field provides the HTTP address where the bioSessionID
string identifier for the bio-session resource can be retrieved.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session in which to create the face. |
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
face | Face | Face details |
mode (optional) | String | The biometric algorithm used to create the face biometric template; allowed values: F5_2_VID75 , F5_1_VID0 , F5_3_VID60 |
imageType | String | The kind of image; allowed values: ID_DOCUMENT , SELFIE , VIDEO_FRAME |
friendlyName (optional) | String | A friendly name for the face; default value: null |
imageRotationEnabled (optional) | Boolean | This enables image rotation for coding. Note: Do not use if the image is not rotated. For optimal performance, it's recommended to use images that are already correctly oriented rather than to use this parameter to rotate them; default value: null |
image | Binary | The face image to process |
Response Example
If the bio-session was successful, then the response will return status code 201
and contain the Location
header string of the URI for the created face image.
Field | Type | Description |
---|---|---|
Location | String | Header containing the URI of the created face |
The 201 Created
response indicates that the bio-session was successfully created. This response also returns the Location
string of the URI for the created bio-session as shown in the snippet:
HTTP1HTTP/1.1 201 Created2Location: /v2/bio-sessions/0991cedc-9111-4b9d-9e4e-8d6eb4db488f/faces/aa0bd6ca-1206-415b-af94-8d2c18aa9c70
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the face |
413 | The request was too big |
500 | Internal error |
CreateDirectFaceFromImage API
This function creates a face resource by processing a face image on the server. The face resource created is not associated with a session.
Note: No more than one face can be detected per image.
Image Requirements :
- There should be at least 60 pixels between the eyes.
- When an image is compressed using JPEG (.jpeg/.jpg), the image quality should be 80% or higher.
Endpoint
This method uses the POST
command with curl
to create the image resource on the BioServer.
The header data is specified with the -H
option and the image paths are flagged with the -F
option, as shown in the snippet:
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/faces \3 -H 'Content-Type: multipart/mixed' \4 -H 'apikey: [APIKEY_VALUE]' \5 -F 'face=@[ABSOLUTE_LOCAL_PATH_TO_FACE]' \6 -F 'image=@[ABSOLUTE_LOCAL_PATH_TO_image]' \7 -d '{"correlationId": "891a6728-1ac4-11e7-93ae-92361f002671"}'
A JSON image object for the API is shown in the snippet:
JSON1{2 "imageType": "SELFIE",3 "friendlyName": "Presidential portrait of Barack Obama",4 "imageRotationEnabled": false5}
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | APIkey value |
Content-Type | Allowed values: multipart/mixed , multipart/form-data |
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
face | Face | Reference face |
mode (optional) | String | The biometric algorithm used to create the face biometric template (currently the algorithm used is the one in the server configuration file) Allowed values: F5_2_VID75 , F5_1_VID60 , F5_3_VID60 |
imageType | String | The kind of image. Allowed values: ID_DOCUMENT , SELFIE , VIDEO_FRAME |
friendlyName (optional) | String | A friendly name for the face. Default value: null |
signatureDisabled (optional) | String | Disable the signature of the result. Default value: false |
imageRotationEnabled (optional) | Boolean | To enable image rotation for coding. Do not use if the image is not rotated. For optimal performance, it is recommended to use images that are already correctly oriented rather than to use this parameter to rotate them. Default value: null |
image | Binary | The face image to process. |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
Response Example
The following JSON object (with payload) is returned when the face image is successfully created, as shown in the snippet:
JSON1{2 "id": "3d069016-e66e-498e-af32-b930ba1c5067",3 "friendlyName": "Presidential portrait of Barack Obama",4 "digest": "8b11d3b37fcdb71da6b26d1c601c262a37b4c0f39edfbd51978cc46ace122862",5 "mode": "F5_3_VID60",6 "imageType": "SELFIE",7 "quality": 295,8 "landmarks": {9 "eyes": {10 "x1": 1220.5284,11 "y1": 1891.722,12 "x2": 1621.1726,13 "y2": 1873.576214 }15 },16 "imageRotationEnabled": false,17 "template": "EQAAAJQDAAACAAE09Uo_fRI...yJzdWIiOiJ0ZAEAAQDAAAC==",18 "templateVersion": 113,19 "created": "2018-10-25T14:32:48.863Z"20}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the face |
413 | The request was too big |
429 | Server is currently experiencing high demand. Request can be sent again after a few seconds. |
500 | Internal error |
CreateFaceFromJson API
This function creates a face resource from a previous face JSON object by processing the face biometric template on the server.
Endpoint
Note: This method is significantly faster than creating faces from images, but you must be careful as newer versions of biometric algorithms don't support the previous version of biometric templates.
This uses the POST
and curl
command to send data to the BioServer to create the face resource.
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces \3 -H 'Content-Type: application/json' \4 -H 'apikey: [APIKEY_VALUE]' \5 -d '{{6"id": "ee9b1742-06f4-4e22-8630-3852d55f314a",7"friendlyName": "Official portrait of First Lady Michelle Obama in the Green Room of the White House",8"digest": "20b4839d1da77fba4ed185e5a4649d1c514b101f823299c928dc43356f68b4df",9"mode": "F5_1_VID60",10"imageType": "SELFIE",11"quality": 306,12"landmarks": {13"eyes": {14"x1": 518.71204,15"y1": 444.68396,16"x2": 655.408,17"y2": 446.59918}19},20"template": "EQAAAMwDAAACA…AAAAAAAAAAAAyMIpAFAA",21"templateVersion": 92,22"created": "2017-11-13T13:28:24.098Z",23"expires": "2017-11-13T13:33:24.108Z",24"signature": "eyJhbGciOiJSUzI1NiJ9.ew0KogImFhMGJkNmNhL…ogIClbmRseU5hbWUoroAE_oxDF_ZtH-E"25}}'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | APIkey value |
Content-Type | Allowed values: application/json |
URI Field
The URI field that provides the HTTP address where the bioSessionID
string identifier for the bio-session resource can be retrieved is shown in the table.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session in which to create the face. |
Request Body Field
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
face | Face | Face details. |
Response Body Fields
If the bio-session was successfully created, then the response will return status code 201
and contain the Location
header string of the URI for the created face image.
Field | Type | Description |
---|---|---|
Location | String | Header containing the URI of the bio-session created |
Response Example
The 201 Created
response indicates that the bio-session was successfully created. This response also returns the Location
string of the URI for the created bio-session as shown in the snippet:
HTTP1HTTP/1.1 201 Created2Location: /v2/bio-sessions/0991cedc-9111-4b9d-9e4e-8d6eb4db488f/faces/aa0bd6ca-1206-415b-af94-8d2c18aa9c70
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown below.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the face |
500 | Internal error |
GetFace API
This function retrieves a face image.
Endpoint
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces/{faceId} \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown below.
Field | Description |
---|---|
apikey | APIkey value |
URI Fields
The URI field and related field that provides the HTTP address for the bioSessionID
string identifier and the bio-session face resource are shown in the table.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session containing the face. |
faceId | String | The identifier of the face resource to retrieve. |
Response Body Fields
The 200
http code response indicates that the request is successful.
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
id | String | The face unique identifier generated by BioServer. |
friendlyName (optional) | String | A friendly name for the face. |
digest (optional) | String | The SHA-256 digest of the image file from which the face has been created for confidentiality and verification purposes. |
mode | String | The biometric algorithm used to create the face biometric template. |
imageType | String | The kind of image. |
quality (optional) | Number | The biometric template quality. A good quality template is a template with a quality superior to 100. If the quality is negative, then the face needs to be sent again. |
landmarks (optional) | Landmarks | Landmarks detected on the face. |
template | String | The biometric template of the face. |
templateVersion | Number | The version of the biometric template Note: Newer versions of biometric algorithms don't support the previous version of biometric templates. |
imageRotationEnabled (optional) | Boolean | Image rotation enabled. Default value: null |
created | Datetime | The date on which the face is created. |
expires | Datetime | The date after which the face will expire and will be removed from the server. |
signature (optional) | String | A digital signature (JWS) of the response. Authentication and integrity can be verified afterward using the Biometric Services public certificate. |
Response Example
A sample success object with payload is shown in the snippet:
JSON1{2 "id": "aa0bd6ca-1206-415b-af94-8d2c18aa9c70",3 "friendlyName": "Presidential portrait of Barack Obama",4 "digest": "39bd0d9606a772b1e7076401f32f14bdde403b9608e789e0771b90fb79b664a4",5 "mode": "F5_1_VID60",6 "imageType": "SELFIE",7 "quality": 295,8 "landmarks": {9 "eyes": {10 "x1": 1191.4584,11 "y1": 582.79565,12 "x2": 1477.8955,13 "y2": 580.332414 }15 },16 "template": "EQAAAMwDAAACA…AAAAAAAAAAAAyMIpAFAA",17 "templateVersion": 92,18 "created": "2017-05-18T12:39:48.987Z",19 "expires": "2017-05-18T12:40:48.988Z",20 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KogImFhMGJkNmNhL…ogIClbmRseU5hbWUoroAE_oxDF_ZtH-E"21}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown below.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to retrieve the face |
404 | Unable to find a bio-session or a face for the given identifier |
500 | Internal error |
GetFaceImage API
Note: This function is only possible if image storage has been enabled for the bio-session.
This function retrieves the image that has been used to create a face resource as shown in the snippet.
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces/{faceId}/image?compression=true \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier that is used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Name | Description |
---|---|
apikey | TheAPIkey value |
URI Fields
The URI field and related fields that provide the HTTP address for the bioSessionID
string identifier and the bio-session face resource are shown in the table.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session containing the face. |
faceId | String | The identifier of the face resource for which the image needs to be retrieved. |
compression (optional) | Boolean | To enable image jpeg compression. Default value: false |
Response Example
The success status code 200
will be generated when the face image is successfully retrieved as shown in the table.
The 200 success response status code is shown in the snippet:
HTTP1HTTP/1.1 200 OK2Content-Type: image/jpeg3(image)
The 204
status code will be generated when storage is not enabled for the bio-session as shown below.
Name | Description |
---|---|
200 | The image has been successfully retrieved. |
204 | Storage is not enabled for the bio-session. |
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown below.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to retrieve the face image |
404 | Unable to find a bio-session or a face for the given identifier |
500 | Internal error |
GetFaces API
This function retrieves the list of faces that were created in a bio-session.
Endpoint
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown below.
Field | Description |
---|---|
apikey | APIkey value |
URI Field
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session. |
Response Example
The success status code 200
means the faces have been successfully retrieved.
JSON1[2 {3 "id": "3fd2bf77-244a-4563-a6ba-70abdc14b2ee",4 "friendlyName": "Barack Obama's Columbia University Student ID",5 "digest": "94d1b6ff2acf368c3e0ccaebe1d8e447ed1ccd7b596dc5cac3c13a4822b256c6",6 "mode": "F5_1_VID60",7 "imageType": "ID_DOCUMENT",8 "quality": 186,9 "landmarks": {10 "eyes": {11 "x1": 141.83296,12 "y1": 217.47075,13 "x2": 241.09653,14 "y2": 216.056815 }16 },17 "template": "EQAAAMwDAAACA…AAAAAAAAAAAAyMIpAFAA",18 "templateVersion": 92,19 "created": "2017-05-18T12:43:05.373Z",20 "expires": "2017-05-18T12:44:08.132Z",21 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KICAiaWQiIDog…JPKaeptOVlY4_InM6HQOm9JzFBMnzajI"22 },23 {24 "id": "aa0bd6ca-1206-415b-af94-8d2c18aa9c70",25 "friendlyName": "Presidential portrait of Barack Obama",26 "digest": "39bd0d9606a772b1e7076401f32f14bdde403b9608e789e0771b90fb79b664a4",27 "mode": "F5_1_VID60",28 "imageType": "SELFIE",29 "quality": 295,30 "landmarks": {31 "eyes": {32 "x1": 1191.4584,33 "y1": 582.79565,34 "x2": 1477.8955,35 "y2": 580.332436 }37 },38 "template": "EQAAAMwDAAACA…AAAAAAAAAAAAyMIpAFAA",39 "templateVersion": 92,40 "created": "2017-05-18T12:43:06.945Z",41 "expires": "2017-05-18T12:44:08.132Z",42 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KogImFhMGJkNmNhL…ogIClbmRseU5hbWUoroAE_oxDF_ZtH-E"43 }44]
HTTP Error Codes
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to retrieve the face list |
404 | Unable to find a bio-session for the given identifier |
500 | Internal error |
DeleteFace API
This function deletes a face image.
Shell1curl -X DELETE \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces/{faceId} \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
URI Field
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session |
Response Example
The 204
status code will be returned when the face image has been successfully deleted.
Name | Description |
---|---|
204 | The face has been successfully deleted. |
The sample response for the 204
status code is shown in the snippet:
HTTP1HTTP/1.1 204 No Content
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to delete the face list |
404 | Unable to find a bio-session or a face for the given identifier |
500 | Internal error |
DeleteFaces API
This function deletes the entire collection of faces in the current bio-session.
Endpoint
Shell1curl -X DELETE \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
URI Field
The URI field that provides the HTTP address where the bioSessionID
string identifier for the bio-session resource can be retrieved is shown in the table.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session. |
Response Example
The 204
status code will be returned when the face image has been successfully deleted.
Name | Description |
---|---|
204 | The face has been successfully deleted. |
The sample response for the 204
status code is shown in the snippet:
HTTP1HTTP/1.1 204 No Content
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown below.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to delete the face list |
404 | Unable to find a bio-session for the given identifier |
500 | Internal error |
Matches APIs
This section discusses how to perform face image matching.
GetMatches API
This function retrieves a list of ordered matches (best scores come first) for a given face.
The reference face is compared to all the faces created in the bio-session. The result of each comparison is called a “match”. Each match is composed of the reference face, a candidate face, a matching score, and a false acceptance rate.
False Acceptance Rate
The threshold you want to avoid using is driven by the expected FAR (False Acceptance Rate).
FAR | Matching threshold |
---|---|
0.0001% | 4500 |
0.001% | 4000 |
0.01% | 3500 |
0.1% | 3000 |
1% | 2500 |
Recommended Threshold
- Matching Document/Selfie: The recommended threshold 3500 (ie FAR 0.01%).
- Matching Selfie/Selfie: The recommended threshold is 4000 (ie FAR 0.001%).
Endpoint
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/faces/{referenceFaceId}/matches \3 -H 'apikey: [APIKEY_VALUE]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown “.
Field | Description |
---|---|
apikey | APIkey value |
URI Field
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session containing the faces. |
referenceFaceId | String | The identifier of the reference face. |
Response Body Fields
Field | Type | Description |
---|---|---|
reference | Face | Reference face. |
candidate | Face | Candidate face. |
score | Number | The matching score. |
falseAcceptanceRate | Number | The false acceptance rate, or FAR: measure of the likelihood that the Biometric Services will incorrectly return a match when the faces do not actually belong to the same person. For instance, "100" means there is no chance the two faces belong to the same person, "0.000000000028650475" means there is almost no chance Biometric Services can be wrong. |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
created | Datetime | The date on which the match has been created. |
expires | Datetime | The date after which the match will expire and will be removed from the server. |
signature (optional) | String | A digital signature (JWS) of the response. Authentication and integrity can be verified afterward using the Biometric Services public certificate. |
Response Example
The success status code 200
means the match results have been successfully retrieved.
JSON1[2 {3 "reference": {4 "id": "aa0bd6ca-1206-415b-af94-8d2c18aa9c70",5 "friendlyName": "Presidential portrait of Barack Obama",6 "digest": "39bd0d9606a772b1e7076401f32f14bdde403b9608e789e0771b90fb79b664a4",7 "mode": "F5_1_VID60",8 "imageType": "SELFIE",9 "quality": 295,10 "landmarks": {11 "eyes": {12 "x1": 1191.4584,13 "y1": 582.79565,14 "x2": 1477.8955,15 "y2": 580.332416 }17 }18 },19 "candidate": {20 "id": "6e1741f1-3715-416a-bfc6-4fc381d228a3",21 "friendlyName": "Barack Obama's Columbia University Student ID",22 "digest": "94d1b6ff2acf368c3e0ccaebe1d8e447ed1ccd7b596dc5cac3c13a4822b256c6",23 "mode": "F5_1_VID60",24 "imageType": "ID_DOCUMENT",25 "quality": 186,26 "landmarks": {27 "eyes": {28 "x1": 141.83296,29 "y1": 217.47075,30 "x2": 241.09653,31 "y2": 216.056832 }33 }34 },35 "score": 7771.43408203125,36 "falseAcceptanceRate": 0.000000000028650475616752694,37 "correlationId": "891a6728-1ac4-11e7-93ae-92361f002671",38 "created": "2017-05-18T12:41:09.58Z",39 "expires": "2017-05-18T12:42:00.844Z",40 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KICAicm…0NCiAgICB9DQHSQfU7Q"41 }42]
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to retrieve the matches |
404 | Unable to find a bio-session or a face for the given identifier |
500 | Internal error |
Images Match API
This function serves a direct image match by returning a single matched object (see Get images matches) computed by two images: a reference image and a candidate image.
False Acceptance Rate
The threshold you want to avoid using is driven by the expected FAR (False Acceptance Rate).
FAR | Matching threshold |
---|---|
0.0001% | 4500 |
0.001% | 4000 |
0.01% | 3500 |
0.1% | 3000 |
1% | 2500 |
Thresholds
The recommended thresholds are the following:
- Matching Document/Selfie: The recommended threshold 3500 (ie FAR 0.01%).
- Matching Selfie/Selfie: The recommended threshold is 4000 (ie FAR 0.001%).
Endpoint
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/match/images \3 -H 'Content-Type: multipart/form-data' \4 -H 'apikey: [APIKEY_VALUE]' \5 -F 'referenceImage=@[ABSOLUTE_LOCAL_PATH_TO_referenceImage]' \6 -F 'candidateImage=@[ABSOLUTE_LOCAL_PATH_TO_candidateImage]' \7 -F 'referenceImageType=@[ABSOLUTE_LOCAL_PATH_TO_referenceImageType]' \8 -F 'candidateImageType=@[ABSOLUTE_LOCAL_PATH_TO_candidateImageType]'
Permissions
APIkey - (the API key unique identifier) - API key used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
Content-Type | Allowed values: multipart/mixed , multipart/form-data |
Request Body Fields
Field | Type | Description |
---|---|---|
referenceImage | Binary | A reference face image to process. |
candidateImage | Binary | A candidate face image to process. |
referenceImageType | String | The kind of image for the reference face. Allowed values: ID_DOCUMENT , SELFIE , VIDEO_FRAME |
candidateImageType | String | The kind of image for the candidate face. Allowed values: ID_DOCUMENT , SELFIE , VIDEO_FRAME |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
imageRotationEnabled (optional) | Boolean | Enables image rotation for coding. Do not use if the image is not rotated. For best performance, use images that are already correctly oriented instead of using this parameter to rotate incorrectly oriented images. Default value: null |
Response Example
The success status code 200
means the match results have been successfully retrieved.
JSON1{2 "reference": {3 "id": "31214b58-9edc-425b-9436-60dcd94fbc3a",4 "mode": "F5_1_VID60",5 "imageType": "SELFIE",6 "quality": 306,7 "landmarks": {8 "eyes": {9 "x1": 518.71204,10 "y1": 444.68396,11 "x2": 655.408,12 "y2": 446.59913 }14 }15 },16 "candidate": {17 "id": "7d94bbfd-b779-44a3-a8fa-dfc20324fb2b",18 "mode": "F5_1_VID60",19 "imageType": "SELFIE",20 "quality": 306,21 "landmarks": {22 "eyes": {23 "x1": 518.71204,24 "y1": 444.68396,25 "x2": 655.408,26 "y2": 446.59927 }28 }29 },30 "score": 10269.438178710938,31 "falseAcceptanceRate": 0.000000000000001,32 "correlationId": "c5a0aec2-1262-41b6-82bd-e9d60da92ef2",33 "created": "2017-11-14T14:31:42.228Z",34 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KICAicmV…jQvj1G8qNqhOTbg8cWMQ1k_5F-GQTnco"35}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the face |
413 | The request was too big |
429 | Server is currently experiencing high demand. Request can be sent again after a few seconds. |
500 | Internal error |
Match API
This function returns a direct match by returning a single match object (see ) that was computed from a reference face (i.e., a previous face JSON) and a candidate's face image.
False Acceptance Rate
The threshold you should avoid using is driven by the expected FAR (False Acceptance Rate) as shown in the table.
FAR | Matching threshold |
---|---|
0.0001% | 4500 |
0.001% | 4000 |
0.01% | 3500 |
0.1% | 3000 |
1% | 2500 |
Thresholds
The following thresholds are recommended:
- Matching Document/Selfie: The recommended threshold 3500 (ie FAR 0.01%).
- Matching Selfie/Selfie: The recommended threshold is 4000 (ie FAR 0.001%).
Endpoint
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/match \3 -H 'Content-Type: multipart/form-data' \4 -H 'apikey: [APIKEY_VALUE]' \5 --F 'candidateImage=@[ABSOLUTE_LOCAL_PATH_TO_candidateImage]' \6 --F 'candidateImageType="SELFIE"' \7 --F 'referenceFace=@[ABSOLUTE_LOCAL_PATH_TO_referenceFace]' \8 --F 'imageRotationEnabled="true"' \9 --F 'correlationId="c5a0aec2-1262-41b6-82bd-e9d60da92ef2"'
Permissions
TheAPIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | APIkey value |
Content-Type | Allowed values: multipart/mixed , multipart/form-data |
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
candidateImage | Binary | A candidate face image to process. |
candidateImageType | String | The kind of image for the candidate face. Allowed values: ID_DOCUMENT , SELFIE , VIDEO_FRAME |
referenceFace | Face | Reference face. |
imageRotationEnabled (optional) | Boolean | To enable image rotation for coding. Do not use if the image is not rotated. For best performance, use images that are already correctly oriented instead of using this parameter to rotate incorrectly oriented images. Default value: null |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
Response Example
The success status code 200
means the match result has been successfully retrieved.
JSON1{2 "reference": {3 "id": "31214b58-9edc-425b-9436-60dcd94fbc3a",4 "friendlyName": "Official portrait of First Lady Michelle Obama in the Green Room of the White House",5 "mode": "F5_1_VID60",6 "imageType": "SELFIE"7 },8 "candidate": {9 "id": "7d94bbfd-b779-44a3-a8fa-dfc20324fb2b",10 "mode": "F5_1_VID60",11 "imageType": "SELFIE",12 "quality": 306,13 "imageRotationEnabled":false14 "landmarks": {15 "eyes": {16 "x1": 518.71204,17 "y1": 444.68396,18 "x2": 655.408,19 "y2": 446.59920 }21 }22 },23 "score": 10269.438178710938,24 "falseAcceptanceRate": 0.000000000000001,25 "correlationId": "c5a0aec2-1262-41b6-82bd-e9d60da92ef2",26 "created": "2017-11-14T14:31:42.228Z",27 "signature": "eyJhbGciOiJSUzI1NiJ9.ew0KICAicmV…jQvj1G8qNqhOTbg8cWMQ1k_5F-GQTnco"28}
HTTP Error Codes
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Missing permissions to create the face |
413 | The request was too big |
429 | Server is currently experiencing high demand. Request can be sent again after a few seconds. |
500 | Internal error |
Replay Liveness APIs
This section discusses APIs for replaying liveness.
initLivenessParameters
This function posts the liveness parameter(s) that will be used to run the challenge.
Endpoint
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/bio-sessions/{bioSessionId}/init-liveness-parameters \3 -H 'Content-Type: application/json' \4 -H 'apikey: [APIKEY_VALUE]' \5 -d '[{6 "type": "LIVENESS_PASSIVE"7 }]'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
Content-Type | Allowed values: application/json |
URI Field
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session containing the livenessParameter . |
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
type | String | Liveness type. Allowed values: LIVENESS_ACTIVE , LIVENESS_PASSIVE , LIVENESS_PASSIVE_VIDEO . NO_LIVENESS and LIVENESS_MEDIUM are not supported anymore. LIVENESS_HIGH is now deprecated, please use LIVENESS_ACTIVE instead. Recommendation: LIVENESS_PASSIVE_VIDEO mode. |
securityLevel (optional) | String | The security level applied on fraud detection. The higher the level, the stricter the fraud verification. Allowed values: LOW , MEDIUM ,HIGH . Recommendation: HIGH level for all liveness modes. By default value is set to HIGH |
nbChallenge (optional) | Number | Number of challenges to ask. Must be one or greater. Only used with LIVENESS_ACTIVE |
imageRetrievalDisabled (optional) | Boolean | Retrieve the best image with the liveness result. By default value is true. |
id (optional) | String | The replay liveness identifier used to correlate responses of the replay liveness process |
Examples :
- Passive video liveness
JSON1{2 "type": "LIVENESS_PASSIVE_VIDEO",3 "securityLevel": "HIGH",4 "id": "replay-id"5}
- Active liveness
JSON1{2 "type": "LIVENESS_ACTIVE",3 "securityLevel": "HIGH",4 "nbChallenge": 2,5 "imageRetrievalDisabled": false6}
Response Body Fields
Field | Type | Description |
---|---|---|
signature (optional) | String | A digital signature (JWS) of the response. Authentication and integrity can be verified afterward using the BioServer public certificate |
id | String | The replay liveness identifier (automatically generated if not provided in the request) |
type | String | Liveness type. Allowed values: LIVENESS_ACTIVE , LIVENESS_PASSIVE , LIVENESS_PASSIVE_VIDEO . NO_LIVENESS and LIVENESS_MEDIUM are not supported anymore. LIVENESS_HIGH is now deprecated, please use LIVENESS_ACTIVE instead. Recommendation: LIVENESS_PASSIVE_VIDEO mode. |
securityLevel | String | The security level applied on fraud detection. The higher the level, the stricter the fraud verification. Allowed values: LOW , MEDIUM ,HIGH . Recommendation: HIGH level for all liveness modes. By default value is set to HIGH |
nbChallenge | Integer | Number of challenges to ask. Must be one or greater. Only used with LIVENESS_ACTIVE |
useAccurateMatch | Boolean | Deprecated. |
matchThreshold | Integer | Deprecated. |
logLevel | String | Deprecated. |
imageRetrievalDisabled | Boolean | Retrieve the best image with the liveness result. |
seed | Interger | Seed generated by the server used to run the challenge |
certificate | Array | List of Base64 encoded certificates in DER format. It is used to encrypt data sent to the server |
serverRandom | String | Random 32 bytes string generated by the server. It is used to check the encrypted data sent to the server |
Response Example
- Passive video liveness
JSON1{2 "signature": "eyJl5V1E5Tm1TS21",3 "id": "replay-id",4 "type": "LIVENESS_PASSIVE_VIDEO",5 "securityLevel": "HIGH",6 "seed": 1150867590,7 "certificates": ["MIIEATCCAumgAwIBAgICC"],8 "serverRandom": "avf0FHLahDrdfdseUI1fdfyo81HR4="9}
- Active liveness
JSON1{2 "signature": "eyJl5V1E5Tm1TS21",3 "id": "c672be72-89c1-4035-b0b6-9e9afa6bc85b",4 "type": "LIVENESS_ACTIVE",5 "securityLevel": "HIGH",6 "nbChallenge": 2,7 "useAccurateMatch": true,8 "matchThreshold": 2500,9 "logLevel": "DEBUG",10 "imageRetrievalDisabled": false,11 "seed": 1150867590,12 "certificates": ["MIIEATCCAumgAwIBAgICC"],13 "serverRandom": "avf0FHLahDrdfdseUI1fdfyo81HR4="14}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Forbidden |
404 | Unable to find a bio-session for the given identifier |
500 | Internal error |
getReplayStatus (v2) - Deprecated
Deprecated
replayLivenessCallback
WebCapture SDK uses the callbackURL
, if provided, within [CreateBioSession API](#createbiosession API) to POST sessionId
to the Service Provider (SP), as shown in the snippet:
Endpoint
HTTP1POST https://service-provider-domain/callback-url
Request Body Fields
The parameters for are shown in the table.
Name | Type | Description |
---|---|---|
sessionId | String | The identifier of the session |
Request Example
JSON1{2 "sessionId": "7b4e38f6-de53-4dd5-a8b8-985833f771d2"3}
Response Example
The success HTTP code expected from the backend is 200
:
HTTP Code | Description |
---|---|
200 | Request sent to the service provider |
HTTP Error Codes
The error response codes for CallbackSP
are shown in the table.
Code | Description |
---|---|
404 | Unable to reach the endpoint |
500 | Server error |
getReplayStatus (v3)
This function retrieves a challenge replay response.
Endpoint
Shell1curl -X GET \2 https://[URL_MAIN_PART]/bioserver-app/v3/bio-sessions/{bioSessionId}/replay-liveness-metadata \3 -H 'apikey: [APIKEY_VALUE]' \
Permissions
TheAPIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
URI Field
The URI field that provides the HTTP address where the bioSessionID
string identifier for the bio-session resource can be retrieved is shown in the table.
Field | Type | Description |
---|---|---|
bioSessionId | String | The identifier of the bio-session resource to retrieve. |
Response Body Fields
The success status code 200
means the results have been successfully retrieved.
Field | Type | Description |
---|---|---|
id | String | The replay liveness identifier as returned in response of /init-liveness-parameters |
status | String | Liveness challenge response. Allowed values: INITIALIZED, IN_PROGRESS, ERROR, SUCCESS, FAILED, SPOOF, TIMEOUT |
image (optional) | String | Best image from replay liveness (Base64-encoded). |
landmarks (optional) | Landmarks | Landmarks detected on the face. |
signature (optional) | String | A digital signature (JWS) of the response. If the image field is present, the payload is detached; the JWS payload has to be reconstructed from the trimmed JSON response (without the signature field). Authentication and integrity can be verified afterward using the Biometric Services public certificate. |
deviceInfo (optional) | DeviceInfo | Mobile information from nativeSDK. |
sdkInfo (optional) | SdkInfo | SDK information from nativeSDK. |
imageStorage (optional) | ImageStorage | Storage information regarding the best image. This field is not linked to imageRetrievalDisabled field. |
videoStorage (optional) | VideoStorage | If the video recording is enabled on AWS S3, storage information regarding the video generated is available only if the feature is enabled on the backend configuration |
Response Example
The following JSON payload is an example response when the liveness is still in processing.
JSON1{2 "signature": "eyJhbGciOiJSUzI1NiJ9..ciOeyJhiJSmRseU5hbWogIClbmRseU5hbWUoroAE_oxDF_ZtH-E",3 "id": "c672be72-89c1-4035-b0b6-9e9afa6bc85b",4 "status": "IN_PROGRESS"5}
The following JSON payload is an example response when the face image is successfully created.
JSON1{2 "signature": "eyJhbGciOiJSUzI1NiJ9..ciOeyJhiJSmRseU5hbWogIClbmRseU5hbWUoroAE_oxDF_ZtH-E",3 "id": "c672be72-89c1-4035-b0b6-9e9afa6bc85b",4 "status": "SUCCESS",5 "image": "F401MTb6QMNy8VFDMYDJ0dBQZepKDeHbTTCXRGaL+gFOCAomRITeZeJoQG3+CU2YNT2JXVzVgcZWD5LQNASqJA==",6 "landmarks": {7 "eyes": {8 "x1": 581.0,9 "y1": 270.0,10 "x2": 695.0,11 "y2": 266.012 },13 "box": {14 "x": 465,15 "y": 149,16 "width": 348,17 "height": 34818 }19 }20}
The following JSON payload is an example response when the liveness returns a SPOOF.
JSON1{2 "signature": "eyJhbGciOiJSUzI1NiJ9..ciOeyJhiJSmRseU5hbWogIClbmRseU5hbWUoroAE_oxDF_ZtH-E",3 "id": "c672be72-89c1-4035-b0b6-9e9afa6bc85b",4 "status": "SPOOF"5}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
403 | Forbidden |
404 | Unable to find a bio-session for the given identifier |
500 | Internal error |
Ages APIs (Beta)
This section discusses APIs for age estimation.
createDirectAgeFromImage
This function computes an estimation of the age of the person given as input. Under the response, it also indicates if the estimated age is above or equal to the input threshold
Endpoint
Shell1curl -X POST \2 https://[URL_MAIN_PART]/bioserver-app/v2/ages \3 -H 'Content-Type: multipart/form-data' \4 -H 'apikey: [APIKEY_VALUE]' \5 --F 'image=@[ABSOLUTE_LOCAL_PATH_TO_image]' \6 --F 'age=@[ABSOLUTE_LOCAL_PATH_TO_age_json]' \7 --F 'correlationId="c5a0aec2-1262-41b6-82bd-e9d60da92ef2"'
Permissions
The APIkey
is the API key unique identifier used to authenticate requests and track and control API usage.
Header Fields
The HTTP header fields that contains metadata associated with the API request and response fields is shown in the table.
Field | Description |
---|---|
apikey | The APIkey value |
Content-Type | Allowed values: multipart/mixed , multipart/form-data |
Request Body Fields
The request body is used to create the resource information returned by the API. It contains the representation of the resource to be created as shown in the fields in the table.
Field | Type | Description |
---|---|---|
image | Binary | The face image to process |
age | Age | Age estimation options |
correlationId (optional) | String | A custom identifier coming from the caller. Default value: null |
evidenceId (optional) | String | Evidence identifier coming from GIPS in ID_PROOFING workflow. Default value: null |
Response Body Fields
Field | Type | Description |
---|---|---|
id | String | Unique identifier of the processed image |
aboveThreshold (optional) | Boolean | true when estimated age is above or equal to the input threshold, false otherwise. If the algorithm cannot compute age estimation because of poor quality or no person visible in the input image, the field is not set. |
ageEstimated (optional) | Float | Estimated age computed. If the algorithm cannot compute age estimation because of poor quality or no person visible in the input image, the field is not set. |
threshold | String | Input threshold given under request used to compute the aboveThreshold field. |
digest | String | The SHA-256 digest of the image file from which the face has been processed for confidentiality and verification purposes. |
imageType | String | The kind of image. Allowed values: SELFIE (default), VIDEO_FRAME |
quality | Integer | The quality of the image. If the algorithm cannot compute age estimation because of poor quality or no person visible in the input image, a negative value is set. |
created | String | The date on which the age was computed |
signature (optional) | String | A digital signature (JWS) of the response. Authentication and integrity can be verified afterward using the BioServer public certificate |
Response Example
- Nominal output
JSON1{2 "id": "305e113e-b8cd-4d84-a43d-f3d2c79c22b3",3 "aboveThreshold": true,4 "ageEstimated": 23.1,5 "threshold": 18,6 "digest": "94d1b6ff2acf368c3e0ccaebe1d8e447ed1ccd7b596dc5cac3c13a4822b256c6",7 "imageType": "SELFIE",8 "quality": 212,9 "created": "2024-06-24T14:38:17.972Z",10 "signature": "eyJhbGciOiJFUzI1"11}
- No person detected
JSON1{2 "id": "b6d18093-761a-41b8-8dd9-8e4268d1782e",3 "threshold": 18,4 "digest": "44ef3f8eac461453721b8463a9edaa37e77f5f2f421edd8a449d55119d76b6f2",5 "imageType": "SELFIE",6 "quality": -10000,7 "created": "2024-06-24T14:37:23.801Z",8 "signature": "eyJhbGciOiJFUzI1"9}
HTTP Error Codes
If an error occurs, one of the 4xx
status codes will be generated. The error response code indicates the specific error type and the error code issue as shown in the table.
Name | Description |
---|---|
400 | Something is wrong with the request |
401 | Authentication is required |
413 | The request was too big |
429 | Server is currently experiencing high demand. Request can be sent again after a few seconds. |
500 | Internal error |
Objects
Face
The Face
object describes face characteristics.
Parameters
The parameters for Face
are shown in the table.
Field | Type | Description |
---|---|---|
id | String | The face unique identifier generated |
friendlyName (optional) | String | Friendly name for the face |
digest (optional) | String | SHA-256 digest of the image file from which the face has been created for confidentiality and verification purposes |
mode | String | Biometric algorithm used to create the face biometric template |
imageType | String | Image type |
quality (optional) | Number | Biometric template quality — a good quality template is a template with a quality superior to 100; if the quality is negative, then the face needs to be sent again |
landmarks (optional) | Landmarks | Landmarks detected on the face |
template (optional) | String | Biometric template of the face |
templateVersion (optional) | Number | Version of the biometric template; newer versions of biometric algorithms don't support the previous version of biometric templates |
imageRotationEnabled (optional) | Boolean | Image rotation enabled; default value: null |
created (optional) | Datetime | The date on which the face is created |
Example usage
An example usage for Landmarks
is shown in the snippet"
JSON1{2 "id": "6e1741f1-3715-416a-bfc6-4fc381d228a3",3 "friendlyName": "Barack Obama's Columbia University Student ID",4 "digest": "94d1b6ff2acf368c3e0ccaebe1d8e447ed1ccd7b596dc5cac3c13a4822b256c6",5 "mode": "F5_1_VID60",6 "imageType": "ID_DOCUMENT",7 "quality": 186,8 "landmarks": {9 "eyes": {10 "x1": 141.83296,11 "y1": 217.47075,12 "x2": 241.09653,13 "y2": 216.056814 }15 }16}
Landmarks
The Landmarks
object describes the Landmarks detected on the face.
Parameters
The parameters for Landmarks
are shown in the table.
Name | Type | Description |
---|---|---|
eyes (optional) | LandmarksEyes | Eye detection information |
box (optional) | LandmarksBox | Face position inside a box |
Example usage
An example usage for Landmarks
is shown in the snippet"
JSON1{2 "eyes": {3 "x1": 581.0,4 "y1": 270.0,5 "x2": 695.0,6 "y2": 266.07 },8 "box": {9 "x": 465,10 "y": 149,11 "width": 348,12 "height": 34813 }14}
LandmarksEyes
The LandmarksEyes
object describes the eye detection information
Parameters
The parameters for LandmarksEyes
are shown in the table.
Name | Type | Description |
---|---|---|
x1 | number | The x-coordinate of the first eye |
y1 | number | The y-coordinate of the first eye |
x2 | number | The x-coordinate of the second eye |
y2 | number | The y-coordinate of the second eye |
Example usage
An example usage for LandmarksEyes
is shown in the snippet"
JSON1{2 "x1": 581.0,3 "y1": 270.0,4 "x2": 695.0,5 "y2": 266.06}
LandmarksBox
The LandmarksBox
object describes the face position inside a box
Parameters
The parameters for LandmarksBox
are shown in the table.
Name | Type | Description |
---|---|---|
x | number | The x-coordinate of the left corner |
y | number | The y-coordinate of the left corner |
width | number | The width of the box |
height | number | The height of the box |
Example usage
An example usage for LandmarksBox
is shown in the snippet"
JSON1{2 "x": 465,3 "y": 149,4 "width": 348,5 "height": 3486}
VideoStorage
The VideoStorage
object describes the storage information of the recorded video of the document captured if the video recording is enabled on AWS S3, as shown in the snippet:
Parameters
The parameters for VideoStorage
are shown in the table.
Name | Type | Description |
---|---|---|
region | String | Region (S3, Minio) where the media is stored. |
key | String | Path (S3, Minio) where the media is storied. |
bucketName | String | Bucket (S3, Minio) where the media is stored. |
hash | String | Hash of the stored media. |
hashAlgorithm | String | Hash algorithm used to hash the data. |
contentType | String | Content type of the media. |
Example usage
An example usage for VideoStorage
is shown in the snippet:
JSON1{2 "region": "eu-central-1",3 "bucketName": "wbs-video-storage",4 "key": "doc-dev/11b57ca2-7798-4c9d-8ab9-3099506d221e/0dec15a2-0ea1-49b2-baf0-812048f9e6da.webm",5 "hash": "d32c4ff2770a4f9d4d10d048492dbb456fb153153db5ae5f1454d1442d488093",6 "hashAlgorithm": "SHA_256",7 "contentType": "video/webm"8}
ImageStorage
The ImageStorage
object describes the storage information of the best image of a document side.
Parameters
The parameters for ImageStorage
are shown in the table.
Name | Type | Description |
---|---|---|
region | String | Region (S3, Minio) where the media is stored. |
key | String | Path (S3, Minio) where the media is storied. |
bucketName | String | Bucket (S3, Minio) where the media is stored. |
hash | String | Hash of the stored media. |
hashAlgorithm | String | Hash algorithm used to hash the data. Available value is : SHA_256 |
contentType | String | Content type of the media. |
Example usage
An example usage for ImageStorage
is shown in the snippet:
JSON1{2 "region": "eu-central-1",3 "bucketName": "wbs-video-storage",4 "key": "doc-dev/11b57ca2-7798-4c9d-8ab9-3099506d221e/0dec15a2-0ea1-49b2-baf0-812048f9e6da.png",5 "hash": "ff2c4ff2770a4f004dffd048492dbb_ç6fb153153db5ae5f1454d1442d4880(è",6 "hashAlgorithm": "SHA_256",7 "contentType": "image/png"8}
DeviceInfo
The DeviceInfo
object describes device information.
Parameters
The parameters for DeviceInfo
are shown in the table.
Name | Type | Description |
---|---|---|
deviceModel (optional) | String | Phone model. |
osType (optional) | String | Mobile OS type (Android or iOS). |
osVersion (optional) | String | Version of phone OS. |
Example usage
An example usage for DeviceInfo
is shown in the snippet:
JSON1{2 "deviceModel": "SM-G935F",3 "osType": "Android",4 "osVersion": "7.0"5}
SdkInfo
The SdkInfo
object describes sdk information.
Parameters
The parameters for SdkInfo
are shown in the table.
Name | Type | Description |
---|---|---|
sdkVersion (optional) | String | Native SDK version |
Example usage
An example usage for SdkInfo
is shown in the snippet:
JSON1{2 "sdkVersion": "1.0.0"3}
Age
The Age
object describes age options for age estimation APIs.
Parameters
The parameters for Age
are shown in the table.
Field | Type | Description |
---|---|---|
threshold | Integer | Input threshold used to compute aboveThreshold field under response. |
imageType (optional) | String | The kind of image. Allowed values: SELFIE , VIDEO_FRAME |
signatureDisabled (optional) | String | Disable the signature of the result. Default value: false |
imageRotationEnabled (optional) | Boolean | To enable image rotation for coding. Do not use if the image is not rotated. For optimal performance, it is recommended to use images that are already correctly oriented rather than to use this parameter to rotate them. Default value: null |
Example usage
An example usage for Age
is shown in the snippet:
JSON1{2 "threshold" : 183}
FAQ
What are the recommended liveness settings?
Recommended liveness settings are :
- Mode :
LIVENESS_PASSIVE_VIDEO
- Security level :
HIGH
How do I verify a signature from JSON responses ?
Signatures are JWT signatures.
As an example you can use an online tool to verify the signature from JSON response: https://jwt.io/ There are two inputs required:
- The content of the signature attribute
- The public key from Biometric service
Note: Also, you can verify the signature of JSON response programmatically according to the technology you use.