# Authentication

To use all CommercioAPI web services You need to authenticate. The Authenticatin method used is a Bearer authentication.

You can obtain the security token through an interaction with the IDM using the credential of your registered user in the Web app. As per the OpenID Connect protocol

Check the Prerequistes in order to perform correctly the process.

# Get the ID token

The ID token resembles the concept of an identity card, in a standard JWT formatThe ID token statements, or claims, are packaged in a simple JSON object

The ID token header, claims JSON and signature are encoded into a base 64 URL-safe string, for easy passing arround, for example as URL parameter.

You can read more about the JWT data structure and its encoding in RFC 7519

The endpoint to interact with the IDM has the following path

https://{{.commercio_login_url}}/auth/realms/commercio/protocol/openid-connect/token

The process can be performed via CLI for obtaining the ID Token from the IDM .

curl -s --request POST \
    'https://{{.commercio_login_url}}/auth/realms/commercio/protocol/openid-connect/token' \
    --header 'Content-Type: application/x-www-form-urlencoded'  \
    --data-urlencode 'client_id={{.openid_client_id}}'  \
    --data-urlencode 'grant_type=password'  \
    --data-urlencode 'scope=openid'  \
    --data-urlencode 'username=<EMAIL>'  \
    --data-urlencode 'password=<PASSWORD>' | jq -r '.id_token'

Where <EMAIL> and <PASSWORD> are those of the user you registered in Web app

The id_token obtaneined must be used to autheticate using the API

# Example

Suppose to have the user

  • <EMAIL>: testuser001@commercio.app
  • <PASSWORD>: Testuser001

Acquire the ID_Token

curl -s --request POST \
    'https://devlogin.commercio.app/auth/realms/commercio/protocol/openid-connect/token' \
    --header 'Content-Type: application/x-www-form-urlencoded'  \
    --data-urlencode 'client_id=dev.commercio.app'  \
    --data-urlencode 'grant_type=password'  \
    --data-urlencode 'scope=openid'  \
    --data-urlencode 'username=testuser001@commercio.app'  \
    --data-urlencode 'password=Testuser001' | jq -r '.id_token'

Acquire Bearer ID_Token

Simple way to compose Bearer ID_token string through curl

echo "Bearer "$(curl -s --request POST  \
    'https://devlogin.commercio.app/auth/realms/commercio/protocol/openid-connect/token' \
    --header 'Content-Type: application/x-www-form-urlencoded' \
    --header 'Cookie: KEYCLOAK_LOCALE=en' \
    --data-urlencode 'client_id=dev.commercio.app' \
    --data-urlencode 'grant_type=password' \
    --data-urlencode 'scope=openid' \
    --data-urlencode 'username=testuser001@commercio.app' \
    --data-urlencode 'password=Testuser001' | jq -r '.id_token')

Identity Manager (IDM) reply

eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2MjEwMDMwMjEsImlhdCI6MTYyMTAwMjcyMSwiYXV0aF90aW1lIjowLCJqdGkiOiJmNTA5YjQ0YS0xYzIxLTQ5NjktYjE5Ni03YWYxOGFmZDkyYTciLCJpc3MiOiJodHRwczovL2RldmxvZ2luLmNvbW1lcmNpby5hcHAvYXV0aC9yZWFsbXMvY29tbWVyY2lvIiwiYXVkIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzdWIiOiJhMmIzZGI5Yi03NzUwLTQzYTEtODExZC1iOGI3MjA2NmQzZDYiLCJ0eXAiOiJJRCIsImF6cCI6ImRldi5jb21tZXJjaW8uYXBwIiwic2Vzc2lvbl9zdGF0ZSI6ImE5ZGNmMWFjLTdjMTctNDViYS1hY2JlLWZkMmY1MGNhZGEzMyIsImF0X2hhc2giOiJLZko4XzJfWGxCQmFFNjVBYVhOWWRnIiwiYWNyIjoiMSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyMDk5NDk2MCIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhZGRyZXNzIjp7fSwibmFtZSI6Ik1hcmNvIEF1cm8iLCJwaG9uZV9udW1iZXIiOiIxMjM0NTY3ODkwMSIsInByZWZlcnJlZF91c2VybmFtZSI6Im1hcmNvLnJ1YXJvQGdtYWlsLmNvbSIsImdpdmVuX25hbWUiOiJNYXJjbyIsImZhbWlseV9uYW1lIjoiQXVybyIsImVtYWlsIjoibWFyY28ucnVhcm9AZ21haWwuY29tIiwidXNlcm5hbWUiOiJtYXJjby5ydWFyb0BnbWFpbC5jb20ifQ.hDParV3scvir8B9kkNN-e56IF5Jmqxuhkfd7B__s8Vn41VAaccJBTl1bwqLggcrNJ2Yjl3jAKOxfXX3PFf_RtsFloFyYSZDlOdt73qD1m-8TzdPGfMjNwgiCLc7IvKIFV3_8JYsgkm3fsqtMGqOdsqZSD_s9KrGK7oYcoMIWHqiBKqeymAX9urLFg4lbHlEY1rJJ6C0zpFhA1nrqSFqwu3MuYdfylmtkhvKVreOl9jR8kG326BvwEd7NnwaYtJI6Anoe2ojNHzWgRwFTzd3djhwhYLziJTt3Q8SE7ag_FKxQ4BhjaK3w4PlBz9HK15B4rp_shd_ZUohVaZtJsNrKwg

