Swedish BankID

GII supplies a headless API for Swedish BankID.

Examples

Auth

The Auth-endpoint is used for logging in a user.

Flow:

  1. Call Auth.
  2. Call Poll every 2 seconds with the value from the Location-header returned from Auth as long as HTTP status code is 202.

Request

The Auth-endpoint is called when starting a login. Called using the HTTP method POST.

Request parameters:

  • ip: IP of person that is logging in. String in v4 or v6 format. JSON-name: IP.
  • personal_number: Optional. Personal number of person that is logging in. Full format (YYYYMMDDNNNN). It is not recommended do use this! JSON-name: PersonalNumber.
  • get_qr: Optional. Set to true when a QR-code is requested. It is recommended do use this instead of personal_number! JSON-name: GetQR.
  • autostart_token_required: Optional. Set to true when it is required that the login is performed by either automatically starting the device (on same device) or by scanning the QR-code. JSON-name: AutostartTokenRequired.

Example request (curl):

curl -v https://demo-api.gii.cloud/api/ip/bankid-se/s2s/auth --data "ip=83.250.5.1&get_qr=true&autostart_token_required=true" --user my-user:my-password

Example request (http form parameters):

POST /api/ip/bankid-se/s2s/auth HTTP/2
 Host: demo-api.gii.cloud
 Authorization: Basic bXktdXNlcjpteS1wYXNzd29yZAo=
 Content-Length: 55
 Content-Type: application/x-www-form-urlencoded

 ip=83.250.5.1&get_qr=true&autostart_token_required=true

Example request (JSON payload):

POST /api/ip/bankid-se/s2s/auth HTTP/2
 Host: demo-api.gii.cloud
 Authorization: Basic bXktdXNlcjpteS1wYXNzd29yZAo=
 Content-Length: 62
 Content-Type: application/json

 {"IP":"83.250.5.1","GetQR":true,"AutostartTokenRequired":true}

Response

The response is a JSON-object with the parameters:

  • AutoStartToken: Useful when creating a custom AutoStartURL.
  • AutoStartURL: Use this to start BankID on same device. Example JavaScript: location.href = resp.AutoStartURL will open BankID on same device.
  • QR: Contains a base64-encoded png (200x200) of a QR-code that can be inserted in an img-tag. Example HTML: <img src="<%= resp.QR %>" width="200" height="200" />

Example reponse (JSON):

{
    "AutoStartToken": "[TOKEN]",
    "AutoStartURL": "bankid:///?autostarttoken=[TOKEN]&redirect=null",
    "QR": ""
}

Example response (full):

HTTP/2 201
 date: Tue, 18 Sep 2018 13:37:00 GMT
 content-type: application/json
 cache-control: no-cache, no-store, must-revalidate
 expires: 0
 location: https://demo-api.gii.cloud/api/ip/bankid-se/s2s/auth?id=89839028338
 pragma: no-cache

{"AutoStartToken":"f11dd910-046e-4fca-b995-60928226c98b","AutoStartURL":"bankid:///?autostarttoken=f11dd910-046e-4fca-b995-60928226c98b\u0026redirect=null","QR":""}

Example HTML for rendering the output:

<!DOCTYPE html>
<html lang="sv">

<head>
    <meta charset="utf-8">
    <meta name="referrer" content="no-referrer">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!-- automatically reload page after 2 sec -->
    <meta http-equiv="refresh" content="2">
</head>

<body>
    <!-- display qr code to scan. Use the QR-response -->
    <img src="" />

    <script>
        // try to start BankID automatically. Use the AutoStartURL-response.
        location.href = "bankid:///?autostarttoken=f11dd910-046e-4fca-b995-60928226c98b\u0026redirect=null";
    </script>

</body>

Sign

The Sign-endpoint is used for signing a text.

Flow:

  1. Call Sign.
  2. Call Poll every 2 seconds with the location returned from Sign as long as 202.

