- Getting started
- Authentication
- Scopes and permissions
- Platform Management APIs
- API rate limits for Identity Server
- Retrieving partitionGlobalId for API use
- Alerts
- External client - Federated credentials

Automation Cloud API guide
Federated credentials let an OAuth external application authenticate to UiPath using a JSON Web Token (JWT) issued by an external identity provider, without requiring a client secret. Each application supports a maximum of 20 federated credentials.
Use the endpoints on this page to list, create, retrieve, update, and delete federated credentials for a registered OAuth external application. To manage external applications themselves, see Managing external OAuth applications.
Retrieve all federated credentials registered for a specific OAuth external application.
GET
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentialsGET
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentialsPath parameters
| Parameter | Description |
|---|---|
partitionGlobalId | The organization global ID. |
clientId | The ID of the OAuth external application. |
--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'{access_token}, use an
organization administrator token or authenticate through one of the methods
described in Authentication methods.
Responses
Returns an array of FederatedCredentialDto objects. Returns an empty array if no credentials are registered.
Example request
curl --request GET \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials' \
--header 'Authorization: Bearer {access_token}'curl --request GET \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials' \
--header 'Authorization: Bearer {access_token}'Example response
[{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":"1539a53a-e34f-4803-adef-b9cd82f18858",
"name":"GitHub Actions","description":
"Used for GitHub Actions CI/CD pipeline","issuer":
"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg",
"subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z",
"updatedAt":"2026-03-01T10:00:00Z"}][{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":"1539a53a-e34f-4803-adef-b9cd82f18858",
"name":"GitHub Actions","description":
"Used for GitHub Actions CI/CD pipeline","issuer":
"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg",
"subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z",
"updatedAt":"2026-03-01T10:00:00Z"}]Create a federated identity credential for a specific OAuth external application.
POST
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentialsPOST
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentialsPath parameters
| Parameter | Description |
|---|---|
partitionGlobalId | The organization global ID. |
clientId | The ID of the OAuth external application. |
Requires either one of the following scopes:
- PM.OAuthApp
- PM.OAuthApp.Write
Request headers
--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'Request body
{"name":"azure-production-workload","description":"Federated credential for production Azure workload",
"issuer":"https://login.microsoftonline.com/{tenant-id}/v2.0",
"audience":"api://uipath-production","subject":"00000000-0000-0000-0000-000000000000"}{"name":"azure-production-workload","description":"Federated credential for production Azure workload",
"issuer":"https://login.microsoftonline.com/{tenant-id}/v2.0",
"audience":"api://uipath-production","subject":"00000000-0000-0000-0000-000000000000"}| Field | Required | Description |
|---|---|---|
name | Yes | A descriptive name for the credential. Must be unique within the application. Maximum 128 characters. |
description | No | Optional context for the credential. Maximum 512 characters. |
issuer | Yes | The HTTPS URI of the external identity provider. Must be reachable at create time. |
audience | Yes | A single string that must appear in the JWT aud
claim.
|
subject | Yes | A value that must exactly match the JWT sub
claim.
|
Responses
Returns the created FederatedCredentialDto object.
name is not unique within
the client, issuer is not a valid HTTPS URI, the issuer's JWKS
endpoint is unreachable, or the maximum of 20 credentials per application has been
reached.
clientId does not exist or does not belong to the
caller's organization.
Example request
curl --request POST \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials' \
--header 'Authorization: Bearer {access_token}' \
--header 'Content-Type: application/json' \
--data '{"name":"GitHub Actions","description":"Used for GitHub Actions CI/CD pipeline","issuer":"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main"}'
curl --request POST \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials' \
--header 'Authorization: Bearer {access_token}' \
--header 'Content-Type: application/json' \
--data '{"name":"GitHub Actions","description":"Used for GitHub Actions CI/CD pipeline","issuer":"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main"}'
Example response
{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":
"1539a53a-e34f-4803-adef-b9cd82f18858","name":"GitHub Actions","description":
"Used for GitHub Actions CI/CD pipeline","issuer":"https://token.actions.githubusercontent.com","audience":
"https://cloud.uipath.com/myorg","subject":
"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-01T10:00:00Z"}{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":
"1539a53a-e34f-4803-adef-b9cd82f18858","name":"GitHub Actions","description":
"Used for GitHub Actions CI/CD pipeline","issuer":"https://token.actions.githubusercontent.com","audience":
"https://cloud.uipath.com/myorg","subject":
"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-01T10:00:00Z"}GET
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}GET
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}Path parameters
| Parameter | Description |
|---|---|
partitionGlobalId | The organization global ID. |
clientId | The ID of the OAuth external application. |
credentialId | The ID of the federated credential. |
Requires either one of the following scopes:
- PM.OAuthApp
- PM.OAuthApp.Read
Request headers
--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'Responses
Returns the FederatedCredentialDto object for the requested credential.
The specified credential or application does not exist in the caller's organization.
Example request
curl --request GET \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}'curl --request GET \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}'Example response
{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":"1539a53a-e34f-4803-adef-b9cd82f18858",
"name":"GitHub Actions","description":"Used for GitHub Actions CI/CD pipeline",
"issuer":"https://token.actions.githubusercontent.com","audience":
"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-15T08:30:00Z"}{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6","clientId":"1539a53a-e34f-4803-adef-b9cd82f18858",
"name":"GitHub Actions","description":"Used for GitHub Actions CI/CD pipeline",
"issuer":"https://token.actions.githubusercontent.com","audience":
"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-15T08:30:00Z"}Update an existing federated credential. All required fields must be included in the request body.
PUT
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}PUT
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}Path parameters
| Parameter | Description |
|---|---|
partitionGlobalId | The organization global ID. |
clientId | The ID of the OAuth external application. |
credentialId | The ID of the federated credential to update. |
Requires either one of the following scopes:
- PM.OAuthApp
- PM.OAuthApp.Write
Request headers
--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'Request body
{"name":"azure-production-workload-updated","description":"Updated description","issuer"
:"https://login.microsoftonline.com/{tenant-id}/v2.0","audience":
"api://uipath-production","subject":"00000000-0000-0000-0000-000000000000"}{"name":"azure-production-workload-updated","description":"Updated description","issuer"
:"https://login.microsoftonline.com/{tenant-id}/v2.0","audience":
"api://uipath-production","subject":"00000000-0000-0000-0000-000000000000"}| Field | Required | Description |
|---|---|---|
name | Yes | A descriptive name for the credential. Must be unique within the application. Maximum 128 characters. |
description | No | Optional context for the credential. Maximum 512 characters. |
issuer | Yes | The HTTPS URI of the external identity provider. Must be reachable at create time. |
audience | Yes | A single string that must appear in the JWT aud
claim.
|
subject | Yes | A value that must exactly match the JWT sub
claim.
|
Returns the updated FederatedCredentialDto object.
name, invalid issuer
URI, or unreachable JWKS endpoint.
Example request
curl --request PUT \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}' \
--header 'Content-Type: application/json' \
--data '{"name":"GitHub Actions — Production","description":"Production branch deployments only","issuer":"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main"}'
curl --request PUT \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}' \
--header 'Content-Type: application/json' \
--data '{"name":"GitHub Actions — Production","description":"Production branch deployments only","issuer":"https://token.actions.githubusercontent.com","audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main"}'
Example response
{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6",
"clientId":"1539a53a-e34f-4803-adef-b9cd82f18858","name":"GitHub Actions — Production","description":
"Production branch deployments only","issuer":"https://token.actions.githubusercontent.com",
"audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-20T14:00:00Z"}{"id":"3fa85f64-5717-4562-b3fc-2c963f66afa6",
"clientId":"1539a53a-e34f-4803-adef-b9cd82f18858","name":"GitHub Actions — Production","description":
"Production branch deployments only","issuer":"https://token.actions.githubusercontent.com",
"audience":"https://cloud.uipath.com/myorg","subject":"repo:myorg/myrepo:ref:refs/heads/main",
"createdAt":"2026-03-01T10:00:00Z","updatedAt":"2026-03-20T14:00:00Z"}DELETE
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}DELETE
{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}Path parameters
| Parameter | Description |
|---|---|
partitionGlobalId | The organization global ID. |
clientId | The ID of the OAuth external application. |
credentialId | The ID of the federated credential to delete. |
Requires either one of the following scopes:
- PM.OAuthApp
- PM.OAuthApp.Write
Request headers
--header 'Authorization: Bearer {access_token}'--header 'Content-Type: application/json'Responses
The specified credential or application does not exist in the caller's organization.
Example request
curl --request DELETE \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}'curl --request DELETE \
'{accessURL}/identity_/api/ExternalClient/{partitionGlobalId}/{clientId}/FederatedCredentials/{credentialId}' \
--header 'Authorization: Bearer {access_token}'Exchange a JWT from your external identity provider for a UiPath access token.
POST
{accessURL}/identity_/connect/token
--header 'Content-Type: application/x-www-form-urlencoded'grant_type=client_credentials
&client_id={client_id}&client_assertion_type=urn:ietf:params:oauth:client-assertion-type:jwt-bearer
&client_assertion={jwt_token}&scope={requested_scopes}grant_type=client_credentials
&client_id={client_id}&client_assertion_type=urn:ietf:params:oauth:client-assertion-type:jwt-bearer
&client_assertion={jwt_token}&scope={requested_scopes}| Parameter | Description |
|---|---|
grant_type | Must be client_credentials.
|
client_id | The client ID of the registered OAuth external application. |
client_assertion_type | Must be
urn:ietf:params:oauth:client-assertion-type:jwt-bearer.
|
client_assertion | The JWT issued by your external identity provider. |
scope | The OAuth scopes requested for the access token. |
access_token value in the
Authorization: Bearer header of subsequent API calls.
Token acquisition failed. Possible causes: JWT signature invalid, issuer or audience mismatch, subject mismatch, expired JWT, or JWT exceeds 8 KB.
The object returned by GET, POST, and PUT operations.
| Property | Type | Nullable | Description |
|---|---|---|---|
id | string (uuid) | No | The unique identifier of the federated credential. |
clientId | string | Yes | The application ID of the OAuth external application this credential belongs to. |
name | string | Yes | The display name of the federated credential. |
description | string | Yes | The description of the federated credential. |
issuer | string | Yes | The URL of the external identity provider. |
audience | string | Yes | The expected aud claim value in the JWT.
|
subject | string | Yes | The expected sub claim value in the JWT.
|
createdAt | string (date-time) | No | The UTC timestamp when the credential was created. |
updatedAt | string (date-time) | No | The UTC timestamp when the credential was last updated. |
- List federated credentials
- API endpoint
- Scopes
- Request headers
- 200 OK
- Create a federated credential
- API endpoint
- Scopes
- 201 Created
- 400 Bad Request
- 404 Not Found
- Get a federated credential
- API endpoint
- Scopes
- 200 OK
- 404 Not Found
- Update a federated credential
- API endpoint
- Scopes
- 200 OK
- 400 Bad Request
- Delete a federated credential
- API endpoint
- Scopes
- 204 No Content
- 404 Not Found
- Acquire a token using a federated credential
- API endpoint
- 200 OK
- 400 Bad Request
- FederatedCredentialDto