You can decode the Id_token here jwt.io

# Usage in swagger interface

For the Tryout in the Swagger (available at the CommercioAPI base url) use in the modal associated to the Authorize button composing the two element separated by a space

  • Method : Beared
  • id_token obtained.

Example :

Bearer eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2MjEwMDMwMjEsImlhdCI6MTYyMTAwMjcyMSwiYXV0aF90aW1lIjowLCJqdGkiOiJmNTA5YjQ0YS0xYzIxLTQ5NjktYjE5Ni03YWYxOGFmZDkyYTciLCJpc3MiOiJodHRwczovL2RldmxvZ2luLmNvbW1lcmNpby5hcHAvYXV0aC9yZWFsbXMvY29tbWVyY2lvIiwiYXVkIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzdWIiOiJhMmIzZGI5Yi03NzUwLTQzYTEtODExZC1iOGI3MjA2NmQzZDYiLCJ0eXAiOiJJRCIsImF6cCI6ImRldi5jb21tZXJjaW8uYXBwIiwic2Vzc2lvbl9zdGF0ZSI6ImE5ZGNmMWFjLTdjMTctNDViYS1hY2JlLWZkMmY1MGNhZGEzMyIsImF0X2hhc2giOiJLZko4XzJfWGxCQmFFNjVBYVhOWWRnIiwiYWNyIjoiMSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyMDk5NDk2MCIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhZGRyZXNzIjp7fSwibmFtZSI6Ik1hcmNvIEF1cm8iLCJwaG9uZV9udW1iZXIiOiIxMjM0NTY3ODkwMSIsInByZWZlcnJlZF91c2VybmFtZSI6Im1hcmNvLnJ1YXJvQGdtYWlsLmNvbSIsImdpdmVuX25hbWUiOiJNYXJjbyIsImZhbWlseV9uYW1lIjoiQXVybyIsImVtYWlsIjoibWFyY28ucnVhcm9AZ21haWwuY29tIiwidXNlcm5hbWUiOiJtYXJjby5ydWFyb0BnbWFpbC5jb20ifQ.hDParV3scvir8B9kkNN-e56IF5Jmqxuhkfd7B__s8Vn41VAaccJBTl1bwqLggcrNJ2Yjl3jAKOxfXX3PFf_RtsFloFyYSZDlOdt73qD1m-8TzdPGfMjNwgiCLc7IvKIFV3_8JYsgkm3fsqtMGqOdsqZSD_s9KrGK7oYcoMIWHqiBKqeymAX9urLFg4lbHlEY1rJJ6C0zpFhA1nrqSFqwu3MuYdfylmtkhvKVreOl9jR8kG326BvwEd7NnwaYtJI6Anoe2ojNHzWgRwFTzd3djhwhYLziJTt3Q8SE7ag_FKxQ4BhjaK3w4PlBz9HK15B4rp_shd_ZUohVaZtJsNrKwg