Request

The Sign-endpoint is called when starting a signing request. Called using the HTTP method POST. The request parameters are similar to the Auth endpoint but got two additional parameters (visibleText and hiddenText).

Request parameters:

  • ip: IP of person that is logging in. String in v4 or v6 format. JSON-name: IP.
  • personal_number: Optional. Personal number of person that is logging in. Full format (YYYYMMDDNNNN). It is not recommended do use this! JSON-name: PersonalNumber.
  • get_qr: Optional. Set to true when a QR-code is requested. It is recommended do use this instead of personal_number! JSON-name: GetQR.
  • autostart_token_required: Optional. Set to true when it is required that the login is performed by either automatically starting the device (on same device) or by scanning the QR-code. JSON-name: AutostartTokenRequired.
  • visible_text: Required. The visible text to sign. JSON-name: VisibleText.
  • hidden_text: Optional. Hidden text to sign. Typically a file hash or an internal reference number. JSON-name: HiddenText

Example request (curl):

curl -v https://demo-api.gii.cloud/api/ip/bankid-se/s2s/sign --data "ip=83.250.5.1&get_qr=true&autostart_token_required=true&visible_text=texttosign&hidden_text=REF1337" --user my-user:my-password

Example request (http form parameters):

POST /api/ip/bankid-se/s2s/auth HTTP/2
 Host: demo-api.gii.cloud
 Authorization: Basic bXktdXNlcjpteS1wYXNzd29yZAo=
 Content-Length: 55
 Content-Type: application/x-www-form-urlencoded

 ip=83.250.5.1&get_qr=true&autostart_token_required=true&visible_text=texttosign&hidden_text=REF1337

Example request (JSON payload):

POST /api/ip/bankid-se/s2s/auth HTTP/2
 Host: demo-api.gii.cloud
 Authorization: Basic bXktdXNlcjpteS1wYXNzd29yZAo=
 Content-Length: 62
 Content-Type: application/json

 {"IP":"83.250.5.1","GetQR":true,"AutostartTokenRequired":true,"VisibleText":"texttosign","HiddenText":"REF1337"}

Response

The response is a JSON-object with the parameters:

  • AutoStartToken: Useful when creating a custom AutoStartURL.
  • AutoStartURL: Use this to start BankID on same device. Example JavaScript: location.href = resp.AutoStartURL will open BankID on same device.
  • QR: Contains a base64-encoded png (200x200) of a QR-code that can be inserted in an img-tag. Example HTML: <img src="<%= resp.QR %>" width="200" height="200" />

The location-header points to the resource that should be polled.

Example reponse (JSON):

{
    "AutoStartToken": "[TOKEN]",
    "AutoStartURL": "bankid:///?autostarttoken=[TOKEN]&redirect=null",
    "QR": ""
}

Example response (full):

HTTP/2 201
 date: Tue, 18 Sep 2018 13:37:00 GMT
 content-type: application/json
 cache-control: no-cache, no-store, must-revalidate
 expires: 0
 pragma: no-cache
 location: https://demo-api.gii.cloud/api/ip/bankid-se/s2s/sign?id=2038382922020

{"AutoStartToken":"9046f685-4b03-48ca-bf25-108809dc69e9","AutoStartURL":"bankid:///?autostarttoken=9046f685-4b03-48ca-bf25-108809dc69e9\u0026redirect=null","QR":""}

Example HTML for rendering the output:

<!DOCTYPE html>
<html lang="sv">

<head>
    <meta charset="utf-8">
    <meta name="referrer" content="no-referrer">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!-- automatically reload page after 2 sec -->
    <meta http-equiv="refresh" content="2">
</head>

<body>
    <!-- display qr code to scan. Use the QR-response -->
    <img src="" />

    <script>
        // try to start BankID automatically. Use the AutoStartURL-response.
        location.href = "bankid:///?autostarttoken=9046f685-4b03-48ca-bf25-108809dc69e9&redirect=null";
    </script>

