Skip to main content

Get Signed JWT

The Get Signed JWT task is used to sign a JWT (JSON Web Token).

Using the RS256 algorithm, the task ensures robust cryptographic security during JWT signing. The resulting token effectively encapsulates specified authorization scopes and incorporates a TTL (time-to-live) mechanism to enforce its expiration, thereby maintaining secure access control.

Task configuration

Configure these parameters for the Get Signed JWT task.

ParameterDescriptionRequired/ Optional
inputParameters. subjectThe subject of the JWT, typically representing the entity (e.g., user or service) for which the token is issued.Required.
inputParameters issuerThe entity issuing the JWT, identifying who created and signed the token.Required.
inputParameters. privateKeyThe private key used to sign the JWT.Required.
inputParameters. privateKeyIdThe identifier for the private key used to sign the JWT.Required.
inputParameters. audienceThe intended recipient(s) of the JWT.Required.
inputParameters. ttlInSecondsThe time-to-live (TTL) or expiration time of the JWT, specified in seconds.Required.
inputParameters. scopesThe scopes associated with the JWT, defining the access permissions granted by the token. It can be a string or an array of strings.Required.
inputParameters. algorithmThe signing algorithm to use for the JWT. Currently set to RS256, which refers to the RSA signature with the SHA-256 hash algorithm.Required.

Task output

The Get Signed JWT task will return the signed JWT in the secret variable _secrets. The signed JWT will be masked (***).

Task definition

This is the JSON schema for a Get Signed JWT task definition.

{
"name": "get_signed_jwt",
"taskReferenceName": "get_signed_jwt_ref",
"inputParameters": {
"subject": "${workflow.input.subject}",
"issuer": "${workflow.input.issuer}",
"privateKey": "${workflow.secrets.jwt-privatekey}",
"privateKeyId": "key-123",
"audience": "${workflow.input.audience}",
"ttlInSeconds": 3600,
"scopes": "${workflow.input.scope}",
"algorithm": "RS256"
},
"type": "GET_SIGNED_JWT"
}

Adding a Get Signed JWT task in UI

To add a Get Signed JWT task:

  1. In your workflow, select the (+) icon and add a Get Signed JWT task.
  2. Enter the Subject and Issuer of the JWT.
  3. Provide the PrivateKey and PrivateKeyId used for signing JWT.
  4. Set the Audience, TTL (in seconds), Scopes, and Algorithm as required.

Adding Get Signed JWT task

Examples

Here are some examples for using the Get Signed JWT task.

Authorization
{
"name": "get_signed_jwt_token",
"taskReferenceName": "get_signed_jwt_token_ref",
"inputParameters": {
"privateKey": "${workflow.secrets.gcp_private_key}",
"privateKeyId": "${workflow.secrets.gcp_private_key_id}",
"audience": "https://oauth2.googleapis.com/token",
"ttlInSecond": 3600,
"scopes": [
"https://www.googleapis.com/auth/cloud-platform",
"https://www.googleapis.com/auth/documents",
"https://www.googleapis.com/auth/drive"
],
"subject": "service-account-name@project-id.iam.gserviceaccount.com",
"issuer": "service-account-name@project-id.iam.gserviceaccount.com"
},
"type": "GET_SIGNED_JWT",
}