Modal

# Usage in the api endpoint

Example path /sharedoc/process

curl -X 'GET' \
  'https://dev-api.commercio.app/v1/sharedoc/process' \
  -H 'accept: application/json' \
  -H 'Authorization: Bearer eyJhbGciOiJSUzI1.....NiIsInR5cCIgOi'

# Expiration time

Pay attention that the id_token has an expiration time

{
  "access_token": "eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2MjE0OTU1NjcsImlhdCI6MTYyMTQ5NTI2NywianRpIjoiODE4NzdlZjMtNDQ3Yy00N2JlLTlhYjYtN2E2ZjBkZDhlMjEwIiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6WyJkZXYuY29tbWVyY2lvLmFwcCIsImFjY291bnQiXSwic3ViIjoiNDhhMDRiMjctZDY3OS00NDJiLWJlNmItMDJhNmQ4MmYxMGIzIiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiNTQ0ZWZiMDctNGE2ZC00N2RkLWEwYjYtYTg0ZWJkZDg1ZGU2IiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwczovL2Rldi5jb21tZXJjaW8uYXBwIl0sInJlYWxtX2FjY2VzcyI6eyJyb2xlcyI6WyJvZmZsaW5lX2FjY2VzcyIsInVtYV9hdXRob3JpemF0aW9uIl19LCJyZXNvdXJjZV9hY2Nlc3MiOnsiYWNjb3VudCI6eyJyb2xlcyI6WyJtYW5hZ2UtYWNjb3VudCIsIm1hbmFnZS1hY2NvdW50LWxpbmtzIiwidmlldy1wcm9maWxlIl19fSwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyMTQzMjUzOCIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhZGRyZXNzIjp7fSwibmFtZSI6IkVudGVycHJpc2V1c2VyMDAyIEVudGVycHJpc2V1c2VyMDAyIiwicGhvbmVfbnVtYmVyIjoiMzQ4NTI0MTY0OSIsInByZWZlcnJlZF91c2VybmFtZSI6ImVudGVycHJpc2V1c2VyMDAyQHpvdHNlbGwuY29tIiwiZ2l2ZW5fbmFtZSI6IkVudGVycHJpc2V1c2VyMDAyIiwiZmFtaWx5X25hbWUiOiJFbnRlcnByaXNldXNlcjAwMiIsImVtYWlsIjoiZW50ZXJwcmlzZXVzZXIwMDJAem90c2VsbC5jb20iLCJ1c2VybmFtZSI6ImVudGVycHJpc2V1c2VyMDAyQHpvdHNlbGwuY29tIn0.Wkho3o1Ef535BdGnyeQOiVQsOYKDvlNQGYCY_cIJHg23Ep2kr9gSM7KhSWvXz9o4Z7hMgCdX2jT7T2JL_6KLrv1sGeu8XYYbG1AbQDtoL5ZsKGtbSKl8yiL8QZZ5my-6lSPHmbg-xF8zePJYe3xhYR1evNaoO8WnDmTlyVyGsBoIu7Y2cBKVQtSyivD20XJx6V1ijp-Nr88wJTQFZYq4MSQS4IVdOeXTUbcVq3Ebc53tmOcfKg10OdZLKC2JoZQzh8Igomup-PaVB8MZUIv54Yxwg8nC45VNrgq6gVF32hJhlWVGf-LlhnP1Vmqjv7gSali6FsHg8sOBbxHbz99cew", 
  "expires_in": 300, 
  "id_token": "eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2MjE0OTU1NjcsImlhdCI6MTYyMTQ5NTI2NywiYXV0aF90aW1lIjowLCJqdGkiOiI3NGMzNTE1OS1lOTQyLTQ4OWUtOWNlNS0wMDY2NmQ0NzQyNjIiLCJpc3MiOiJodHRwczovL2RldmxvZ2luLmNvbW1lcmNpby5hcHAvYXV0aC9yZWFsbXMvY29tbWVyY2lvIiwiYXVkIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzdWIiOiI0OGEwNGIyNy1kNjc5LTQ0MmItYmU2Yi0wMmE2ZDgyZjEwYjMiLCJ0eXAiOiJJRCIsImF6cCI6ImRldi5jb21tZXJjaW8uYXBwIiwic2Vzc2lvbl9zdGF0ZSI6IjU0NGVmYjA3LTRhNmQtNDdkZC1hMGI2LWE4NGViZGQ4NWRlNiIsImF0X2hhc2giOiI1SkEyYXRjYWIyaUt5WnE3bkg3ZjVRIiwiYWNyIjoiMSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyMTQzMjUzOCIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhZGRyZXNzIjp7fSwibmFtZSI6IkVudGVycHJpc2V1c2VyMDAyIEVudGVycHJpc2V1c2VyMDAyIiwicGhvbmVfbnVtYmVyIjoiMzQ4NTI0MTY0OSIsInByZWZlcnJlZF91c2VybmFtZSI6ImVudGVycHJpc2V1c2VyMDAyQHpvdHNlbGwuY29tIiwiZ2l2ZW5fbmFtZSI6IkVudGVycHJpc2V1c2VyMDAyIiwiZmFtaWx5X25hbWUiOiJFbnRlcnByaXNldXNlcjAwMiIsImVtYWlsIjoiZW50ZXJwcmlzZXVzZXIwMDJAem90c2VsbC5jb20iLCJ1c2VybmFtZSI6ImVudGVycHJpc2V1c2VyMDAyQHpvdHNlbGwuY29tIn0.T680TaiH_MfZqAnRNTlZa5rdC7k_dLRpmyAHRwIBVFNOj4wv6KHrZ-COSkm37l2hQvPutdehpJSa4B_9CGjL7h2ywmkZh3lAJnb1xEJsRtvBrfpiCUCHiWaGcZZ7KMJCWhCXYuaidGud4GbEb2wLRVPr_l1IVvbeKQ3d1OI2ure_4sNChVUuGpFFiNwHR4G-Q2sEWdmWd3GsLn10ninuafS2uJUH2VubbtGBVqbFLPGuYxNXYZjzId-p4Z12z7QXVvtc0zKHEhhpmq1ay2Mr60OjKefqshttfKg6zGB_E91zuUkEzsARLa3i8m6hulz2NyyAzGoz6kaN9fazWnMptg", 
  "not-before-policy": 0, 
  "refresh_expires_in": 1800, 
  "refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICI1YzcxNGJmZC03NThmLTRkZDItYTIyYy1jODJmMTk3NGIwZmMifQ.eyJleHAiOjE2MjE0OTcwNjcsImlhdCI6MTYyMTQ5NTI2NywianRpIjoiZmQ0OTdjZTItYjc0Yi00ZDJmLWJhYjMtZDQzYWUyYzJkMjZhIiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6Imh0dHBzOi8vZGV2bG9naW4uY29tbWVyY2lvLmFwcC9hdXRoL3JlYWxtcy9jb21tZXJjaW8iLCJzdWIiOiI0OGEwNGIyNy1kNjc5LTQ0MmItYmU2Yi0wMmE2ZDgyZjEwYjMiLCJ0eXAiOiJSZWZyZXNoIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiNTQ0ZWZiMDctNGE2ZC00N2RkLWEwYjYtYTg0ZWJkZDg1ZGU2Iiwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSJ9.8c_9L0RSA52E3CgmvA-ahLyB5dH6Bc7eBNfGD6IcLx4", 
  "scope": "openid email profile", 
  "session_state": "544efb07-4a6d-47dd-a0b6-a84ebdd85de6", 
  "token_type": "Bearer"
}