</body>

Poll

The Poll-endpoint is called when polling for authentication or signature status. Called using the HTTP method GET. Use the location-header value supplied from the Auth or Sign request.

Request

Example request (curl):

curl 'https://demo-api.gii.cloud/api/ip/bankid-se/s2s/auth?id=229292292099' --user my-user:my-password

Example request (http):

GET /api/ip/bankid-se/s2s/auth?id=229292292099 HTTP/1.1
 Host: demo-api.gii.cloud
 Authorization: Basic bXktdXNlcjpteS1wYXNzd29yZAo=
 Content-Length: 0

Response

The response is a JSON-object with the parameters:

  • MessageSV: String. Message to user in plain Swedish. Empty if complete (HTTP status code 200).
  • MessageEN: String. Message to user in plain English. Empty if complete (HTTP status code 200).
  • CompletionData: Object when complete (HTTP status code is 200), otherwise null.
    • Signature: String. Signature.
    • OCSPResponse: String. OCSP that validate the certificate.
    • User: Object
      • PersonalNumber: String. Personal number of user that logged in or signed.
      • Name: String. Name of user that logged in or signed.
      • GivenName: String. Given name of user that logged in or signed.
      • Surname: String. Surname of user that logged in or signed.
    • Device: Object
      • IPAddress: IP address of device that logged in or signed.
    • Cert: Object
      • NotBefore: Start time the users cert is valid.
      • NotAfter: End time the users cert is valid.

Possible HTTP status codes are:

  • 200: The request is completed successfully. Stop polling.
  • 202: Continue to poll.
  • 4XX: Client errors.
  • 410: The request failed (user error). This is e.g. user cancelled login or never started the BankID-app.
  • 5XX: Internal server errors.

Polling should continue as long as the HTTP status code is 202. See Errors for handling error responses.

Example reponse for pending (JSON):

{
    "MessageSV": "Identifiering eller underskrift pågår.",
    "MessageEN": "Identification or signing in progress."
}

Example response for pending (full):

HTTP/2 202 
 date: Tue, 18 Sep 2018 13:37:00 GMT
 content-type: application/json
 cache-control: no-cache, no-store, must-revalidate
 expires: 0
 pragma: no-cache

{"MessageSV": "Identifiering eller underskrift pågår.","MessageEN": "Identification or signing in progress."}

Example response for complete (JSON):

{
    "CompletionData": {
        "Signature": "[SIGNATURE]",
        "OCSPResponse": "[OCSPResponse]",
        "User": {
            "PersonalNumber": "4205111018",
            "Name": "Ture Abrahamsson",
            "GivenName": "Ture",
            "Surname": "Abrahamsson"
        },
        "Device": {
            "IP": "83.250.5.1"
        },
        "Cert": {
            "NotBefore": "[DATE]",
            "NotAfter": "[DATE]"
        }
    }
}

Example HTML for rendering the output (pending):

<!DOCTYPE html>
<html lang="sv">

<head>
    <meta charset="utf-8">
    <meta name="referrer" content="no-referrer">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!-- automatically reload page after 2 sec -->
    <meta http-equiv="refresh" content="2">
</head>

<body>
    <!-- display qr code to scan. Use the QR-response -->
    <img src="" />

    <!-- display message in Swedish. Use the MessageSV-response -->
    <p>Identifiering eller underskrift pågår.</p>

</body>

Errors

Error responses (HTTP status code >= 400) has these parameters:

  • MessageSV: String. Message to user in plain Swedish.
  • MessageEN: String. Message to user in plain English.
  • Details: String. Internal error message that should not be displayed to users.

Example response (JSON):

{
    "MessageSV": "Internt tekniskt fel. Försök igen.",
    "MessageEN": "Internal error. Please try again.",
    "Details": "It took too long time to transmit the request."
}