# Using refresh_token

In order to obtain a new id_token due to the fact that it expires in time as per expires_in value it is possible to use alternatively the refresh_token instead of using the Get id token procedure

So initialy use the Get id token procedure to obtain the full JWT

# Get the id token Request

curl -s --request POST  'https://devlogin.commercio.app/auth/realms/commercio/protocol/openid-connect/token'  --header 'Content-Type: application/x-www-form-urlencoded'   --header 'Cookie: KEYCLOAK_LOCALE=en'  --data-urlencode 'client_id=dev.commercio.app'   --data-urlencode 'grant_type=password'   --data-urlencode 'scope=openid'   --data-urlencode 'username=youruseraccount@yourdomain.aaa'   --data-urlencode 'password=yourpassword'

# Login Reply

{
   "access_token":"eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2NDk4NDU2MjcsImlhdCI6MTY0OTg0MzgyNywianRpIjoiMzA1NDFlNTItYzdjYy00YmI5LWE1MGYtZGVhOTliMDhmMzU5IiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6WyJkZXYuY29tbWVyY2lvLmFwcCIsImFjY291bnQiXSwic3ViIjoiOTk3ZDI3Y2EtZWUxNS00N2E2LWEyOWUtZDIzOWNhNzA1MGFjIiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiYzgwZmI5NjctYzQ4Yi00NDVjLTliMTMtMjMyYjYwMzBkNzE3IiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwczovL2Rldi5jb21tZXJjaW8uYXBwIl0sInJlYWxtX2FjY2VzcyI6eyJyb2xlcyI6WyJvZmZsaW5lX2FjY2VzcyIsInVtYV9hdXRob3JpemF0aW9uIl19LCJyZXNvdXJjZV9hY2Nlc3MiOnsiYWNjb3VudCI6eyJyb2xlcyI6WyJtYW5hZ2UtYWNjb3VudCIsIm1hbmFnZS1hY2NvdW50LWxpbmtzIiwidmlldy1wcm9maWxlIl19fSwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyNDYzMzA4MCIsInJlZmVycmFsIjoiIiwiZW1haWxfdmVyaWZpZWQiOnRydWUsImFkZHJlc3MiOnt9LCJuYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEgRW50ZXJwcmlzZXVzZXIwMDEiLCJwaG9uZV9udW1iZXIiOiIzNDg1MjQxMDAxIiwicHJlZmVycmVkX3VzZXJuYW1lIjoiZW50ZXJwcmlzZXVzZXIwMDFAem90c2VsbC5jb20iLCJnaXZlbl9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJsb2NhbGUiOiJpdCIsImZhbWlseV9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJlbWFpbCI6ImVudGVycHJpc2V1c2VyMDAxQHpvdHNlbGwuY29tIiwidXNlcm5hbWUiOiJlbnRlcnByaXNldXNlcjAwMUB6b3RzZWxsLmNvbSJ9.iVct5CAL0aGbX40Z9GarcLGvXw0alVfPRWSWoiVgPqebENdcDpAQBCi1169_C_cG5STlybtVqosOFI_0bjMfqg6mm5P5_miWTLjZ6bWgRYfG1wmC1xhBzy5QM_ciR9CLb6r_8jckyCbd4tZS0iVrZmqcFNS9r_Iw5KEf4C8cjNacTYyv7ROGm09q9k5TBe2W7RJd6xtLV34e4eUqL6kDABhy61QplF6f9LaUrMyQEHJE3KU2lweL6NFTFJMngFer9Cocw_tXZ_VSMG63thjPKIWBJbfkNgajeMvvsHNvBOgzydYqbNGpS5HEsZAafE37ulf4k6d0TYSVFWzmwdATkg",
   "expires_in":1800,
   "refresh_expires_in":1800,
   "refresh_token":"eyJhbGciOiJIUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICI1YzcxNGJmZC03NThmLTRkZDItYTIyYy1jODJmMTk3NGIwZmMifQ.eyJleHAiOjE2NDk4NDU2MjcsImlhdCI6MTY0OTg0MzgyNywianRpIjoiOTk2Mjk4OWUtYWNjNC00MWVlLTlmMGQtN2NiNjQwMzQ4NzZjIiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6Imh0dHBzOi8vZGV2bG9naW4uY29tbWVyY2lvLmFwcC9hdXRoL3JlYWxtcy9jb21tZXJjaW8iLCJzdWIiOiI5OTdkMjdjYS1lZTE1LTQ3YTYtYTI5ZS1kMjM5Y2E3MDUwYWMiLCJ0eXAiOiJSZWZyZXNoIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiYzgwZmI5NjctYzQ4Yi00NDVjLTliMTMtMjMyYjYwMzBkNzE3Iiwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSJ9.VeN7bEwyD9e83rdapOXhXtDWTS31_bxtBMizSdNAKV8",
   "token_type":"Bearer",
   "id_token":"eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2NDk4NDU2MjcsImlhdCI6MTY0OTg0MzgyNywiYXV0aF90aW1lIjowLCJqdGkiOiJlMjVkNWZhNy0yYWRlLTRhNjYtYjEwMi0zOGQ5MmE4NTYyMDUiLCJpc3MiOiJodHRwczovL2RldmxvZ2luLmNvbW1lcmNpby5hcHAvYXV0aC9yZWFsbXMvY29tbWVyY2lvIiwiYXVkIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzdWIiOiI5OTdkMjdjYS1lZTE1LTQ3YTYtYTI5ZS1kMjM5Y2E3MDUwYWMiLCJ0eXAiOiJJRCIsImF6cCI6ImRldi5jb21tZXJjaW8uYXBwIiwic2Vzc2lvbl9zdGF0ZSI6ImM4MGZiOTY3LWM0OGItNDQ1Yy05YjEzLTIzMmI2MDMwZDcxNyIsImF0X2hhc2giOiJGZ2JodWJCUWtydThlTW5QR3N3cmN3IiwiYWNyIjoiMSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyNDYzMzA4MCIsInJlZmVycmFsIjoiIiwiZW1haWxfdmVyaWZpZWQiOnRydWUsImFkZHJlc3MiOnt9LCJuYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEgRW50ZXJwcmlzZXVzZXIwMDEiLCJwaG9uZV9udW1iZXIiOiIzNDg1MjQxMDAxIiwicHJlZmVycmVkX3VzZXJuYW1lIjoiZW50ZXJwcmlzZXVzZXIwMDFAem90c2VsbC5jb20iLCJnaXZlbl9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJsb2NhbGUiOiJpdCIsImZhbWlseV9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJlbWFpbCI6ImVudGVycHJpc2V1c2VyMDAxQHpvdHNlbGwuY29tIiwidXNlcm5hbWUiOiJlbnRlcnByaXNldXNlcjAwMUB6b3RzZWxsLmNvbSJ9.A2yvD484yZU-uVg9GBNuO5MS3pWvHzdlTZBPZrFz-PHTSfdSkQYqSsdOx2RABLdYeItQo5V2LobNlrzCxNN1F_yZ2Kgc7gk52CCwJWho8Vjii6kNgPR6_nYPMUCymekGESg5owZAw-RscX0LHYVdNLUp5qDHGfNQeid_wIbz3SzAOZK6O3kPRb_raMupfaXLhkUzfQ7xM3j7wop-fTn4CaVc7fpNtbNUTUmps0sRMWylPkQb36_kvgNeSOVTzQn7GE3cEiEtVI_Frazm6evUdDxYylihzT_RRY6mX6zZtrlu6w2Js0bt-gaMMT_CuAjvYkO0OZ55FLrHPzLhNGVK6w",
...
}

When you need to refresh the id_token before it expires you can perform the following steps using the refresh_token

# Get the id token by refresh_token Request

curl -s --request POST \
  'https://devlogin.commercio.app/auth/realms/commercio/protocol/openid-connect/token' \
  header 'Content-Type: application/x-www-form-urlencoded' \
  --data-urlencode 'client_id=dev.commercio.app' \
  --data-urlencode 'grant_type=refresh_token' \
  --data-urlencode 'refresh_token=eyJhbGciOiJIUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICI1YzcxNGJmZC03NThmLTRkZDItYTIyYy1jODJmMTk3NGIwZmMifQ.eyJleHAiOjE2NDk4NDU2MjcsImlhdCI6MTY0OTg0MzgyNywianRpIjoiOTk2Mjk4OWUtYWNjNC00MWVlLTlmMGQtN2NiNjQwMzQ4NzZjIiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6Imh0dHBzOi8vZGV2bG9naW4uY29tbWVyY2lvLmFwcC9hdXRoL3JlYWxtcy9jb21tZXJjaW8iLCJzdWIiOiI5OTdkMjdjYS1lZTE1LTQ3YTYtYTI5ZS1kMjM5Y2E3MDUwYWMiLCJ0eXAiOiJSZWZyZXNoIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiYzgwZmI5NjctYzQ4Yi00NDVjLTliMTMtMjMyYjYwMzBkNzE3Iiwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSJ9.VeN7bEwyD9e83rdapOXhXtDWTS31_bxtBMizSdNAKV8' | jq '.'

# Login Reply

You will obtain a new JWT

{
  "access_token": "eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2NDk4NDcyNDAsImlhdCI6MTY0OTg0NTQ0MCwianRpIjoiMzM1NjVkYmQtNWI2OS00NzJiLTgzZjQtYmJjMzM1Y2JhNjk4IiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6WyJkZXYuY29tbWVyY2lvLmFwcCIsImFjY291bnQiXSwic3ViIjoiOTk3ZDI3Y2EtZWUxNS00N2E2LWEyOWUtZDIzOWNhNzA1MGFjIiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiYzgwZmI5NjctYzQ4Yi00NDVjLTliMTMtMjMyYjYwMzBkNzE3IiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwczovL2Rldi5jb21tZXJjaW8uYXBwIl0sInJlYWxtX2FjY2VzcyI6eyJyb2xlcyI6WyJvZmZsaW5lX2FjY2VzcyIsInVtYV9hdXRob3JpemF0aW9uIl19LCJyZXNvdXJjZV9hY2Nlc3MiOnsiYWNjb3VudCI6eyJyb2xlcyI6WyJtYW5hZ2UtYWNjb3VudCIsIm1hbmFnZS1hY2NvdW50LWxpbmtzIiwidmlldy1wcm9maWxlIl19fSwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSIsInRlcm1zX2FuZF9jb25kaXRpb25zIjoiMTYyNDYzMzA4MCIsInJlZmVycmFsIjoiIiwiZW1haWxfdmVyaWZpZWQiOnRydWUsImFkZHJlc3MiOnt9LCJuYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEgRW50ZXJwcmlzZXVzZXIwMDEiLCJwaG9uZV9udW1iZXIiOiIzNDg1MjQxMDAxIiwicHJlZmVycmVkX3VzZXJuYW1lIjoiZW50ZXJwcmlzZXVzZXIwMDFAem90c2VsbC5jb20iLCJnaXZlbl9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJsb2NhbGUiOiJpdCIsImZhbWlseV9uYW1lIjoiRW50ZXJwcmlzZXVzZXIwMDEiLCJlbWFpbCI6ImVudGVycHJpc2V1c2VyMDAxQHpvdHNlbGwuY29tIiwidXNlcm5hbWUiOiJlbnRlcnByaXNldXNlcjAwMUB6b3RzZWxsLmNvbSJ9.T49W5WcOxpOQ19l1urAOURBFUQ9UQPyJWBieqP-ZgELIR2fhxtj9BKAAC4WiUM7NZcsvGEr11Uxu0eZJqI5B50SqWFROEX5DHJ5wuRCvhLwIVGWKAVxNs1Y4_gFZAGMDLKCfa5Dg6g_zvd2Sce1YahhlLj81jBfq1Ik8RfSOlun6eZ6FjgC7-PDxXiuCZVQP4PDsY4W0r-3zHcawdYiznW8unRREvwECWo0pnS7GOw6RL3x_-o83hsEKgcv0B6ysgDq5i43KtqfF11zBBeAJAa5z3WeVMuF-bp11sFao3cSfkzf3Nq1bo7zZwUBs3z6SLZlZ83kAaq3OrEiQecFCHQ",
  "expires_in": 1800,
  "refresh_expires_in": 1800,
  "refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICI1YzcxNGJmZC03NThmLTRkZDItYTIyYy1jODJmMTk3NGIwZmMifQ.eyJleHAiOjE2NDk4NDcyNDAsImlhdCI6MTY0OTg0NTQ0MCwianRpIjoiMGIzODkzNGUtYjg2NC00YmViLWJjNjktYWI0YzFmNzMwZjE1IiwiaXNzIjoiaHR0cHM6Ly9kZXZsb2dpbi5jb21tZXJjaW8uYXBwL2F1dGgvcmVhbG1zL2NvbW1lcmNpbyIsImF1ZCI6Imh0dHBzOi8vZGV2bG9naW4uY29tbWVyY2lvLmFwcC9hdXRoL3JlYWxtcy9jb21tZXJjaW8iLCJzdWIiOiI5OTdkMjdjYS1lZTE1LTQ3YTYtYTI5ZS1kMjM5Y2E3MDUwYWMiLCJ0eXAiOiJSZWZyZXNoIiwiYXpwIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzZXNzaW9uX3N0YXRlIjoiYzgwZmI5NjctYzQ4Yi00NDVjLTliMTMtMjMyYjYwMzBkNzE3Iiwic2NvcGUiOiJvcGVuaWQgZW1haWwgcHJvZmlsZSJ9.PX5jgdC-5-v1Fe74wpzwWM5hBwFQJcRYxZKWYmt-Oys",
  "token_type": "Bearer",
  "id_token": "eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJwSnpWTkVBa1JieGJvazJGajZPenlmR3RNR25IRVhYNjA4bEVDOXJyNTlRIn0.eyJleHAiOjE2NDk4NDcyNDAsImlhdCI6MTY0OTg0NTQ0MCwiYXV0aF90aW1lIjowLCJqdGkiOiJlZDU4OGJmYy0yODQ4LTQxY2QtYjU0NC1iZWI0OWI2ZmRhMTIiLCJpc3MiOiJodHRwczovL2RldmxvZ2luLmNvbW1lcmNpby5hcHAvYXV0aC9yZWFsbXMvY29tbWVyY2lvIiwiYXVkIjoiZGV2LmNvbW1lcmNpby5hcHAiLCJzdWIiOiI5OTdkMjdjYS1lZTE1LTQ3YTYtYTI5ZS1kMjM5Y2E3MDUwYWMiLCJ0eXAiOiJJRCIsImF6cCI6ImRldi5jb21tZXJjaW8uYXBwIiwic2Vzc2lvbl9zdGF0ZSI6ImM4MGZiOTY3LWM0OGItNDQ1Yy05YjEzLTIzMmI2MDMwZDcxNyIsImFjciI6IjEiLCJ0ZXJtc19hbmRfY29uZGl0aW9ucyI6IjE2MjQ2MzMwODAiLCJyZWZlcnJhbCI6IiIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhZGRyZXNzIjp7fSwibmFtZSI6IkVudGVycHJpc2V1c2VyMDAxIEVudGVycHJpc2V1c2VyMDAxIiwicGhvbmVfbnVtYmVyIjoiMzQ4NTI0MTAwMSIsInByZWZlcnJlZF91c2VybmFtZSI6ImVudGVycHJpc2V1c2VyMDAxQHpvdHNlbGwuY29tIiwiZ2l2ZW5fbmFtZSI6IkVudGVycHJpc2V1c2VyMDAxIiwibG9jYWxlIjoiaXQiLCJmYW1pbHlfbmFtZSI6IkVudGVycHJpc2V1c2VyMDAxIiwiZW1haWwiOiJlbnRlcnByaXNldXNlcjAwMUB6b3RzZWxsLmNvbSIsInVzZXJuYW1lIjoiZW50ZXJwcmlzZXVzZXIwMDFAem90c2VsbC5jb20ifQ.aDT0OpBb3o3cLwsZL9vbgA5pm0NlGO75VgjFZzi7hYykKrXqaN20YWZuYoQXzeOeTh-AeSwMLCHDc6ie1_bz2dDJzDfECEzQ7PBRKaAgQy3LqZXrZG9uktO-magZ8CK0jzpuAKY1DD9SItzfcTrnxYwIYEzuPq8juUDEfkHgBnkahLdjj2__EGiD6i9eI_BDYJFGY6IrsObOPbnfd-pa7AqHkC47SzvLkjGajN3rj0dxDuD1rU2Eer392IvfVFAso1kkJjjTTSh1unnx7pu-wJSDTxmshF1i7CYCy5rMqS9D4VnJ2KDUswfM9Ooz3MvWCvCkjdGHWFEOUEncFutylw",
  "not-before-policy": 1630412674,
  "session_state": "c80fb967-c48b-445c-9b13-232b6030d717",
  "scope": "openid email profile"
}

This can be reiterated in time


# Securing your App

Coming next