Overview
The User Account and Authentication Service (UAA):
- is an OAuth2 / OpenID Connect (OIDC) server that can be used for centralized identity management.
- owns the user accounts and authentication sources (SAML, LDAP, OIDC) and proxied authentication
- supports standard protocols such as SAML, LDAP and OIDC to provide single sign-on and delegated authorization to web applications
- can be invoked via JSON APIs
- provides a basic login/approval UI for web client apps
- supports APIs for user account management for an external web UI
- most of the APIs are defined by the specs for the OAuth2, OIDC, and SCIM standards.
Authorization
Authorization Code Grant
Browser flow
$ curl 'http://localhost/oauth/authorize?response_type=code&client_id=login&scope=openid+oauth.approvals&redirect_uri=http%3A%2F%2Flocalhost%2Fapp&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D&code_challenge=E9Melhoa2OwvFrEMTJguCHaoeK1t8URWbuGJSstw-cM&code_challenge_method=S256' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=code&client_id=login&scope=openid+oauth.approvals&redirect_uri=http%3A%2F%2Flocalhost%2Fapp&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D&code_challenge=E9Melhoa2OwvFrEMTJguCHaoeK1t8URWbuGJSstw-cM&code_challenge_method=S256 HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=DZes4Dnn37zHkPNOX6NsZE; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:17 GMT; HttpOnly; SameSite=Lax
Cache-Control: no-store
Content-Language: en
Location: http://localhost/app?code=TGst-YeeE2iEJhaN7emPTjfFyzM335XY
X-Frame-Options: DENY
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, code for requesting an authorization code for an access token, as per OAuth spec |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
code_challenge |
UAA 75.5.0 PKCE Code Challenge. When code_challenge is present also a code_challenge_method must be provided. A matching code_verifier parameter must be provided in the subsequent request to get an access_token from /oauth/token |
code_challenge_method |
UAA 75.5.0 PKCE Code Challenge Method. S256 and plain methods are supported. S256 method creates a BASE64 URL encoded SHA256 hash of the code_verifier . The plain method is intended for constrained devices unable to calculate SHA256. In this case the code_verifier equals the code_challenge . If possible it is recommended to use S256 . |
login_hint |
UAA 4.19.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. |
Api flow
$ curl 'http://localhost/oauth/authorize?response_type=code&client_id=login&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf&code_challenge=E9Melhoa2OwvFrEMTJguCHaoeK1t8URWbuGJSstw-cM&code_challenge_method=S256&state=GH7Lcj' -i -X GET \
-H 'Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJ1c2VyX25hbWUiOiJtYXJpc3NhIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNmIiwiYXVkIjpbImNmIiwidWFhIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJwYXNzd29yZCIsInVzZXJfaWQiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJhenAiOiJjZiIsInNjb3BlIjpbInVhYS51c2VyIl0sImF1dGhfdGltZSI6MTc2MDcxMjkxNiwiZXhwIjoxNzYwNzU2MTE2LCJpYXQiOjE3NjA3MTI5MTYsImp0aSI6ImMxODA0NjRmNjU4MzRkMDFhOGZhOGJmNzVlZjExMWJiIiwiZW1haWwiOiJtYXJpc3NhQHRlc3Qub3JnIiwicmV2X3NpZyI6IjI4MDdmNzdhIiwiY2xpZW50X2F1dGhfbWV0aG9kIjoibm9uZSIsImNpZCI6ImNmIn0.nlbcl_gukzelRGcIl_JE26bRpQ9XZbkzZxgCImFMvIX8epcuu7LfL0trhHpla5haitaCn1ax00Sue9zpsZIWdghqyg7yksTRPvo31vbfxmtPDIU9z6lHc0zAU_lRmve8ZLD4AAmKB-y7j3cmWlgSVVtA-6H703zLL71cKji9k7HAT3iWLgwLtHrLZuyl3FhAKOaN0bgrobB4knFc-u266cu92WpGiimDCUZo2WdhGco2-ZBtFoRAemVh4n-M9_xl6H5fQZ8qD3TFKpDCVDITkpKfhmBvNNYJvE9gNutdb0xMyOEBYyUGOV0wCQPfPkmny3Yfr8ypsbfSbinbyp9FOw'
GET /oauth/authorize?response_type=code&client_id=login&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf&code_challenge=E9Melhoa2OwvFrEMTJguCHaoeK1t8URWbuGJSstw-cM&code_challenge_method=S256&state=GH7Lcj HTTP/1.1
Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJ1c2VyX25hbWUiOiJtYXJpc3NhIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNmIiwiYXVkIjpbImNmIiwidWFhIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJwYXNzd29yZCIsInVzZXJfaWQiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJhenAiOiJjZiIsInNjb3BlIjpbInVhYS51c2VyIl0sImF1dGhfdGltZSI6MTc2MDcxMjkxNiwiZXhwIjoxNzYwNzU2MTE2LCJpYXQiOjE3NjA3MTI5MTYsImp0aSI6ImMxODA0NjRmNjU4MzRkMDFhOGZhOGJmNzVlZjExMWJiIiwiZW1haWwiOiJtYXJpc3NhQHRlc3Qub3JnIiwicmV2X3NpZyI6IjI4MDdmNzdhIiwiY2xpZW50X2F1dGhfbWV0aG9kIjoibm9uZSIsImNpZCI6ImNmIn0.nlbcl_gukzelRGcIl_JE26bRpQ9XZbkzZxgCImFMvIX8epcuu7LfL0trhHpla5haitaCn1ax00Sue9zpsZIWdghqyg7yksTRPvo31vbfxmtPDIU9z6lHc0zAU_lRmve8ZLD4AAmKB-y7j3cmWlgSVVtA-6H703zLL71cKji9k7HAT3iWLgwLtHrLZuyl3FhAKOaN0bgrobB4knFc-u266cu92WpGiimDCUZo2WdhGco2-ZBtFoRAemVh4n-M9_xl6H5fQZ8qD3TFKpDCVDITkpKfhmBvNNYJvE9gNutdb0xMyOEBYyUGOV0wCQPfPkmny3Yfr8ypsbfSbinbyp9FOw
Host: localhost
HTTP/1.1 302 Found
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Content-Language: en
Location: http://localhost/redirect/cf?code=MaISCEGCzNeC6h8MDdL4bCfvzL4VtaVG&state=GH7Lcj
X-XSS-Protection: 0
X-Frame-Options: DENY
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, code for requesting an authorization code for an access token, as per OAuth spec |
client_id |
a unique string representing the registration information provided by the client |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
code_challenge |
UAA 75.5.0 PKCE Code Challenge. When code_challenge is present also a code_challenge_method must be provided. A matching code_verifier parameter must be provided in the subsequent request to get an access_token from /oauth/token |
code_challenge_method |
UAA 75.5.0 PKCE Code Challenge Method. S256 and plain methods are supported. S256 method creates a BASE64 URL encoded SHA256 hash of the code_verifier . The plain method is intended for constrained devices unable to calculate SHA256. In this case the code_verifier equals the code_challenge . If possible it is recommended to use S256 . |
state |
any random string to be returned in the Location header as a query parameter, used to achieve per-request customization |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing uaa.user scope - the authentication for this user |
Implicit Grant
$ curl 'http://localhost/oauth/authorize?response_type=token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=pbqoN2N4kclV6_6A07KZwc; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:17 GMT; HttpOnly; SameSite=Lax
Cache-Control: no-store
Content-Language: en
X-Frame-Options: DENY
Location: http://localhost:8080/app/#token_type=bearer&access_token=eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJ1c2VyX25hbWUiOiJtYXJpc3NhIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImFwcCIsImF1ZCI6WyJhcHAiLCJvcGVuaWQiXSwiemlkIjoidWFhIiwiZ3JhbnRfdHlwZSI6ImltcGxpY2l0IiwidXNlcl9pZCI6IjcwZTBjZWFjLWM0MmMtNGUxMC1iNjk4LWNmZmY5ODdmMGU0NiIsImF6cCI6ImFwcCIsInNjb3BlIjpbIm9wZW5pZCJdLCJhdXRoX3RpbWUiOjE3NjA3MTI5MTcsImV4cCI6MTc2MDc1NjExNywiaWF0IjoxNzYwNzEyOTE3LCJqdGkiOiI1MGEwMDUxNTE1MTU0NjY4OWIzNzFmNDY2ZDE5YjE2ZCIsImVtYWlsIjoibWFyaXNzYUB0ZXN0Lm9yZyIsInJldl9zaWciOiIzNDAyNGJhIiwiY2lkIjoiYXBwIn0.kkAEdgrF6-AYqzzp-pRCJp4Gtpva85UqFDDAsYWguTlzVPTBTbyc0bd1BTpBIozWK44bDZk1vwUNSDtkf2Pvp0xmkYb65roOYDr6_6oJgzUGAzqeqyQ2ww9grmhJylmH6yYEWuT8xYwBeqEXHIoNr55KLPUl-jUSGOQWkPf4QJw2SAduzj-I9XSJiGyOalrKt73a1md0DcuHps4_h4_xp8o8Y4iV4O1z2nIH9Il50c8i_VMPgnhTU2jC-Znln3zylTuWF_EuOVYVEt76drHBomBmP41YqbRFqUejG1WdHX6s6lsxW9Jt8YyIImsbMZ7eq4_xCnyiCrmJ8Wy7AT-cHg&expires_in=43199&jti=50a00515151546689b371f466d19b16d
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, token , i.e. an access token |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
login_hint |
UAA 4.19.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. |
Response Headers
Name | Description |
---|---|
Location |
Location as defined in the spec includes access_token in the reply fragment if successful |
Implicit Grant with prompt
$ curl 'http://localhost/oauth/authorize?response_type=token&client_id=app&scope=openid&prompt=none&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=token&client_id=app&scope=openid&prompt=none&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: Current-User=; Path=/; Max-Age=0; Expires=Thu, 01 Jan 1970 00:00:00 GMT
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Location: http://localhost:8080/app/#error=login_required&session_state=4df4a94f3d69c3988f46b0ae78c6f55ecefac527bd2c27712bcd53c6b5d78ddd.3b4e3c2c3426fe8e72dfbb1aba2925554262058ca835dc3660d454382c29ecc2
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, token , i.e. an access token |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
prompt |
specifies whether to prompt for user authentication. Only value none is supported. |
Response Headers
Name | Description |
---|---|
Location |
Redirect url specified in the request parameters. |
OpenID Connect flow
OpenID Provider Configuration Request
An OpenID Provider Configuration Document MUST be queried using an HTTP GET request at the previously specified path.
$ curl 'http://localhost/.well-known/openid-configuration' -i -X GET \
-H 'Accept: application/json'
GET /.well-known/openid-configuration HTTP/1.1
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1375
{
"issuer" : "http://localhost:8080/uaa/oauth/token",
"authorization_endpoint" : "http://localhost/oauth/authorize",
"token_endpoint" : "http://localhost/oauth/token",
"token_endpoint_auth_methods_supported" : [ "client_secret_basic", "client_secret_post", "private_key_jwt" ],
"token_endpoint_auth_signing_alg_values_supported" : [ "RS256", "HS256" ],
"userinfo_endpoint" : "http://localhost/userinfo",
"jwks_uri" : "http://localhost/token_keys",
"end_session_endpoint" : "http://localhost/logout.do",
"scopes_supported" : [ "openid", "profile", "email", "phone", "roles", "user_attributes" ],
"response_types_supported" : [ "code", "code id_token", "id_token", "token id_token" ],
"subject_types_supported" : [ "public" ],
"id_token_signing_alg_values_supported" : [ "RS256", "HS256" ],
"id_token_encryption_alg_values_supported" : [ "none" ],
"claim_types_supported" : [ "normal" ],
"claims_supported" : [ "sub", "user_name", "origin", "iss", "auth_time", "amr", "acr", "client_id", "aud", "zid", "grant_type", "user_id", "azp", "scope", "exp", "iat", "jti", "rev_sig", "cid", "given_name", "family_name", "phone_number", "email" ],
"claims_parameter_supported" : false,
"service_documentation" : "http://docs.cloudfoundry.org/api/uaa/",
"ui_locales_supported" : [ "en-US" ],
"code_challenge_methods_supported" : [ "S256", "plain" ]
}
Response Fields
Path | Type | Description |
---|---|---|
issuer |
String |
URL using the https scheme with no query or fragment component that the OP asserts as its Issuer Identifier. |
authorization_endpoint |
String |
URL of authorization endpoint. |
token_endpoint |
String |
URL of token endpoint. |
userinfo_endpoint |
String |
URL of the OP's UserInfo Endpoint. |
jwks_uri |
String |
URL of the OP's JSON Web Key Set document. |
end_session_endpoint |
String |
URL of the logout endpoint. |
scopes_supported |
Array |
JSON array containing a list of the OAuth 2.0 scope values that this server supports. |
subject_types_supported |
Array |
JSON array containing a list of the Subject Identifier types that this OP supports. |
token_endpoint_auth_methods_supported |
Array |
JSON array containing a list of Client Authentication methods supported by this Token Endpoint. |
token_endpoint_auth_signing_alg_values_supported |
Array |
JSON array containing a list of the JWS signing algorithms. |
response_types_supported |
Array |
JSON array containing a list of the OAuth 2.0 response_type values that this OP supports. |
id_token_signing_alg_values_supported |
Array |
JSON array containing a list of the JWS signing algorithms (alg values) supported by the OP for the ID Token to encode the Claims in a JWT. |
id_token_encryption_alg_values_supported |
Array |
JSON array containing a list of the JWE encryption algorithms (alg values) supported by the OP. |
claim_types_supported |
Array |
JSON array containing a list of the Claim Types that the OpenID Provider supports. |
claims_supported |
Array |
JSON array containing a list of the Claim Names of the Claims that the OpenID Provider MAY be able to supply values for. |
claims_parameter_supported |
Boolean |
Boolean value specifying whether the OP supports use of the claims parameter. |
service_documentation |
String |
URL of a page containing human-readable information that developers might want or need to know when using the OpenID Provider. |
code_challenge_methods_supported |
Array |
UAA 75.5.0JSON array containing a list of PKCE code challenge methods supported by this authorization endpoint. |
ui_locales_supported |
Array |
Languages and scripts supported for the user interface. |
ID token
The authorization request may specify a response type of id_token, and an ID token as defined by OpenID Connect will be included in the fragment of the redirect URL.
$ curl 'http://localhost/oauth/authorize?response_type=id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=dkCVR4NBFVzqgs4qz32r10; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:17 GMT; HttpOnly; SameSite=Lax
Cache-Control: no-store
Content-Language: en
X-Frame-Options: DENY
Location: http://localhost:8080/app/#token_type=bearer&id_token=eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoibWFyaXNzYSIsIm9yaWdpbiI6InVhYSIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJjbGllbnRfaWQiOiJhcHAiLCJhdWQiOlsiYXBwIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJpbXBsaWNpdCIsInVzZXJfaWQiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJhenAiOiJhcHAiLCJzY29wZSI6WyJvcGVuaWQiXSwiYXV0aF90aW1lIjoxNzYwNzEyOTE3LCJleHAiOjE3NjA3NTYxMTcsImlhdCI6MTc2MDcxMjkxNywiZW1haWwiOiJtYXJpc3NhQHRlc3Qub3JnIiwianRpIjoiY2QzMDE1ZDFmOGIxNGQyMDk1Y2Q1MDQ2MDJiNTQ0YWYiLCJyZXZfc2lnIjoiMzQwMjRiYSIsImNpZCI6ImFwcCJ9.Um7LNMeTPkEVyl_5lKRkvV05D01Z7qlOwl16EZXAMuXUakZJ0Lq6iDEUDxbXGE442bVgzAm4yJIaPfclN5de3EqXVjFvbuzzqePqFlbty0uXKRJiUWR1nnyuIp3ynQg5hj1NA1FZW8G0WiPvwbbJVuG-jh1Udf4UwSg1xCtQEokzZfIRKwMlIYpkhsdvbOLNCCen-4q8Ymjd41D2zDNCVMZ09v4O3GJZQEFkuER6n5X6TsUTnMThdyD5Blf619W_b8tOiy_DWSwROGUOoagSduI5mHRt7j6gGwL8EWqQlrGgCNOfSdh8gx35-6U1cofy_0SmKtfmHrs4k5cs3TtFGA&expires_in=43199&jti=cd3015d1f8b14d2095cd504602b544af
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, id_token |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
login_hint |
UAA 4.19.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. |
Response Headers
Name | Description |
---|---|
Location |
Location as defined in the spec includes id_token in the reply fragment if successful |
ID token and Access token
The request may specify that the client expects an ID token as defined by OpenID Connect, and this ID token will be included alongside the access token.
$ curl 'http://localhost/oauth/authorize?response_type=token+id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=token+id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=5_t4RNEPcKm8ajbKgA5aLY; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:17 GMT; HttpOnly; SameSite=Lax
Cache-Control: no-store
Content-Language: en
X-Frame-Options: DENY
Location: http://localhost:8080/app/#token_type=bearer&access_token=eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJ1c2VyX25hbWUiOiJtYXJpc3NhIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImFwcCIsImF1ZCI6WyJhcHAiLCJvcGVuaWQiXSwiemlkIjoidWFhIiwiZ3JhbnRfdHlwZSI6ImltcGxpY2l0IiwidXNlcl9pZCI6IjcwZTBjZWFjLWM0MmMtNGUxMC1iNjk4LWNmZmY5ODdmMGU0NiIsImF6cCI6ImFwcCIsInNjb3BlIjpbIm9wZW5pZCJdLCJhdXRoX3RpbWUiOjE3NjA3MTI5MTcsImV4cCI6MTc2MDc1NjExNywiaWF0IjoxNzYwNzEyOTE3LCJqdGkiOiI5ZDk1MDUxMzNhNTU0MDQwYjZmMzU5ZjFjYWEyNjhmMSIsImVtYWlsIjoibWFyaXNzYUB0ZXN0Lm9yZyIsInJldl9zaWciOiIzNDAyNGJhIiwiY2lkIjoiYXBwIn0.MHcCO2hoCshvFVumsqE1wMsmCxMGrMprMMaQd2VWp2tveyoMliueGNcf19wQ0M6ZsQ3kiWLrG8zNetpO4NQv0ksDR6pZ9kxZ5D8N_7m8ydRFvVa-oD79QWA_pjZwiqU5_7PMsoOmwVVyDPTOGgJx8qAmtITy54J7uhIANWvE1fWYe2StCHD2_Rp8yH2CkBl56WHQH3Viv4RKtxX_svOjvmQks-RKYqwSVS0q_n8qjD0scTcfqKHDV1UX9GMkZ-edse-oxpG3_xgM0CssCmzqmiOgfZ1HQeekxOxiq808TJLgZkuwOKfAcJDPZ_OdHhBQkUxFLkqm4EScVsDoHZZPXg&id_token=eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoibWFyaXNzYSIsIm9yaWdpbiI6InVhYSIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJjbGllbnRfaWQiOiJhcHAiLCJhdWQiOlsiYXBwIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJpbXBsaWNpdCIsInVzZXJfaWQiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJhenAiOiJhcHAiLCJzY29wZSI6WyJvcGVuaWQiXSwiYXV0aF90aW1lIjoxNzYwNzEyOTE3LCJleHAiOjE3NjA3NTYxMTcsImlhdCI6MTc2MDcxMjkxNywiZW1haWwiOiJtYXJpc3NhQHRlc3Qub3JnIiwianRpIjoiOWQ5NTA1MTMzYTU1NDA0MGI2ZjM1OWYxY2FhMjY4ZjEiLCJyZXZfc2lnIjoiMzQwMjRiYSIsImNpZCI6ImFwcCJ9.DzORPTkhT-Ialso49UKw5kWNABHHF9ti1rc2g2mO1EdqMK-Kdj71KiP0tnhBeaOnEkuA5Fop0O5OekMH_UjiYPcHi1AXmfGGUCAT7xEOLQA3s_V9SS1msNFQHdTU4f3Y_i5-iUyKLQxQxFgYUQejTeFA4nUiWZliB4OtMfB7sQp0taAA9yetvsKJucz6cCCAvU14l1tFCEuee_BJcfoYX1eW0fHDLWmW3f1WKFTTTxyxgyaitrN8l4R9zWUvpWhhtym8vpcM0KN2BP8XDp17Yzd8ywtmcAuGvpUE3YSw4GXpS1suf4Kc7zbNUtJzMuDZxfaeUptvpOkrvFrgiQ8zCg&expires_in=43199&jti=9d9505133a554040b6f359f1caa268f1
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, token id_token , indicating both an access token and an ID token. |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
login_hint |
UAA 4.19.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. |
Response Headers
Name | Description |
---|---|
Location |
Location as defined in the spec includes access_token and id_token in the reply fragment if successful |
Hybrid flow
The request may specify that the client expects an ID token as defined by OpenID Connect, and this ID token will be included alongside the authorization code.
$ curl 'http://localhost/oauth/authorize?response_type=code+id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D' -i -X GET \
-H 'Accept: application/x-www-form-urlencoded'
GET /oauth/authorize?response_type=code+id_token&client_id=app&scope=openid&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fapp%2F&login_hint=%257B%2522origin%2522%253A%2522uaa%2522%257D HTTP/1.1
Accept: application/x-www-form-urlencoded
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=rCr_gMrgJH58WMsjmq0vyB; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:17 GMT; HttpOnly; SameSite=Lax
Cache-Control: no-store
Content-Language: en
X-Frame-Options: DENY
Location: http://localhost:8080/app/#token_type=bearer&id_token=eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI3MGUwY2VhYy1jNDJjLTRlMTAtYjY5OC1jZmZmOTg3ZjBlNDYiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoibWFyaXNzYSIsIm9yaWdpbiI6InVhYSIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJjbGllbnRfaWQiOiJhcHAiLCJhdWQiOlsiYXBwIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJhdXRob3JpemF0aW9uX2NvZGUiLCJ1c2VyX2lkIjoiNzBlMGNlYWMtYzQyYy00ZTEwLWI2OTgtY2ZmZjk4N2YwZTQ2IiwiYXpwIjoiYXBwIiwic2NvcGUiOlsib3BlbmlkIl0sImF1dGhfdGltZSI6MTc2MDcxMjkxNywiZXhwIjoxNzYwNzU2MTE3LCJpYXQiOjE3NjA3MTI5MTcsImVtYWlsIjoibWFyaXNzYUB0ZXN0Lm9yZyIsImp0aSI6Ijg2MzQ0YzY2ZGUzMzQxNzJhN2Q1ZTEyMDE5NWZjYjgwIiwicmV2X3NpZyI6IjM0MDI0YmEiLCJjaWQiOiJhcHAifQ.N7eT9I-b--S-KTMcexuM1Mft4bkumwKTsJw_s-kbs3l_oqMZvXUfFM9hKm5epkcTBPQiVrNRL_Z-wWKrY_6fLMo78EB8eGXkxybQpKnmXtN0O2-zEqD5RW4o5DcNjS8cceOHiCNyMuixzu4U4tdcnvuigKvf2pf4HZLZs_rnuI6xmzst3K-bFM8vgZbuNl624r8-6d4AnKjhFGahqvSZOurG7yePdRWVISEYZBFW8nFGZljhFgEwPkY6tYVSBmMZ-PPPyHeAB9vWqCaXQL2cVlJeB5thmAhduxAbwnX4ofcFV5FpbbeeSBgdFpnjb6k9LCVzj_8GtBEwN7eOCqhDog&code=I0QRU4Yc160XeKtshh4jdB_TbApHX-S-&expires_in=43199&jti=86344c66de334172a7d5e120195fcb80
Request Parameters
Parameter | Description |
---|---|
response_type |
Space-delimited list of response types. Here, id_token code , indicating a request for an ID token and an authorization code. |
client_id |
a unique string representing the registration information provided by the client |
scope |
requested scopes, space-delimited |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied), optional if pre-registered by the client |
login_hint |
UAA 4.19.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. |
Response Headers
Name | Description |
---|---|
Location |
Location as defined in the spec includes code and id_token in the reply fragment if successful |
Token
The /oauth/token
endpoint requires client authentication to be accessed, except you allow the public usage. For more details about public usage see
allowpublic flag in client details configuration. For confidential client usages, the client authentication can be passed as part of the request
authorization header, using basic authentication, or as part of the request parameters, using the combination of client_id
and client_secret
or
client_assertion_type
and client_assertion
parameter names. The client authentication methods are explained in the
OpenID Core specification. UAA supports currently none, client_secret_basic,
client_secret_post and private_key_jwt.
Authorization Code Grant
$ curl 'http://localhost/oauth/token' -i -u 'login:loginsecret' -X POST \
-H 'Accept: application/json' \
-d 'client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=authorization_code&code=4jysWshzlWQ1C8buWYNjUUahtI-cQN-G&token_format=opaque&code_verifier=dBjftJeZ4CVP-mB92K27uhbUJU1p1r_wW1gFWFOEjXk&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Authorization: Basic bG9naW46bG9naW5zZWNyZXQ=
Accept: application/json
Host: localhost
Content-Length: 953
client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=authorization_code&code=4jysWshzlWQ1C8buWYNjUUahtI-cQN-G&token_format=opaque&code_verifier=dBjftJeZ4CVP-mB92K27uhbUJU1p1r_wW1gFWFOEjXk&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1376
{
"access_token" : "eab11e183bc74f76b600183e6839a21e",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiIwM2UxYzVkZi0xZjAyLTQ1YTgtOWZjZC0xMDk0YzdjM2E5YTgiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiZ1gwQXVmQHRlc3Qub3JnIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImxvZ2luIiwiYXVkIjpbImxvZ2luIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJhdXRob3JpemF0aW9uX2NvZGUiLCJ1c2VyX2lkIjoiMDNlMWM1ZGYtMWYwMi00NWE4LTlmY2QtMTA5NGM3YzNhOWE4IiwiYXpwIjoibG9naW4iLCJzY29wZSI6WyJvcGVuaWQiXSwiYXV0aF90aW1lIjoxNzYwNzEyOTI0LCJleHAiOjE3NjA3NTYxMjQsImlhdCI6MTc2MDcxMjkyNCwiZW1haWwiOiJnWDBBdWZAdGVzdC5vcmciLCJqdGkiOiJlYWIxMWUxODNiYzc0Zjc2YjYwMDE4M2U2ODM5YTIxZSIsInJldl9zaWciOiJlODdjYmY5ZSIsImNpZCI6ImxvZ2luIn0.IqoyhzbRE87KBbvCV0K0QbGmPvV-vmrbX1YNccpfFFDqiarmir4tPhJ1p5kRN_UtFyEsBMzT4fZr35CZ1dcrtBifO2iImzDQ5_ButkMy7rpSal7jvyZMG2fcPZ_P0wKA1hkbGbCTTekBsTTCdXkJ1OpGjNLBAQT0d7XkWxOqi1nTdMTrTo7FqU8cEUcPKwbYzU35VgBee51rKnqn91NeDWKvqRDMzHC2XZeeFgBE07G-LV8JkC2kMcAujq7RCasOR7jj5Vwc9Jhd3iPH8iaDcQCUmdS0AiNNN8By7gx61loL5J3OgqAOmMmO4QByEaC3QLGU7eO25pX2s-6LCl0vJA",
"refresh_token" : "ca532e2208354b70b4563fa201673545-r",
"expires_in" : 43199,
"scope" : "openid oauth.approvals",
"jti" : "eab11e183bc74f76b600183e6839a21e"
}
Request Headers
Name | Description |
---|---|
Authorization |
Client ID and secret may be passed as a basic authorization header, per RFC 6749 or as request parameters. |
Request Parameters
Parameter | Description |
---|---|
client_id |
A unique string representing the registration information provided by the client, the recipient of the token. Optional if it is passed as part of the Basic Authorization header or as part of the client_assertion. |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied) |
code |
the authorization code, obtained from /oauth/authorize , issued for the user |
grant_type |
the type of authentication being used to obtain the token, in this case authorization_code |
client_secret |
UAA 75.21.0 Optional and can be omitted if client has configured allowpublic and PKCE with code_challenge_method=S256 is used to create to code . |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
code_verifier |
UAA 75.5.0 PKCE Code Verifier. A code_verifier parameter must be provided if a code_challenge parameter was present in the previous call to /oauth/authorize . The code_verifier must match the used code_challenge (according to the selected code_challenge_method ) |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
Client Credentials Grant
Without Authorization
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&scope=scim.write&grant_type=client_credentials&token_format=opaque'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Host: localhost
Content-Length: 822
client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&scope=scim.write&grant_type=client_credentials&token_format=opaque
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 180
{
"access_token" : "fdbdc29528274aaaa8ddf1114992e250",
"token_type" : "bearer",
"expires_in" : 43199,
"scope" : "scim.write",
"jti" : "fdbdc29528274aaaa8ddf1114992e250"
}
Request Parameters
Parameter | Description |
---|---|
client_id |
A unique string representing the registration information provided by the client, the recipient of the token. Optional if it is passed as part of the Basic Authorization header or as part of the client_assertion. |
grant_type |
the type of authentication being used to obtain the token, in this case client_credentials |
client_secret |
The secret passphrase configured for the OAuth client. Optional if it is passed as part of the Basic Authorization header or if client_assertion is sent as part of private_key_jwt authentication. |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
scope |
The list of scopes requested for the token. Use when you wish to reduce the number of scopes the token will have. |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized for this client. This list is derived from the authorities configured on the client. |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
With Authorization
$ curl 'http://localhost/oauth/token' -i -u 'login:loginsecret' -X POST \
-H 'Accept: application/json' \
-d 'grant_type=client_credentials&scope=scim.write&token_format=opaque'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Authorization: Basic bG9naW46bG9naW5zZWNyZXQ=
Host: localhost
Content-Length: 66
grant_type=client_credentials&scope=scim.write&token_format=opaque
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 180
{
"access_token" : "651197176798436483dd57f85920a1fb",
"token_type" : "bearer",
"expires_in" : 43199,
"scope" : "scim.write",
"jti" : "651197176798436483dd57f85920a1fb"
}
Request Header
Name | Description |
---|---|
Authorization |
Base64 encoded client details in the format: Basic client_id:client_secret |
Request Parameters
Parameter | Description |
---|---|
grant_type |
the type of authentication being used to obtain the token, in this case client_credentials |
scope |
The list of scopes requested for the token. Use when you wish to reduce the number of scopes the token will have. |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized for this client. This list is derived from the authorities configured on the client. |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
Password Grant
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'client_id=app&client_secret=appclientsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=password&username=1gB1wC%40test.org&password=secr3T&token_format=opaque&login_hint=%7B%22origin%22%3A%22uaa%22%7D'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Host: localhost
Content-Length: 882
client_id=app&client_secret=appclientsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=password&username=1gB1wC%40test.org&password=secr3T&token_format=opaque&login_hint=%7B%22origin%22%3A%22uaa%22%7D
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1428
{
"access_token" : "7b7a1c308bc145098f86612b9e1e4439",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJjMDJhNDJiOC1lMTFiLTRmMDMtYmFjOC01ZGViNDQ3M2ZmNmIiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiMWdCMXdDQHRlc3Qub3JnIiwiYW1yIjpbInB3ZCJdLCJvcmlnaW4iOiJ1YWEiLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoiYXBwIiwiYXVkIjpbImFwcCJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoicGFzc3dvcmQiLCJ1c2VyX2lkIjoiYzAyYTQyYjgtZTExYi00ZjAzLWJhYzgtNWRlYjQ0NzNmZjZiIiwiYXpwIjoiYXBwIiwic2NvcGUiOlsib3BlbmlkIl0sImF1dGhfdGltZSI6MTc2MDcxMjkyMSwiZXhwIjoxNzYwNzU2MTIyLCJpYXQiOjE3NjA3MTI5MjIsImVtYWlsIjoiMWdCMXdDQHRlc3Qub3JnIiwianRpIjoiN2I3YTFjMzA4YmMxNDUwOThmODY2MTJiOWUxZTQ0MzkiLCJyZXZfc2lnIjoiZmEzYTY4ZDgiLCJjaWQiOiJhcHAifQ.TCJkYTJKHGYm4nYLp3l0jlTyZmlb9DtMwsKY3RDSrl4gMwZN6sPjTMqlHyzFoRu5TQSWk7FKygwFalHJGV6LGwCZ4dEgHvPuDE9Dp4pVxS1tbCw1OnRB6wSEI7AW9BlfYACYw_BJWoJT5WMcMDq2WO-yZOZ7F4ec84hxzJ0mwmhssR8AfEMqHn60bj0PJKNGKeYdR3ravh9zzfzba-uXF48P8TiHXbCRUcxi6u7FbDZUEmd9Zq2sALPaTskQX3XOgmYjb0XzvwYCQM4T4M3tVaWXJptiBkS87e9dVMfwAE9H6VTRfMYVAddPF_eflW323VFXhxoc3Egq6YZNrcLNRw",
"refresh_token" : "ce68e7389c5f42ffaf503984d33fe595-r",
"expires_in" : 43199,
"scope" : "scim.userids openid cloud_controller.read password.write cloud_controller.write",
"jti" : "7b7a1c308bc145098f86612b9e1e4439"
}
Request Parameters
Parameter | Description |
---|---|
client_id |
A unique string representing the registration information provided by the client, the recipient of the token. Optional if it is passed as part of the Basic Authorization header or as part of the client_assertion. |
grant_type |
the type of authentication being used to obtain the token, in this case password |
client_secret |
The secret passphrase configured for the OAuth client. Optional if it is passed as part of the Basic Authorization header or if client_assertion is sent as part of private_key_jwt authentication. |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
username |
the username for the user trying to get a token |
password |
the password for the user trying to get a token |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
login_hint |
UAA 75.5.0 Indicates the identity provider to be used. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. Note that this identity provider must support the grant type password . |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
One-time Passcode
$ curl 'http://localhost/oauth/token' -i -u 'app:appclientsecret' -X POST \
-H 'Accept: application/json' \
-d 'grant_type=password&passcode=J1xfUrnVna0B13adfvvFMwl0H_YowHhd&token_format=opaque'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Authorization: Basic YXBwOmFwcGNsaWVudHNlY3JldA==
Host: localhost
Content-Length: 81
grant_type=password&passcode=J1xfUrnVna0B13adfvvFMwl0H_YowHhd&token_format=opaque
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1369
{
"access_token" : "e27d3557323c4018bea17bcc0120f74f",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI0NTI0NGYxNC1lNDc0LTQ5ZmMtYjNmMS1mZWZiYjA1NjliYzQiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoibWFyaXNzYSIsIm9yaWdpbiI6InVhYSIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJjbGllbnRfaWQiOiJhcHAiLCJhdWQiOlsiYXBwIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJwYXNzd29yZCIsInVzZXJfaWQiOiI0NTI0NGYxNC1lNDc0LTQ5ZmMtYjNmMS1mZWZiYjA1NjliYzQiLCJhenAiOiJhcHAiLCJzY29wZSI6WyJvcGVuaWQiXSwiZXhwIjoxNzYwNzU2MTIxLCJpYXQiOjE3NjA3MTI5MjEsImVtYWlsIjoibWFyaXNzYUB0ZXN0Lm9yZyIsImp0aSI6ImUyN2QzNTU3MzIzYzQwMThiZWExN2JjYzAxMjBmNzRmIiwicmV2X3NpZyI6IjFlMTljOGRmIiwiY2lkIjoiYXBwIn0.IjrT-T_4zA71RYaGMeo-P_3XZ8yQM3UtdmCKsvDpjdM8iu_kKT6fl-wtZhvolZnI672EGgYghzQE0zGUPBG8Yqxx0JRXes9otlGuYy_T_GiidVwicwkg057h03TiDoQUhs_niUBU17lb4q3r-3pIoUHetoU7ZEaU8_-DhaEkjCBCTPjZCzd53GRYoP63PPPbxHrmPfKBxoUju5W9bb3JNcxBQTVrg9R5Tu5PEOkK192IaKhWQ64L1SRQdFMkIfTKYDW_xspZIFrbWUIa9vw-Dten5zLemI0RPfUMkjehI94AGpVIRLOhS9XE7Rn5D31Wslk34HkmlliiHh9g90gU2A",
"refresh_token" : "4fc4d0fc83d84acea8fa847c01fd4750-r",
"expires_in" : 43199,
"scope" : "scim.userids openid cloud_controller.read password.write cloud_controller.write",
"jti" : "e27d3557323c4018bea17bcc0120f74f"
}
Request Header
Name | Description |
---|---|
Authorization |
Base64 encoded client details in the format: Basic client_id:client_secret |
Request Parameters
Parameter | Description |
---|---|
grant_type |
the type of authentication being used to obtain the token, in this case password |
passcode |
the one-time passcode for the user which can be retrieved by going to /passcode |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
User Token Grant
A user_token
grant, is a flow that allows the generation of a refresh_token for another client.
The requesting client, must have grant_type=user_token
and the bearer token for this request must have uaa.user
and be a token that represents an authenticated user.
The idea with this grant flow, is that a user can preapprove a token grant for another client, rather than having to participate in the approval process when the client needs the access token.
The refresh_token
that results from this grant, is opaque, and can only be exchanged by the client it was intended for.
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Authorization: Bearer 7b9918f6ee7c4614a97893ea67b65dc4' \
-H 'Accept: application/json' \
-d 'client_id=app&grant_type=user_token&scope=openid&token_format=jwt'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Authorization: Bearer 7b9918f6ee7c4614a97893ea67b65dc4
Accept: application/json
Host: localhost
Content-Length: 65
client_id=app&grant_type=user_token&scope=openid&token_format=jwt
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 206
{
"access_token" : null,
"token_type" : "bearer",
"refresh_token" : "37ac143198f0401fabdcbca889e24116-r",
"expires_in" : 43199,
"scope" : "openid",
"jti" : "37ac143198f0401fabdcbca889e24116-r"
}
Request Parameters
Parameter | Description |
---|---|
client_id |
The client ID of the receiving client, this client must have refresh_token grant type |
grant_type |
The type of token grant requested, in this case user_token |
token_format |
This parameter is ignored. The refresh_token will always be opaque |
scope |
The list of scopes requested for the token. Use when you wish to reduce the number of scopes the token will have. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
Null |
This field is always null . |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
SAML2 Bearer Grant
The SAML 2.0 bearer grant allows to request an OAuth 2.0 access token with a SAML 2.0 bearer assertion. The flow is defined in
RFC 7522. The requesting client, must have grant_type=urn:ietf:params:oauth:grant-type:saml2-bearer
.
In addition, the requesting client must either allow the IDP in allowedproviders
or omit the property so that any trusted IDP is allowed.
The trust to the assertion issuer is reused from the SAML 2.0 WebSSO profiles.
This grant enables an App2App mechanism with SSO. Typical scenarios are applications outside of CF, which consume a service within the CF world.
The endpoint of the bearer assertion is /oauth/token/alias/<endityid>
so the Recipient attribute in
the bearer assertion must point to the corresponding URI, e.g. http://localhost:8080/uaa/oauth/token/alias/cloudfoundry-saml-login.
$ curl 'http://68uexx.localhost:8080/uaa/oauth/token/alias/68uexx.integration-saml-entity-id' -i -X POST \
-H 'Accept: application/json' \
-H 'Host: 68uexx.localhost' \
-d 'grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Asaml2-bearer&client_id=testclientIlKHF4&client_secret=secret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&assertion=PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBJRD0iQTllNDRjZGFlLTYzZjQtNDRjZS1hNjU2LTEzYzNiNmRkYmY2NCIgSXNzdWVJbnN0YW50PSIyMDI1LTEwLTE3VDE0OjU1OjIzLjE2OVoiIFZlcnNpb249IjIuMCI-PHNhbWwyOklzc3Vlcj42OHVleHguY2xvdWRmb3VuZHJ5LXNhbWwtbG9naW48L3NhbWwyOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj4KPGRzOlNpZ25lZEluZm8-CjxkczpDYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8-CjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8-CjxkczpSZWZlcmVuY2UgVVJJPSIjQTllNDRjZGFlLTYzZjQtNDRjZS1hNjU2LTEzYzNiNmRkYmY2NCI-CjxkczpUcmFuc2Zvcm1zPgo8ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz4KPGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPgo8L2RzOlRyYW5zZm9ybXM-CjxkczpEaWdlc3RNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyNzaGEyNTYiLz4KPGRzOkRpZ2VzdFZhbHVlPmUrMjR5bk96MWROY1lXOXNpQ1krVTc4MEtTZDArclRRWlFQb3dlUzVQdVU9PC9kczpEaWdlc3RWYWx1ZT4KPC9kczpSZWZlcmVuY2U-CjwvZHM6U2lnbmVkSW5mbz4KPGRzOlNpZ25hdHVyZVZhbHVlPgpUMmRJelpBUTNzRWhXdkNER1pjemZQVHIxbGRHOHpkVUc3UDZvOUJJUExWOHdZYkptN3A2a0x0MUljc01vRXc1K2pqQUxVeU91UjV2JiMxMzsKWDdWOGpGVDhuZTR0N2p1ZUJkU3pJa0FqTXpENnlIOUFSMjV3dFNKaldDaXRPZnpFNDJGa1RTUmw3VVArRUViNWdZSnVCODhXSDk5OCYjMTM7CkVQLzQzdENOMExKd3hsZGJpUGc9CjwvZHM6U2lnbmF0dXJlVmFsdWU-CjxkczpLZXlJbmZvPjxkczpYNTA5RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURTVENDQXJLZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRUUZBREI4TVFzd0NRWURWUVFHRXdKaGR6RU9NQXdHQTFVRUNCTUYKWVhKMVltRXhEakFNQmdOVkJBb1RCV0Z5ZFdKaE1RNHdEQVlEVlFRSEV3VmhjblZpWVRFT01Bd0dBMVVFQ3hNRllYSjFZbUV4RGpBTQpCZ05WQkFNVEJXRnlkV0poTVIwd0d3WUpLb1pJaHZjTkFRa0JGZzVoY25WaVlVQmhjblZpWVM1aGNqQWVGdzB4TlRFeE1qQXlNakkyCk1qZGFGdzB4TmpFeE1Ua3lNakkyTWpkYU1Id3hDekFKQmdOVkJBWVRBbUYzTVE0d0RBWURWUVFJRXdWaGNuVmlZVEVPTUF3R0ExVUUKQ2hNRllYSjFZbUV4RGpBTUJnTlZCQWNUQldGeWRXSmhNUTR3REFZRFZRUUxFd1ZoY25WaVlURU9NQXdHQTFVRUF4TUZZWEoxWW1FeApIVEFiQmdrcWhraUc5dzBCQ1FFV0RtRnlkV0poUUdGeWRXSmhMbUZ5TUlHZk1BMEdDU3FHU0liM0RRRUJBUVVBQTRHTkFEQ0JpUUtCCmdRREh0QzVnVVh4QktwRXFaVExrTnZGd05Hbk5Ja2dnTk93T1FWTmJwTzBXVkhJaXZpZzVMMzlXcVM5dTBobkErTzdNQ0EvS2xyQVIKNGJYYWVWVmh3ZlVQWUJLSXBhYVRXRlFSNWNUUjFVRlpKTC9PRjl2QWZwT3d6bm9ENjZERENuUVZwYkNqdERZV1greDZpbXhuOEhDWQp4aE1vbDZablRiU3NGVzZWWmpGTWpRSURBUUFCbzRIYU1JSFhNQjBHQTFVZERnUVdCQlR4MGxEempIL2lPQm5PU1FhU0VXUUx4MXN5CkdEQ0Jwd1lEVlIwakJJR2ZNSUdjZ0JUeDBsRHpqSC9pT0JuT1NRYVNFV1FMeDFzeUdLR0JnS1IrTUh3eEN6QUpCZ05WQkFZVEFtRjMKTVE0d0RBWURWUVFJRXdWaGNuVmlZVEVPTUF3R0ExVUVDaE1GWVhKMVltRXhEakFNQmdOVkJBY1RCV0Z5ZFdKaE1RNHdEQVlEVlFRTApFd1ZoY25WaVlURU9NQXdHQTFVRUF4TUZZWEoxWW1FeEhUQWJCZ2txaGtpRzl3MEJDUUVXRG1GeWRXSmhRR0Z5ZFdKaExtRnlnZ0VBCk1Bd0dBMVVkRXdRRk1BTUJBZjh3RFFZSktvWklodmNOQVFFRUJRQURnWUVBWXZCSjBIT1piYkhDbFhtR1VqR3MrR1MreEMxRk8vYW0KMnN1Q1NZcU5COWR5TVhmT1dpSjErVExKaytvL1ladDh2dXhDS2RjWllnbDRsL0w2UHhKOTgyU1JoYzgzWlcyZGtBWkk0TTAvVWQzbwplUGU4NGs4am0zQTdFdkg1d2k1aHZDa0tScHVSQnduM0VpK2pDUm91eFRiektQc3VDVkIrMXNOeXhNVFh6ZjA9PC9kczpYNTA5Q2VydGlmaWNhdGU-PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8-PC9kczpTaWduYXR1cmU-PHNhbWwyOlN1YmplY3Q-PHNhbWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIiBOYW1lUXVhbGlmaWVyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDp1bnNwZWNpZmllZCI-U2FtbDJCZWFyZXJJbnRlZ3JhdGlvblVzZXI8L3NhbWwyOk5hbWVJRD48c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMjUtMTAtMTdUMTU6NTU6MjMuMTY5WiIgUmVjaXBpZW50PSJodHRwOi8vNjh1ZXh4LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbi9hbGlhcy82OHVleHguaW50ZWdyYXRpb24tc2FtbC1lbnRpdHktaWQiLz48L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24-PC9zYW1sMjpTdWJqZWN0PjxzYW1sMjpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAyNS0xMC0xN1QxNDo1NToyMS4xNjlaIiBOb3RPbk9yQWZ0ZXI9IjIwMjUtMTAtMTdUMTU6NTU6MjMuMTY5WiI-PHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24-PHNhbWwyOkF1ZGllbmNlPjY4dWV4eC5pbnRlZ3JhdGlvbi1zYW1sLWVudGl0eS1pZDwvc2FtbDI6QXVkaWVuY2U-PC9zYW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDI6Q29uZGl0aW9ucz48c2FtbDI6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDI1LTEwLTE3VDE0OjU1OjIzLjE2OVoiIFNlc3Npb25JbmRleD0iYTM1OGEwNmMxNWphOGQ3YTFpZGphajA3amI1MmdkaSIgU2Vzc2lvbk5vdE9uT3JBZnRlcj0iMjAyNS0xMC0xN1QxNTo1NToyMy4xNjlaIj48c2FtbDI6QXV0aG5Db250ZXh0PjxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZDwvc2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY-PC9zYW1sMjpBdXRobkNvbnRleHQ-PC9zYW1sMjpBdXRoblN0YXRlbWVudD48L3NhbWwyOkFzc2VydGlvbj4%3D&scope=openid'
POST /uaa/oauth/token/alias/68uexx.integration-saml-entity-id HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Host: 68uexx.localhost
Content-Length: 5486
grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Asaml2-bearer&client_id=testclientIlKHF4&client_secret=secret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&assertion=PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBJRD0iQTllNDRjZGFlLTYzZjQtNDRjZS1hNjU2LTEzYzNiNmRkYmY2NCIgSXNzdWVJbnN0YW50PSIyMDI1LTEwLTE3VDE0OjU1OjIzLjE2OVoiIFZlcnNpb249IjIuMCI-PHNhbWwyOklzc3Vlcj42OHVleHguY2xvdWRmb3VuZHJ5LXNhbWwtbG9naW48L3NhbWwyOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj4KPGRzOlNpZ25lZEluZm8-CjxkczpDYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8-CjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8-CjxkczpSZWZlcmVuY2UgVVJJPSIjQTllNDRjZGFlLTYzZjQtNDRjZS1hNjU2LTEzYzNiNmRkYmY2NCI-CjxkczpUcmFuc2Zvcm1zPgo8ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz4KPGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPgo8L2RzOlRyYW5zZm9ybXM-CjxkczpEaWdlc3RNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyNzaGEyNTYiLz4KPGRzOkRpZ2VzdFZhbHVlPmUrMjR5bk96MWROY1lXOXNpQ1krVTc4MEtTZDArclRRWlFQb3dlUzVQdVU9PC9kczpEaWdlc3RWYWx1ZT4KPC9kczpSZWZlcmVuY2U-CjwvZHM6U2lnbmVkSW5mbz4KPGRzOlNpZ25hdHVyZVZhbHVlPgpUMmRJelpBUTNzRWhXdkNER1pjemZQVHIxbGRHOHpkVUc3UDZvOUJJUExWOHdZYkptN3A2a0x0MUljc01vRXc1K2pqQUxVeU91UjV2JiMxMzsKWDdWOGpGVDhuZTR0N2p1ZUJkU3pJa0FqTXpENnlIOUFSMjV3dFNKaldDaXRPZnpFNDJGa1RTUmw3VVArRUViNWdZSnVCODhXSDk5OCYjMTM7CkVQLzQzdENOMExKd3hsZGJpUGc9CjwvZHM6U2lnbmF0dXJlVmFsdWU-CjxkczpLZXlJbmZvPjxkczpYNTA5RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURTVENDQXJLZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRUUZBREI4TVFzd0NRWURWUVFHRXdKaGR6RU9NQXdHQTFVRUNCTUYKWVhKMVltRXhEakFNQmdOVkJBb1RCV0Z5ZFdKaE1RNHdEQVlEVlFRSEV3VmhjblZpWVRFT01Bd0dBMVVFQ3hNRllYSjFZbUV4RGpBTQpCZ05WQkFNVEJXRnlkV0poTVIwd0d3WUpLb1pJaHZjTkFRa0JGZzVoY25WaVlVQmhjblZpWVM1aGNqQWVGdzB4TlRFeE1qQXlNakkyCk1qZGFGdzB4TmpFeE1Ua3lNakkyTWpkYU1Id3hDekFKQmdOVkJBWVRBbUYzTVE0d0RBWURWUVFJRXdWaGNuVmlZVEVPTUF3R0ExVUUKQ2hNRllYSjFZbUV4RGpBTUJnTlZCQWNUQldGeWRXSmhNUTR3REFZRFZRUUxFd1ZoY25WaVlURU9NQXdHQTFVRUF4TUZZWEoxWW1FeApIVEFiQmdrcWhraUc5dzBCQ1FFV0RtRnlkV0poUUdGeWRXSmhMbUZ5TUlHZk1BMEdDU3FHU0liM0RRRUJBUVVBQTRHTkFEQ0JpUUtCCmdRREh0QzVnVVh4QktwRXFaVExrTnZGd05Hbk5Ja2dnTk93T1FWTmJwTzBXVkhJaXZpZzVMMzlXcVM5dTBobkErTzdNQ0EvS2xyQVIKNGJYYWVWVmh3ZlVQWUJLSXBhYVRXRlFSNWNUUjFVRlpKTC9PRjl2QWZwT3d6bm9ENjZERENuUVZwYkNqdERZV1greDZpbXhuOEhDWQp4aE1vbDZablRiU3NGVzZWWmpGTWpRSURBUUFCbzRIYU1JSFhNQjBHQTFVZERnUVdCQlR4MGxEempIL2lPQm5PU1FhU0VXUUx4MXN5CkdEQ0Jwd1lEVlIwakJJR2ZNSUdjZ0JUeDBsRHpqSC9pT0JuT1NRYVNFV1FMeDFzeUdLR0JnS1IrTUh3eEN6QUpCZ05WQkFZVEFtRjMKTVE0d0RBWURWUVFJRXdWaGNuVmlZVEVPTUF3R0ExVUVDaE1GWVhKMVltRXhEakFNQmdOVkJBY1RCV0Z5ZFdKaE1RNHdEQVlEVlFRTApFd1ZoY25WaVlURU9NQXdHQTFVRUF4TUZZWEoxWW1FeEhUQWJCZ2txaGtpRzl3MEJDUUVXRG1GeWRXSmhRR0Z5ZFdKaExtRnlnZ0VBCk1Bd0dBMVVkRXdRRk1BTUJBZjh3RFFZSktvWklodmNOQVFFRUJRQURnWUVBWXZCSjBIT1piYkhDbFhtR1VqR3MrR1MreEMxRk8vYW0KMnN1Q1NZcU5COWR5TVhmT1dpSjErVExKaytvL1ladDh2dXhDS2RjWllnbDRsL0w2UHhKOTgyU1JoYzgzWlcyZGtBWkk0TTAvVWQzbwplUGU4NGs4am0zQTdFdkg1d2k1aHZDa0tScHVSQnduM0VpK2pDUm91eFRiektQc3VDVkIrMXNOeXhNVFh6ZjA9PC9kczpYNTA5Q2VydGlmaWNhdGU-PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8-PC9kczpTaWduYXR1cmU-PHNhbWwyOlN1YmplY3Q-PHNhbWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIiBOYW1lUXVhbGlmaWVyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDp1bnNwZWNpZmllZCI-U2FtbDJCZWFyZXJJbnRlZ3JhdGlvblVzZXI8L3NhbWwyOk5hbWVJRD48c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMjUtMTAtMTdUMTU6NTU6MjMuMTY5WiIgUmVjaXBpZW50PSJodHRwOi8vNjh1ZXh4LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbi9hbGlhcy82OHVleHguaW50ZWdyYXRpb24tc2FtbC1lbnRpdHktaWQiLz48L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24-PC9zYW1sMjpTdWJqZWN0PjxzYW1sMjpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAyNS0xMC0xN1QxNDo1NToyMS4xNjlaIiBOb3RPbk9yQWZ0ZXI9IjIwMjUtMTAtMTdUMTU6NTU6MjMuMTY5WiI-PHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24-PHNhbWwyOkF1ZGllbmNlPjY4dWV4eC5pbnRlZ3JhdGlvbi1zYW1sLWVudGl0eS1pZDwvc2FtbDI6QXVkaWVuY2U-PC9zYW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDI6Q29uZGl0aW9ucz48c2FtbDI6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDI1LTEwLTE3VDE0OjU1OjIzLjE2OVoiIFNlc3Npb25JbmRleD0iYTM1OGEwNmMxNWphOGQ3YTFpZGphajA3amI1MmdkaSIgU2Vzc2lvbk5vdE9uT3JBZnRlcj0iMjAyNS0xMC0xN1QxNTo1NToyMy4xNjlaIj48c2FtbDI6QXV0aG5Db250ZXh0PjxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZDwvc2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY-PC9zYW1sMjpBdXRobkNvbnRleHQ-PC9zYW1sMjpBdXRoblN0YXRlbWVudD48L3NhbWwyOkFzc2VydGlvbj4%3D&scope=openid
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
Content-Disposition: inline;filename=f.txt
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1500
{
"access_token" : "eyJqa3UiOiJodHRwczovLzY4dWV4eC5sb2NhbGhvc3Q6ODA4MC91YWEvdG9rZW5fa2V5cyIsImtpZCI6ImtleS1pZC0xIiwidHlwIjoiSldUIiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiI5Y2QzZTEzMC1kOGM2LTQ4NjItYjcwZC1lNTZlZmNkMjhiM2MiLCJ1c2VyX25hbWUiOiJTYW1sMkJlYXJlckludGVncmF0aW9uVXNlciIsIm9yaWdpbiI6IjY4dWV4eC5pbnRlZ3JhdGlvbi1zYW1sLWVudGl0eS1pZCIsImlzcyI6Imh0dHA6Ly82OHVleHgubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoidGVzdGNsaWVudElsS0hGNCIsImF1ZCI6WyJvcGVuaWQiLCJ0ZXN0Y2xpZW50SWxLSEY0Il0sInppZCI6IjY4dWV4eCIsImdyYW50X3R5cGUiOiJ1cm46aWV0ZjpwYXJhbXM6b2F1dGg6Z3JhbnQtdHlwZTpzYW1sMi1iZWFyZXIiLCJ1c2VyX2lkIjoiOWNkM2UxMzAtZDhjNi00ODYyLWI3MGQtZTU2ZWZjZDI4YjNjIiwiYXpwIjoidGVzdGNsaWVudElsS0hGNCIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3MTM1MjMsImlhdCI6MTc2MDcxMjkyMywianRpIjoiZDZlMTYxZTI2Mzk1NDE5ZTg5ZTRjMWJiNmM4MWEzN2IiLCJlbWFpbCI6IlNhbWwyQmVhcmVySW50ZWdyYXRpb25Vc2VyQHRoaXMtZGVmYXVsdC13YXMtbm90LWNvbmZpZ3VyZWQuaW52YWxpZCIsInJldl9zaWciOiJkZWNiYjRjNCIsImNpZCI6InRlc3RjbGllbnRJbEtIRjQifQ.CKzmE0lv9PTLtpvlowo4iFr3aW6lVVyGRQkOFSdSHLj_UV5ucadOVuR6mKshXeq010HmEpNbe4RuLBqn5PZ9tdIAGJ76uJmkkt8jN7sBZ4OhcVQ1Z91UwzfadMdaj1GZGF2fPzKOrLxkljmkQSplg_p9EVncC0vNMrgl672a8O8mOQ3fHvHLWHJQnco0g-yVaYkO8FaGjHyi15DCrl6jrM8vbI82QEp4bCCNqtb-dBnEPnuoUEyY0MTM8LwsqloNg7xoVxZXeLeMpFvSdRn7MfD-EmB94KoDOyFXffxtIhe57zImMDof7Q4tO1TVNy-D7S-1SUf8I6USMcvYyIxhsA",
"token_type" : "bearer",
"refresh_token" : "247d9a2a3dd448cda1d70b24695d73a1-r",
"expires_in" : 599,
"scope" : "openid",
"jti" : "d6e161e26395419e89e4c1bb6c81a37b"
}
Request Parameters
Parameter | Description |
---|---|
client_id |
The client ID of the receiving client, this client must have urn:ietf:params:oauth:grant-type:saml2-bearer grant type |
client_secret |
The secret passphrase configured for the OAuth client. Optional if it is passed as part of the Basic Authorization header or if client_assertion is sent as part of private_key_jwt authentication. |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
grant_type |
The type of token grant requested, in this case urn:ietf:params:oauth:grant-type:saml2-bearer |
assertion |
An XML based SAML 2.0 bearer assertion, which is Base64URl encoded. |
scope |
The list of scopes requested for the token. Use when you wish to reduce the number of scopes the token will have. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
token_type |
String |
The type of the access token issued, always bearer |
expires_in |
Number |
Number of seconds of lifetime for an access_token, when retrieved |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
JWT Bearer Token Grant
The JSON Web Token (JWT) Profile for OAuth 2.0 Client Authentication and Authorization Grants
allows to request an OAuth 2.0 access token with a JWT id_token bearer assertion. The flow is defined in
RFC 7523. The requesting client, must have grant_type=urn:ietf:params:oauth:grant-type:jwt-bearer
.
In addition, the requesting client must either allow the IDP in allowedproviders
or omit the property so that any trusted IDP is allowed.
The trust to the assertion, the issuer claim is used to select an OIDC provider (IDP) configured in the
UAA database. If multiple providers exists that have the same issuer, the grant will fail.
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'client_id=8fw1zsaz8wb2&client_secret=secret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Ajwt-bearer&token_format=opaque&response_type=token+id_token&scope=openid&login_hint=%257B%2522origin%2522%253A%2522idp%2522%257D&assertion=eyJqa3UiOiJodHRwczovL242dTlhaGxjY3BqbC5sb2NhbGhvc3Q6ODA4MC91YWEvdG9rZW5fa2V5cyIsImtpZCI6ImtleS1pZC0xIiwidHlwIjoiSldUIiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiI2ODkwYjhhMy1jNjhlLTQ5NTgtYTY3Ny02YWQ3ODcxMmY2MmUiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiaHp0aXhuMHN5MXNzIiwiYW1yIjpbInB3ZCJdLCJvcmlnaW4iOiJ1YWEiLCJpc3MiOiJodHRwOi8vbjZ1OWFobGNjcGpsLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6IlpnUXJwemU0bzB2SiIsImF1ZCI6WyJaZ1FycHplNG8wdkoiXSwiemlkIjoibjZ1OWFobGNjcGpsIiwiZ3JhbnRfdHlwZSI6InBhc3N3b3JkIiwidXNlcl9pZCI6IjY4OTBiOGEzLWM2OGUtNDk1OC1hNjc3LTZhZDc4NzEyZjYyZSIsImF6cCI6IlpnUXJwemU0bzB2SiIsInNjb3BlIjpbIm9wZW5pZCJdLCJhdXRoX3RpbWUiOjE3NjA3MTI5MzMsImV4cCI6MTc2MDc1NjEzMywiaWF0IjoxNzYwNzEyOTMzLCJlbWFpbCI6Imh6dGl4bjBzeTFzc0B0ZXN0Lm9yZyIsImp0aSI6IjE5NWMyYTY4NjI0YTQxOGNiOWQyYjM5OWVjZGRkZjMwIiwicmV2X3NpZyI6ImY0ODJlMmY5IiwiY2lkIjoiWmdRcnB6ZTRvMHZKIn0.NFdxQcWfAUDaJsI2ZuoHsk0NbRd4LyvWTXiG5U4N6NXsuOAJXbFWFdSbI8ShVEmvPj9tGH86T-hudfTn73mEEfnp-98kBBLtiDuf9qQOwEVBLgX6CWuhP395OZYPtmedun9UYNhXvYwkoT5jXc_mF6LNIh2BcmyZMvkLC97pbhj03NbEndpA8G-td8gqIMI4Xmt9Y87MYNEOaodZq1fDoxXeEbllAKo5D2nwV4tHodGTSRsORUmHs_8P5EsIhBJ3qJG4WxeE4FO5A0xhAfB8TMjLtvPU8Zr0UIVgBcR588AlA8SLMfxALeqFyki8JBMpPrHyjjWoHM-svQxnho37mw'
POST /oauth/token HTTP/1.1
Accept: application/json
Content-Type: application/x-www-form-urlencoded
Host: localhost
Content-Length: 2152
client_id=8fw1zsaz8wb2&client_secret=secret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Ajwt-bearer&token_format=opaque&response_type=token+id_token&scope=openid&login_hint=%257B%2522origin%2522%253A%2522idp%2522%257D&assertion=eyJqa3UiOiJodHRwczovL242dTlhaGxjY3BqbC5sb2NhbGhvc3Q6ODA4MC91YWEvdG9rZW5fa2V5cyIsImtpZCI6ImtleS1pZC0xIiwidHlwIjoiSldUIiwiYWxnIjoiUlMyNTYifQ.eyJzdWIiOiI2ODkwYjhhMy1jNjhlLTQ5NTgtYTY3Ny02YWQ3ODcxMmY2MmUiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiaHp0aXhuMHN5MXNzIiwiYW1yIjpbInB3ZCJdLCJvcmlnaW4iOiJ1YWEiLCJpc3MiOiJodHRwOi8vbjZ1OWFobGNjcGpsLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6IlpnUXJwemU0bzB2SiIsImF1ZCI6WyJaZ1FycHplNG8wdkoiXSwiemlkIjoibjZ1OWFobGNjcGpsIiwiZ3JhbnRfdHlwZSI6InBhc3N3b3JkIiwidXNlcl9pZCI6IjY4OTBiOGEzLWM2OGUtNDk1OC1hNjc3LTZhZDc4NzEyZjYyZSIsImF6cCI6IlpnUXJwemU0bzB2SiIsInNjb3BlIjpbIm9wZW5pZCJdLCJhdXRoX3RpbWUiOjE3NjA3MTI5MzMsImV4cCI6MTc2MDc1NjEzMywiaWF0IjoxNzYwNzEyOTMzLCJlbWFpbCI6Imh6dGl4bjBzeTFzc0B0ZXN0Lm9yZyIsImp0aSI6IjE5NWMyYTY4NjI0YTQxOGNiOWQyYjM5OWVjZGRkZjMwIiwicmV2X3NpZyI6ImY0ODJlMmY5IiwiY2lkIjoiWmdRcnB6ZTRvMHZKIn0.NFdxQcWfAUDaJsI2ZuoHsk0NbRd4LyvWTXiG5U4N6NXsuOAJXbFWFdSbI8ShVEmvPj9tGH86T-hudfTn73mEEfnp-98kBBLtiDuf9qQOwEVBLgX6CWuhP395OZYPtmedun9UYNhXvYwkoT5jXc_mF6LNIh2BcmyZMvkLC97pbhj03NbEndpA8G-td8gqIMI4Xmt9Y87MYNEOaodZq1fDoxXeEbllAKo5D2nwV4tHodGTSRsORUmHs_8P5EsIhBJ3qJG4WxeE4FO5A0xhAfB8TMjLtvPU8Zr0UIVgBcR588AlA8SLMfxALeqFyki8JBMpPrHyjjWoHM-svQxnho37mw
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1420
{
"access_token" : "82c85fe0883c45b89814ecd4c169fb6e",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJmMmI3YzJiNC0yZTE4LTRlYWMtYmU5MC0yODVkMmNkYzdhZTAiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiaHp0aXhuMHN5MXNzQHRlc3Qub3JnIiwib3JpZ2luIjoiWk5oMWlPIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6IjhmdzF6c2F6OHdiMiIsImF1ZCI6WyI4ZncxenNhejh3YjIiXSwiemlkIjoidWFhIiwiZ3JhbnRfdHlwZSI6InVybjppZXRmOnBhcmFtczpvYXV0aDpncmFudC10eXBlOmp3dC1iZWFyZXIiLCJ1c2VyX2lkIjoiZjJiN2MyYjQtMmUxOC00ZWFjLWJlOTAtMjg1ZDJjZGM3YWUwIiwiYXpwIjoiOGZ3MXpzYXo4d2IyIiwic2NvcGUiOlsib3BlbmlkIl0sImV4cCI6MTc2MDc1NjEzMywiaWF0IjoxNzYwNzEyOTMzLCJlbWFpbCI6Imh6dGl4bjBzeTFzc0B0ZXN0Lm9yZyIsImp0aSI6IjgyYzg1ZmUwODgzYzQ1Yjg5ODE0ZWNkNGMxNjlmYjZlIiwicmV2X3NpZyI6ImVmMGY2YTVkIiwiY2lkIjoiOGZ3MXpzYXo4d2IyIn0.MFi523T1wuI8-j6p7qxfur3Nbq9IEkp9WWYgfkS5ZsenLZMOF_A7aAj0gH8NeCzytahIxxHZ2KGmIgwzMerg6BrRackCiVxJ63HU0sk8Arhv0DiEJp6onv8YKo7xvWDeVXhJBdzeo3YxQPgG7G1-CrLwrLN-J9HDNZCopjIND8ZEpNSYnZkauqfopbpir5_rnCbQ5Yf-OVIPxi01Io86CHusCDmypISMhU00dgzaE-4sE7sR65yedTNO5x8WmFqHvUUZJi44aOnmwWbgJdRPvm60nJ7rYscE8IO4MQkGBDZ9cy4oxXqYqMM-LTYLzWpL3zDDvDAEtH31kJ4Ncz0LQg",
"refresh_token" : "f9975e38fa714b449660dcc5d00a91eb-r",
"expires_in" : 43199,
"scope" : "openid",
"jti" : "82c85fe0883c45b89814ecd4c169fb6e"
}
Request Headers
Name | Description |
---|---|
Authorization |
Uses basic authorization with base64(resource_server:shared_secret) assuming the caller (a resource server) is actually also a registered client and has uaa.resource authority |
Request Parameters
Parameter | Description |
---|---|
assertion |
JWT token identifying representing the user to be authenticated |
client_id |
Required, client with |
client_secret |
The secret passphrase configured for the OAuth client. Optional if it is passed as part of the Basic Authorization header or if client_assertion is sent as part of private_key_jwt authentication. |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
grant_type |
Must be set to urn:ietf:params:oauth:grant-type:jwt-bearer |
scope |
Optional parameter to limit the number of scopes in the scope claim of the access token |
response_type |
May be set to token or token id_token or id_token |
login_hint |
UAA 77.29.0 Indicates the identity provider to be used as proxy for assertion validation. The passed string has to be a URL-Encoded JSON Object, containing the field origin with value as origin_key of an identity provider. Note that this identity provider must support the grant type urn:ietf:params:oauth:grant-type:jwt-bearer . |
token_format |
May be set to opaque to retrieve revocable and non identifiable access token |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
Access token generated by this grant |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
Will always be bearer |
scope |
String |
List of scopes present in the scope claim in the access token |
expires_in |
Number |
Number of seconds before this token expires from the time of issuance |
jti |
String |
The unique token ID |
refresh_token |
String |
Refresh token issued by this grant |
Token Exchange Grant
The Token Exchange Grant is a partial implementation of RFC 8693
and is a HTTP- and JSON-based Security Token Service (STS) that allows impersonation of clients and users
via a JWT token exchange. The subject_token must be a JWT token and may be an access token or an id_token
The requesting client, must have grant_type=urn:ietf:params:oauth:grant-type:token-exchange
.
In addition, the requesting client must either allow the IDP in allowedproviders
or omit the property so that any trusted IDP is allowed.
The trust to the assertion, the issuer claim is used to select an OIDC provider (IDP) configured in the
UAA database. If multiple providers exists that have the same issuer, the grant will fail. If
the IDP has addShadowUserOnLogin
set to false and the user does not exist, the grant will fail.
If the IDP has addShadowUserOnLogin
set to true, the origin of the newly created user will be the same
as that of the IDP.
Basic Client Authentication
$ curl 'http://worker-gymlnt.localhost/oauth/token' -i -u 'client-worker-gYMLNT:secret' -X POST \
-H 'Accept: application/json' \
-d 'grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC1wbDFya2YubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtTjJVd3FGIiwib3JpZ2luIjoiY3RsLVBsMVJrZiIsImlzcyI6Imh0dHA6Ly9jdGwtcGwxcmtmLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtUGwxUmtmIiwiYXVkIjpbImNsaWVudC1jdGwtUGwxUmtmIl0sInppZCI6ImN0bC1QbDFSa2YiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJhenAiOiJjbGllbnQtY3RsLVBsMVJrZiIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzMsImlhdCI6MTc2MDcxMjkzMywiZW1haWwiOiJ1c2VyLTNyZC1OMlV3cUZAM3JkLU4yVXdxRi5vcmciLCJqdGkiOiJiMTcyZDZmZDE1OGM0NzQ3ODE2YzJlNjFjM2I3ZDJiYyIsInJldl9zaWciOiI0MmY0YzE0NyIsImNpZCI6ImNsaWVudC1jdGwtUGwxUmtmIn0.GFABh8znukefC_Pv5pl5z6ADP7KvQF5atisqXeEuNEyfsjForfey-cr1GMjbGdy6P9trcLy1nBEcU_DqPGxw7lJ1tZ9IaKE-_T5ZhHpSNkUWXNSIInTkVmzO5x6NfU6AAv9DJXX9jCJlf2K6O4sSqp28wxujIB6Rwn9rSx-j-ACB0OkhyDRWAkPqRDwi47vui8dqN2Zcc_BIg3Q18P9Es41sYF8iGPjSc1uyutdSu4A-6rGHPDLsfz3kcxP3WZ5cXA39H6m7LXFqXg-vNgiw0CUZYzUjJ4nh0-G0QU8S8rJ0AfALA6xhr-r8wUrz7tIpdR9FuN0-7Cl6IRdC9ivsWQ&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_id=client-worker-gYMLNT&response_type=token+id_token'
POST /oauth/token HTTP/1.1
Accept: application/json
Content-Type: application/x-www-form-urlencoded
Authorization: Basic Y2xpZW50LXdvcmtlci1nWU1MTlQ6c2VjcmV0
Host: worker-gymlnt.localhost
Content-Length: 1580
grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC1wbDFya2YubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtTjJVd3FGIiwib3JpZ2luIjoiY3RsLVBsMVJrZiIsImlzcyI6Imh0dHA6Ly9jdGwtcGwxcmtmLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtUGwxUmtmIiwiYXVkIjpbImNsaWVudC1jdGwtUGwxUmtmIl0sInppZCI6ImN0bC1QbDFSa2YiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJhenAiOiJjbGllbnQtY3RsLVBsMVJrZiIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzMsImlhdCI6MTc2MDcxMjkzMywiZW1haWwiOiJ1c2VyLTNyZC1OMlV3cUZAM3JkLU4yVXdxRi5vcmciLCJqdGkiOiJiMTcyZDZmZDE1OGM0NzQ3ODE2YzJlNjFjM2I3ZDJiYyIsInJldl9zaWciOiI0MmY0YzE0NyIsImNpZCI6ImNsaWVudC1jdGwtUGwxUmtmIn0.GFABh8znukefC_Pv5pl5z6ADP7KvQF5atisqXeEuNEyfsjForfey-cr1GMjbGdy6P9trcLy1nBEcU_DqPGxw7lJ1tZ9IaKE-_T5ZhHpSNkUWXNSIInTkVmzO5x6NfU6AAv9DJXX9jCJlf2K6O4sSqp28wxujIB6Rwn9rSx-j-ACB0OkhyDRWAkPqRDwi47vui8dqN2Zcc_BIg3Q18P9Es41sYF8iGPjSc1uyutdSu4A-6rGHPDLsfz3kcxP3WZ5cXA39H6m7LXFqXg-vNgiw0CUZYzUjJ4nh0-G0QU8S8rJ0AfALA6xhr-r8wUrz7tIpdR9FuN0-7Cl6IRdC9ivsWQ&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_id=client-worker-gYMLNT&response_type=token+id_token
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 3574
{
"access_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci1neW1sbnQubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI0ZDNjMjU4OC0wODhkLTQ5MTItOTU2ZS1kMGM5NTgwYzgyMzMiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1OMlV3cUYiLCJvcmlnaW4iOiJjdGwtcGwxcmtmIiwiaXNzIjoiaHR0cDovL3dvcmtlci1neW1sbnQubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci1nWU1MTlQiLCJhdWQiOlsib3BlbmlkIiwiY2xpZW50LXdvcmtlci1nWU1MTlQiXSwiYWN0Ijp7ImlzcyI6Imh0dHA6Ly9jdGwtcGwxcmtmLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsInN1YiI6IjhlMmFkNzczLWYzZjgtNGM1Ny04MjUzLWExMjQzOGY3YzU4YyIsInVzZXJfaWQiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1OMlV3cUYiLCJjbGllbnRfaWQiOiJjbGllbnQtd29ya2VyLWdZTUxOVCIsIm9yaWdpbiI6ImN0bC1QbDFSa2YifSwiemlkIjoid29ya2VyLWdZTUxOVCIsImlzc3VlZF90b2tlbl90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOnRva2VuLXR5cGU6YWNjZXNzX3Rva2VuIiwiZ3JhbnRfdHlwZSI6InVybjppZXRmOnBhcmFtczpvYXV0aDpncmFudC10eXBlOnRva2VuLWV4Y2hhbmdlIiwidXNlcl9pZCI6IjRkM2MyNTg4LTA4OGQtNDkxMi05NTZlLWQwYzk1ODBjODIzMyIsImF6cCI6ImNsaWVudC13b3JrZXItZ1lNTE5UIiwic2NvcGUiOlsib3BlbmlkIl0sImV4cCI6MTc2MDc1NjEzMywiaWF0IjoxNzYwNzEyOTMzLCJqdGkiOiJjYzM3NGEyZmJhZGM0NGRjODAyNDNhOWVlMTJkNWQ4NCIsImVtYWlsIjoidXNlci0zcmQtTjJVd3FGQDNyZC1OMlV3cUYub3JnIiwicmV2X3NpZyI6IjI2YmM5Y2NkIiwiY2lkIjoiY2xpZW50LXdvcmtlci1nWU1MTlQifQ.Qsza_l4KGzkYPAop0nPgBRmkRRjye91xt1KKWs3qdfvu8EQE_OxGx1YyycWUmT8eEw_WLLCCDYidcp41WElrU2xY4Ts3YaCodJDyILmQ9A0thHX5x2xuK7i9tSvHCyBsjExbdgb9DUu423TnosAqC3BuEIiKB_ppIY3-48KSKlSviBScMOwMobbDqM6DnOXs3RWSkGHowIwqHw9BSukHq2C_synS502PgDN2Nvq1JsPp7P_D4UW3x1o3KmRKKRVatQyY-CL3H1M58Kqev2-OdRVS2npXzimwyzVZM1uazGUVi7z1MuwOykrzws4ykwWqUWHvNWUmRTWwaVV8nsulpA",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci1neW1sbnQubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI0ZDNjMjU4OC0wODhkLTQ5MTItOTU2ZS1kMGM5NTgwYzgyMzMiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtTjJVd3FGIiwib3JpZ2luIjoiY3RsLXBsMXJrZiIsImlzcyI6Imh0dHA6Ly93b3JrZXItZ3ltbG50LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC13b3JrZXItZ1lNTE5UIiwiYXVkIjpbImNsaWVudC13b3JrZXItZ1lNTE5UIl0sImFjdCI6eyJpc3MiOiJodHRwOi8vY3RsLXBsMXJrZi5sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJzdWIiOiI4ZTJhZDc3My1mM2Y4LTRjNTctODI1My1hMTI0MzhmN2M1OGMiLCJ1c2VyX2lkIjoiOGUyYWQ3NzMtZjNmOC00YzU3LTgyNTMtYTEyNDM4ZjdjNThjIiwidXNlcl9uYW1lIjoidXNlci0zcmQtTjJVd3FGIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci1nWU1MTlQiLCJvcmlnaW4iOiJjdGwtUGwxUmtmIn0sInppZCI6Indvcmtlci1nWU1MTlQiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6dG9rZW4tZXhjaGFuZ2UiLCJ1c2VyX2lkIjoiNGQzYzI1ODgtMDg4ZC00OTEyLTk1NmUtZDBjOTU4MGM4MjMzIiwiYXpwIjoiY2xpZW50LXdvcmtlci1nWU1MTlQiLCJzY29wZSI6WyJvcGVuaWQiXSwiZXhwIjoxNzYwNzU2MTMzLCJpYXQiOjE3NjA3MTI5MzMsImVtYWlsIjoidXNlci0zcmQtTjJVd3FGQDNyZC1OMlV3cUYub3JnIiwianRpIjoiY2MzNzRhMmZiYWRjNDRkYzgwMjQzYTllZTEyZDVkODQiLCJyZXZfc2lnIjoiMjZiYzljY2QiLCJjaWQiOiJjbGllbnQtd29ya2VyLWdZTUxOVCJ9.eLODmQ8WHwNvP_eVn9y3zVYdykGzpEKvJBGgIspj3SjB2hFsCICGC1JL5h393mmZfMUScQnYu01NypFHKVY9Fvrott5ngmVD0WbjHjwP00CiCYErTjFWKDXz67wQEL_2NcJDiccb7itVNTcsl6Mh4JgK_zGYgB9oZmn5NkIPlL_op1ZehA-83I8ThhXOU8txnzVyovn1DC9_WvK_p6KS2TRzdR0ZsGiacdAFJ7ZRei1gfb1qhFXWdJ-0gFmg-j5E0STRngc7cDx2EmZfkzsDH1mPsmthprqn1ChTPl06_4XkJ90nnP05Ri4mVjiJiPfs67UZcOAfPznor1A-WUHVdA",
"refresh_token" : "a5e6f0e1ca6341648a535659095f07e7-r",
"expires_in" : 43199,
"scope" : "openid",
"issued_token_type" : "urn:ietf:params:oauth:token-type:access_token",
"jti" : "cc374a2fbadc44dc80243a9ee12d5d84"
}
Request Headers
Name | Description |
---|---|
Authorization |
Uses basic authorization with base64(client_id:client_secret) of the client performing the grant. Client must have urn:ietf:params:oauth:grant-type:token-exchange grant type |
Request Parameters
Parameter | Description |
---|---|
grant_type |
Must be set to urn:ietf:params:oauth:grant-type:token-exchange |
resource |
Ignored |
client_id |
Required, registed client with urn:ietf:params:oauth:grant-type:token-exchangegrant type |
audience |
Valid client_id used to impersonate/swap the identity of the calling client in the resulting token. RFC 8693. Note: The calling client must have token_exchange.impersonate.<client_id> as an an authority (client.authorities). For example token_exchange.impersonate.cf to be allowed to impersonate the cf client. |
subject_token |
Must be a valid JWT token representing the identity to be assumed in the resulting token. RFC 8693 |
subject_token_type |
Must be urn:ietf:params:oauth:token-type:access_token or urn:ietf:params:oauth:token-type:id_token. RFC 8693 |
requested_token_type |
Must be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
actor_token |
NOT YET SUPPORTED! RFC 8693 |
actor_token_type |
NOT YET SUPPORTED! RFC 8693 |
scope |
Optional parameter to limit the number of scopes in the scope claim of the access token |
response_type |
May be set to token or token id_token . The latter produces an access_token and an id_token if the scope openid is present and approved |
token_format |
May be set to opaque to retrieve revocable and non identifiable access token |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
Access token generated by this grant. RFC 8693 |
issued_token_type |
String |
Will always be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
Will always be bearer |
scope |
String |
List of scopes present in the scope claim in the access token |
expires_in |
Number |
Number of seconds before this token expires from the time of issuance |
jti |
String |
The unique token ID |
refresh_token |
String |
Refresh token issued by this grant, if the client has grant type refresh_token |
Form Client Authentication
$ curl 'http://worker-2bselh.localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC00Z2d5YzcubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtUURFODJyIiwib3JpZ2luIjoiY3RsLTRHR3ljNyIsImlzcyI6Imh0dHA6Ly9jdGwtNGdneWM3LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtNEdHeWM3IiwiYXVkIjpbImNsaWVudC1jdGwtNEdHeWM3Il0sInppZCI6ImN0bC00R0d5YzciLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJhenAiOiJjbGllbnQtY3RsLTRHR3ljNyIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzQsImlhdCI6MTc2MDcxMjkzNCwiZW1haWwiOiJ1c2VyLTNyZC1RREU4MnJAM3JkLVFERTgyci5vcmciLCJqdGkiOiIxZGM2MjY2ZWVkYTE0YmEwOGYwNWE3MjQyNmVjYzdhNyIsInJldl9zaWciOiJkYTk1YmQzMSIsImNpZCI6ImNsaWVudC1jdGwtNEdHeWM3In0.ERnb1tsXc5MfDZmla-Y7xeCoGgVk4llI1_qGTBgyULQiXjmOpYt1wRAm_pA4djhvDwhE1m3iXoGb_QtR3_4_LFPTTEy8KBNvSxbusuSo6hPiR9bvDccwIDjrM6vze5dZscTlLiymFd6f1KONyIkB87GpL4ThMkrSrXQ2XdQoiXxC2L08AUCJNR7NgGbX327PqDuX7JXn8nDyZK8OT98Vgu4dsZ7HJTT1KEzKZYORjGMAL-SrSMtOuEXd4iNZLaa-8nEXVrYaVTOX8AdltzuB3SblaZ8Le4yP_9JUn7LzsRMOsFC8y8bDq9CRUBjpZCoGfGiAumPtQXgwPqeMm8kY6A&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_id=client-worker-2BSELH&client_secret=secret&response_type=token+id_token'
POST /oauth/token HTTP/1.1
Accept: application/json
Content-Type: application/x-www-form-urlencoded
Host: worker-2bselh.localhost
Content-Length: 1601
grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC00Z2d5YzcubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtUURFODJyIiwib3JpZ2luIjoiY3RsLTRHR3ljNyIsImlzcyI6Imh0dHA6Ly9jdGwtNGdneWM3LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtNEdHeWM3IiwiYXVkIjpbImNsaWVudC1jdGwtNEdHeWM3Il0sInppZCI6ImN0bC00R0d5YzciLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJhenAiOiJjbGllbnQtY3RsLTRHR3ljNyIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzQsImlhdCI6MTc2MDcxMjkzNCwiZW1haWwiOiJ1c2VyLTNyZC1RREU4MnJAM3JkLVFERTgyci5vcmciLCJqdGkiOiIxZGM2MjY2ZWVkYTE0YmEwOGYwNWE3MjQyNmVjYzdhNyIsInJldl9zaWciOiJkYTk1YmQzMSIsImNpZCI6ImNsaWVudC1jdGwtNEdHeWM3In0.ERnb1tsXc5MfDZmla-Y7xeCoGgVk4llI1_qGTBgyULQiXjmOpYt1wRAm_pA4djhvDwhE1m3iXoGb_QtR3_4_LFPTTEy8KBNvSxbusuSo6hPiR9bvDccwIDjrM6vze5dZscTlLiymFd6f1KONyIkB87GpL4ThMkrSrXQ2XdQoiXxC2L08AUCJNR7NgGbX327PqDuX7JXn8nDyZK8OT98Vgu4dsZ7HJTT1KEzKZYORjGMAL-SrSMtOuEXd4iNZLaa-8nEXVrYaVTOX8AdltzuB3SblaZ8Le4yP_9JUn7LzsRMOsFC8y8bDq9CRUBjpZCoGfGiAumPtQXgwPqeMm8kY6A&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_id=client-worker-2BSELH&client_secret=secret&response_type=token+id_token
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 3574
{
"access_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci0yYnNlbGgubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiJlOWQ2YzQ4Ny01NDQ3LTQ1NzAtYTQwMS05MDY4NWJiYTZjYzIiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1RREU4MnIiLCJvcmlnaW4iOiJjdGwtNGdneWM3IiwiaXNzIjoiaHR0cDovL3dvcmtlci0yYnNlbGgubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci0yQlNFTEgiLCJhdWQiOlsiY2xpZW50LXdvcmtlci0yQlNFTEgiLCJvcGVuaWQiXSwiYWN0Ijp7ImlzcyI6Imh0dHA6Ly9jdGwtNGdneWM3LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsInN1YiI6IjA3MThlMjUxLTM1NTgtNDYyNS1hY2YzLTQzNTE5MDA4MjBjNSIsInVzZXJfaWQiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1RREU4MnIiLCJjbGllbnRfaWQiOiJjbGllbnQtd29ya2VyLTJCU0VMSCIsIm9yaWdpbiI6ImN0bC00R0d5YzcifSwiemlkIjoid29ya2VyLTJCU0VMSCIsImlzc3VlZF90b2tlbl90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOnRva2VuLXR5cGU6YWNjZXNzX3Rva2VuIiwiZ3JhbnRfdHlwZSI6InVybjppZXRmOnBhcmFtczpvYXV0aDpncmFudC10eXBlOnRva2VuLWV4Y2hhbmdlIiwidXNlcl9pZCI6ImU5ZDZjNDg3LTU0NDctNDU3MC1hNDAxLTkwNjg1YmJhNmNjMiIsImF6cCI6ImNsaWVudC13b3JrZXItMkJTRUxIIiwic2NvcGUiOlsib3BlbmlkIl0sImV4cCI6MTc2MDc1NjEzNCwiaWF0IjoxNzYwNzEyOTM0LCJqdGkiOiJhYTEwMTAwNGI1NzM0ODA3YjE0NzkyMmIwNDJlZTdhYSIsImVtYWlsIjoidXNlci0zcmQtUURFODJyQDNyZC1RREU4MnIub3JnIiwicmV2X3NpZyI6IjNiZWVkZmEyIiwiY2lkIjoiY2xpZW50LXdvcmtlci0yQlNFTEgifQ.dohKOuNgRhNMxMFgkOsivjlXu93SCbPqJdSe28r1SkhwHPFM_HNEo1bNxNxuAaMh9IxKwZJoOsCJ5fX6hK7shxPLfGTIVy04zNj94OeolZH5LtDZRiUWjGfhEkfVuEWxUAqoiwACG0NtdstGwNS38flzz1n7adTNKmFECYwOBH67UlJEXXhx06Xhh785-dJBHDRe8X4BInQS11JUUbEpz3s92p3XRBEGSE-pigMxtflg0fdAItFzTRXI69lvVJ3gpWymkK3SnYO7Fq_KgGOJQ8BB8PjluNXdHbOkJNNpSwZx5KG2HXT3xA7bNqxgspxpNCt_jJK74PpoLn-IAMApHg",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci0yYnNlbGgubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiJlOWQ2YzQ4Ny01NDQ3LTQ1NzAtYTQwMS05MDY4NWJiYTZjYzIiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtUURFODJyIiwib3JpZ2luIjoiY3RsLTRnZ3ljNyIsImlzcyI6Imh0dHA6Ly93b3JrZXItMmJzZWxoLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC13b3JrZXItMkJTRUxIIiwiYXVkIjpbImNsaWVudC13b3JrZXItMkJTRUxIIl0sImFjdCI6eyJpc3MiOiJodHRwOi8vY3RsLTRnZ3ljNy5sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJzdWIiOiIwNzE4ZTI1MS0zNTU4LTQ2MjUtYWNmMy00MzUxOTAwODIwYzUiLCJ1c2VyX2lkIjoiMDcxOGUyNTEtMzU1OC00NjI1LWFjZjMtNDM1MTkwMDgyMGM1IiwidXNlcl9uYW1lIjoidXNlci0zcmQtUURFODJyIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci0yQlNFTEgiLCJvcmlnaW4iOiJjdGwtNEdHeWM3In0sInppZCI6Indvcmtlci0yQlNFTEgiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6dG9rZW4tZXhjaGFuZ2UiLCJ1c2VyX2lkIjoiZTlkNmM0ODctNTQ0Ny00NTcwLWE0MDEtOTA2ODViYmE2Y2MyIiwiYXpwIjoiY2xpZW50LXdvcmtlci0yQlNFTEgiLCJzY29wZSI6WyJvcGVuaWQiXSwiZXhwIjoxNzYwNzU2MTM0LCJpYXQiOjE3NjA3MTI5MzQsImVtYWlsIjoidXNlci0zcmQtUURFODJyQDNyZC1RREU4MnIub3JnIiwianRpIjoiYWExMDEwMDRiNTczNDgwN2IxNDc5MjJiMDQyZWU3YWEiLCJyZXZfc2lnIjoiM2JlZWRmYTIiLCJjaWQiOiJjbGllbnQtd29ya2VyLTJCU0VMSCJ9.Xs4pfeJotYj_o54iWAveC_iElP2kApmqnY5toDWyj8AAFkWegucxelVi-0a-tBvvaaGYLRQf-k-ou4liMvpvcUKbs2cULa4DfeqTPrxFHFsCVC8dRnOlS7peok-L_iY7HvzOoeov-rIPUsAM4QH7AZqq2aSF8ZxN7Hj5pwEZFv6lN_tVGF5haGw7ukKKl2uWTqgeehjnM-c-xnETRKIR2ZxMVyOuXUYSCUyKxJSRYubdKktnboHjNCui904yuvDqGNca4dxKpzPnetJ2nQj2kn8M2lbBFGHohVGSjgFS3cK1GcWFYB4JpwOxwAsMxtzo84WIziucSiQm4qOGsV4ytA",
"refresh_token" : "4ae1ca7184d046a197404d41111970f0-r",
"expires_in" : 43199,
"scope" : "openid",
"issued_token_type" : "urn:ietf:params:oauth:token-type:access_token",
"jti" : "aa101004b5734807b147922b042ee7aa"
}
Request Headers
Name | Description |
---|
Request Parameters
Parameter | Description |
---|---|
grant_type |
Must be set to urn:ietf:params:oauth:grant-type:token-exchange |
resource |
Ignored |
client_id |
Required, registed client with urn:ietf:params:oauth:grant-type:token-exchangegrant type |
client_secret |
The secret passphrase configured for the OAuth client. Optional if it is passed as part of the Basic Authorization header or if client_assertion is sent as part of private_key_jwt authentication. |
audience |
Valid client_id used to impersonate/swap the identity of the calling client in the resulting token. RFC 8693. Note: The calling client must have token_exchange.impersonate.<client_id> as an an authority (client.authorities). For example token_exchange.impersonate.cf to be allowed to impersonate the cf client. |
subject_token |
Must be a valid JWT token representing the identity to be assumed in the resulting token. RFC 8693 |
subject_token_type |
Must be urn:ietf:params:oauth:token-type:access_token or urn:ietf:params:oauth:token-type:id_token. RFC 8693 |
requested_token_type |
Must be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
actor_token |
NOT YET SUPPORTED! RFC 8693 |
actor_token_type |
NOT YET SUPPORTED! RFC 8693 |
scope |
Optional parameter to limit the number of scopes in the scope claim of the access token |
response_type |
May be set to token or token id_token . The latter produces an access_token and an id_token if the scope openid is present and approved |
token_format |
May be set to opaque to retrieve revocable and non identifiable access token |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
Access token generated by this grant. RFC 8693 |
issued_token_type |
String |
Will always be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
Will always be bearer |
scope |
String |
List of scopes present in the scope claim in the access token |
expires_in |
Number |
Number of seconds before this token expires from the time of issuance |
jti |
String |
The unique token ID |
refresh_token |
String |
Refresh token issued by this grant, if the client has grant type refresh_token |
Client Assertion Authentication
$ curl 'http://worker-jiynst.localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC1nYmpia2UubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtVDVnenpUIiwib3JpZ2luIjoiY3RsLWdiamJrZSIsImlzcyI6Imh0dHA6Ly9jdGwtZ2JqYmtlLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtZ2JqYmtlIiwiYXVkIjpbImNsaWVudC1jdGwtZ2JqYmtlIl0sInppZCI6ImN0bC1nYmpia2UiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJhenAiOiJjbGllbnQtY3RsLWdiamJrZSIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzQsImlhdCI6MTc2MDcxMjkzNCwiZW1haWwiOiJ1c2VyLTNyZC1UNWd6elRAM3JkLVQ1Z3p6VC5vcmciLCJqdGkiOiIxMzk1YWJkMzg4NWM0NjBiYWY2NGNmMDI0NzlhMjIxMyIsInJldl9zaWciOiI4NzhmN2Q5MyIsImNpZCI6ImNsaWVudC1jdGwtZ2JqYmtlIn0.ecqQGpU040WdbpfVjKRTwL9kN4EsoWFHCQYXKzroGRgXvEL_D33yx1WoyTYupWtf_PLgxcrp-TV4EjuLhkpMK2v6v7rVssDWXrj9uSdo1fl8GbzYQsvrACyNNes0-Eci2L8sV711zz2Y7AABY5elkRy_s2HFp4NRe0RMTG3JzyaMBydiaXrV6cNGd7Na8BSoZgBEM2F6E4JNRndI11pAhWdf9tVBpjWKfP3d2kbvPP7zWdjQ5BniEJyGyOrsxzk1U3NP8OVF5NAyjO2XF1nbDSovPhXwY6UbQcmMWzLXSldNUJWm0sGZhn3d7xUsMcLvuMWupIUzXsZQzjGMg0dLng&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_assertion=eyJqa3UiOiJodHRwczovL3NvbWUudXJsL3Rva2VuX2tleXMiLCJraWQiOiJpZCIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJhdWQiOlsiaHR0cDovL3dvcmtlci1qaXluc3QubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIl0sInN1YiI6ImNsaWVudC13b3JrZXItaklZTnN0IiwiaXNzIjoiY2xpZW50LXdvcmtlci1qSVlOc3QiLCJyZXZvY2FibGUiOmZhbHNlLCJleHAiOjE3NjA3MTMyMzQsImlhdCI6MTc2MDcxMjgxNCwianRpIjoiZTY5YTBhZTg1NDRkNDIwMWFiMDY1ZGE5NzlmZGQ2ZjIifQ.DWQaQ9vlhkHDqr_Jhk53pp0dbLjKm8P-ikdRJZEHNFmyaVS2qNxxt7ifqiAF_s5CODIOsTqehrn5YsbjUcVdnds5Vdu7HJggs4qT3LmSNv57gzQuua3GtzAGKR8V92Q8lJ3eDjgH8vRVUgafCNPvUDo_B5h3MIfwM3Wjnpna0-4&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&response_type=token+id_token'
POST /oauth/token HTTP/1.1
Accept: application/json
Content-Type: application/x-www-form-urlencoded
Host: worker-jiynst.localhost
Content-Length: 2212
grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange&scope=openid&scope=&subject_token=eyJqa3UiOiJodHRwczovL2N0bC1nYmpia2UubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtVDVnenpUIiwib3JpZ2luIjoiY3RsLWdiamJrZSIsImlzcyI6Imh0dHA6Ly9jdGwtZ2JqYmtlLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC1jdGwtZ2JqYmtlIiwiYXVkIjpbImNsaWVudC1jdGwtZ2JqYmtlIl0sInppZCI6ImN0bC1nYmpia2UiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6and0LWJlYXJlciIsInVzZXJfaWQiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJhenAiOiJjbGllbnQtY3RsLWdiamJrZSIsInNjb3BlIjpbIm9wZW5pZCJdLCJleHAiOjE3NjA3NTYxMzQsImlhdCI6MTc2MDcxMjkzNCwiZW1haWwiOiJ1c2VyLTNyZC1UNWd6elRAM3JkLVQ1Z3p6VC5vcmciLCJqdGkiOiIxMzk1YWJkMzg4NWM0NjBiYWY2NGNmMDI0NzlhMjIxMyIsInJldl9zaWciOiI4NzhmN2Q5MyIsImNpZCI6ImNsaWVudC1jdGwtZ2JqYmtlIn0.ecqQGpU040WdbpfVjKRTwL9kN4EsoWFHCQYXKzroGRgXvEL_D33yx1WoyTYupWtf_PLgxcrp-TV4EjuLhkpMK2v6v7rVssDWXrj9uSdo1fl8GbzYQsvrACyNNes0-Eci2L8sV711zz2Y7AABY5elkRy_s2HFp4NRe0RMTG3JzyaMBydiaXrV6cNGd7Na8BSoZgBEM2F6E4JNRndI11pAhWdf9tVBpjWKfP3d2kbvPP7zWdjQ5BniEJyGyOrsxzk1U3NP8OVF5NAyjO2XF1nbDSovPhXwY6UbQcmMWzLXSldNUJWm0sGZhn3d7xUsMcLvuMWupIUzXsZQzjGMg0dLng&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aid_token&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token&audience=&token_format=jwt&client_assertion=eyJqa3UiOiJodHRwczovL3NvbWUudXJsL3Rva2VuX2tleXMiLCJraWQiOiJpZCIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJhdWQiOlsiaHR0cDovL3dvcmtlci1qaXluc3QubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIl0sInN1YiI6ImNsaWVudC13b3JrZXItaklZTnN0IiwiaXNzIjoiY2xpZW50LXdvcmtlci1qSVlOc3QiLCJyZXZvY2FibGUiOmZhbHNlLCJleHAiOjE3NjA3MTMyMzQsImlhdCI6MTc2MDcxMjgxNCwianRpIjoiZTY5YTBhZTg1NDRkNDIwMWFiMDY1ZGE5NzlmZGQ2ZjIifQ.DWQaQ9vlhkHDqr_Jhk53pp0dbLjKm8P-ikdRJZEHNFmyaVS2qNxxt7ifqiAF_s5CODIOsTqehrn5YsbjUcVdnds5Vdu7HJggs4qT3LmSNv57gzQuua3GtzAGKR8V92Q8lJ3eDjgH8vRVUgafCNPvUDo_B5h3MIfwM3Wjnpna0-4&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&response_type=token+id_token
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 3626
{
"access_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci1qaXluc3QubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI2NjI4NDk5My03YWVkLTQ1Y2QtYmI3Yy00ZDlmZWRmNWY2MTUiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1UNWd6elQiLCJvcmlnaW4iOiJjdGwtZ2JqYmtlIiwiaXNzIjoiaHR0cDovL3dvcmtlci1qaXluc3QubG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci1qSVlOc3QiLCJhdWQiOlsib3BlbmlkIiwiY2xpZW50LXdvcmtlci1qSVlOc3QiXSwiYWN0Ijp7ImlzcyI6Imh0dHA6Ly9jdGwtZ2JqYmtlLmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsInN1YiI6IjlkZjk2MjYxLWNkODEtNDlhNy1hNjU5LWQxYWI5MWNlMmQyMiIsInVzZXJfaWQiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJ1c2VyX25hbWUiOiJ1c2VyLTNyZC1UNWd6elQiLCJjbGllbnRfaWQiOiJjbGllbnQtd29ya2VyLWpJWU5zdCIsIm9yaWdpbiI6ImN0bC1nYmpia2UifSwiemlkIjoid29ya2VyLWpJWU5zdCIsImlzc3VlZF90b2tlbl90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOnRva2VuLXR5cGU6YWNjZXNzX3Rva2VuIiwiZ3JhbnRfdHlwZSI6InVybjppZXRmOnBhcmFtczpvYXV0aDpncmFudC10eXBlOnRva2VuLWV4Y2hhbmdlIiwidXNlcl9pZCI6IjY2Mjg0OTkzLTdhZWQtNDVjZC1iYjdjLTRkOWZlZGY1ZjYxNSIsImF6cCI6ImNsaWVudC13b3JrZXItaklZTnN0Iiwic2NvcGUiOlsib3BlbmlkIl0sImV4cCI6MTc2MDc1NjEzNCwiaWF0IjoxNzYwNzEyOTM0LCJqdGkiOiIzNDdhNDI0YjBmZWU0NWViYjRjOTNiYzhhOTU0YzQyOSIsImVtYWlsIjoidXNlci0zcmQtVDVnenpUQDNyZC1UNWd6elQub3JnIiwicmV2X3NpZyI6ImZmZTRmMTIyIiwiY2xpZW50X2F1dGhfbWV0aG9kIjoicHJpdmF0ZV9rZXlfand0IiwiY2lkIjoiY2xpZW50LXdvcmtlci1qSVlOc3QifQ.gb9yPzeGHyOjje_Ir53PBA6f3Fscus-xElB7H6nfKIFPNhkKWpKULcIiBJgBXk-Oc9pFve_w-dWdtrpUnT2DyZPlWFeQlYjz2fzX3YfdBbT1HJCNnv0PlFabgZgaKfF_WlECPtWLnZwBX8Azagb-D_L31R_T4kCHq2j3HRPHrnV-L2j3Nb1tHqD5lsw1ZaSQybms6Jto_NF0515eBcETz3HtegUdJtFaAsyENGXOEHMJCOG66ZJGz5fIGLngOfFJqR0zxPelvYGS6GdSjcQ-FdVxlPAxFkmaGnJet-Zv0XcbDusAi5JREpTgRc-4DmJPqEoLaYSGug4Z5MPAhZV76w",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL3dvcmtlci1qaXluc3QubG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJrZXktaWQtMSIsInR5cCI6IkpXVCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiI2NjI4NDk5My03YWVkLTQ1Y2QtYmI3Yy00ZDlmZWRmNWY2MTUiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoidXNlci0zcmQtVDVnenpUIiwib3JpZ2luIjoiY3RsLWdiamJrZSIsImlzcyI6Imh0dHA6Ly93b3JrZXItaml5bnN0LmxvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImNsaWVudC13b3JrZXItaklZTnN0IiwiYXVkIjpbImNsaWVudC13b3JrZXItaklZTnN0Il0sImFjdCI6eyJpc3MiOiJodHRwOi8vY3RsLWdiamJrZS5sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJzdWIiOiI5ZGY5NjI2MS1jZDgxLTQ5YTctYTY1OS1kMWFiOTFjZTJkMjIiLCJ1c2VyX2lkIjoiOWRmOTYyNjEtY2Q4MS00OWE3LWE2NTktZDFhYjkxY2UyZDIyIiwidXNlcl9uYW1lIjoidXNlci0zcmQtVDVnenpUIiwiY2xpZW50X2lkIjoiY2xpZW50LXdvcmtlci1qSVlOc3QiLCJvcmlnaW4iOiJjdGwtZ2JqYmtlIn0sInppZCI6Indvcmtlci1qSVlOc3QiLCJncmFudF90eXBlIjoidXJuOmlldGY6cGFyYW1zOm9hdXRoOmdyYW50LXR5cGU6dG9rZW4tZXhjaGFuZ2UiLCJ1c2VyX2lkIjoiNjYyODQ5OTMtN2FlZC00NWNkLWJiN2MtNGQ5ZmVkZjVmNjE1IiwiYXpwIjoiY2xpZW50LXdvcmtlci1qSVlOc3QiLCJzY29wZSI6WyJvcGVuaWQiXSwiZXhwIjoxNzYwNzU2MTM0LCJpYXQiOjE3NjA3MTI5MzQsImVtYWlsIjoidXNlci0zcmQtVDVnenpUQDNyZC1UNWd6elQub3JnIiwianRpIjoiMzQ3YTQyNGIwZmVlNDVlYmI0YzkzYmM4YTk1NGM0MjkiLCJyZXZfc2lnIjoiZmZlNGYxMjIiLCJjaWQiOiJjbGllbnQtd29ya2VyLWpJWU5zdCJ9.gmAsx6jqqvalPJ-kjug_xNUhzB_4R5ytZqa7l0nDNZsp0KTc2_ozaxUnH4U9_gl4cypunJmKh4zU_ta0jpcEvWXF-W5VpmLU9Lt8Ut9d4FdItPmgjdA95CUcf53AtKHT--Z72gjqSe00pUwfFY2VQpKhuVfvb3rc_chR6LKyEPdW5eL-ehRMFuCqd29r7N0027KCjPJLTscbpp1XDyNAzY87wiFGtzUzxDsYKqPhsazJAZ47cqKL114tYs7zXIQeOAr2wCNnhUHFbdWtdqgL1wDaX9o8VNsIYxWmylhz8cYNfI7Ee3qReeANd4b-hyZo9nOfxoqjfgp7gDWa2ZtAyg",
"refresh_token" : "6a2f3dbd2283487fbd1874c36623fce9-r",
"expires_in" : 43199,
"scope" : "openid",
"issued_token_type" : "urn:ietf:params:oauth:token-type:access_token",
"jti" : "347a424b0fee45ebb4c93bc8a954c429"
}
Request Headers
Name | Description |
---|
Request Parameters
Parameter | Description |
---|---|
grant_type |
Must be set to urn:ietf:params:oauth:grant-type:token-exchange |
resource |
Ignored |
client_assertion |
NOT YET SUPPORTED! UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
NOT YET SUPPORTED!UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
audience |
Valid client_id used to impersonate/swap the identity of the calling client in the resulting token. RFC 8693. Note: The calling client must have token_exchange.impersonate.<client_id> as an an authority (client.authorities). For example token_exchange.impersonate.cf to be allowed to impersonate the cf client. |
subject_token |
Must be a valid JWT token representing the identity to be assumed in the resulting token. RFC 8693 |
subject_token_type |
Must be urn:ietf:params:oauth:token-type:access_token or urn:ietf:params:oauth:token-type:id_token. RFC 8693 |
requested_token_type |
Must be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
actor_token |
NOT YET SUPPORTED! RFC 8693 |
actor_token_type |
NOT YET SUPPORTED! RFC 8693 |
scope |
Optional parameter to limit the number of scopes in the scope claim of the access token |
response_type |
May be set to token or token id_token . The latter produces an access_token and an id_token if the scope openid is present and approved |
token_format |
May be set to opaque to retrieve revocable and non identifiable access token |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
Access token generated by this grant. RFC 8693 |
issued_token_type |
String |
Will always be urn:ietf:params:oauth:token-type:access_token. RFC 8693 |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
Will always be bearer |
scope |
String |
List of scopes present in the scope claim in the access token |
expires_in |
Number |
Number of seconds before this token expires from the time of issuance |
jti |
String |
The unique token ID |
refresh_token |
String |
Refresh token issued by this grant, if the client has grant type refresh_token |
Refresh Token
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'client_id=app&client_secret=appclientsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=refresh_token&token_format=opaque&refresh_token=d1d42366cc2c46efb144a85fbe98a87f-r'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Host: localhost
Content-Length: 851
client_id=app&client_secret=appclientsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=refresh_token&token_format=opaque&refresh_token=d1d42366cc2c46efb144a85fbe98a87f-r
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1428
{
"access_token" : "e9cfcfdfe400413c9d0ab37f82b487cd",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJlYjUyNmE2My0wOWQwLTRmZDEtOTQ5ZS1jNjU5ZjUyNjRjNzIiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiWFRac3ByQHRlc3Qub3JnIiwiYW1yIjpbInB3ZCJdLCJvcmlnaW4iOiJ1YWEiLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiY2xpZW50X2lkIjoiYXBwIiwiYXVkIjpbImFwcCJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoicGFzc3dvcmQiLCJ1c2VyX2lkIjoiZWI1MjZhNjMtMDlkMC00ZmQxLTk0OWUtYzY1OWY1MjY0YzcyIiwiYXpwIjoiYXBwIiwic2NvcGUiOlsib3BlbmlkIl0sImF1dGhfdGltZSI6MTc2MDcxMjkyMywiZXhwIjoxNzYwNzU2MTI0LCJpYXQiOjE3NjA3MTI5MjQsImVtYWlsIjoiWFRac3ByQHRlc3Qub3JnIiwianRpIjoiZjIwNjFkZDFhOTI1NDFjOGI1OTU5MzFjNDJjZjUyZGIiLCJyZXZfc2lnIjoiOTgwZWJhYzUiLCJjaWQiOiJhcHAifQ.McMY72kNxaU4ik1yVmnnEY_c90wwyKM6qw-Ex1lUGXy5rSpZVWIO30XlzZfhZ78VUShwGe_AfaapLK0OKgD9RTD1XyWJ2Dl77g5XLVXtl7IlB1PWw7uS4t5UnTkp7c0X-qLVAQM1JNWaSo_P8a8MOSzxI1SAyubqaJeyv2zvM7bBziYfVmAwTgwwrn2jcaIb4SOM6CCqzyTjnB3VrazpdeBFYK8q01TBTf9m18mVNsP9CYgmjcL8sUr1cABJ35DxCplGwRJl4D1M0b03UUifH-ep3I3j5844qVbGr6o8ffl8Sg-KX45oYqNeHNupPzvWCsE-c6tTPksORf2GjWK1hg",
"refresh_token" : "d1d42366cc2c46efb144a85fbe98a87f-r",
"expires_in" : 43199,
"scope" : "scim.userids cloud_controller.read password.write cloud_controller.write openid",
"jti" : "e9cfcfdfe400413c9d0ab37f82b487cd"
}
Request Parameters
Parameter | Description |
---|---|
grant_type |
the type of authentication being used to obtain the token, in this case refresh_token |
client_id |
A unique string representing the registration information provided by the client, the recipient of the token. Optional if it is passed as part of the Basic Authorization header or as part of the client_assertion. |
client_secret |
Optional and can be omitted if token before was requested using PKCE with code_challenge_method=S256 without a secret or client_assertion is used for private_key_jwt client authentication. |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
refresh_token |
the refresh_token that was returned along with the access token. |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
OpenID Connect
The token endpoint can provide an ID token as defined by OpenID Connect.
$ curl 'http://localhost/oauth/token' -i -X POST \
-H 'Accept: application/json' \
-d 'client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=authorization_code&code=_cyOZdi6F9fdxO858Qrk04bGgJ3HU06l&token_format=opaque&code_verifier=dBjftJeZ4CVP-mB92K27uhbUJU1p1r_wW1gFWFOEjXk&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf'
POST /oauth/token HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Accept: application/json
Host: localhost
Content-Length: 953
client_id=login&client_secret=loginsecret&client_assertion=eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImtpZCI6IjU4ZDU1YzUwMGNjNmI1ODM3OTYxN2UwNmU3ZGVjNmNhIn0.eyJzdWIiOiJsb2dpbiIsImlzcyI6ImxvZ2luIiwianRpIjoiNThkNTVjNTAwY2M2YjU4Mzc5NjE3ZTA2ZTdhZmZlZSIsImV4cCI6MTIzNDU2NzgsImF1ZCI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4ifQ.jwWw0OKZecd4ZjtwQ_ievqBVrh2SieqMF6vY74Oo5H6v-Ibcmumq96NLNtoUEwaAEQQOHb8MWcC8Gwi9dVQdCrtpomC86b_LKkihRBSKuqpw0udL9RMH5kgtC04ctsN0yZNifUWMP85VHn97Ual5eZ2miaBFob3H5jUe98CcBj1TSRehr64qBFYuwt9vD19q6U-ONhRt0RXBPB7ayHAOMYtb1LFIzGAiKvqWEy9f-TBPXSsETjKkAtSuM-WVWi4EhACMtSvI6iJN15f7qlverRSkGIdh1j2vPXpKKBJoRhoLw6YqbgcUC9vAr17wfa_POxaRHvh9JPty0ZXLA4XPtA&client_assertion_type=urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer&grant_type=authorization_code&code=_cyOZdi6F9fdxO858Qrk04bGgJ3HU06l&token_format=opaque&code_verifier=dBjftJeZ4CVP-mB92K27uhbUJU1p1r_wW1gFWFOEjXk&redirect_uri=http%3A%2F%2Flocalhost%2Fredirect%2Fcf
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Cache-Control: no-store
Pragma: no-cache
Content-Type: application/json
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 1376
{
"access_token" : "0d77994b2c0644f0a206259cabad4730",
"token_type" : "bearer",
"id_token" : "eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiI5YzBjMWM3Zi1kYTk0LTRjMTgtODY5ZS1lMGZmODUyMDQ3ZjYiLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwidXNlcl9uYW1lIjoiUVpuWXRXQHRlc3Qub3JnIiwib3JpZ2luIjoidWFhIiwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgwL3VhYS9vYXV0aC90b2tlbiIsImNsaWVudF9pZCI6ImxvZ2luIiwiYXVkIjpbImxvZ2luIl0sInppZCI6InVhYSIsImdyYW50X3R5cGUiOiJhdXRob3JpemF0aW9uX2NvZGUiLCJ1c2VyX2lkIjoiOWMwYzFjN2YtZGE5NC00YzE4LTg2OWUtZTBmZjg1MjA0N2Y2IiwiYXpwIjoibG9naW4iLCJzY29wZSI6WyJvcGVuaWQiXSwiYXV0aF90aW1lIjoxNzYwNzEyOTIyLCJleHAiOjE3NjA3NTYxMjIsImlhdCI6MTc2MDcxMjkyMiwiZW1haWwiOiJRWm5ZdFdAdGVzdC5vcmciLCJqdGkiOiIwZDc3OTk0YjJjMDY0NGYwYTIwNjI1OWNhYmFkNDczMCIsInJldl9zaWciOiIxNzJkZjhkYiIsImNpZCI6ImxvZ2luIn0.iBtELAopbtBBzMFyry1TFNwasTYeEGo0aTkmzUo3pZdZOnj7NKhlx7kWdo3r1SYOfQr6_sBXmMV3dp6TEt37rL5D95neSALQ-ZtWYm7LH1Xj4Y4-FnBcE8R66NrDJuMq6Sfn83fye1D4hzUM-L9RHnuvn1JU6hDPiBrsqAr8xRqq8W7Gs3dhOP5wo7VQTQzGaC0Vi6RZG2y-5KzmmLFwh1B0vc2-dLilSEtD9y_pOBuR1EPumpZ8R_36biUoP_A32uqjyVI0hAgG5ngm8jAHokyei-irEoT-sj85hwtA_oixaWh6RzhgJW5mK_0INPnVX3T8h5lH_liQWmrK_7b_FQ",
"refresh_token" : "f81d9b9aeb24401796579e6710473058-r",
"expires_in" : 43199,
"scope" : "openid oauth.approvals",
"jti" : "0d77994b2c0644f0a206259cabad4730"
}
Request Parameters
Parameter | Description |
---|---|
client_id |
A unique string representing the registration information provided by the client, the recipient of the token. Optional if it is passed as part of the Basic Authorization header or as part of the client_assertion. |
redirect_uri |
redirection URI to which the authorization server will send the user-agent back once access is granted (or denied) |
code |
the authorization code, obtained from /oauth/authorize , issued for the user |
grant_type |
the type of authentication being used to obtain the token, in this case authorization_code |
client_secret |
UAA 75.21.0 Optional and can be omitted if client has configured allowpublic and PKCE with code_challenge_method=S256 is used to create to code . |
client_assertion |
UAA 76.23.0 Client authentication using method private_key_jwt. Optional as replacement of methods client_secret_basic or client_secret_post using secrets. The client needs to have a valid JWT confiuration for trust to JWT in client_assertion. |
client_assertion_type |
UAA 76.23.0 RFC 7523 describes the type. Must be set to urn:ietf:params:oauth:client-assertion-type:jwt-bearer if client_assertion parameter is present. |
code_verifier |
UAA 75.5.0 PKCE Code Verifier. A code_verifier parameter must be provided if a code_challenge parameter was present in the previous call to /oauth/authorize . The code_verifier must match the used code_challenge (according to the selected code_challenge_method ) |
token_format |
Can be set to opaque to retrieve an opaque token or to jwt to retrieve a JWT token. Please refer to the Revoke Tokens endpoint doc for information about the revocability of opaque vs. jwt tokens. |
Response Fields
Path | Type | Description |
---|---|---|
access_token |
String |
An OAuth2 access token. When token_format=opaque is requested this value will be a random string that can only be validated using the UAA's /check_token or /introspect endpoints. When token_format=jwt is requested, this token will be a JSON Web Token suitable for offline validation by OAuth2 Resource Servers. |
id_token |
String |
An OpenID Connect ID token. This portion of the token response is only returned when clients are configured with the scope openid , the response_type includes id_token , and the user has granted approval to the client for the openid scope. |
token_type |
String |
The type of the access token issued. This field is mandated in RFC 6749. In the UAA, the only supported token_type is bearer . |
expires_in |
Number |
The number of seconds until the access token expires. |
scope |
String |
A space-delimited list of scopes authorized by the user for this client. This list is the intersection of the scopes configured on the client, the group memberships of the user, and the user's approvals (when autoapprove: true is not configured on the client). |
refresh_token |
String |
An OAuth2 refresh token. Clients typically use the refresh token to obtain a new access token without the need for the user to authenticate again. They do this by calling /oauth/token with grant_type=refresh_token . See here for more information. A refresh token will only be issued to clients that have refresh_token in their list of authorized_grant_types . |
jti |
String |
A globally unique identifier for this access token. This identifier is used when revoking tokens. |
Revoke tokens
Both access and refresh tokens can be passed to the /revoke
endpoint.
When the /revoke
endpoint is successfully invoked with an access token, and then when the same token is
passed to the UAA Introspect Token endpoint (/introspect
), the UAA Introspect Token endpoint
will respond with "active": false
.
If the access token is in the JWT format (as opposed to the opaque format), the server config uaa.jwt.revocable
or
the Identity Zone config config.tokenPolicy.jwtRevocable
must be set to true
for
the revocation to work. However, OAuth resource servers are not required to call the UAA Introspect
Token endpoint to validate the token. Once issued, from a security point of view, a valid access token
in the JWT format should be considered valid until its expiry. Hence, we do not recommend
relying on this endpoint to revoke access tokens in the JWT format. If the ability
to remove/limit access after the tokens are issued is important to you, we recommend the following instead:
- Ask the OAuth client to use opaque tokens only, so that the OAuth resource server is required to use the UAA Introspect Token endpoint to validate that the tokens have not been revoked.
- If the access tokens are in the JWT format, configure the access tokens to be short-lived (e.g. a few minutes), and when needed, revoke the more long-lived refresh tokens so that they may no longer be used to obtain refreshed access tokens.
When the /revoke
endpoint is successfully invoked with a refresh token,
the refresh token can no longer be used to perform the Refresh Token grant.
Refresh tokens in any format can be revoked using the "Revoke all tokens for a user" endpoint (/oauth/token/revoke/user/{userId}
),
the "Revoke all tokens for a client" endpoint (/oauth/token/revoke/client/{clientId}
), or
the "Revoke all tokens for a user and client combination" endpoint (/oauth/token/revoke/user/{userId}/client/{clientId}
).
Refresh tokens in the opaque format can be individually revoked using
the "Revoke a single token" endpoint (/oauth/token/revoke/{tokenId}
).
However, refresh tokens in the JWT format can only be individually revoked using
the "Revoke a single token" endpoint when the server config uaa.jwt.revocable
or
the Identity Zone config config.tokenPolicy.jwtRevocable
is set to true
.
Revoke all tokens for a user
$ curl 'http://localhost/oauth/token/revoke/user/9dd5eb29-e120-4c91-ab1c-e0c0a6c93c15' -i -X GET \
-H 'Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiY2xpZW50X2lkIjoiYWRtaW4iLCJhdWQiOlsic2NpbSIsImNsaWVudHMiLCJ1YWEiLCJhZG1pbiJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoiYWRtaW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiZXhwIjoxNzYwNzU2MTI0LCJpYXQiOjE3NjA3MTI5MjQsImp0aSI6IjAwMWFiMmM0YzYwYzQ4OTQ4YmFhNjJlYjYyNGQ0MWViIiwicmV2X3NpZyI6IjY1MWE3YmYxIiwiY2lkIjoiYWRtaW4ifQ.oihRjBhTFdZsuZbtTXgrKRklgV_B6GA4cZZSNLkuDgMTI_P354L4Aa_XPjwiQnFsNkHLKP2v07NBzo8xXFTWkkJY43guYdCfql-XoJpGwqdoi_8jjaAwnC0jf_uYX1Z8imTgPkC4S51UKuuwYKFSYovdx8JZnoohNnbyszMECgIQMEIYOGSDYmGLMdXy2OsZGMVcHesuSVQikKePytudo83Jj6lQAOs9w71nsHiHsIDoqjsYAd3F0SLwJGMIIP24JCUmFTe7-PeOQlpxAlYJKPLf4YlrebwnNs-TKgusWCKO1ppOYgtquuGlk9fvyc3qwoJJhXJSc3rsHFmdqLboPA'
GET /oauth/token/revoke/user/9dd5eb29-e120-4c91-ab1c-e0c0a6c93c15 HTTP/1.1
Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiY2xpZW50X2lkIjoiYWRtaW4iLCJhdWQiOlsic2NpbSIsImNsaWVudHMiLCJ1YWEiLCJhZG1pbiJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoiYWRtaW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiZXhwIjoxNzYwNzU2MTI0LCJpYXQiOjE3NjA3MTI5MjQsImp0aSI6IjAwMWFiMmM0YzYwYzQ4OTQ4YmFhNjJlYjYyNGQ0MWViIiwicmV2X3NpZyI6IjY1MWE3YmYxIiwiY2lkIjoiYWRtaW4ifQ.oihRjBhTFdZsuZbtTXgrKRklgV_B6GA4cZZSNLkuDgMTI_P354L4Aa_XPjwiQnFsNkHLKP2v07NBzo8xXFTWkkJY43guYdCfql-XoJpGwqdoi_8jjaAwnC0jf_uYX1Z8imTgPkC4S51UKuuwYKFSYovdx8JZnoohNnbyszMECgIQMEIYOGSDYmGLMdXy2OsZGMVcHesuSVQikKePytudo83Jj6lQAOs9w71nsHiHsIDoqjsYAd3F0SLwJGMIIP24JCUmFTe7-PeOQlpxAlYJKPLf4YlrebwnNs-TKgusWCKO1ppOYgtquuGlk9fvyc3qwoJJhXJSc3rsHFmdqLboPA
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Path Parameters
/oauth/token/revoke/user/{userId}
Parameter | Description |
---|---|
userId | The id of the user |
Request Header
Name | Description |
---|---|
Authorization |
Bearer token with one of: uaa.admin scope OR tokens.revoke scope OR matching user_id |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Revoke all tokens for a client
$ curl 'http://localhost/oauth/token/revoke/client/2VzHfC' -i -X GET \
-H 'Authorization: Bearer c40005f0da264f17af9f87f186d93519'
GET /oauth/token/revoke/client/2VzHfC HTTP/1.1
Authorization: Bearer c40005f0da264f17af9f87f186d93519
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Path Parameters
/oauth/token/revoke/client/{clientId}
Parameter | Description |
---|---|
clientId | The id of the client |
Request Header
Name | Description |
---|---|
Authorization |
Bearer token with uaa.admin or tokens.revoke scope. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Revoke all tokens for a user and client combination
$ curl 'http://localhost/oauth/token/revoke/user/7b0e2ecb-4939-4464-a81a-47b9de156098/client/t9mUPJ' -i -X GET \
-H 'Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiY2xpZW50X2lkIjoiYWRtaW4iLCJhdWQiOlsic2NpbSIsImNsaWVudHMiLCJ1YWEiLCJhZG1pbiJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoiYWRtaW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiZXhwIjoxNzYwNzU2MTIyLCJpYXQiOjE3NjA3MTI5MjIsImp0aSI6IjQyZTRkMmExMzM2NjRhMGVhMDdkYzY2ODVlODZiZWI4IiwicmV2X3NpZyI6IjY1MWE3YmYxIiwiY2lkIjoiYWRtaW4ifQ.dEDAEhP3gHklJEviLmzX7NouhwpZxwUFGBn9I82rkVVFyuA5qwa_kDBs2kkol_Gu6fmM61NuDiJ8dCU9iSbgUZgeyKlYV379R5rL4nkkoeiVU4JxpTiu4KPwRMD502JIcvPWPPzEEDhXtKOVFchhc0SvXPsMmD2BXONg3XfEGB-ApTR2CYgtC9drz1s0sfvqWIRHmC7YSIgogBMQAYX6kvRz-BJ0dKmLYzGJ--_XSfl949FP-ckswI4-9LPksCsP_wizTWKbaznYLIk5Wn2BS1oFjNLjlng6r6W7BUVzSwsmMmjDHNwWYpjOHtAQGzFBQbpJ9E64pqq6bIOW8uwblw'
GET /oauth/token/revoke/user/7b0e2ecb-4939-4464-a81a-47b9de156098/client/t9mUPJ HTTP/1.1
Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiY2xpZW50X2lkIjoiYWRtaW4iLCJhdWQiOlsic2NpbSIsImNsaWVudHMiLCJ1YWEiLCJhZG1pbiJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoiYWRtaW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJjbGllbnRzLnNlY3JldCIsImNsaWVudHMudHJ1c3QiLCJjbGllbnRzLndyaXRlIiwidWFhLmFkbWluIiwiY2xpZW50cy5hZG1pbiIsInNjaW0ud3JpdGUiLCJzY2ltLnJlYWQiXSwiZXhwIjoxNzYwNzU2MTIyLCJpYXQiOjE3NjA3MTI5MjIsImp0aSI6IjQyZTRkMmExMzM2NjRhMGVhMDdkYzY2ODVlODZiZWI4IiwicmV2X3NpZyI6IjY1MWE3YmYxIiwiY2lkIjoiYWRtaW4ifQ.dEDAEhP3gHklJEviLmzX7NouhwpZxwUFGBn9I82rkVVFyuA5qwa_kDBs2kkol_Gu6fmM61NuDiJ8dCU9iSbgUZgeyKlYV379R5rL4nkkoeiVU4JxpTiu4KPwRMD502JIcvPWPPzEEDhXtKOVFchhc0SvXPsMmD2BXONg3XfEGB-ApTR2CYgtC9drz1s0sfvqWIRHmC7YSIgogBMQAYX6kvRz-BJ0dKmLYzGJ--_XSfl949FP-ckswI4-9LPksCsP_wizTWKbaznYLIk5Wn2BS1oFjNLjlng6r6W7BUVzSwsmMmjDHNwWYpjOHtAQGzFBQbpJ9E64pqq6bIOW8uwblw
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Path Parameters
/oauth/token/revoke/user/{userId}/client/{clientId}
Parameter | Description |
---|---|
userId | The id of the user |
clientId | The id of the client |
Request Header
Name | Description |
---|---|
Authorization |
Bearer token with one of: uaa.admin scope OR tokens.revoke scope OR (matching user_id AND client_id ) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Revoke a single token
$ curl 'http://localhost/oauth/token/revoke/72129f7f43a14fb58cac8b8f45a61ee0' -i -X DELETE \
-H 'Authorization: Bearer 72129f7f43a14fb58cac8b8f45a61ee0'
DELETE /oauth/token/revoke/72129f7f43a14fb58cac8b8f45a61ee0 HTTP/1.1
Authorization: Bearer 72129f7f43a14fb58cac8b8f45a61ee0
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Path Parameters
/oauth/token/revoke/{tokenId}
Parameter | Description |
---|---|
tokenId | The identifier for the token to be revoked. For opaque tokens, use the token itself. For JWT tokens use the jti claim in the token. |
Request Header
Name | Description |
---|---|
Authorization |
Bearer token with one of: uaa.admin scope OR tokens.revoke scope OR the token ID to be revoked |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
List tokens
List all tokens for a user
The /oauth/token/list/user/{userId}
will return all the metadata for tokens that match the user_id in the path parameter.
This token requires the tokens.list
scope.
$ curl 'http://localhost/oauth/token/list/user/4bbe1567-99a9-4721-88ca-a0a8335210c3' -i -X GET \
-H 'Authorization: Bearer 31a9156f90034a94832ddbdf44298ff4' \
-H 'Accept: application/json'
GET /oauth/token/list/user/4bbe1567-99a9-4721-88ca-a0a8335210c3 HTTP/1.1
Authorization: Bearer 31a9156f90034a94832ddbdf44298ff4
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 631
[ {
"tokenId" : "a107de508aa24af49153cc632eaa3e65",
"clientId" : "05iEw0",
"userId" : "4bbe1567-99a9-4721-88ca-a0a8335210c3",
"format" : "opaque",
"responseType" : "ACCESS_TOKEN",
"issuedAt" : 1760712924833,
"expiresAt" : 1760756124824,
"scope" : "[openid]",
"value" : null,
"zoneId" : "uaa"
}, {
"tokenId" : "932acf2a7aff45828f1f6370865ca951-r",
"clientId" : "05iEw0",
"userId" : "4bbe1567-99a9-4721-88ca-a0a8335210c3",
"format" : "opaque",
"responseType" : "REFRESH_TOKEN",
"issuedAt" : 1760712924833,
"expiresAt" : 1763304924820,
"scope" : "[openid]",
"value" : null,
"zoneId" : "uaa"
} ]
Request Header
Name | Description |
---|---|
Authorization |
Bearer token containing the tokens.list scope. |
Accept |
Set to application/json |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Path Parameters
/oauth/token/list/user/{userId}
Parameter | Description |
---|---|
userId | The user ID to retrieve tokens for |
Response Fields
Path | Type | Description |
---|---|---|
[].zoneId |
String |
The zone ID for the token |
[].tokenId |
String |
The unique ID for the token |
[].clientId |
String |
Client ID for this token, will always match the client_id claim in the access token used for this call |
[].userId |
String |
User ID for this token, will always match the user_id claim in the access token used for this call |
[].format |
String |
What format was requested, possible values OPAQUE or JWT |
[].expiresAt |
Number |
Token expiration date, as a epoch timestamp, in milliseconds between the expires time and midnight, January 1, 1970 UTC. |
[].issuedAt |
Number |
Token issue date as, a epoch timestamp, in milliseconds between the issued time and midnight, January 1, 1970 UTC. |
[].scope |
String |
Comma separated list of scopes this token holds, up to 1000 characters |
[].responseType |
String |
Response type requested during the token request, possible values ACCESS_TOKEN or REFRESH_TOKEN |
[].value |
String |
Access token value will always be null |
List all tokens for a client
The /oauth/token/list/client/{clientId}
will return all the tokens that match the client_id in the path parameter.
This token requires the tokens.list
scope.
$ curl 'http://localhost/oauth/token/list/client/j1Atwr' -i -X GET \
-H 'Authorization: Bearer f0cfd5238fcf4a21b0a14de5bc42bb81' \
-H 'Accept: application/json'
GET /oauth/token/list/client/j1Atwr HTTP/1.1
Authorization: Bearer f0cfd5238fcf4a21b0a14de5bc42bb81
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 286
[ {
"tokenId" : "f0cfd5238fcf4a21b0a14de5bc42bb81",
"clientId" : "j1Atwr",
"userId" : null,
"format" : "opaque",
"responseType" : "ACCESS_TOKEN",
"issuedAt" : 1760712924508,
"expiresAt" : 1760756124499,
"scope" : "[tokens.list]",
"value" : null,
"zoneId" : "uaa"
} ]
Request Header
Name | Description |
---|---|
Authorization |
Bearer token containing the tokens.list scope. |
Accept |
Set to application/json |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Path Parameters
/oauth/token/list/client/{clientId}
Parameter | Description |
---|---|
clientId | The client ID to retrieve tokens for |
Response Fields
Path | Type | Description |
---|---|---|
[].zoneId |
String |
The zone ID for the token |
[].tokenId |
String |
The unique ID for the token |
[].clientId |
String |
Client ID for this token, will always match the client_id claim in the access token used for this call |
[].userId |
String |
User ID for this token, will always match the user_id claim in the access token used for this call |
[].format |
String |
What format was requested, possible values OPAQUE or JWT |
[].expiresAt |
Number |
Token expiration date, as a epoch timestamp, in milliseconds between the expires time and midnight, January 1, 1970 UTC. |
[].issuedAt |
Number |
Token issue date as, a epoch timestamp, in milliseconds between the issued time and midnight, January 1, 1970 UTC. |
[].scope |
String |
Comma separated list of scopes this token holds, up to 1000 characters |
[].responseType |
String |
Response type requested during the token request, possible values ACCESS_TOKEN or REFRESH_TOKEN |
[].value |
String |
Access token value will always be null |
Introspect Token
Introspect token endpoint is RFC-7662 compliant. Active flag is responsible for showing the validity of the token and not the HTTP status code. Status code will be 200 OK for both valid and invalid tokens.
$ curl 'http://localhost/introspect' -i -X POST \
-H 'Authorization: bearer 48f770f13c3940a2ba02418813c0a1f3' \
-d 'token=740e29e980864e5bbdf8a0f2425e2ad9'
POST /introspect HTTP/1.1
Authorization: bearer 48f770f13c3940a2ba02418813c0a1f3
Content-Type: application/x-www-form-urlencoded
Host: localhost
Content-Length: 38
token=740e29e980864e5bbdf8a0f2425e2ad9
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 706
{
"user_id" : "11b0b1b5-21be-4375-b99c-43f16159e723",
"user_name" : "marissa",
"email" : "[email protected]",
"client_id" : "app",
"exp" : 1760756131,
"scope" : [ "scim.userids", "openid", "cloud_controller.read", "password.write", "cloud_controller.write" ],
"jti" : "740e29e980864e5bbdf8a0f2425e2ad9",
"aud" : [ "app", "scim", "cloud_controller", "password", "openid" ],
"sub" : "11b0b1b5-21be-4375-b99c-43f16159e723",
"iss" : "http://localhost:8080/uaa/oauth/token",
"iat" : 1760712931,
"cid" : "app",
"grant_type" : "password",
"azp" : "app",
"auth_time" : 1760712931,
"zid" : "uaa",
"rev_sig" : "1f8fd9e8",
"origin" : "uaa",
"revocable" : true,
"active" : true
}
Request Headers
Name | Description |
---|---|
Authorization |
One of the following authentication/authorization mechanisms:
|
Request Parameters
Parameter | Description |
---|---|
token |
The token |
Response Fields
Path | Type | Description |
---|---|---|
active |
Boolean |
Indicates whether or not the presented token is currently valid (given token has been issued by this authorization server, has not been revoked by the resource owner, and is within its given time window of validity) |
user_id |
String |
Only applicable for user tokens |
user_name |
String |
Only applicable for user tokens |
email |
String |
Only applicable for user tokens |
client_id |
String |
A unique string representing the registration information provided by the client |
exp |
Number |
Expiration Time Claim |
authorities |
Array |
Only applicable for client tokens |
scope |
Array |
List of scopes authorized by the user for this client |
jti |
String |
JWT ID Claim |
aud |
Array |
Audience Claim |
sub |
String |
Subject Claim |
iss |
String |
Issuer Claim |
iat |
Number |
Issued At Claim |
cid |
String |
See client_id |
grant_type |
String |
The type of authentication being used to obtain the token, in this case password |
azp |
String |
Authorized party |
auth_time |
Number |
Only applicable for user tokens |
zid |
String |
Zone ID |
rev_sig |
String |
Revocation Signature - token revocation hash salted with at least client ID and client secret, and optionally various user values. |
origin |
String |
Only applicable for user tokens |
revocable |
Boolean |
Set to true if this token is revocable |
Check Token
$ curl 'http://localhost/check_token' -i -u 'app:appclientsecret' -X POST \
-d 'token=68639434fb1043e68f321267db4d832c&scopes=password.write%2Cscim.userids'
POST /check_token HTTP/1.1
Authorization: Basic YXBwOmFwcGNsaWVudHNlY3JldA==
Content-Type: application/x-www-form-urlencoded
Host: localhost
Content-Length: 75
token=68639434fb1043e68f321267db4d832c&scopes=password.write%2Cscim.userids
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 687
{
"user_id" : "86be4950-a613-4e6b-a8cf-ff9aa777cc7f",
"user_name" : "marissa",
"email" : "[email protected]",
"client_id" : "app",
"exp" : 1760756131,
"scope" : [ "scim.userids", "openid", "cloud_controller.read", "password.write", "cloud_controller.write" ],
"jti" : "68639434fb1043e68f321267db4d832c",
"aud" : [ "app", "scim", "cloud_controller", "password", "openid" ],
"sub" : "86be4950-a613-4e6b-a8cf-ff9aa777cc7f",
"iss" : "http://localhost:8080/uaa/oauth/token",
"iat" : 1760712931,
"cid" : "app",
"grant_type" : "password",
"azp" : "app",
"auth_time" : 1760712931,
"zid" : "uaa",
"rev_sig" : "38bcdb20",
"origin" : "uaa",
"revocable" : true
}
Request Headers
Name | Description |
---|---|
Authorization |
Uses basic authorization with base64(resource_server:shared_secret) assuming the caller (a resource server) is actually also a registered client and has uaa.resource authority |
Request Parameters
Parameter | Description |
---|---|
token |
The token |
scopes |
String of comma-separated scopes, for checking presence of scopes on the token |
Response Fields
Path | Type | Description |
---|---|---|
user_id |
String |
Only applicable for user tokens |
user_name |
String |
Only applicable for user tokens |
email |
String |
Only applicable for user tokens |
client_id |
String |
A unique string representing the registration information provided by the client |
exp |
Number |
Expiration Time Claim |
authorities |
Array |
Only applicable for client tokens |
scope |
Array |
List of scopes authorized by the user for this client |
jti |
String |
JWT ID Claim |
aud |
Array |
Audience Claim |
sub |
String |
Subject Claim |
iss |
String |
Issuer Claim |
iat |
Number |
Issued At Claim |
cid |
String |
See client_id |
grant_type |
String |
The type of authentication being used to obtain the token, in this case password |
azp |
String |
Authorized party |
auth_time |
Number |
Only applicable for user tokens |
zid |
String |
Zone ID |
rev_sig |
String |
Revocation Signature - token revocation hash salted with at least client ID and client secret, and optionally various user values. |
origin |
String |
Only applicable for user tokens |
revocable |
Boolean |
Set to true if this token is revocable |
Token Key(s)
Token Key
An endpoint which returns the JSON Web Token (JWT) key, used by the UAA to sign JWT access tokens, and to be used by authorized clients to verify that a token came from the UAA. The key is in JSON Web Key format. For complete information about JSON Web Keys, see RFC 7517. In the case when the token key is symmetric, signer key and verifier key are the same, then this call is authenticated with client credentials using the HTTP Basic method.
JWT signing keys are specified via the identity zone configuration (see /identity-zones). An identity zone token policy can be configured with multiple keys for purposes of key rotation. When adding a new key, set its ID as the activeKeyId
to use it to sign all new tokens. /introspect will continue to verify tokens signed with the previous signing key for as long as it is present in the keys
of the identity zone's token policy. Remove it to invalidate all those tokens.
Asymmetric
$ curl 'http://localhost/token_key' -i -X GET \
-H 'Accept: application/json' \
-H 'If-None-Match: 1501570800000'
GET /token_key HTTP/1.1
Accept: application/json
If-None-Match: 1501570800000
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1760712934758"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 920
{
"kty" : "RSA",
"e" : "AQAB",
"use" : "sig",
"kid" : "testKey",
"alg" : "RS256",
"value" : "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0m59l2u9iDnMbrXHfqkO\nrn2dVQ3vfBJqcDuFUK03d+1PZGbVlNCqnkpIJ8syFppW8ljnWweP7+LiWpRoz0I7\nfYb3d8TjhV86Y997Fl4DBrxgM6KTJOuE/uxnoDhZQ14LgOU2ckXjOzOdTsnGMKQB\nLCl0vpcXBtFLMaSbpv1ozi8h7DJyVZ6EnFQZUWGdgTMhDrmqevfx95U/16c5WBDO\nkqwIn7Glry9n9Suxygbf8g5AzpWcusZgDLIIZ7JTUldBb8qU2a0Dl4mvLZOn4wPo\njfj9Cw2QICsc5+Pwf21fP+hzf+1WSRHbnYv8uanRO0gZ8ekGaghM/2H6gqJbo2nI\nJwIDAQAB\n-----END PUBLIC KEY-----",
"n" : "0m59l2u9iDnMbrXHfqkOrn2dVQ3vfBJqcDuFUK03d-1PZGbVlNCqnkpIJ8syFppW8ljnWweP7-LiWpRoz0I7fYb3d8TjhV86Y997Fl4DBrxgM6KTJOuE_uxnoDhZQ14LgOU2ckXjOzOdTsnGMKQBLCl0vpcXBtFLMaSbpv1ozi8h7DJyVZ6EnFQZUWGdgTMhDrmqevfx95U_16c5WBDOkqwIn7Glry9n9Suxygbf8g5AzpWcusZgDLIIZ7JTUldBb8qU2a0Dl4mvLZOn4wPojfj9Cw2QICsc5-Pwf21fP-hzf-1WSRHbnYv8uanRO0gZ8ekGaghM_2H6gqJbo2nIJw"
}
Request Headers
Name | Description |
---|---|
If-None-Match |
Optional. See Ref: RFC 2616 |
Response Headers
Name | Description |
---|---|
ETag |
The ETag version of the resource - used to decide if the client's version of the resource is already up to date. The UAA will set the ETag value to the epoch time in milliseconds of the last zone configuration change. |
Response Fields
Path | Type | Description |
---|---|---|
kid |
String |
Key ID of key to be used for verification of the token. |
alg |
String |
Encryption algorithm |
value |
String |
Verifier key |
kty |
String |
Key type (RSA) |
use |
String |
Public key use parameter - identifies intended use of the public key. (defaults to "sig") |
n |
String |
RSA key modulus |
e |
String |
RSA key public exponent |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Unregistered client or incorrect client secret |
Symmetric
$ curl 'http://localhost/token_key' -i -u 'app:appclientsecret' -X GET \
-H 'Accept: application/json' \
-H 'If-None-Match: 1501570800000'
GET /token_key HTTP/1.1
Accept: application/json
Authorization: Basic YXBwOmFwcGNsaWVudHNlY3JldA==
If-None-Match: 1501570800000
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1760712934725"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 95
{
"kty" : "MAC",
"alg" : "HS256",
"value" : "key",
"use" : "sig",
"kid" : "testKey"
}
Request Headers
Name | Description |
---|---|
Authorization |
Uses basic authorization with base64(resource_server:shared_secret) assuming the caller (a resource server) is actually also a registered client and has uaa.resource authority |
If-None-Match |
Optional. See Ref: RFC 2616 |
Response Fields
Path | Type | Description |
---|---|---|
kid |
String |
Key ID of key to be used for verification of the token. |
alg |
String |
Encryption algorithm |
value |
String |
Verifier key |
kty |
String |
Key type (MAC) |
use |
String |
Public key use parameter - identifies intended use of the public key. (defaults to "sig") |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Unregistered client or incorrect client secret |
403 | Forbidden - Not a resource server (missing uaa.resource scope) |
Token Keys
An endpoint which returns the list of JWT keys. To support key rotation, this list specifies the IDs of all currently valid keys. JWT tokens issued by the UAA contain a kid
field, indicating which key should be used for verification of the token.
$ curl 'http://localhost/token_keys' -i -u 'app:appclientsecret' -X GET \
-H 'Accept: application/json' \
-H 'If-None-Match: 1501570800000'
GET /token_keys HTTP/1.1
Accept: application/json
Authorization: Basic YXBwOmFwcGNsaWVudHNlY3JldA==
If-None-Match: 1501570800000
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1760712934684"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 955
{
"keys" : [ {
"kty" : "RSA",
"e" : "AQAB",
"use" : "sig",
"kid" : "testKey",
"alg" : "RS256",
"value" : "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0m59l2u9iDnMbrXHfqkO\nrn2dVQ3vfBJqcDuFUK03d+1PZGbVlNCqnkpIJ8syFppW8ljnWweP7+LiWpRoz0I7\nfYb3d8TjhV86Y997Fl4DBrxgM6KTJOuE/uxnoDhZQ14LgOU2ckXjOzOdTsnGMKQB\nLCl0vpcXBtFLMaSbpv1ozi8h7DJyVZ6EnFQZUWGdgTMhDrmqevfx95U/16c5WBDO\nkqwIn7Glry9n9Suxygbf8g5AzpWcusZgDLIIZ7JTUldBb8qU2a0Dl4mvLZOn4wPo\njfj9Cw2QICsc5+Pwf21fP+hzf+1WSRHbnYv8uanRO0gZ8ekGaghM/2H6gqJbo2nI\nJwIDAQAB\n-----END PUBLIC KEY-----",
"n" : "0m59l2u9iDnMbrXHfqkOrn2dVQ3vfBJqcDuFUK03d-1PZGbVlNCqnkpIJ8syFppW8ljnWweP7-LiWpRoz0I7fYb3d8TjhV86Y997Fl4DBrxgM6KTJOuE_uxnoDhZQ14LgOU2ckXjOzOdTsnGMKQBLCl0vpcXBtFLMaSbpv1ozi8h7DJyVZ6EnFQZUWGdgTMhDrmqevfx95U_16c5WBDOkqwIn7Glry9n9Suxygbf8g5AzpWcusZgDLIIZ7JTUldBb8qU2a0Dl4mvLZOn4wPojfj9Cw2QICsc5-Pwf21fP-hzf-1WSRHbnYv8uanRO0gZ8ekGaghM_2H6gqJbo2nIJw"
} ]
}
Request Headers
Name | Description |
---|---|
Authorization |
No authorization is required for requesting public keys. |
If-None-Match |
Optional. See Ref: RFC 2616 |
Response Headers
Name | Description |
---|---|
ETag |
The ETag version of the resource - used to decide if the client's version of the resource is already up to date. The UAA will set the ETag value to the epoch time in milliseconds of the last zone configuration change. |
Response Fields
Path | Type | Description |
---|---|---|
keys.[].kid |
String |
Key ID of key to be used for verification of the token. |
keys.[].alg |
String |
Encryption algorithm |
keys.[].value |
String |
Verifier key |
keys.[].kty |
String |
Key type (RSA or MAC) |
keys.[].use |
String |
Public key use parameter - identifies intended use of the public key. (defaults to "sig") |
keys.[].n |
String |
RSA key modulus |
keys.[].e |
String |
RSA key public exponent |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Unregistered client or incorrect client secret |
Session Management
Logout.do
The logout endpoint is meant to be used by applications to log the user out of the UAA session. UAA will only log a user out of the UAA session if they also hit this endpoint, and may also perform Single Logout with SAML providers if configured to do so. UAA may also log users out of OIDC proxied authenticated sessions based on OpenID Connect Session Management if configured to do so. The recommendation for application authors is to:
- provide a local logout feature specific to the client application and use that to clear state in the client
- as part of the logout redirect to the logout endpoint using their client ID
- provide a redirect param in the link to the logout success page of their application so that the user come back to a familiar place when logged out
- add the logout success page to the client's redirect_uri (or rather post_logout_redirect_uri) configuration to whitelist the URL
If the chosen redirect URI is not whitelisted, users will land on the UAA login page. This is a security feature intended to prevent open redirects as per RFC 6749.
$ curl 'http://localhost/logout.do?redirect=http%3A%2F%2Fredirect.localhost&client_id=some_client_that_contains_redirect_uri_matching_request_param&post_logout_redirect_uri=http%3A%2F%2Fredirect.localhost&id_token_hint=eyJhbGciOiJSUzI1NiIsImprdSI6Imh0dHBzOi8vbG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJsZWdhY3ktdG9rZW4ta2V5IiwidHlwIjoiSldUIn0.eyJzdWIiOiJhMGZlMGQ4OS1lZTJjLTRkMjEtYjFjMS0yNTQ2MzZjNzAxMTUiLCJhdWQiOlsic29tZV9jbGllbnRfdGhhdF9jb250YWluc19yZWRpcmVjdF91cmlfbWF0Y2hpbmdfcmVxdWVzdF9wYXJhbSJdLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiYXpwIjoic29tZV9jbGllbnRfdGhhdF9jb250YWluc19yZWRpcmVjdF91cmlfbWF0Y2hpbmdfcmVxdWVzdF9wYXJhbSJ9.efdaWKPkFlgXyaHeQPGgIBAhiJgfcRScVbmuVWu-aUVCZsPnhjCcJQfxcXn61yKSbs8y5Pze3PkSCZdnyh_TvjHtqGBAvTRHuC3ZEDv7tZMQd3reyiS3pLCmn0OSwLB5-Ni4-_DDOcrVy-kOF4yU8rHXiXhGtcFZWpTShvXQgm_WNFKA-kHUOxzl4bQE5S2EnJUB7i1yUMYgaWnhYGzxcIm94AuYrD3OW2D2DFkEqJnQCYUIH6h3iNs_ABHs-O2JUtz12IRVLJCrmTssF-KRBfv_dIwLxSMgK3hI0i9yYZt_pbLbshNkeu32iZgvstSGZeoYbzpZq3mGp9M1CMtvvQ' -i -X GET
GET /logout.do?redirect=http%3A%2F%2Fredirect.localhost&client_id=some_client_that_contains_redirect_uri_matching_request_param&post_logout_redirect_uri=http%3A%2F%2Fredirect.localhost&id_token_hint=eyJhbGciOiJSUzI1NiIsImprdSI6Imh0dHBzOi8vbG9jYWxob3N0OjgwODAvdWFhL3Rva2VuX2tleXMiLCJraWQiOiJsZWdhY3ktdG9rZW4ta2V5IiwidHlwIjoiSldUIn0.eyJzdWIiOiJhMGZlMGQ4OS1lZTJjLTRkMjEtYjFjMS0yNTQ2MzZjNzAxMTUiLCJhdWQiOlsic29tZV9jbGllbnRfdGhhdF9jb250YWluc19yZWRpcmVjdF91cmlfbWF0Y2hpbmdfcmVxdWVzdF9wYXJhbSJdLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvdWFhL29hdXRoL3Rva2VuIiwiYXpwIjoic29tZV9jbGllbnRfdGhhdF9jb250YWluc19yZWRpcmVjdF91cmlfbWF0Y2hpbmdfcmVxdWVzdF9wYXJhbSJ9.efdaWKPkFlgXyaHeQPGgIBAhiJgfcRScVbmuVWu-aUVCZsPnhjCcJQfxcXn61yKSbs8y5Pze3PkSCZdnyh_TvjHtqGBAvTRHuC3ZEDv7tZMQd3reyiS3pLCmn0OSwLB5-Ni4-_DDOcrVy-kOF4yU8rHXiXhGtcFZWpTShvXQgm_WNFKA-kHUOxzl4bQE5S2EnJUB7i1yUMYgaWnhYGzxcIm94AuYrD3OW2D2DFkEqJnQCYUIH6h3iNs_ABHs-O2JUtz12IRVLJCrmTssF-KRBfv_dIwLxSMgK3hI0i9yYZt_pbLbshNkeu32iZgvstSGZeoYbzpZq3mGp9M1CMtvvQ HTTP/1.1
Host: localhost
HTTP/1.1 302 Found
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=yH_xa1ly2DwLAMBxboxEzD; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:25 GMT; HttpOnly; SameSite=Lax
Set-Cookie: Current-User=; Path=/; Max-Age=0; Expires=Thu, 01 Jan 1970 00:00:00 GMT
Set-Cookie: X-Uaa-Csrf=DjaK0U08vkotK1V-U64pKY; Path=/; Max-Age=0; Expires=Thu, 1 Jan 1970 00:00:10 GMT; HttpOnly; SameSite=Lax
Set-Cookie: JSESSIONID=; Path=/; Max-Age=0; Expires=Thu, 01 Jan 1970 00:00:00 GMT
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Location: http://redirect.localhost
Request Parameters
Parameter | Description |
---|---|
redirect |
On a successful logout redirect the user to here, provided the URL is whitelisted |
client_id |
On a successful logout the client's redirect_uri configuration is used as the redirect uri whitelist. If this value is not provided, the identity zone whitelist will be used instead. |
post_logout_redirect_uri |
Support the parameter for OIDC applications based on OpenID Connect Session Management. |
id_token_hint |
ID token from OIDC authentication. Used to identify the oauth client redirect uri whitelist. If this value is not provided, the identity zone whitelist will be used instead.redirect uri whitelist. |
Response Headers
Name | Description |
---|---|
Location |
Redirect URI |
Identity Zones
The UAA supports multi tenancy. This is referred to as identity zones. An identity zone is accessed through a unique subdomain. If the standard UAA responds to https://uaa.10.244.0.34.xip.io a zone on this UAA would be accessed through https://testzone1.uaa.10.244.0.34.xip.io
A zone contains a unique identifier as well as a unique subdomain:
{
"id":"testzone1",
"subdomain":"testzone1",
"name":"The Twiglet Zone[testzone1]",
"version":0,
"description":"Like the Twilight Zone but tastier[testzone1].",
"created":1426258488910,
"last_modified":1426258488910
}
The UAA by default creates a default zone. This zone will always be present, the ID will always be
uaa
, and the subdomain is blank:
{
"id": "uaa",
"subdomain": "",
"name": "uaa",
"version": 0,
"description": "The system zone for backwards compatibility",
"created": 946710000000,
"last_modified": 946710000000
}
Creating an identity zone
An identity zone is created using a POST
with an IdentityZone
object. If the object contains an id, this id will be used as the identifier, otherwise an identifier will be generated. Once a zone has been created, the UAA will start accepting requests on the subdomain defined in the subdomain
field of the identity zone.
When an Identity Zone is created, an internal Identity Provider is automatically created with the default password policy.
$ curl 'http://localhost/identity-zones' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a6ff6b08633b4664be03321bb47a03f0' \
-d '{
"id" : "twiglet-create",
"subdomain" : "twiglet-create",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1",
"keys" : {
"active-key-1" : {
"signingKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"signingCert" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"signingAlg" : "RS256"
}
}
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"key" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"passphrase" : "password",
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"privateKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"privateKeyPassword" : "password"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa",
"defaultIdentityProvider" : "uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"description" : "Like the Twilight Zone but tastier.",
"created" : 1760712935404,
"active" : true,
"last_modified" : 1760712935404
}'
POST /identity-zones HTTP/1.1
Content-Type: application/json
Authorization: Bearer a6ff6b08633b4664be03321bb47a03f0
Content-Length: 7785
Host: localhost
{
"id" : "twiglet-create",
"subdomain" : "twiglet-create",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1",
"keys" : {
"active-key-1" : {
"signingKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"signingCert" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"signingAlg" : "RS256"
}
}
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"key" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"passphrase" : "password",
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"privateKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"privateKeyPassword" : "password"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa",
"defaultIdentityProvider" : "uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"description" : "Like the Twilight Zone but tastier.",
"created" : 1760712935404,
"active" : true,
"last_modified" : 1760712935404
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 5195
{
"id" : "twiglet-create",
"subdomain" : "twiglet-create",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa",
"defaultIdentityProvider" : "uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"description" : "Like the Twilight Zone but tastier.",
"created" : 1760712935417,
"active" : true,
"last_modified" : 1760712935417
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.write or uaa.admin |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
id | String | Optional | Unique ID of the identity zone |
subdomain | String | Required | Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name | String | Required | Human-readable zone name |
description | String | Optional | Description of the zone |
version | Number | Optional | Reserved for future use of E-Tag versioning |
active | Boolean | Optional | Indicates whether the identity zone is active. Defaults to true. |
config.clientSecretPolicy.minLength | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength | Number | Required when clientSecretPolicy in the config is not null |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.tokenPolicy | Object | Optional | Various fields pertaining to the JWT access and refresh tokens. |
config.tokenPolicy.activeKeyId | String | Required if config.tokenPolicy.keys are set |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.keys.*.signingKey | String | Key to be used for signing | Keys which will be used to sign the token |
config.tokenPolicy.keys.*.signingAlg | String | Optional. Can only be used in conjunction with keys.<key-id>.signingKey and keys.<key-id>.signingCert |
Algorithm parameter according to RFC7518 |
config.tokenPolicy.keys.*.signingCert | String | Optional. Can only be used in conjunction with keys.<key-id>.signingKey and keys.<key-id>.signingCert |
PEM encoded X.509 to be used in x5c, e.g. RFC7517 |
config.tokenPolicy.accessTokenValidity | Number | Optional | Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity | Number | Optional | Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable | Boolean | Optional | Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique | Boolean | Optional | If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate | Boolean | Optional | If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat | String | Optional | The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.samlConfig.disableInResponseToCheck | Boolean | Optional | If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned | Boolean | Optional | Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned | Boolean | Optional | Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID | String | Optional | Unique ID of the SAML2 entity |
config.samlConfig.certificate | String | Deprecated | Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.privateKey | String | Deprecated | Exposed SAML metadata property. The SAML provider's private key. |
config.samlConfig.privateKeyPassword | String | Deprecated | Exposed SAML metadata property. The SAML provider's private key password. Reserved for future use. |
config.samlConfig.activeKeyId | String | Required if a list of keys defined in keys map |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.key | String | Optional. Can only be used in conjunction with keys.<key-id>.passphrase and keys.<key-id>.certificate |
Exposed SAML metadata property. The SAML provider's private key. |
config.samlConfig.keys.*.passphrase | String | Optional. Can only be used in conjunction with keys.<key-id>.key and keys.<key-id>.certificate |
Exposed SAML metadata property. The SAML provider's private key password. Reserved for future use. |
config.samlConfig.keys.*.certificate | String | Optional. Can only be used in conjunction with keys.<key-id>.key and keys.<key-id>.passphrase |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.entityID | String | Optional | Unique ID of the SAML2 entity |
config.links.logout.redirectUrl | String | Optional | Logout redirect url |
config.links.homeRedirect | String | Optional | Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName | String | Optional | Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter | Boolean | Optional | Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist | Array | Optional | List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled | Boolean | Optional | Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup | Null | Optional | Where users are directed upon clicking the account creation link |
config.links.selfService.passwd | Null | Optional | Where users are directed upon clicking the password reset link |
config.prompts[] | Array | Optional | List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name | String | Optional | Name of field |
config.prompts[].type | String | Optional | What kind of field this is (e.g. text or password) |
config.prompts[].text | String | Optional | Actual text displayed on prompt for field |
config.idpDiscoveryEnabled | Boolean | Optional | IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled | Boolean | Optional | This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer | String | Optional | Issuer of this zone. Must be a valid URL. |
config.defaultIdentityProvider | String | Optional | This value can be set to the origin key of an identity provider. If set, the user will be directed to this identity provider automatically if no other identity provider is discovered or selected via login_hint. |
config.branding.companyName | String | Optional | This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo | String | Optional | This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo | String | Optional | This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText | String | Optional | This text appears on the footer of all UAA pages |
config.branding.footerLinks.* | String | Optional | These links (Map |
config.branding.banner.text | String | Optional | This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo | String | Optional | This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link | String | Optional | The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor | String | Optional | Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor | String | Optional | Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text | String | Optional. Must be set if configuring consent. | If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link | String | Optional. Can be null if configuring consent. | If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.xhrConfiguration.allowedOrigins | Array | Optional | Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns | Array | Optional | Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris | Array | Optional | The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns | Array | Optional | The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders | Array | Optional | Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods | Array | Optional | Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials | Boolean | Optional | Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge | Number | Optional | Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.defaultConfiguration.allowedOrigins | Array | Optional | Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns | Array | Optional | Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris | Array | Optional | The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns | Array | Optional | The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders | Array | Optional | Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods | Array | Optional | Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials | Boolean | Optional | Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge | Number | Optional | Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups | Array | Optional | Default groups each user in the zone inherits. |
config.userConfig.allowedGroups | Array | Optional | Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers | Number | Optional number, default -1, no limit. | Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled | Boolean | Optional | Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop | Boolean | Optional | Flag for switching off the loop over all origins in a zone (defaults to true) |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
Unique ID of the identity zone |
subdomain |
String |
Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name |
String |
Human-readable zone name |
description |
String |
Description of the zone |
version |
Number |
Reserved for future use of E-Tag versioning |
active |
Boolean |
Indicates whether the identity zone is active. Defaults to true. |
config.tokenPolicy.activeKeyId |
String |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.accessTokenValidity |
Number |
Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity |
Number |
Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable |
Boolean |
Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique |
Boolean |
If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate |
Boolean |
If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat |
String |
The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.clientSecretPolicy.minLength |
Number |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength |
Number |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter |
Number |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter |
Number |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit |
Number |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter |
Number |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.samlConfig.disableInResponseToCheck |
Boolean |
If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned |
Boolean |
Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned |
Boolean |
Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID |
String |
Unique ID of the SAML2 entity |
config.samlConfig.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.activeKeyId |
String |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.links.logout.redirectUrl |
String |
Logout redirect url |
config.links.homeRedirect |
String |
Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName |
String |
Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter |
Boolean |
Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist |
Array |
List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled |
Boolean |
Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup |
Null |
Where users are directed upon clicking the account creation link |
config.links.selfService.passwd |
Null |
Where users are directed upon clicking the password reset link |
config.prompts[] |
Array |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name |
String |
Name of field |
config.prompts[].type |
String |
What kind of field this is (e.g. text or password) |
config.prompts[].text |
String |
Actual text displayed on prompt for field |
config.defaultIdentityProvider |
String |
This value can be set to the origin key of an identity provider. If set, the user will be directed to this identity provider automatically if no other identity provider is discovered or selected via login_hint. |
config.idpDiscoveryEnabled |
Boolean |
IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled |
Boolean |
This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer |
String |
Issuer of this zone. Must be a valid URL. |
config.branding.companyName |
String |
This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo |
String |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo |
String |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText |
String |
This text appears on the footer of all UAA pages |
config.branding.footerLinks.* |
String |
These links (Map |
config.branding.banner.text |
String |
This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo |
String |
This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link |
String |
The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor |
String |
Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor |
String |
Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text |
String |
If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link |
String |
If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.defaultConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.xhrConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups |
Array |
Default groups each user in the zone inherits. |
config.userConfig.allowedGroups |
Array |
Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers |
Number |
Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled |
Boolean |
Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop |
Boolean |
Flag for switching off the loop over all origins in a zone (defaults to true) |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (Zones can only be created by being authenticated in the default zone.) |
422 | Unprocessable Entity - Invalid zone details |
Sequential example of creating a zone and creating an admin client in that zone:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac client update admin --authorities "uaa.admin,clients.read,clients.write,clients.secret,scim.read,scim.write,clients.admin,zones.testzone1.admin,zones.write"
uaac token client get admin -s adminsecret
uaac -t curl -XPOST -H"Content-Type:application/json" -H"Accept:application/json" --data '{ "id":"testzone1", "subdomain":"testzone1", "name":"The Twiglet Zone[testzone1]", "version":0, "description":"Like the Twilight Zone but tastier[testzone1]."}' /identity-zones
uaac -t curl -H"X-Identity-Zone-Id:testzone1" -XPOST -H"Content-Type:application/json" -H"Accept:application/json" --data '{ "client_id" : "admin", "client_secret" : "adminsecret", "scope" : ["uaa.none"], "resource_ids" : ["none"], "authorities" : ["uaa.admin","clients.read","clients.write","clients.secret","scim.read","scim.write","clients.admin"], "authorized_grant_types" : ["client_credentials"]}' /oauth/clients
uaac target http://testzone1.localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac token decode
Retrieving an identity zone
$ curl 'http://localhost/identity-zones/twiglet-get' -i -X GET \
-H 'Authorization: Bearer c27107d1e73c4c739e7252fcb1bfe2b0'
GET /identity-zones/twiglet-get HTTP/1.1
Authorization: Bearer c27107d1e73c4c739e7252fcb1bfe2b0
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 5093
{
"id" : "twiglet-get",
"subdomain" : "twiglet-get",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"created" : 1760712935306,
"active" : true,
"last_modified" : 1760712935306
}
Path Parameters
/identity-zones/{id}
Parameter | Description |
---|---|
id | Unique ID of the identity zone to retrieve |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.read or zones.write or uaa.admin . If you use the zone-switching header, bear token containing zones.<zone id>.admin or zones.<zone id>.read can be used. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
Unique ID of the identity zone |
subdomain |
String |
Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name |
String |
Human-readable zone name |
description |
String |
Description of the zone |
version |
Number |
Reserved for future use of E-Tag versioning |
active |
Boolean |
Indicates whether the identity zone is active. Defaults to true. |
config.tokenPolicy.activeKeyId |
String |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.accessTokenValidity |
Number |
Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity |
Number |
Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable |
Boolean |
Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique |
Boolean |
If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate |
Boolean |
If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat |
String |
The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.clientSecretPolicy.minLength |
Number |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength |
Number |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter |
Number |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter |
Number |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit |
Number |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter |
Number |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.samlConfig.disableInResponseToCheck |
Boolean |
If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned |
Boolean |
Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned |
Boolean |
Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID |
String |
Unique ID of the SAML2 entity |
config.samlConfig.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.activeKeyId |
String |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.links.logout.redirectUrl |
String |
Logout redirect url |
config.links.homeRedirect |
String |
Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName |
String |
Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter |
Boolean |
Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist |
Array |
List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled |
Boolean |
Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup |
Null |
Where users are directed upon clicking the account creation link |
config.links.selfService.passwd |
Null |
Where users are directed upon clicking the password reset link |
config.prompts[] |
Array |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name |
String |
Name of field |
config.prompts[].type |
String |
What kind of field this is (e.g. text or password) |
config.prompts[].text |
String |
Actual text displayed on prompt for field |
config.defaultIdentityProvider |
String |
This value can be set to the origin key of an identity provider. If set, the user will be directed to this identity provider automatically if no other identity provider is discovered or selected via login_hint. |
config.idpDiscoveryEnabled |
Boolean |
IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled |
Boolean |
This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer |
String |
Issuer of this zone. Must be a valid URL. |
config.branding.companyName |
String |
This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo |
String |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo |
String |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText |
String |
This text appears on the footer of all UAA pages |
config.branding.footerLinks.* |
String |
These links (Map |
config.branding.banner.text |
String |
This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo |
String |
This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link |
String |
The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor |
String |
Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor |
String |
Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text |
String |
If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link |
String |
If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.defaultConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.xhrConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups |
Array |
Default groups each user in the zone inherits. |
config.userConfig.allowedGroups |
Array |
Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers |
Number |
Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled |
Boolean |
Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop |
Boolean |
Flag for switching off the loop over all origins in a zone (defaults to true) |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope |
404 | Not Found - Zone does not exist |
Retrieving all identity zones
$ curl 'http://localhost/identity-zones' -i -X GET \
-H 'Authorization: Bearer c2132a6e028f4f87b1ef50d37d09a139'
GET /identity-zones HTTP/1.1
Authorization: Bearer c2132a6e028f4f87b1ef50d37d09a139
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 14318
[ {
"id" : "twiglet-get-1",
"subdomain" : "twiglet-get-1",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"created" : 1760712934919,
"active" : true,
"last_modified" : 1760712934919
}, {
"id" : "twiglet-get-2",
"subdomain" : "twiglet-get-2",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"created" : 1760712934958,
"active" : true,
"last_modified" : 1760712934958
}, {
"id" : "uaa",
"subdomain" : "",
"config" : {
"clientSecretPolicy" : {
"minLength" : 0,
"maxLength" : 255,
"requireUpperCaseCharacter" : 0,
"requireLowerCaseCharacter" : 0,
"requireDigit" : 0,
"requireSpecialCharacter" : 0
},
"tokenPolicy" : {
"accessTokenValidity" : 43200,
"refreshTokenValidity" : 2592000,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "key-id-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "key1",
"keys" : {
"key1" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIIDSTCCArKgAwIBAgIBADANBgkqhkiG9w0BAQQFADB8MQswCQYDVQQGEwJhdzEO\nMAwGA1UECBMFYXJ1YmExDjAMBgNVBAoTBWFydWJhMQ4wDAYDVQQHEwVhcnViYTEO\nMAwGA1UECxMFYXJ1YmExDjAMBgNVBAMTBWFydWJhMR0wGwYJKoZIhvcNAQkBFg5h\ncnViYUBhcnViYS5hcjAeFw0xNTExMjAyMjI2MjdaFw0xNjExMTkyMjI2MjdaMHwx\nCzAJBgNVBAYTAmF3MQ4wDAYDVQQIEwVhcnViYTEOMAwGA1UEChMFYXJ1YmExDjAM\nBgNVBAcTBWFydWJhMQ4wDAYDVQQLEwVhcnViYTEOMAwGA1UEAxMFYXJ1YmExHTAb\nBgkqhkiG9w0BCQEWDmFydWJhQGFydWJhLmFyMIGfMA0GCSqGSIb3DQEBAQUAA4GN\nADCBiQKBgQDHtC5gUXxBKpEqZTLkNvFwNGnNIkggNOwOQVNbpO0WVHIivig5L39W\nqS9u0hnA+O7MCA/KlrAR4bXaeVVhwfUPYBKIpaaTWFQR5cTR1UFZJL/OF9vAfpOw\nznoD66DDCnQVpbCjtDYWX+x6imxn8HCYxhMol6ZnTbSsFW6VZjFMjQIDAQABo4Ha\nMIHXMB0GA1UdDgQWBBTx0lDzjH/iOBnOSQaSEWQLx1syGDCBpwYDVR0jBIGfMIGc\ngBTx0lDzjH/iOBnOSQaSEWQLx1syGKGBgKR+MHwxCzAJBgNVBAYTAmF3MQ4wDAYD\nVQQIEwVhcnViYTEOMAwGA1UEChMFYXJ1YmExDjAMBgNVBAcTBWFydWJhMQ4wDAYD\nVQQLEwVhcnViYTEOMAwGA1UEAxMFYXJ1YmExHTAbBgkqhkiG9w0BCQEWDmFydWJh\nQGFydWJhLmFyggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEEBQADgYEAYvBJ\n0HOZbbHClXmGUjGs+GS+xC1FO/am2suCSYqNB9dyMXfOWiJ1+TLJk+o/YZt8vuxC\nKdcZYgl4l/L6PxJ982SRhc83ZW2dkAZI4M0/Ud3oePe84k8jm3A7EvH5wi5hvCkK\nRpuRBwn3Ei+jCRouxTbzKPsuCVB+1sNyxMTXzf0=\n-----END CERTIFICATE-----\n"
}
},
"disableInResponseToCheck" : false
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : [ ]
},
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code ( Get one at http://localhost:8080/uaa/passcode )"
} ],
"idpDiscoveryEnabled" : false,
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "scim.me", "cloud_controller.read", "cloud_controller.write", "cloud_controller_service_permissions.read", "password.write", "scim.userids", "uaa.user", "approvals.me", "oauth.approvals", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
}
},
"name" : "uaa",
"version" : 1,
"description" : "The system zone for backwards compatibility",
"created" : 946684800000,
"active" : true,
"last_modified" : 1760712934850
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.read or zones.write or uaa.admin . If you use the zone-switching header, bear token containing zones.<zone id>.admin can be used. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
[].id |
String |
Unique ID of the identity zone |
[].subdomain |
String |
Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
[].name |
String |
Human-readable zone name |
[].description |
String |
Description of the zone |
[].version |
Number |
Reserved for future use of E-Tag versioning |
[].active |
Boolean |
Indicates whether the identity zone is active. Defaults to true. |
[].config.tokenPolicy.activeKeyId |
Varies |
The ID for the key that is being used to sign tokens |
[].config.tokenPolicy.accessTokenValidity |
Number |
Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
[].config.tokenPolicy.refreshTokenValidity |
Number |
Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
[].config.tokenPolicy.jwtRevocable |
Boolean |
Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
[].config.tokenPolicy.refreshTokenUnique |
Boolean |
If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
[].config.tokenPolicy.refreshTokenRotate |
Boolean |
If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
[].config.tokenPolicy.refreshTokenFormat |
String |
The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
[].config.clientSecretPolicy.minLength |
Number |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
[].config.clientSecretPolicy.maxLength |
Number |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
[].config.clientSecretPolicy.requireUpperCaseCharacter |
Number |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
[].config.clientSecretPolicy.requireLowerCaseCharacter |
Number |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
[].config.clientSecretPolicy.requireDigit |
Number |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
[].config.clientSecretPolicy.requireSpecialCharacter |
Number |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
[].config.samlConfig.disableInResponseToCheck |
Boolean |
If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
[].config.samlConfig.wantAssertionSigned |
Boolean |
Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
[].config.samlConfig.requestSigned |
Boolean |
Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
[].config.samlConfig.entityID |
String |
Unique ID of the SAML2 entity |
[].config.samlConfig.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
[].config.samlConfig.activeKeyId |
String |
The ID of the key that should be used for signing metadata and assertions. |
[].config.samlConfig.keys.* |
Object |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
[].config.samlConfig.keys.*.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
[].config.links.logout.redirectUrl |
String |
Logout redirect url |
[].config.links.homeRedirect |
String |
Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
[].config.links.logout.redirectParameterName |
String |
Changes the name of the redirect parameter |
[].config.links.logout.disableRedirectParameter |
Boolean |
Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
[].config.links.logout.whitelist |
Array |
List of allowed whitelist redirects |
[].config.links.selfService.selfServiceLinksEnabled |
Boolean |
Whether or not users are allowed to sign up or reset their passwords via the UI |
[].config.links.selfService.signup |
Null |
Where users are directed upon clicking the account creation link |
[].config.links.selfService.passwd |
Null |
Where users are directed upon clicking the password reset link |
[].config.branding.companyName |
Varies |
This name is used on the UAA Pages and in account management related communication in UAA |
[].config.branding.productLogo |
Varies |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
[].config.branding.squareLogo |
Varies |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
[].config.branding.footerLegalText |
Varies |
This text appears on the footer of all UAA pages |
[].config.branding.footerLinks |
Object |
These links (Map |
[].config.branding.consent.text |
String |
If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
[].config.branding.consent.link |
String |
If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
[].config.prompts[] |
Array |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
[].config.prompts[].name |
String |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
[].config.prompts[].type |
String |
What kind of field this is (e.g. text or password) |
[].config.prompts[].text |
String |
Actual text displayed on prompt for field |
[].config.idpDiscoveryEnabled |
Boolean |
IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
[].config.accountChooserEnabled |
Boolean |
This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
[].config.issuer |
String |
Issuer of this zone. Must be a valid URL. |
[].config.branding.companyName |
String |
This name is used on the UAA Pages and in account management related communication in UAA |
[].config.branding.productLogo |
String |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
[].config.branding.squareLogo |
String |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
[].config.branding.footerLegalText |
String |
This text appears on the footer of all UAA pages |
[].config.branding.footerLinks.* |
String |
These links (Map |
[].config.branding.banner.text |
String |
This is text displayed in a banner at the top of the UAA login page |
[].config.branding.banner.logo |
String |
This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
[].config.branding.banner.link |
String |
The UAA login banner will be a link pointing to this url |
[].config.branding.banner.textColor |
String |
Hexadecimal color code for banner text color, does not allow color names |
[].config.branding.banner.backgroundColor |
String |
Hexadecimal color code for banner background color, does not allow color names |
[].config.corsPolicy.xhrConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
[].config.corsPolicy.xhrConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
[].config.corsPolicy.xhrConfiguration.allowedUris |
Array |
The list of allowed URIs. |
[].config.corsPolicy.xhrConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
[].config.corsPolicy.xhrConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
[].config.corsPolicy.xhrConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
[].config.corsPolicy.xhrConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
[].config.corsPolicy.xhrConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
[].config.corsPolicy.defaultConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
[].config.corsPolicy.defaultConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
[].config.corsPolicy.defaultConfiguration.allowedUris |
Array |
The list of allowed URIs. |
[].config.corsPolicy.defaultConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
[].config.corsPolicy.defaultConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
[].config.corsPolicy.defaultConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
[].config.corsPolicy.defaultConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
[].config.corsPolicy.defaultConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
[].config.userConfig.defaultGroups |
Array |
Default groups each user in the zone inherits. |
[].config.userConfig.allowedGroups |
Array |
Allowed groups in the zone. Defaults to null (all groups allowed) |
[].config.userConfig.maxUsers |
Number |
Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
[].config.userConfig.checkOriginEnabled |
Boolean |
Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
[].config.userConfig.allowOriginLoop |
Boolean |
Flag for switching off the loop over all origins in a zone (defaults to true) |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope |
Updating an Identity Zone
$ curl 'http://localhost/identity-zones/twiglet-update' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 01abc8f3fa894019b2045a849f0c8d3c' \
-d '{
"subdomain" : "twiglet-update",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : -1,
"refreshTokenValidity" : -1,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "updatedKeyId",
"keys" : {
"updatedKeyId" : {
"signingKey" : "upD4t3d.s1gNiNg.K3y/t3XT",
"signingCert" : null,
"signingAlg" : "HS256"
}
}
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"key" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"passphrase" : "password",
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"privateKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"privateKeyPassword" : "password"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Updated Twiglet Zone",
"version" : 0,
"description" : "Like the Twilight Zone but not tastier.",
"created" : 1760712935216,
"active" : true,
"last_modified" : 1760712935216
}'
PUT /identity-zones/twiglet-update HTTP/1.1
Content-Type: application/json
Authorization: Bearer 01abc8f3fa894019b2045a849f0c8d3c
Content-Length: 6455
Host: localhost
{
"subdomain" : "twiglet-update",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : -1,
"refreshTokenValidity" : -1,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "updatedKeyId",
"keys" : {
"updatedKeyId" : {
"signingKey" : "upD4t3d.s1gNiNg.K3y/t3XT",
"signingCert" : null,
"signingAlg" : "HS256"
}
}
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"key" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"passphrase" : "password",
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n",
"privateKey" : "-----BEGIN RSA PRIVATE KEY-----\nMIIBOwIBAAJBAJv8ZpB5hEK7qxP9K3v43hUS5fGT4waKe7ix4Z4mu5UBv+cw7WSF\nAt0Vaag0sAbsPzU8Hhsrj/qPABvfB8asUwcCAwEAAQJAG0r3ezH35WFG1tGGaUOr\nQA61cyaII53ZdgCR1IU8bx7AUevmkFtBf+aqMWusWVOWJvGu2r5VpHVAIl8nF6DS\nkQIhAMjEJ3zVYa2/Mo4ey+iU9J9Vd+WoyXDQD4EEtwmyG1PpAiEAxuZlvhDIbbce\n7o5BvOhnCZ2N7kYb1ZC57g3F+cbJyW8CIQCbsDGHBto2qJyFxbAO7uQ8Y0UVHa0J\nBO/g900SAcJbcQIgRtEljIShOB8pDjrsQPxmI1BLhnjD1EhRSubwhDw5AFUCIQCN\nA24pDtdOHydwtSB5+zFqFLfmVZplQM/g5kb4so70Yw==\n-----END RSA PRIVATE KEY-----\n",
"privateKeyPassword" : "password"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Updated Twiglet Zone",
"version" : 0,
"description" : "Like the Twilight Zone but not tastier.",
"created" : 1760712935216,
"active" : true,
"last_modified" : 1760712935216
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 5164
{
"id" : "twiglet-update",
"subdomain" : "twiglet-update",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : -1,
"refreshTokenValidity" : -1,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "updatedKeyId"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Updated Twiglet Zone",
"version" : 1,
"description" : "Like the Twilight Zone but not tastier.",
"created" : 1760712935202,
"active" : true,
"last_modified" : 1760712935229
}
Path Parameters
/identity-zones/{id}
Parameter | Description |
---|---|
id | Unique ID of the identity zone to update |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.write or uaa.admin . If you use the zone-switching header, bear token containing zones.<zone id>.admin can be used. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
subdomain | String | Required | Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name | String | Required | Human-readable zone name |
description | String | Optional | Description of the zone |
version | Number | Optional | Reserved for future use of E-Tag versioning |
active | Boolean | Optional | Indicates whether the identity zone is active. Defaults to true. |
config.tokenPolicy.activeKeyId | String | Required if config.tokenPolicy.keys are set |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.keys.*.signingKey | String | Key to be used for signing | Keys which will be used to sign the token. If null value is specified for keys, then existing value will be retained. |
config.tokenPolicy.keys.*.signingAlg | String | Optional. Can only be used in conjunction with keys.<key-id>.signingKey and keys.<key-id>.signingCert |
Algorithm parameter according to RFC7518 |
config.tokenPolicy.keys.*.signingCert | Null | Optional. Can only be used in conjunction with keys.<key-id>.signingKey and keys.<key-id>.signingCert |
PEM encoded X.509 to be used in x5c, e.g. RFC7517 |
config.tokenPolicy.accessTokenValidity | Number | Optional | Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity | Number | Optional | Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable | Boolean | Optional | Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique | Boolean | Optional | If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate | Boolean | Optional | If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat | String | Optional | The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.clientSecretPolicy.minLength | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength | Number | Required when clientSecretPolicy in the config is not null |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter | Number | Required when clientSecretPolicy in the config is not null |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.samlConfig.disableInResponseToCheck | Boolean | Optional | If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned | Boolean | Optional | Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned | Boolean | Optional | Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID | String | Optional | Unique ID of the SAML2 entity |
config.samlConfig.certificate | String | Deprecated | Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.privateKey | String | Deprecated | Exposed SAML metadata property. The SAML provider's private key. |
config.samlConfig.privateKeyPassword | String | Deprecated | Exposed SAML metadata property. The SAML provider's private key password. Reserved for future use. |
config.samlConfig.activeKeyId | String | Required if a list of keys defined in keys map |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.key | String | Optional. Can only be used in conjunction with keys.<key-id>.passphrase and keys.<key-id>.certificate |
Exposed SAML metadata property. The SAML provider's private key. |
config.samlConfig.keys.*.passphrase | String | Optional. Can only be used in conjunction with keys.<key-id>.key and keys.<key-id>.certificate |
Exposed SAML metadata property. The SAML provider's private key password. Reserved for future use. |
config.samlConfig.keys.*.certificate | String | Optional. Can only be used in conjunction with keys.<key-id>.key and keys.<key-id>.passphrase |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.links.logout.redirectUrl | String | Optional | Logout redirect url |
config.links.homeRedirect | String | Optional | Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName | String | Optional | Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter | Boolean | Optional | Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist | Array | Optional | List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled | Boolean | Optional | Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup | Null | Optional | Where users are directed upon clicking the account creation link |
config.links.selfService.passwd | Null | Optional | Where users are directed upon clicking the password reset link |
config.prompts[] | Array | Optional | List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name | String | Optional | Name of field |
config.prompts[].type | String | Optional | What kind of field this is (e.g. text or password) |
config.prompts[].text | String | Optional | Actual text displayed on prompt for field |
config.idpDiscoveryEnabled | Boolean | Optional | IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled | Boolean | Optional | This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer | String | Optional | Issuer of this zone. Must be a valid URL. |
config.branding.companyName | String | Optional | This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo | String | Optional | This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo | String | Optional | This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText | String | Optional | This text appears on the footer of all UAA pages |
config.branding.footerLinks.* | String | Optional | These links (Map |
config.branding.banner.text | String | Optional | This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo | String | Optional | This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link | String | Optional | The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor | String | Optional | Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor | String | Optional | Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text | String | Optional. Must be set if configuring consent. | If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link | String | Optional. Can be null if configuring consent. | If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.xhrConfiguration.allowedOrigins | Array | Optional | Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns | Array | Optional | Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris | Array | Optional | The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns | Array | Optional | The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders | Array | Optional | Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods | Array | Optional | Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials | Boolean | Optional | Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge | Number | Optional | Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.defaultConfiguration.allowedOrigins | Array | Optional | Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns | Array | Optional | Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris | Array | Optional | The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns | Array | Optional | The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders | Array | Optional | Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods | Array | Optional | Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials | Boolean | Optional | Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge | Number | Optional | Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups | Array | Optional | Default groups each user in the zone inherits. |
config.userConfig.allowedGroups | Array | Optional | Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers | Number | Optional number, default -1, no limit. | Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled | Boolean | Optional | Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop | Boolean | Optional | Flag for switching off the loop over all origins in a zone (defaults to true) |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
Unique ID of the identity zone |
subdomain |
String |
Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name |
String |
Human-readable zone name |
description |
String |
Description of the zone |
version |
Number |
Reserved for future use of E-Tag versioning |
active |
Boolean |
Indicates whether the identity zone is active. Defaults to true. |
config.tokenPolicy.activeKeyId |
String |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.accessTokenValidity |
Number |
Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity |
Number |
Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable |
Boolean |
Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique |
Boolean |
If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate |
Boolean |
If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat |
String |
The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.clientSecretPolicy.minLength |
Number |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength |
Number |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter |
Number |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter |
Number |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit |
Number |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter |
Number |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.samlConfig.disableInResponseToCheck |
Boolean |
If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned |
Boolean |
Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned |
Boolean |
Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID |
String |
Unique ID of the SAML2 entity |
config.samlConfig.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.activeKeyId |
String |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.links.logout.redirectUrl |
String |
Logout redirect url |
config.links.homeRedirect |
String |
Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName |
String |
Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter |
Boolean |
Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist |
Array |
List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled |
Boolean |
Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup |
Null |
Where users are directed upon clicking the account creation link |
config.links.selfService.passwd |
Null |
Where users are directed upon clicking the password reset link |
config.prompts[] |
Array |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name |
String |
Name of field |
config.prompts[].type |
String |
What kind of field this is (e.g. text or password) |
config.prompts[].text |
String |
Actual text displayed on prompt for field |
config.defaultIdentityProvider |
String |
This value can be set to the origin key of an identity provider. If set, the user will be directed to this identity provider automatically if no other identity provider is discovered or selected via login_hint. |
config.idpDiscoveryEnabled |
Boolean |
IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled |
Boolean |
This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer |
String |
Issuer of this zone. Must be a valid URL. |
config.branding.companyName |
String |
This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo |
String |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo |
String |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText |
String |
This text appears on the footer of all UAA pages |
config.branding.footerLinks.* |
String |
These links (Map |
config.branding.banner.text |
String |
This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo |
String |
This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link |
String |
The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor |
String |
Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor |
String |
Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text |
String |
If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link |
String |
If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.defaultConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.xhrConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups |
Array |
Default groups each user in the zone inherits. |
config.userConfig.allowedGroups |
Array |
Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers |
Number |
Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled |
Boolean |
Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop |
Boolean |
Flag for switching off the loop over all origins in a zone (defaults to true) |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (zone admins can only update own zone) |
404 | Not Found - Update to nonexistent zone |
422 | Unprocessable Entity - Invalid zone details |
Deleting an Identity Zone
$ curl 'http://localhost/identity-zones/twiglet-delete' -i -X DELETE \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a28df30937ea4f8c91d687f91860c0b5'
DELETE /identity-zones/twiglet-delete HTTP/1.1
Content-Type: application/json
Authorization: Bearer a28df30937ea4f8c91d687f91860c0b5
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 5099
{
"id" : "twiglet-delete",
"subdomain" : "twiglet-delete",
"config" : {
"clientSecretPolicy" : {
"minLength" : -1,
"maxLength" : -1,
"requireUpperCaseCharacter" : -1,
"requireLowerCaseCharacter" : -1,
"requireDigit" : -1,
"requireSpecialCharacter" : -1
},
"tokenPolicy" : {
"accessTokenValidity" : 3600,
"refreshTokenValidity" : 7200,
"jwtRevocable" : false,
"refreshTokenUnique" : false,
"refreshTokenRotate" : false,
"refreshTokenFormat" : "opaque",
"activeKeyId" : "active-key-1"
},
"samlConfig" : {
"requestSigned" : true,
"wantAssertionSigned" : true,
"activeKeyId" : "legacy-saml-key",
"keys" : {
"legacy-saml-key" : {
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
}
},
"entityID" : "cloudfoundry-saml-login",
"disableInResponseToCheck" : false,
"certificate" : "-----BEGIN CERTIFICATE-----\nMIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG\nA1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE\nMRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl\nYiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw\nODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE\nCAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs\nZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl\n8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID\nAQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx\n8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy\n2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0\nHn+GmxZA\n-----END CERTIFICATE-----\n"
},
"corsPolicy" : {
"xhrConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
},
"defaultConfiguration" : {
"allowedOrigins" : [ ".*" ],
"allowedOriginPatterns" : [ ],
"allowedUris" : [ ".*" ],
"allowedUriPatterns" : [ ],
"allowedHeaders" : [ "Accept", "Authorization", "Content-Type" ],
"allowedMethods" : [ "GET" ],
"allowedCredentials" : false,
"maxAge" : 1728000
}
},
"links" : {
"logout" : {
"redirectUrl" : "/login",
"redirectParameterName" : "redirect",
"disableRedirectParameter" : false,
"whitelist" : null
},
"homeRedirect" : "http://my.hosted.homepage.com/",
"selfService" : {
"selfServiceLinksEnabled" : true,
"signup" : null,
"passwd" : null
}
},
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ],
"idpDiscoveryEnabled" : false,
"branding" : {
"companyName" : "Test Company",
"productLogo" : "VGVzdFByb2R1Y3RMb2dv",
"squareLogo" : "VGVzdFNxdWFyZUxvZ28=",
"footerLegalText" : "Test footer legal text",
"footerLinks" : {
"Support" : "http://support.example.com"
},
"banner" : {
"logo" : "VGVzdFByb2R1Y3RMb2dv",
"text" : "Announcement",
"textColor" : "#000000",
"backgroundColor" : "#89cff0",
"link" : "http://announce.example.com"
},
"consent" : {
"text" : "Some Policy",
"link" : "http://policy.example.com"
}
},
"accountChooserEnabled" : false,
"userConfig" : {
"defaultGroups" : [ "openid", "password.write", "uaa.user", "approvals.me", "profile", "roles", "user_attributes", "uaa.offline_token" ],
"maxUsers" : -1,
"checkOriginEnabled" : false,
"allowOriginLoop" : true
},
"issuer" : "http://localhost:8080/uaa"
},
"name" : "The Twiglet Zone",
"version" : 0,
"created" : 1760712935086,
"active" : true,
"last_modified" : 1760712935086
}
Path Parameters
/identity-zones/{id}
Parameter | Description |
---|---|
id | Unique ID of the identity zone to delete |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.write or uaa.admin . If you use the zone-switching header, bear token containing zones.<zone id>.admin can be used. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
Unique ID of the identity zone |
subdomain |
String |
Unique subdomain for the running instance. May only contain legal characters for a subdomain name. |
name |
String |
Human-readable zone name |
description |
String |
Description of the zone |
version |
Number |
Reserved for future use of E-Tag versioning |
active |
Boolean |
Indicates whether the identity zone is active. Defaults to true. |
config.tokenPolicy.activeKeyId |
String |
The ID for the key that is being used to sign tokens |
config.tokenPolicy.accessTokenValidity |
Number |
Time in seconds between when a access token is issued and when it expires. Defaults to global accessTokenValidity |
config.tokenPolicy.refreshTokenValidity |
Number |
Time in seconds between when a refresh token is issued and when it expires. Defaults to global refreshTokenValidity |
config.tokenPolicy.jwtRevocable |
Boolean |
Set to true if JWT tokens should be stored in the token store, and thus made individually revocable. Opaque tokens are always stored and revocable. |
config.tokenPolicy.refreshTokenUnique |
Boolean |
If true, uaa will only issue one refresh token per client_id/user_id combination. Defaults to false . |
config.tokenPolicy.refreshTokenRotate |
Boolean |
If true, uaa will issue a new refresh token value in grant type refresh_token. Defaults to false . |
config.tokenPolicy.refreshTokenFormat |
String |
The format for the refresh token. Allowed values are jwt , opaque . Defaults to opaque . |
config.clientSecretPolicy.minLength |
Number |
Minimum number of characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.maxLength |
Number |
Maximum number of characters required for secret to be considered valid (defaults to 255). |
config.clientSecretPolicy.requireUpperCaseCharacter |
Number |
Minimum number of uppercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireLowerCaseCharacter |
Number |
Minimum number of lowercase characters required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireDigit |
Number |
Minimum number of digits required for secret to be considered valid (defaults to 0). |
config.clientSecretPolicy.requireSpecialCharacter |
Number |
Minimum number of special characters required for secret to be considered valid (defaults to 0). |
config.samlConfig.disableInResponseToCheck |
Boolean |
If true , this zone will not validate the InResponseToField part of an incoming IDP assertion. Please see https://docs.spring.io/spring-security-saml/docs/current/reference/html/chapter-troubleshooting.html |
config.samlConfig.wantAssertionSigned |
Boolean |
Exposed SAML metadata property. If true , all assertions received by the SAML provider must be signed. Defaults to true . |
config.samlConfig.requestSigned |
Boolean |
Exposed SAML metadata property. If true , the service provider will sign all outgoing authentication requests. Defaults to true . |
config.samlConfig.entityID |
String |
Unique ID of the SAML2 entity |
config.samlConfig.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.samlConfig.activeKeyId |
String |
The ID of the key that should be used for signing metadata and assertions. |
config.samlConfig.keys.*.certificate |
String |
Exposed SAML metadata property. The certificate used to verify the authenticity all communications. |
config.links.logout.redirectUrl |
String |
Logout redirect url |
config.links.homeRedirect |
String |
Overrides the UAA home page and issues a redirect to this URL when the browser requests / and /home . |
config.links.logout.redirectParameterName |
String |
Changes the name of the redirect parameter |
config.links.logout.disableRedirectParameter |
Boolean |
Deprecated, no longer affects zone behavior. Whether or not to allow the redirect parameter on logout |
config.links.logout.whitelist |
Array |
List of allowed whitelist redirects |
config.links.selfService.selfServiceLinksEnabled |
Boolean |
Whether or not users are allowed to sign up or reset their passwords via the UI |
config.links.selfService.signup |
Null |
Where users are directed upon clicking the account creation link |
config.links.selfService.passwd |
Null |
Where users are directed upon clicking the password reset link |
config.prompts[] |
Array |
List of fields that users are prompted for to login. Defaults to username, password, and passcode. |
config.prompts[].name |
String |
Name of field |
config.prompts[].type |
String |
What kind of field this is (e.g. text or password) |
config.prompts[].text |
String |
Actual text displayed on prompt for field |
config.defaultIdentityProvider |
String |
This value can be set to the origin key of an identity provider. If set, the user will be directed to this identity provider automatically if no other identity provider is discovered or selected via login_hint. |
config.idpDiscoveryEnabled |
Boolean |
IDP Discovery should be set to true if you have configured more than one identity provider for UAA. The discovery relies on email domain being set for each additional provider |
config.accountChooserEnabled |
Boolean |
This flag enables the account choosing functionality. If idpDiscoveryEnabled is set to true in the config the IDP is chosen by discovery. Otherwise, the user can enter the IDP by providing the origin. |
config.issuer |
String |
Issuer of this zone. Must be a valid URL. |
config.branding.companyName |
String |
This name is used on the UAA Pages and in account management related communication in UAA |
config.branding.productLogo |
String |
This is a base64Url encoded PNG image which will be used as the logo on all UAA pages like Login, Sign Up etc. |
config.branding.squareLogo |
String |
This is a base64 encoded PNG image which will be used as the favicon for the UAA pages |
config.branding.footerLegalText |
String |
This text appears on the footer of all UAA pages |
config.branding.footerLinks.* |
String |
These links (Map |
config.branding.banner.text |
String |
This is text displayed in a banner at the top of the UAA login page |
config.branding.banner.logo |
String |
This is base64 encoded PNG data displayed in a banner at the top of the UAA login page, overrides banner text |
config.branding.banner.link |
String |
The UAA login banner will be a link pointing to this url |
config.branding.banner.textColor |
String |
Hexadecimal color code for banner text color, does not allow color names |
config.branding.banner.backgroundColor |
String |
Hexadecimal color code for banner background color, does not allow color names |
config.branding.consent.text |
String |
If set, a checkbox on the registration and invitation pages will appear with the phrase I agree to followed by this text. The checkbox must be selected before the user can continue. |
config.branding.consent.link |
String |
If config.branding.consent.text is set, the text after I agree to will be hyperlinked to this location. |
config.corsPolicy.defaultConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.defaultConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.defaultConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.defaultConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.defaultConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.defaultConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.defaultConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.defaultConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.corsPolicy.xhrConfiguration.allowedOrigins |
Array |
Access-Control-Allow-Origin header . Indicates whether a resource can be shared based by returning the value of the Origin request header, "*", or "null" in the response. |
config.corsPolicy.xhrConfiguration.allowedOriginPatterns |
Array |
Indicates whether a resource can be shared based by returning the value of the Origin patterns. |
config.corsPolicy.xhrConfiguration.allowedUris |
Array |
The list of allowed URIs. |
config.corsPolicy.xhrConfiguration.allowedUriPatterns |
Array |
The list of allowed URI patterns. |
config.corsPolicy.xhrConfiguration.allowedHeaders |
Array |
Access-Control-Allow-Headers header. Indicates which header field names can be used during the actual response |
config.corsPolicy.xhrConfiguration.allowedMethods |
Array |
Access-Control-Allow-Methods header. Indicates which method will be used in the actual request as part of the preflight request. |
config.corsPolicy.xhrConfiguration.allowedCredentials |
Boolean |
Access-Control-Allow-Credentials header. Indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.. |
config.corsPolicy.xhrConfiguration.maxAge |
Number |
Access-Control-Max-Age header. Indicates how long the results of a preflight request can be cached in a preflight result cache |
config.userConfig.defaultGroups |
Array |
Default groups each user in the zone inherits. |
config.userConfig.allowedGroups |
Array |
Allowed groups in the zone. Defaults to null (all groups allowed) |
config.userConfig.maxUsers |
Number |
Number of users in the zone. If more than 0, it limits the amount of users in the zone. (defaults to -1, no limit). |
config.userConfig.checkOriginEnabled |
Boolean |
Flag for switching on the check if origin is valid when creating or updating users (defaults to false) |
config.userConfig.allowOriginLoop |
Boolean |
Flag for switching off the loop over all origins in a zone (defaults to true) |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (zone admins can only delete their own zone) |
404 | Not Found - Zone does not exist |
422 | Unprocessable Entity - at least one IdP with alias exists in the zone |
Identity Providers
Create
SAML
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 6961239696184c8199117101ead779b5' \
-d '{
"type" : "saml",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" entityID=\"http://www.okta.com/SAML\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\"true\" protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\"><md:KeyDescriptor use=\"signing\"><ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/></md:IDPSSODescriptor></md:EntityDescriptor>\n",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"originKey" : "SAML",
"name" : "SAML name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
Authorization: Bearer 6961239696184c8199117101ead779b5
Content-Length: 3031
Host: localhost
{
"type" : "saml",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" entityID=\"http://www.okta.com/SAML\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\"true\" protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\"><md:KeyDescriptor use=\"signing\"><ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/></md:IDPSSODescriptor></md:EntityDescriptor>\n",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"originKey" : "SAML",
"name" : "SAML name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 3280
{
"type" : "saml",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" entityID=\"http://www.okta.com/SAML\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\"true\" protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\"><md:KeyDescriptor use=\"signing\"><ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/><md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\"/></md:IDPSSODescriptor></md:EntityDescriptor>\n",
"idpEntityAlias" : "SAML",
"zoneId" : "uaa",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"id" : "3f01d699-e78d-4e04-8e6f-e1ce51596f88",
"originKey" : "SAML",
"name" : "SAML name",
"version" : 0,
"created" : 1760712927343,
"last_modified" : 1760712927343,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 6961239696184c8199117101ead779b5' \
-d '{
"type" : "saml",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : { },
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\"?>\n<md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\" entityID=\"http://example.com/saml2/idp/metadata.php\" ID=\"_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Signature>\n <ds:SignedInfo><ds:CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/>\n <ds:SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\"/>\n <ds:Reference URI=\"#_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Transforms><ds:Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\"/><ds:Transform Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/></ds:Transforms><ds:DigestMethod Algorithm=\"http://www.w3.org/2001/04/xmlenc#sha256\"/><ds:DigestValue>HOSWDJYkLvErI1gVynUVmufFVDCKPqExLnnnMjXgoJQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ryMe0PXC+vR/c0nSEhSJsTaF0lHiuZ6PguqCbul7RC9WKLmFS9DD7Dgp3WHQ2zWpRimCTHxw/VO9hyCTxAcW9zxW4OdpD4YorqcmXtLkpasBCVuFLbQ8oylnjrem4kpGflfnuk3bW1mp6AXy52jwALDm8MsTwLK+O74YkeVTPP5bki/PK0N4jHnhYhvhHKUyT8Gug0v2o4KA/1ik83e9vcYEFc/9WGpXFeDMF6pXsJQqC/+eWoLfZJDNrwSsSlg+oD+ZF91YccN9i9lJoaIPcVvPWDfEv7vL79LgnmPBeYxm/fWb4/ANMxvCLIP1R3Ixrz5oFoIX2NP1+uZOpoRWbg==</ds:SignatureValue>\n<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature>\n <md:IDPSSODescriptor protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\">\n <md:KeyDescriptor use=\"signing\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:KeyDescriptor use=\"encryption\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:SingleLogoutService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SingleLogoutService.php\"/>\n <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</md:NameIDFormat>\n <md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SSOService.php\"/>\n </md:IDPSSODescriptor>\n <md:ContactPerson contactType=\"technical\">\n <md:GivenName>Filip</md:GivenName>\n <md:SurName>Hanik</md:SurName>\n <md:EmailAddress>[email protected]</md:EmailAddress>\n </md:ContactPerson>\n</md:EntityDescriptor>\n",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:transient",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"originKey" : "SAMLMetadataUrl",
"name" : "SAML name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
Authorization: Bearer 6961239696184c8199117101ead779b5
Content-Length: 7658
Host: localhost
{
"type" : "saml",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : { },
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\"?>\n<md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\" entityID=\"http://example.com/saml2/idp/metadata.php\" ID=\"_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Signature>\n <ds:SignedInfo><ds:CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/>\n <ds:SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\"/>\n <ds:Reference URI=\"#_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Transforms><ds:Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\"/><ds:Transform Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/></ds:Transforms><ds:DigestMethod Algorithm=\"http://www.w3.org/2001/04/xmlenc#sha256\"/><ds:DigestValue>HOSWDJYkLvErI1gVynUVmufFVDCKPqExLnnnMjXgoJQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ryMe0PXC+vR/c0nSEhSJsTaF0lHiuZ6PguqCbul7RC9WKLmFS9DD7Dgp3WHQ2zWpRimCTHxw/VO9hyCTxAcW9zxW4OdpD4YorqcmXtLkpasBCVuFLbQ8oylnjrem4kpGflfnuk3bW1mp6AXy52jwALDm8MsTwLK+O74YkeVTPP5bki/PK0N4jHnhYhvhHKUyT8Gug0v2o4KA/1ik83e9vcYEFc/9WGpXFeDMF6pXsJQqC/+eWoLfZJDNrwSsSlg+oD+ZF91YccN9i9lJoaIPcVvPWDfEv7vL79LgnmPBeYxm/fWb4/ANMxvCLIP1R3Ixrz5oFoIX2NP1+uZOpoRWbg==</ds:SignatureValue>\n<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature>\n <md:IDPSSODescriptor protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\">\n <md:KeyDescriptor use=\"signing\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:KeyDescriptor use=\"encryption\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:SingleLogoutService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SingleLogoutService.php\"/>\n <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</md:NameIDFormat>\n <md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SSOService.php\"/>\n </md:IDPSSODescriptor>\n <md:ContactPerson contactType=\"technical\">\n <md:GivenName>Filip</md:GivenName>\n <md:SurName>Hanik</md:SurName>\n <md:EmailAddress>[email protected]</md:EmailAddress>\n </md:ContactPerson>\n</md:EntityDescriptor>\n",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:transient",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"originKey" : "SAMLMetadataUrl",
"name" : "SAML name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 7918
{
"type" : "saml",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : { },
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"metaDataLocation" : "<?xml version=\"1.0\"?>\n<md:EntityDescriptor xmlns:md=\"urn:oasis:names:tc:SAML:2.0:metadata\" xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\" entityID=\"http://example.com/saml2/idp/metadata.php\" ID=\"_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Signature>\n <ds:SignedInfo><ds:CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/>\n <ds:SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\"/>\n <ds:Reference URI=\"#_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\"><ds:Transforms><ds:Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\"/><ds:Transform Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\"/></ds:Transforms><ds:DigestMethod Algorithm=\"http://www.w3.org/2001/04/xmlenc#sha256\"/><ds:DigestValue>HOSWDJYkLvErI1gVynUVmufFVDCKPqExLnnnMjXgoJQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ryMe0PXC+vR/c0nSEhSJsTaF0lHiuZ6PguqCbul7RC9WKLmFS9DD7Dgp3WHQ2zWpRimCTHxw/VO9hyCTxAcW9zxW4OdpD4YorqcmXtLkpasBCVuFLbQ8oylnjrem4kpGflfnuk3bW1mp6AXy52jwALDm8MsTwLK+O74YkeVTPP5bki/PK0N4jHnhYhvhHKUyT8Gug0v2o4KA/1ik83e9vcYEFc/9WGpXFeDMF6pXsJQqC/+eWoLfZJDNrwSsSlg+oD+ZF91YccN9i9lJoaIPcVvPWDfEv7vL79LgnmPBeYxm/fWb4/ANMxvCLIP1R3Ixrz5oFoIX2NP1+uZOpoRWbg==</ds:SignatureValue>\n<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature>\n <md:IDPSSODescriptor protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\">\n <md:KeyDescriptor use=\"signing\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:KeyDescriptor use=\"encryption\">\n <ds:KeyInfo xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\">\n <ds:X509Data>\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\n </ds:X509Data>\n </ds:KeyInfo>\n </md:KeyDescriptor>\n <md:SingleLogoutService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SingleLogoutService.php\"/>\n <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</md:NameIDFormat>\n <md:SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"http://example.com/saml2/idp/SSOService.php\"/>\n </md:IDPSSODescriptor>\n <md:ContactPerson contactType=\"technical\">\n <md:GivenName>Filip</md:GivenName>\n <md:SurName>Hanik</md:SurName>\n <md:EmailAddress>[email protected]</md:EmailAddress>\n </md:ContactPerson>\n</md:EntityDescriptor>\n",
"idpEntityAlias" : "SAMLMetadataUrl",
"zoneId" : "uaa",
"nameID" : "urn:oasis:names:tc:SAML:1.1:nameid-format:transient",
"assertionConsumerIndex" : 0,
"metadataTrustCheck" : false,
"showSamlLink" : false,
"linkText" : "IDPEndpointsMockTests Saml Provider:SAML",
"iconUrl" : null,
"groupMappingMode" : "EXPLICITLY_MAPPED",
"skipSslValidation" : false,
"authnContext" : null,
"socketFactoryClassName" : null
},
"id" : "e45c2a28-a45f-423e-a8ac-5ec4beea58ce",
"originKey" : "SAMLMetadataUrl",
"name" : "SAML name",
"version" : 0,
"created" : 1760712927464,
"last_modified" : 1760712927464,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | saml |
originKey | String | Required | A unique alias for the SAML provider |
config.skipSslValidation | Boolean | Optional (defaults to false ) |
Set to true, to skip SSL validation when fetching metadata. |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
config.metaDataLocation | String | Required | SAML Metadata - either an XML string or a URL that will deliver XML content |
config.nameID | String | Optional | The name ID to use for the username, default is "urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified". |
config.assertionConsumerIndex | Number | Optional | SAML assertion consumer index, default is 0 |
config.metadataTrustCheck | Boolean | Optional | Should metadata be validated, defaults to false |
config.showSamlLink | Boolean | Optional | Should the SAML login link be displayed on the login page, defaults to false |
config.linkText | String | Required if the showSamlLink is set to true |
The link text for the SAML IDP on the login page |
config.groupMappingMode | String | Optional (defaults to "EXPLICITLY_MAPPED" ) |
Either EXPLICITLY_MAPPED in order to map external groups to OAuth scopes using the group mappings, or AS_SCOPES to use SAML group names as scopes. |
config.iconUrl | String | Optional | Reserved for future use |
config.socketFactoryClassName | Null | Optional | Property is deprecated and value is ignored. |
config.authnContext | Array | Optional | List of AuthnContextClassRef to include in the SAMLRequest. If not specified no AuthnContext will be requested. |
config.attributeMappings.user_name | String | Optional (defaults to "NameID" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for SAML is NameID . |
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.email | String | Optional | Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name | String | Optional | Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional | Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional | Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups | Array | Optional | Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] | String | Optional | Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set, an alias identity provider is created in the referenced zone and aliasId is set accordingly. |
Response Fields
Path | Type | Description |
---|---|---|
name |
String |
Human-readable name for this provider |
config.providerDescription |
String |
Human readable name/description of this provider |
config.emailDomain |
Array |
List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active |
Boolean |
Defaults to true. |
config.addShadowUserOnLogin |
Boolean |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes |
Boolean |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type |
String |
saml |
originKey |
String |
A unique alias for the SAML provider |
config.skipSslValidation |
Boolean |
Set to true, to skip SSL validation when fetching metadata. |
config.storeCustomAttributes |
Boolean |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
config.metaDataLocation |
String |
SAML Metadata - either an XML string or a URL that will deliver XML content |
config.nameID |
String |
The name ID to use for the username, default is "urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified". |
config.assertionConsumerIndex |
Number |
SAML assertion consumer index, default is 0 |
config.metadataTrustCheck |
Boolean |
Should metadata be validated, defaults to false |
config.showSamlLink |
Boolean |
Should the SAML login link be displayed on the login page, defaults to false |
config.linkText |
String |
The link text for the SAML IDP on the login page |
config.groupMappingMode |
String |
Either EXPLICITLY_MAPPED in order to map external groups to OAuth scopes using the group mappings, or AS_SCOPES to use SAML group names as scopes. |
config.iconUrl |
String |
Reserved for future use |
config.socketFactoryClassName |
Null |
Property is deprecated and value is ignored. |
config.authnContext |
Array |
List of AuthnContextClassRef to include in the SAMLRequest. If not specified no AuthnContext will be requested. |
config.attributeMappings.user_name |
String |
Map user_name to the attribute for user name in the provider assertion or token. The default for SAML is NameID . |
config.attributeMappings |
Object |
Map external attribute to UAA recognized mappings. |
config.attributeMappings.email |
String |
Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name |
String |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name |
String |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number |
String |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified |
String |
Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups |
Array |
Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] |
String |
Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
version |
Number |
Version of the identity provider data. Clients can use this to protect against conflicting updates |
id |
String |
Unique identifier for this provider - GUID generated by the UAA |
config.additionalConfiguration |
Object |
(Unused.) |
identityZoneId |
String |
Set to the zone that this provider will be active in. Determined either by the Host header or the zone switch header. |
created |
Number |
UAA sets the creation date |
last_modified |
Number |
UAA sets the modification date |
config.idpEntityAlias |
String |
This will be set to originKey |
config.zoneId |
String |
This will be set to the ID of the zone where the provider is being created |
aliasId |
String |
The ID of the alias IdP. |
aliasZid |
String |
The ID of the identity zone in which an alias of this IdP is maintained. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
LDAP
LDAP supports several different configurations. The most common one is that authentication is done using a search and bind strategy. The available strategies for authentication are
- Bind authentication - the UAA uses the user's credentials to construct a DN and attempt a BIND operation to the LDAP server
- Search and Bind authentication - We take the username and password, search for the user DN, and attempt a bind operation to the LDAP server
- Search and Compare authentication - We take the username and password, search for the user DN and the user password, and perform a comparison of the provided password with the LDAP password
Group integration also supports different strategies
- No group integration - LDAP is only used for authentication
- Map a group to a UAA scope - using external group mappings
- LDAP groups contain scopes - an entry in the LDAP record contains UAA scope names
LDAP Simple Bind
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'X-Identity-Zone-Subdomain: avtxhgzr' \
-H 'Authorization: Bearer 1d9c9d97521d416abf42e4a51b08c56d' \
-d '{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-simple-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : "cn={0},ou=Users,dc=test,dc=com",
"userDNPatternDelimiter" : ";",
"bindUserDn" : null,
"userSearchBase" : null,
"userSearchFilter" : null,
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-null.xml",
"groupSearchBase" : null,
"groupSearchFilter" : null,
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 10,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
X-Identity-Zone-Subdomain: avtxhgzr
Authorization: Bearer 1d9c9d97521d416abf42e4a51b08c56d
Content-Length: 1242
Host: localhost
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-simple-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : "cn={0},ou=Users,dc=test,dc=com",
"userDNPatternDelimiter" : ";",
"bindUserDn" : null,
"userSearchBase" : null,
"userSearchFilter" : null,
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-null.xml",
"groupSearchBase" : null,
"groupSearchFilter" : null,
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 10,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1443
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-simple-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : "cn={0},ou=Users,dc=test,dc=com",
"userDNPatternDelimiter" : ";",
"bindUserDn" : null,
"userSearchBase" : null,
"userSearchFilter" : null,
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-null.xml",
"groupSearchBase" : null,
"groupSearchFilter" : null,
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 10,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"id" : "8fc9978b-325b-4890-b4e5-1e5fc9398cfc",
"originKey" : "ldap",
"name" : "ldap name",
"version" : 0,
"created" : 1760712929262,
"last_modified" : 1760712929262,
"active" : true,
"identityZoneId" : "avtxhgzr",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Missing or invalid token |
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
LDAP Search and Bind
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'X-Identity-Zone-Subdomain: rmvm2kne' \
-H 'Authorization: Bearer 2e41b5d785dd4df3a6440ee74f54620f' \
-d '{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"bindPassword" : "adminsecret",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : "{0}@my.org",
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-map-to-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
X-Identity-Zone-Subdomain: rmvm2kne
Authorization: Bearer 2e41b5d785dd4df3a6440ee74f54620f
Content-Length: 1347
Host: localhost
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"bindPassword" : "adminsecret",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : "{0}@my.org",
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-map-to-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1512
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-bind.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : null,
"passwordEncoder" : null,
"localPasswordCompare" : null,
"mailAttributeName" : "mail",
"mailSubstitute" : "{0}@my.org",
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-map-to-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : null,
"tlsConfiguration" : "none"
},
"id" : "8785e5ce-fbda-40f1-9229-125d0aad8b89",
"originKey" : "ldap",
"name" : "ldap name",
"version" : 0,
"created" : 1760712927707,
"last_modified" : 1760712927707,
"active" : true,
"identityZoneId" : "rmvm2kne",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Missing or invalid token |
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
LDAP Search and Compare
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'X-Identity-Zone-Subdomain: adj121hk' \
-H 'Authorization: Bearer 3cb3c75b8b7d4210b7cf80ac40523650' \
-d '{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-compare.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"bindPassword" : "adminsecret",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : "userPassword",
"passwordEncoder" : "org.cloudfoundry.identity.uaa.provider.ldap.DynamicPasswordComparator",
"localPasswordCompare" : true,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-as-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : "description",
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
X-Identity-Zone-Subdomain: adj121hk
Authorization: Bearer 3cb3c75b8b7d4210b7cf80ac40523650
Content-Length: 1424
Host: localhost
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-compare.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"bindPassword" : "adminsecret",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : "userPassword",
"passwordEncoder" : "org.cloudfoundry.identity.uaa.provider.ldap.DynamicPasswordComparator",
"localPasswordCompare" : true,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-as-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : "description",
"tlsConfiguration" : "none"
},
"originKey" : "ldap",
"name" : "ldap name",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1589
{
"type" : "ldap",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"ldapProfileFile" : "ldap/ldap-search-and-compare.xml",
"baseUrl" : "ldap://localhost:35473",
"referral" : null,
"skipSSLVerification" : false,
"userDNPattern" : null,
"userDNPatternDelimiter" : null,
"bindUserDn" : "cn=admin,ou=Users,dc=test,dc=com",
"userSearchBase" : "dc=test,dc=com",
"userSearchFilter" : "cn={0}",
"passwordAttributeName" : "userPassword",
"passwordEncoder" : "org.cloudfoundry.identity.uaa.provider.ldap.DynamicPasswordComparator",
"localPasswordCompare" : true,
"mailAttributeName" : "mail",
"mailSubstitute" : null,
"mailSubstituteOverridesLdap" : false,
"ldapGroupFile" : "ldap/ldap-groups-as-scopes.xml",
"groupSearchBase" : "ou=scopes,dc=test,dc=com",
"groupSearchFilter" : "member={0}",
"groupsIgnorePartialResults" : null,
"autoAddGroups" : true,
"groupSearchSubTree" : true,
"maxGroupSearchDepth" : 3,
"groupRoleAttribute" : "description",
"tlsConfiguration" : "none"
},
"id" : "6d2bf6ba-6849-42e5-80b9-968be3d689d7",
"originKey" : "ldap",
"name" : "ldap name",
"version" : 0,
"created" : 1760712928639,
"last_modified" : 1760712928639,
"active" : true,
"identityZoneId" : "adj121hk",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | ldap |
originKey | String | Required | Origin key must be ldap for an LDAP provider |
config.ldapProfileFile | String | Required | The file to be used for configuring the LDAP authentication. Options are: ldap/ldap-simple-bind.xml , ldap/ldap-search-and-bind.xml , ldap/ldap-search-and-compare.xml |
config.ldapGroupFile | String | Required | The file to be used for group integration. Options are: ldap/ldap-groups-null.xml , ldap/ldap-groups-as-scopes.xml , ldap/ldap-groups-map-to-scopes.xml |
config.baseUrl | String | Required | The URL to the ldap server, must start with ldap:// or ldaps:// |
config.bindPassword | String | Required | Used with search-and-bind and search-and-compare . Password for the LDAP ID that performs a search of the LDAP tree for user information. |
config.mailAttributeName | String | Optional (defaults to "mail" ) |
The name of the LDAP attribute that contains the user's email address |
config.mailSubstitute | String | Optional | Defines an email pattern containing a {0} to generate an email address for an LDAP user during authentication |
config.mailSubstituteOverridesLdap | Boolean | Optional (defaults to false ) |
Set to true if you wish to override an LDAP user email address with a generated one |
config.skipSSLVerification | Boolean | Optional (defaults to false ) |
Skips validation of the LDAP cert if set to true. |
config.tlsConfiguration | String | Optional (defaults to "none" ) |
Sets the StartTLS options, valid values are none , simple or external |
config.referral | String | Optional (defaults to "follow" ) |
Configures the UAA LDAP referral behavior. The following values are possible:
|
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.user_name | String | Optional (defaults to "user_name" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for LDAP is the User Name filter |
config.attributeMappings.first_name | String | Optional (defaults to "givenname" ) |
Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional (defaults to "sn" ) |
Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional (defaults to "telephonenumber" ) |
Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null , since alias identity providers are not supported for LDAP. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Must be set to null , since alias identity providers are not supported for LDAP. |
Error Codes
Error Code | Description |
---|---|
401 | Unauthorized - Missing or invalid token |
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
OAuth/OIDC
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 6e659aa5f471459f89d44bba3e735111' \
-d '{
"type" : "oauth2.0",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : "http://auth.url",
"tokenUrl" : "http://token.url",
"tokenKeyUrl" : null,
"tokenKey" : "token-key",
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : false,
"relyingPartyId" : "uaa",
"relyingPartySecret" : "secret",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"cacheJwks" : true
},
"originKey" : "my-oauth2-provider",
"name" : "UAA Provider",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
Authorization: Bearer 6e659aa5f471459f89d44bba3e735111
Content-Length: 1162
Host: localhost
{
"type" : "oauth2.0",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : "http://auth.url",
"tokenUrl" : "http://token.url",
"tokenKeyUrl" : null,
"tokenKey" : "token-key",
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : false,
"relyingPartyId" : "uaa",
"relyingPartySecret" : "secret",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"cacheJwks" : true
},
"originKey" : "my-oauth2-provider",
"name" : "UAA Provider",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1428
{
"type" : "oauth2.0",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : "http://auth.url",
"tokenUrl" : "http://token.url",
"tokenKeyUrl" : null,
"tokenKey" : "token-key",
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : false,
"relyingPartyId" : "uaa",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"authMethod" : "client_secret_basic",
"cacheJwks" : true,
"checkTokenUrl" : null
},
"id" : "cf857694-753f-4a74-823b-2dd0e54bcfc6",
"originKey" : "my-oauth2-provider",
"name" : "UAA Provider",
"version" : 0,
"created" : 1760712928359,
"last_modified" : 1760712928359,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | "oauth2.0" |
originKey | String | Required | A unique alias for a OAuth provider |
config.authUrl | String | Required | The OAuth 2.0 authorization endpoint URL |
config.tokenUrl | String | Required | The OAuth 2.0 token endpoint URL |
config.tokenKeyUrl | String | Optional | The URL of the token key endpoint which renders the JWKS (verification key for validating token signatures). |
config.cacheJwks | Boolean | Used only if discoveryUrl or tokenKeyUrl is set. |
UAA 77.11.0. Option to enable caching for the JWKS (verification key for validating token signatures). Setting it to true increases UAA performance and is hence recommended. Setting it to false forces UAA to fetch the remote JWKS at each token validation, which impacts performance but may be required for when the remote JWKS changes very frequently. |
config.tokenKey | String | Optional | A verification key for validating token signatures, set to null if a tokenKeyUrl is provided. |
config.userInfoUrl | String | Optional | A URL for fetching user info attributes when queried with the obtained token authorization. |
config.showLinkText | Boolean | Optional (defaults to true ) |
A flag controlling whether a link to this provider's login will be shown on the UAA login page |
config.linkText | String | Optional | Text to use for the login link to the provider |
config.relyingPartyId | String | Required | The client ID which is registered with the external OAuth provider for use by the UAA |
config.skipSslValidation | Boolean | Optional | A flag controlling whether SSL validation should be skipped when communicating with the external OAuth server |
config.scopes | Array | Optional | What scopes to request on a call to the external OAuth provider |
config.checkTokenUrl | Object | Optional | Reserved for future OAuth use. |
config.logoutUrl | Object | Optional | OAuth 2.0 logout endpoint. |
config.responseType | String | Optional (defaults to "code" ) |
Response type for the authorize request, will be sent to OAuth server, defaults to code |
config.clientAuthInBody | Boolean | Optional (defaults to false ) |
Sends the client credentials in the token retrieval call as body parameters instead of a Basic Authorization header. |
config.pkce | Boolean | Optional (defaults to true ) |
A flag controlling whether PKCE (RFC 7636) is active in authorization code flow when requesting tokens from the external provider. |
config.performRpInitiatedLogout | Boolean | Optional (defaults to true ) |
A flag controlling whether to log out of the external provider after a successful UAA logout per OIDC RP-Initiated Logout |
config.issuer | String | Optional | The OAuth 2.0 token issuer. This value is used to validate the issuer inside the token. |
config.userPropagationParameter | String | Optional (defaults to "username" ) |
Name of the request parameter that is used to pass a known username when redirecting to this identity provider from the account chooser |
config.attributeMappings.user_name | String | Optional (defaults to "sub" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for OpenID Connect is sub |
config.groupMappingMode | String | Optional (defaults to "EXPLICITLY_MAPPED" ) |
Either EXPLICITLY_MAPPED in order to map external claim values to OAuth scopes using the group mappings, or AS_SCOPES to use claim values names as scopes. You need to define also external_groups for the mapping in order to use this feature. |
config.authMethod | String | Optional (defaults to "client_secret_basic" ) |
UAA 77.10.0 Define an explicit method to authenticate against the identity provider. Supported values are client_secret_basic , client_secret_post , private_key_jwt , and none . Remark: If you switch the method from client_secret_basic to private_key_jwt or to none , your existing config.relyingPartySecret will be removed from UAA database. If you want to switch back to client_secret_basic , provide again a config.relyingPartySecret in the configuration. |
config.jwtClientAuthentication | Object | Required if config.authMethod is set to private_key_jwt |
UAA 76.5.0 Only effective if relyingPartySecret is not set or null. Creates private_key_jwt client authentication according to OIDC or OAuth2 (RFC 7523) standard. For standard OIDC compliance, set this field to true . Alternatively, you can further configure the created JWT for client authentication by setting this parameter to an Object containing sub-parameters, e.g. if your IdP follows OAuth2 standard according to RFC 7523. The supported sub-parameters are
The values in the list can be a reference to another section in uaa yaml, e.g. define for key a reference like ${"jwt.client.key"}. This will load the private key from yaml context jwt.client.key. The advantage is, that you can use a single key for many IdP configurations and the key itself is not persistent in the UAA DB. |
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.email | String | Optional | Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name | String | Optional | Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional | Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional | Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups | Array | Optional | Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] | String | Optional | Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set, an alias identity provider is created in the referenced zone and aliasId is set accordingly. |
config.relyingPartySecret | String | Required if config.authMethod is set to client_secret_basic . |
The client secret of the relying party at the external OAuth provider. If not set and jwtClientAuthentication is not set, then the external OAuth client is treated as public client and the flow is protected with PKCE using code challenge method S256 . It is recommended to set jwtClientAuthentication:true instead. |
Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | "oauth2.0" |
originKey | String | Required | A unique alias for a OAuth provider |
config.authUrl | String | Required | The OAuth 2.0 authorization endpoint URL |
config.tokenUrl | String | Required | The OAuth 2.0 token endpoint URL |
config.tokenKeyUrl | String | Optional | The URL of the token key endpoint which renders the JWKS (verification key for validating token signatures). |
config.cacheJwks | Boolean | Used only if discoveryUrl or tokenKeyUrl is set. |
UAA 77.11.0. Option to enable caching for the JWKS (verification key for validating token signatures). Setting it to true increases UAA performance and is hence recommended. Setting it to false forces UAA to fetch the remote JWKS at each token validation, which impacts performance but may be required for when the remote JWKS changes very frequently. |
config.tokenKey | String | Optional | A verification key for validating token signatures, set to null if a tokenKeyUrl is provided. |
config.userInfoUrl | String | Optional | A URL for fetching user info attributes when queried with the obtained token authorization. |
config.showLinkText | Boolean | Optional (defaults to true ) |
A flag controlling whether a link to this provider's login will be shown on the UAA login page |
config.linkText | String | Optional | Text to use for the login link to the provider |
config.relyingPartyId | String | Required | The client ID which is registered with the external OAuth provider for use by the UAA |
config.skipSslValidation | Boolean | Optional | A flag controlling whether SSL validation should be skipped when communicating with the external OAuth server |
config.scopes | Array | Optional | What scopes to request on a call to the external OAuth provider |
config.checkTokenUrl | Object | Optional | Reserved for future OAuth use. |
config.logoutUrl | Object | Optional | OAuth 2.0 logout endpoint. |
config.responseType | String | Optional (defaults to "code" ) |
Response type for the authorize request, will be sent to OAuth server, defaults to code |
config.clientAuthInBody | Boolean | Optional (defaults to false ) |
Sends the client credentials in the token retrieval call as body parameters instead of a Basic Authorization header. |
config.pkce | Boolean | Optional (defaults to true ) |
A flag controlling whether PKCE (RFC 7636) is active in authorization code flow when requesting tokens from the external provider. |
config.performRpInitiatedLogout | Boolean | Optional (defaults to true ) |
A flag controlling whether to log out of the external provider after a successful UAA logout per OIDC RP-Initiated Logout |
config.issuer | String | Optional | The OAuth 2.0 token issuer. This value is used to validate the issuer inside the token. |
config.userPropagationParameter | String | Optional (defaults to "username" ) |
Name of the request parameter that is used to pass a known username when redirecting to this identity provider from the account chooser |
config.attributeMappings.user_name | String | Optional (defaults to "sub" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for OpenID Connect is sub |
config.groupMappingMode | String | Optional (defaults to "EXPLICITLY_MAPPED" ) |
Either EXPLICITLY_MAPPED in order to map external claim values to OAuth scopes using the group mappings, or AS_SCOPES to use claim values names as scopes. You need to define also external_groups for the mapping in order to use this feature. |
config.authMethod | String | Optional (defaults to "client_secret_basic" ) |
UAA 77.10.0 Define an explicit method to authenticate against the identity provider. Supported values are client_secret_basic , client_secret_post , private_key_jwt , and none . Remark: If you switch the method from client_secret_basic to private_key_jwt or to none , your existing config.relyingPartySecret will be removed from UAA database. If you want to switch back to client_secret_basic , provide again a config.relyingPartySecret in the configuration. |
config.jwtClientAuthentication | Object | Required if config.authMethod is set to private_key_jwt |
UAA 76.5.0 Only effective if relyingPartySecret is not set or null. Creates private_key_jwt client authentication according to OIDC or OAuth2 (RFC 7523) standard. For standard OIDC compliance, set this field to true . Alternatively, you can further configure the created JWT for client authentication by setting this parameter to an Object containing sub-parameters, e.g. if your IdP follows OAuth2 standard according to RFC 7523. The supported sub-parameters are
The values in the list can be a reference to another section in uaa yaml, e.g. define for key a reference like ${"jwt.client.key"}. This will load the private key from yaml context jwt.client.key. The advantage is, that you can use a single key for many IdP configurations and the key itself is not persistent in the UAA DB. |
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.email | String | Optional | Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name | String | Optional | Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional | Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional | Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups | Array | Optional | Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] | String | Optional | Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set, an alias identity provider is created in the referenced zone and aliasId is set accordingly. |
config.relyingPartySecret | String | Required if config.authMethod is set to client_secret_basic . |
The client secret of the relying party at the external OAuth provider. If not set and jwtClientAuthentication is not set, then the external OAuth client is treated as public client and the flow is protected with PKCE using code challenge method S256 . It is recommended to set jwtClientAuthentication:true instead. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
$ curl 'http://localhost/identity-providers?rawConfig=true' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 116f66cf9fe24a1ea87c826a2e034c18' \
-d '{
"type" : "oidc1.0",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ "uaa.user" ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : null,
"tokenUrl" : null,
"tokenKeyUrl" : null,
"tokenKey" : null,
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : true,
"relyingPartyId" : "uaa",
"relyingPartySecret" : "secret",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"cacheJwks" : true,
"discoveryUrl" : "https://accounts.google.com/.well-known/openid-configuration",
"passwordGrantEnabled" : false,
"setForwardHeader" : false,
"tokenExchangeEnabled" : null,
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ]
},
"originKey" : "my-oidc-provider-8drzq5",
"name" : "UAA Provider",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}'
POST /identity-providers?rawConfig=true HTTP/1.1
Content-Type: application/json
Authorization: Bearer 116f66cf9fe24a1ea87c826a2e034c18
Content-Length: 1690
Host: localhost
{
"type" : "oidc1.0",
"config" : {
"emailDomain" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ "uaa.user" ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : null,
"tokenUrl" : null,
"tokenKeyUrl" : null,
"tokenKey" : null,
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : true,
"relyingPartyId" : "uaa",
"relyingPartySecret" : "secret",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"cacheJwks" : true,
"discoveryUrl" : "https://accounts.google.com/.well-known/openid-configuration",
"passwordGrantEnabled" : false,
"setForwardHeader" : false,
"tokenExchangeEnabled" : null,
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ]
},
"originKey" : "my-oidc-provider-8drzq5",
"name" : "UAA Provider",
"active" : true,
"aliasId" : null,
"aliasZid" : null
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1891
{
"type" : "oidc1.0",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"externalGroupsWhitelist" : [ "uaa.user" ],
"attributeMappings" : {
"email_verified" : "emailVerified",
"external_groups" : [ "roles" ],
"user.attribute.department" : "department",
"phone_number" : "telephone",
"given_name" : "first_name",
"family_name" : "last_name",
"email" : "emailAddress"
},
"addShadowUserOnLogin" : true,
"storeCustomAttributes" : true,
"authUrl" : null,
"tokenUrl" : null,
"tokenKeyUrl" : null,
"tokenKey" : null,
"userInfoUrl" : null,
"logoutUrl" : null,
"linkText" : null,
"showLinkText" : false,
"clientAuthInBody" : false,
"skipSslValidation" : true,
"relyingPartyId" : "uaa",
"scopes" : null,
"issuer" : null,
"responseType" : "code",
"userPropagationParameter" : "username",
"pkce" : true,
"performRpInitiatedLogout" : true,
"authMethod" : "client_secret_basic",
"cacheJwks" : true,
"discoveryUrl" : "https://accounts.google.com/.well-known/openid-configuration",
"passwordGrantEnabled" : false,
"setForwardHeader" : false,
"tokenExchangeEnabled" : null,
"prompts" : [ {
"name" : "username",
"type" : "text",
"text" : "Email"
}, {
"name" : "password",
"type" : "password",
"text" : "Password"
}, {
"name" : "passcode",
"type" : "password",
"text" : "Temporary Authentication Code (Get on at /passcode)"
} ]
},
"id" : "6c72189b-5d24-43c6-9394-1437af3a8cb1",
"originKey" : "my-oidc-provider-8drzq5",
"name" : "UAA Provider",
"version" : 0,
"created" : 1760712928427,
"last_modified" : 1760712928427,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | "oidc1.0" |
originKey | String | Required | A unique alias for the OIDC 1.0 provider |
config.discoveryUrl | String | Optional | The OpenID Connect Discovery URL, typically ends with /.well-known/openid-configurationmit |
config.authUrl | String | Required unless discoveryUrl is set. |
The OIDC 1.0 authorization endpoint URL. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.tokenUrl | String | Required unless discoveryUrl is set. |
The OIDC 1.0 token endpoint URL. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.tokenKeyUrl | String | Required unless discoveryUrl is set. |
The URL of the token key endpoint which renders the JWKS (verification key for validating token signatures). This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.cacheJwks | Boolean | Used only if discoveryUrl or tokenKeyUrl is set. |
UAA 77.11.0. Option to enable caching for the JWKS (verification key for validating token signatures). Setting it to true increases UAA performance and is hence recommended. Setting it to false forces UAA to fetch the remote JWKS at each token validation, which impacts performance but may be required for when the remote JWKS changes very frequently. |
config.tokenKey | String | Required unless discoveryUrl is set. |
A verification key for validating token signatures. We recommend not setting this as it will not allow for key rotation. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.showLinkText | Boolean | Optional (defaults to true ) |
A flag controlling whether a link to this provider's login will be shown on the UAA login page |
config.linkText | String | Optional | Text to use for the login link to the provider |
config.relyingPartyId | String | Required | The client ID which is registered with the external OAuth provider for use by the UAA |
config.skipSslValidation | Boolean | Optional | A flag controlling whether SSL validation should be skipped when communicating with the external OAuth server |
config.scopes | Array | Optional | What scopes to request on a call to the external OAuth/OpenID provider. For example, can provide openid , roles , or profile to request ID token, scopes populated in the ID token external groups attribute mappings, or the user profile information, respectively. |
config.checkTokenUrl | Object | Optional | Reserved for future OAuth/OIDC use. |
config.clientAuthInBody | Boolean | Optional (defaults to false ) |
Only effective if relyingPartySecret is defined. Sends the client credentials in the token retrieval call as body parameters instead of a Basic Authorization header. It is recommended to set jwtClientAuthentication:true instead. |
config.pkce | Boolean | Optional (defaults to true ) |
A flag controlling whether PKCE (RFC 7636) is active in authorization code flow when requesting tokens from the external provider. |
config.performRpInitiatedLogout | Boolean | Optional (defaults to true ) |
A flag controlling whether to log out of the external provider after a successful UAA logout per OIDC RP-Initiated Logout |
config.userInfoUrl | Object | Optional | Reserved for future OIDC use. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.logoutUrl | Object | Optional | OIDC logout endpoint. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.responseType | String | Optional (defaults to "code" ) |
Response type for the authorize request, defaults to code , but can be code id_token if the OIDC server can return an id_token as a query parameter in the redirect. |
config.issuer | String | Optional | The OAuth 2.0 token issuer. This value is used to validate the issuer inside the token. |
config.userPropagationParameter | String | Optional (defaults to "username" ) |
Name of the request parameter that is used to pass a known username when redirecting to this identity provider from the account chooser |
config.externalGroupsWhitelist | Array | Optional | JSON Array containing the groups names which need to be populated in the user's id_token or response from /userinfo endpoint. If you don't specify the whitelist no groups will be populated in the id_token or /userinfo response.Please note that regex is allowed. Acceptable patterns are
|
config.passwordGrantEnabled | Boolean | Optional (defaults to false ) |
Enable Resource Owner Password Grant flow for this identity provider. |
config.tokenExchangeEnabled | Boolean | Optional (defaults to false ) |
Enable JWT Bearer Token Exchange Grant flow for this identity provider. |
config.setForwardHeader | Boolean | Optional (defaults to false ) |
Only effective if Password Grant enabled. Set X-Forward-For header in Password Grant request to this identity provider. |
config.authMethod | String | Optional (defaults to "client_secret_basic" ) |
UAA 77.10.0 Define an explicit method to authenticate against the identity provider. Supported values are client_secret_basic , client_secret_post , private_key_jwt , and none . Remark: If you switch the method from client_secret_basic to private_key_jwt or to none , your existing config.relyingPartySecret will be removed from UAA database. If you want to switch back to client_secret_basic , provide again a config.relyingPartySecret in the configuration. |
config.jwtClientAuthentication | Object | Required if config.authMethod is set to private_key_jwt |
UAA 76.5.0 Only effective if relyingPartySecret is not set or null. Creates private_key_jwt client authentication according to OIDC or OAuth2 (RFC 7523) standard. For standard OIDC compliance, set this field to true . Alternatively, you can further configure the created JWT for client authentication by setting this parameter to an Object containing sub-parameters, e.g. if your IdP follows OAuth2 standard according to RFC 7523. The supported sub-parameters are
The values in the list can be a reference to another section in uaa yaml, e.g. define for key a reference like ${"jwt.client.key"}. This will load the private key from yaml context jwt.client.key. The advantage is, that you can use a single key for many IdP configurations and the key itself is not persistent in the UAA DB. |
config.attributeMappings.user_name | String | Optional (defaults to "sub" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for OpenID Connect is sub . |
config.additionalAuthzParameters | Object | Optional | UAA 76.17.0Map of key-value pairs that are added as additional parameters for grant type authorization_code . For example, configure an entry with key token_format and value jwt . |
config.prompts[] | Array | Optional | List of fields that users are prompted on to the OIDC provider through the password grant flow. Defaults to username, password, and passcode. Any additional prompts beyond username, password, and passcode will be forwarded on to the OIDC provider. |
config.prompts[].name | String | Optional | Name of field |
config.prompts[].type | String | Optional | What kind of field this is (e.g. text or password) |
config.prompts[].text | String | Optional | Actual text displayed on prompt for field |
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.email | String | Optional | Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name | String | Optional | Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional | Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional | Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups | Array | Optional | Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] | String | Optional | Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set, an alias identity provider is created in the referenced zone and aliasId is set accordingly. |
config.relyingPartySecret | String | Required if config.authMethod is set to client_secret_basic . |
The client secret of the relying party at the external OAuth provider. If not set and jwtClientAuthentication is not set, then the external OAuth client is treated as public client and the flow is protected with PKCE using code challenge method S256 . It is recommended to set jwtClientAuthentication:true instead. |
Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | "oidc1.0" |
originKey | String | Required | A unique alias for the OIDC 1.0 provider |
config.discoveryUrl | String | Optional | The OpenID Connect Discovery URL, typically ends with /.well-known/openid-configurationmit |
config.authUrl | String | Required unless discoveryUrl is set. |
The OIDC 1.0 authorization endpoint URL. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.tokenUrl | String | Required unless discoveryUrl is set. |
The OIDC 1.0 token endpoint URL. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.tokenKeyUrl | String | Required unless discoveryUrl is set. |
The URL of the token key endpoint which renders the JWKS (verification key for validating token signatures). This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.cacheJwks | Boolean | Used only if discoveryUrl or tokenKeyUrl is set. |
UAA 77.11.0. Option to enable caching for the JWKS (verification key for validating token signatures). Setting it to true increases UAA performance and is hence recommended. Setting it to false forces UAA to fetch the remote JWKS at each token validation, which impacts performance but may be required for when the remote JWKS changes very frequently. |
config.tokenKey | String | Required unless discoveryUrl is set. |
A verification key for validating token signatures. We recommend not setting this as it will not allow for key rotation. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.showLinkText | Boolean | Optional (defaults to true ) |
A flag controlling whether a link to this provider's login will be shown on the UAA login page |
config.linkText | String | Optional | Text to use for the login link to the provider |
config.relyingPartyId | String | Required | The client ID which is registered with the external OAuth provider for use by the UAA |
config.skipSslValidation | Boolean | Optional | A flag controlling whether SSL validation should be skipped when communicating with the external OAuth server |
config.scopes | Array | Optional | What scopes to request on a call to the external OAuth/OpenID provider. For example, can provide openid , roles , or profile to request ID token, scopes populated in the ID token external groups attribute mappings, or the user profile information, respectively. |
config.checkTokenUrl | Object | Optional | Reserved for future OAuth/OIDC use. |
config.clientAuthInBody | Boolean | Optional (defaults to false ) |
Only effective if relyingPartySecret is defined. Sends the client credentials in the token retrieval call as body parameters instead of a Basic Authorization header. It is recommended to set jwtClientAuthentication:true instead. |
config.pkce | Boolean | Optional (defaults to true ) |
A flag controlling whether PKCE (RFC 7636) is active in authorization code flow when requesting tokens from the external provider. |
config.performRpInitiatedLogout | Boolean | Optional (defaults to true ) |
A flag controlling whether to log out of the external provider after a successful UAA logout per OIDC RP-Initiated Logout |
config.userInfoUrl | Object | Optional | Reserved for future OIDC use. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.logoutUrl | Object | Optional | OIDC logout endpoint. This can be left blank if a discovery URL is provided. If both are provided, this property overrides the discovery URL. |
config.responseType | String | Optional (defaults to "code" ) |
Response type for the authorize request, defaults to code , but can be code id_token if the OIDC server can return an id_token as a query parameter in the redirect. |
config.issuer | String | Optional | The OAuth 2.0 token issuer. This value is used to validate the issuer inside the token. |
config.userPropagationParameter | String | Optional (defaults to "username" ) |
Name of the request parameter that is used to pass a known username when redirecting to this identity provider from the account chooser |
config.externalGroupsWhitelist | Array | Optional | JSON Array containing the groups names which need to be populated in the user's id_token or response from /userinfo endpoint. If you don't specify the whitelist no groups will be populated in the id_token or /userinfo response.Please note that regex is allowed. Acceptable patterns are
|
config.passwordGrantEnabled | Boolean | Optional (defaults to false ) |
Enable Resource Owner Password Grant flow for this identity provider. |
config.tokenExchangeEnabled | Boolean | Optional (defaults to false ) |
Enable JWT Bearer Token Exchange Grant flow for this identity provider. |
config.setForwardHeader | Boolean | Optional (defaults to false ) |
Only effective if Password Grant enabled. Set X-Forward-For header in Password Grant request to this identity provider. |
config.authMethod | String | Optional (defaults to "client_secret_basic" ) |
UAA 77.10.0 Define an explicit method to authenticate against the identity provider. Supported values are client_secret_basic , client_secret_post , private_key_jwt , and none . Remark: If you switch the method from client_secret_basic to private_key_jwt or to none , your existing config.relyingPartySecret will be removed from UAA database. If you want to switch back to client_secret_basic , provide again a config.relyingPartySecret in the configuration. |
config.jwtClientAuthentication | Object | Required if config.authMethod is set to private_key_jwt |
UAA 76.5.0 Only effective if relyingPartySecret is not set or null. Creates private_key_jwt client authentication according to OIDC or OAuth2 (RFC 7523) standard. For standard OIDC compliance, set this field to true . Alternatively, you can further configure the created JWT for client authentication by setting this parameter to an Object containing sub-parameters, e.g. if your IdP follows OAuth2 standard according to RFC 7523. The supported sub-parameters are
The values in the list can be a reference to another section in uaa yaml, e.g. define for key a reference like ${"jwt.client.key"}. This will load the private key from yaml context jwt.client.key. The advantage is, that you can use a single key for many IdP configurations and the key itself is not persistent in the UAA DB. |
config.attributeMappings.user_name | String | Optional (defaults to "sub" ) |
Map user_name to the attribute for user name in the provider assertion or token. The default for OpenID Connect is sub . |
config.additionalAuthzParameters | Object | Optional | UAA 76.17.0Map of key-value pairs that are added as additional parameters for grant type authorization_code . For example, configure an entry with key token_format and value jwt . |
config.prompts[] | Array | Optional | List of fields that users are prompted on to the OIDC provider through the password grant flow. Defaults to username, password, and passcode. Any additional prompts beyond username, password, and passcode will be forwarded on to the OIDC provider. |
config.prompts[].name | String | Optional | Name of field |
config.prompts[].type | String | Optional | What kind of field this is (e.g. text or password) |
config.prompts[].text | String | Optional | Actual text displayed on prompt for field |
config.attributeMappings | Object | Optional | Map external attribute to UAA recognized mappings. |
config.attributeMappings.email | String | Optional | Map email to the attribute for email in the provider assertion or token. |
config.attributeMappings.given_name | String | Optional | Map given_name to the attribute for given name in the provider assertion or token. |
config.attributeMappings.family_name | String | Optional | Map family_name to the attribute for family name in the provider assertion or token. |
config.attributeMappings.phone_number | String | Optional | Map phone_number to the attribute for phone number in the provider assertion or token. |
config.attributeMappings.email_verified | String | Optional | Maps the attribute on the assertion to the email_verified user record at the time of authentication. Default is false. Once set to true, record remains true for subsequent authentications. |
config.attributeMappings.external_groups | Array | Optional | Map external_groups to the attribute for groups in the provider assertion. |
config.attributeMappings['user.attribute.department'] | String | Optional | Map external attribute to UAA recognized mappings. Mapping should be of the format user.attribute.<attribute_name> . department is used in the documentation as an example attribute. |
aliasId | String | Optional | The ID of the alias IdP. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set, an alias identity provider is created in the referenced zone and aliasId is set accordingly. |
config.relyingPartySecret | String | Required if config.authMethod is set to client_secret_basic . |
The client secret of the relying party at the external OAuth provider. If not set and jwtClientAuthentication is not set, then the external OAuth client is treated as public client and the flow is protected with PKCE using code challenge method S256 . It is recommended to set jwtClientAuthentication:true instead. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
409 | Conflict - Provider with same origin and zone id exists |
422 | Unprocessable Entity - Invalid configuration |
500 | Internal Server Error |
Retrieve All
$ curl 'http://localhost/identity-providers?rawConfig=false' -i -X GET \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 4be4b7ba42864741835832dea1b4e1f7'
GET /identity-providers?rawConfig=false HTTP/1.1
Content-Type: application/json
Authorization: Bearer 4be4b7ba42864741835832dea1b4e1f7
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 22238
[ {
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\" encoding=\\\"UTF-8\\\"?><md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" entityID=\\\"http://www.okta.com/SAML\\\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\\\"true\\\" protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\"><md:KeyDescriptor use=\\\"signing\\\"><ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/></md:IDPSSODescriptor></md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"SAML\",\"zoneId\":\"uaa\",\"nameID\":\"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\",\"assertionConsumerIndex\":0,\"metadataTrustCheck\":false,\"showSamlLink\":false,\"linkText\":\"IDPEndpointsMockTests Saml Provider:SAML\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":false,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "3f01d699-e78d-4e04-8e6f-e1ce51596f88",
"originKey" : "SAML",
"name" : "SAML name",
"version" : 0,
"created" : 1760712927343,
"last_modified" : 1760712927343,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\"?>\\n<md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\" entityID=\\\"http://example.com/saml2/idp/metadata.php\\\" ID=\\\"_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\\\"><ds:Signature>\\n <ds:SignedInfo><ds:CanonicalizationMethod Algorithm=\\\"http://www.w3.org/2001/10/xml-exc-c14n#\\\"/>\\n <ds:SignatureMethod Algorithm=\\\"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\\\"/>\\n <ds:Reference URI=\\\"#_7a1d882b1a0cb702f97968d831d70eecce036d6d0c249ae65cca0e91f5656d58\\\"><ds:Transforms><ds:Transform Algorithm=\\\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\\\"/><ds:Transform Algorithm=\\\"http://www.w3.org/2001/10/xml-exc-c14n#\\\"/></ds:Transforms><ds:DigestMethod Algorithm=\\\"http://www.w3.org/2001/04/xmlenc#sha256\\\"/><ds:DigestValue>HOSWDJYkLvErI1gVynUVmufFVDCKPqExLnnnMjXgoJQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ryMe0PXC+vR/c0nSEhSJsTaF0lHiuZ6PguqCbul7RC9WKLmFS9DD7Dgp3WHQ2zWpRimCTHxw/VO9hyCTxAcW9zxW4OdpD4YorqcmXtLkpasBCVuFLbQ8oylnjrem4kpGflfnuk3bW1mp6AXy52jwALDm8MsTwLK+O74YkeVTPP5bki/PK0N4jHnhYhvhHKUyT8Gug0v2o4KA/1ik83e9vcYEFc/9WGpXFeDMF6pXsJQqC/+eWoLfZJDNrwSsSlg+oD+ZF91YccN9i9lJoaIPcVvPWDfEv7vL79LgnmPBeYxm/fWb4/ANMxvCLIP1R3Ixrz5oFoIX2NP1+uZOpoRWbg==</ds:SignatureValue>\\n<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature>\\n <md:IDPSSODescriptor protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\">\\n <md:KeyDescriptor use=\\\"signing\\\">\\n <ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\">\\n <ds:X509Data>\\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\\n </ds:X509Data>\\n </ds:KeyInfo>\\n </md:KeyDescriptor>\\n <md:KeyDescriptor use=\\\"encryption\\\">\\n <ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\">\\n <ds:X509Data>\\n <ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate>\\n </ds:X509Data>\\n </ds:KeyInfo>\\n </md:KeyDescriptor>\\n <md:SingleLogoutService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"http://example.com/saml2/idp/SingleLogoutService.php\\\"/>\\n <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</md:NameIDFormat>\\n <md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"http://example.com/saml2/idp/SSOService.php\\\"/>\\n </md:IDPSSODescriptor>\\n <md:ContactPerson contactType=\\\"technical\\\">\\n <md:GivenName>Filip</md:GivenName>\\n <md:SurName>Hanik</md:SurName>\\n <md:EmailAddress>[email protected]</md:EmailAddress>\\n </md:ContactPerson>\\n</md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"SAMLMetadataUrl\",\"zoneId\":\"uaa\",\"nameID\":\"urn:oasis:names:tc:SAML:1.1:nameid-format:transient\",\"assertionConsumerIndex\":0,\"metadataTrustCheck\":false,\"showSamlLink\":false,\"linkText\":\"IDPEndpointsMockTests Saml Provider:SAML\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":false,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "e45c2a28-a45f-423e-a8ac-5ec4beea58ce",
"originKey" : "SAMLMetadataUrl",
"name" : "SAML name",
"version" : 0,
"created" : 1760712927464,
"last_modified" : 1760712927464,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "keystone",
"config" : "null",
"id" : "4a48cc45-d8aa-4212-9a7e-a187755cc2f8",
"originKey" : "keystone",
"name" : "keystone",
"version" : 0,
"created" : 946684800000,
"last_modified" : 946684800000,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "ldap",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[\"*\"],\"attributeMappings\":{},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"ldapProfileFile\":\"ldap/ldap-search-and-bind.xml\",\"baseUrl\":\"ldap://localhost:389/\",\"referral\":null,\"skipSSLVerification\":false,\"userDNPattern\":null,\"userDNPatternDelimiter\":null,\"bindUserDn\":\"cn=admin,dc=test,dc=com\",\"userSearchBase\":\"dc=test,dc=com\",\"userSearchFilter\":\"cn={0}\",\"passwordAttributeName\":null,\"passwordEncoder\":null,\"localPasswordCompare\":null,\"mailAttributeName\":\"mail\",\"mailSubstitute\":null,\"mailSubstituteOverridesLdap\":false,\"ldapGroupFile\":\"ldap/ldap-groups-as-scopes.xml\",\"groupSearchBase\":\"dc=test,dc=com\",\"groupSearchFilter\":\"member={0}\",\"groupsIgnorePartialResults\":null,\"autoAddGroups\":true,\"groupSearchSubTree\":true,\"maxGroupSearchDepth\":10,\"groupRoleAttribute\":\"cn\",\"tlsConfiguration\":\"none\"}",
"id" : "1ed67b40-3670-4fc3-b661-7330ac4b7729",
"originKey" : "ldap",
"name" : "UAA LDAP Provider",
"version" : 1,
"created" : 946684800000,
"last_modified" : 1760712926774,
"active" : false,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "login-server",
"config" : "null",
"id" : "45770705-0c00-4fd5-a094-8c5327372990",
"originKey" : "login-server",
"name" : "login-server",
"version" : 0,
"created" : 946684800000,
"last_modified" : 946684800000,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "oauth2.0",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"authUrl\":\"http://auth.url\",\"tokenUrl\":\"http://token.url\",\"tokenKeyUrl\":null,\"tokenKey\":\"token-key\",\"userInfoUrl\":null,\"logoutUrl\":null,\"linkText\":null,\"showLinkText\":false,\"clientAuthInBody\":false,\"skipSslValidation\":false,\"relyingPartyId\":\"uaa\",\"scopes\":null,\"issuer\":null,\"responseType\":\"code\",\"userPropagationParameter\":\"username\",\"pkce\":true,\"performRpInitiatedLogout\":true,\"authMethod\":\"client_secret_basic\",\"cacheJwks\":true,\"checkTokenUrl\":null}",
"id" : "cf857694-753f-4a74-823b-2dd0e54bcfc6",
"originKey" : "my-oauth2-provider",
"name" : "UAA Provider",
"version" : 0,
"created" : 1760712928359,
"last_modified" : 1760712928359,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "oidc1.0",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[\"uaa.user\"],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"authUrl\":null,\"tokenUrl\":null,\"tokenKeyUrl\":null,\"tokenKey\":null,\"userInfoUrl\":null,\"logoutUrl\":null,\"linkText\":null,\"showLinkText\":false,\"clientAuthInBody\":false,\"skipSslValidation\":true,\"relyingPartyId\":\"uaa\",\"scopes\":null,\"issuer\":null,\"responseType\":\"code\",\"userPropagationParameter\":\"username\",\"pkce\":true,\"performRpInitiatedLogout\":true,\"authMethod\":\"client_secret_basic\",\"cacheJwks\":true,\"discoveryUrl\":\"https://accounts.google.com/.well-known/openid-configuration\",\"passwordGrantEnabled\":false,\"setForwardHeader\":false,\"tokenExchangeEnabled\":null,\"prompts\":[{\"name\":\"username\",\"type\":\"text\",\"text\":\"Email\"},{\"name\":\"password\",\"type\":\"password\",\"text\":\"Password\"},{\"name\":\"passcode\",\"type\":\"password\",\"text\":\"Temporary Authentication Code (Get on at /passcode)\"}]}",
"id" : "6c72189b-5d24-43c6-9394-1437af3a8cb1",
"originKey" : "my-oidc-provider-8drzq5",
"name" : "UAA Provider",
"version" : 0,
"created" : 1760712928427,
"last_modified" : 1760712928427,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\"?><md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" entityID=\\\"https://some.idp.test/saml2/idp\\\"><md:IDPSSODescriptor protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\"><md:KeyDescriptor use=\\\"signing\\\"><ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\"><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\\\" Location=\\\"https://www.cloudfoundry.org\\\"/></md:IDPSSODescriptor></md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"testsaml-post-binding\",\"zoneId\":\"uaa\",\"nameID\":null,\"assertionConsumerIndex\":0,\"metadataTrustCheck\":true,\"showSamlLink\":true,\"linkText\":\"testsaml-post-binding\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":true,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "894c79d6-7dd4-4d79-a73b-8094f49e7891",
"originKey" : "testsaml-post-binding",
"name" : "UAA SAML Identity Provider[testsaml-post-binding]",
"version" : 0,
"created" : 1760712926779,
"last_modified" : 1760712926779,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\"?><md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" entityID=\\\"https://some.idp.test/saml/idp\\\"><md:IDPSSODescriptor protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\"><md:KeyDescriptor use=\\\"signing\\\"><ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\"><ds:X509Data><ds:X509Certificate>MIIEEzCCAvugAwIBAgIJAIc1qzLrv+5nMA0GCSqGSIb3DQEBCwUAMIGfMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ08xFDASBgNVBAcMC0Nhc3RsZSBSb2NrMRwwGgYDVQQKDBNTYW1sIFRlc3RpbmcgU2VydmVyMQswCQYDVQQLDAJJVDEgMB4GA1UEAwwXc2ltcGxlc2FtbHBocC5jZmFwcHMuaW8xIDAeBgkqhkiG9w0BCQEWEWZoYW5pa0BwaXZvdGFsLmlvMB4XDTE1MDIyMzIyNDUwM1oXDTI1MDIyMjIyNDUwM1owgZ8xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDTzEUMBIGA1UEBwwLQ2FzdGxlIFJvY2sxHDAaBgNVBAoME1NhbWwgVGVzdGluZyBTZXJ2ZXIxCzAJBgNVBAsMAklUMSAwHgYDVQQDDBdzaW1wbGVzYW1scGhwLmNmYXBwcy5pbzEgMB4GCSqGSIb3DQEJARYRZmhhbmlrQHBpdm90YWwuaW8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC4cn62E1xLqpN34PmbrKBbkOXFjzWgJ9b+pXuaRft6A339uuIQeoeH5qeSKRVTl32L0gdz2ZivLwZXW+cqvftVW1tvEHvzJFyxeTW3fCUeCQsebLnA2qRa07RkxTo6Nf244mWWRDodcoHEfDUSbxfTZ6IExSojSIU2RnD6WllYWFdD1GFpBJOmQB8rAc8wJIBdHFdQnX8Ttl7hZ6rtgqEYMzYVMuJ2F2r1HSU1zSAvwpdYP6rRGFRJEfdA9mm3WKfNLSc5cljz0X/TXy0vVlAV95l9qcfFzPmrkNIst9FZSwpvB49LyAVke04FQPPwLgVH4gphiJH3jvZ7I+J5lS8VAgMBAAGjUDBOMB0GA1UdDgQWBBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAfBgNVHSMEGDAWgBTTyP6Cc5HlBJ5+ucVCwGc5ogKNGzAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAvMS4EQeP/ipV4jOG5lO6/tYCb/iJeAduOnRhkJk0DbX329lDLZhTTL/x/w/9muCVcvLrzEp6PN+VWfw5E5FWtZN0yhGtP9R+vZnrV+oc2zGD+no1/ySFOe3EiJCO5dehxKjYEmBRv5sU/LZFKZpozKN/BMEa6CqLuxbzb7ykxVr7EVFXwltPxzE9TmL9OACNNyF5eJHWMRMllarUvkcXlh4pux4ks9e6zV9DQBy2zds9f1I3qxg0eX6JnGrXi/ZiCT+lJgVe3ZFXiejiLAiKB04sXW3ti0LW3lx13Y1YlQ4/tlpgTgfIJxKV6nyPiLoK0nywbMd+vpAirDt2Oc+hk</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"https://www.cloudfoundry.org\\\"/></md:IDPSSODescriptor></md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"testsaml-redirect-binding\",\"zoneId\":\"uaa\",\"nameID\":null,\"assertionConsumerIndex\":0,\"metadataTrustCheck\":true,\"showSamlLink\":true,\"linkText\":\"testsaml-redirect-binding\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":true,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "fed168a1-5ae4-4bf7-b7d1-31b763f8a509",
"originKey" : "testsaml-redirect-binding",
"name" : "UAA SAML Identity Provider[testsaml-redirect-binding]",
"version" : 0,
"created" : 1760712926777,
"last_modified" : 1760712926777,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}, {
"type" : "uaa",
"config" : "null",
"id" : "b6fa3bf1-84cc-491b-8629-1984142adb64",
"originKey" : "uaa",
"name" : "uaa",
"version" : 3,
"created" : 946684800000,
"last_modified" : 1760712928510,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or zones.<zone id>.idps.read or uaa.admin or idps.read (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or zones.<zone id>.idps.read or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Response Fields
Path | Type | Description |
---|---|---|
[].type |
String |
Type of the identity provider. |
[].originKey |
String |
Unique identifier for the identity provider. |
[].name |
String |
Human-readable name for this provider |
[].config |
String |
Json config for the Identity Provider |
[].aliasId |
String |
The ID of the alias IdP. |
[].aliasZid |
String |
The ID of the identity zone in which an alias of this IdP is maintained. |
[].version |
Number |
Version of the identity provider data. Clients can use this to protect against conflicting updates |
[].active |
Boolean |
Defaults to true. |
[].id |
String |
Unique identifier for this provider - GUID generated by the UAA |
[].identityZoneId |
String |
Set to the zone that this provider will be active in. Determined either by the Host header or the zone switch header. |
[].created |
Number |
UAA sets the creation date |
[].last_modified |
Number |
UAA sets the modification date |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
Retrieve with Filtering
$ curl 'http://localhost/identity-providers?rawConfig=false&active_only=false&originKey=my-oauth2-provider' -i -X GET \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer c28e0e9823e348029629392d491439dd'
GET /identity-providers?rawConfig=false&active_only=false&originKey=my-oauth2-provider HTTP/1.1
Content-Type: application/json
Authorization: Bearer c28e0e9823e348029629392d491439dd
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1267
[ {
"type" : "oauth2.0",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"authUrl\":\"http://auth.url\",\"tokenUrl\":\"http://token.url\",\"tokenKeyUrl\":null,\"tokenKey\":\"token-key\",\"userInfoUrl\":null,\"logoutUrl\":null,\"linkText\":null,\"showLinkText\":false,\"clientAuthInBody\":false,\"skipSslValidation\":false,\"relyingPartyId\":\"uaa\",\"scopes\":null,\"issuer\":null,\"responseType\":\"code\",\"userPropagationParameter\":\"username\",\"pkce\":true,\"performRpInitiatedLogout\":true,\"authMethod\":\"client_secret_basic\",\"cacheJwks\":true,\"checkTokenUrl\":null}",
"id" : "cf857694-753f-4a74-823b-2dd0e54bcfc6",
"originKey" : "my-oauth2-provider",
"name" : "UAA Provider",
"version" : 0,
"created" : 1760712928359,
"last_modified" : 1760712928359,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or zones.<zone id>.idps.read or uaa.admin or idps.read (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or zones.<zone id>.idps.read or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
active_only |
Flag indicating whether only active IdPs should be returned or all. |
originKey |
UAA 77.10.0 Return only IdPs with specific origin. |
Response Fields
Path | Type | Description |
---|---|---|
[].type |
String |
Type of the identity provider. |
[].originKey |
String |
Unique identifier for the identity provider. |
[].name |
String |
Human-readable name for this provider |
[].config |
String |
Json config for the Identity Provider |
[].aliasId |
String |
The ID of the alias IdP. |
[].aliasZid |
String |
The ID of the identity zone in which an alias of this IdP is maintained. |
[].version |
Number |
Version of the identity provider data. Clients can use this to protect against conflicting updates |
[].active |
Boolean |
Defaults to true. |
[].id |
String |
Unique identifier for this provider - GUID generated by the UAA |
[].identityZoneId |
String |
Set to the zone that this provider will be active in. Determined either by the Host header or the zone switch header. |
[].created |
Number |
UAA sets the creation date |
[].last_modified |
Number |
UAA sets the modification date |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
Retrieve
$ curl 'http://localhost/identity-providers/770bb7d4-1c7b-4f6e-9deb-cffd18c7882e?rawConfig=false' -i -X GET \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer b3a1772c80a84f5595ec8762f9987d98'
GET /identity-providers/770bb7d4-1c7b-4f6e-9deb-cffd18c7882e?rawConfig=false HTTP/1.1
Content-Type: application/json
Authorization: Bearer b3a1772c80a84f5595ec8762f9987d98
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 3248
{
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\" encoding=\\\"UTF-8\\\"?><md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" entityID=\\\"http://www.okta.com/saml-for-get\\\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\\\"true\\\" protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\"><md:KeyDescriptor use=\\\"signing\\\"><ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/></md:IDPSSODescriptor></md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"saml-for-get\",\"zoneId\":\"uaa\",\"nameID\":\"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\",\"assertionConsumerIndex\":0,\"metadataTrustCheck\":false,\"showSamlLink\":false,\"linkText\":\"IDPEndpointsMockTests Saml Provider:saml-for-get\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":false,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "770bb7d4-1c7b-4f6e-9deb-cffd18c7882e",
"originKey" : "saml-for-get",
"name" : "saml-for-get name",
"version" : 0,
"created" : 1760712928262,
"last_modified" : 1760712928262,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Path Parameters
/identity-providers/{id}
Parameter | Description |
---|---|
id | Unique identifier for this provider - GUID generated by the UAA |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or zones.<zone id>.idps.read or uaa.admin or idps.read (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or zones.<zone id>.idps.read or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Response Fields
Path | Type | Description |
---|---|---|
name |
String |
Human-readable name for this provider |
config.providerDescription |
String |
Human readable name/description of this provider |
config.emailDomain |
Array |
List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active |
Boolean |
Defaults to true. |
config.addShadowUserOnLogin |
Boolean |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes |
Boolean |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type |
String |
Type of the identity provider. |
originKey |
String |
Unique identifier for the identity provider. |
config |
String |
Various configuration properties for the identity provider. |
config.additionalConfiguration |
Object |
(Unused.) |
version |
Number |
Version of the identity provider data. Clients can use this to protect against conflicting updates |
id |
String |
Unique identifier for this provider - GUID generated by the UAA |
identityZoneId |
String |
Set to the zone that this provider will be active in. Determined either by the Host header or the zone switch header. |
created |
Number |
UAA sets the creation date |
last_modified |
Number |
UAA sets the modification date |
aliasId |
String |
The ID of the alias IdP. |
aliasZid |
String |
The ID of the identity zone in which an alias of this IdP is maintained. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
Update
$ curl 'http://localhost/identity-providers/b6fa3bf1-84cc-491b-8629-1984142adb64?rawConfig=true' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer d4a2ace619004cf1a0e71d9fbb4c22bb' \
-d '{"type":"uaa","config":{"emailDomain":null,"providerDescription":null,"passwordPolicy":null,"lockoutPolicy":{"lockoutPeriodSeconds":8,"lockoutAfterFailures":8,"countFailuresWithin":8},"disableInternalUserManagement":false},"originKey":"uaa","name":"uaa","version":3,"active":true,"aliasId":null,"aliasZid":null}'
PUT /identity-providers/b6fa3bf1-84cc-491b-8629-1984142adb64?rawConfig=true HTTP/1.1
Content-Type: application/json
Authorization: Bearer d4a2ace619004cf1a0e71d9fbb4c22bb
Content-Length: 311
Host: localhost
{"type":"uaa","config":{"emailDomain":null,"providerDescription":null,"passwordPolicy":null,"lockoutPolicy":{"lockoutPeriodSeconds":8,"lockoutAfterFailures":8,"countFailuresWithin":8},"disableInternalUserManagement":false},"originKey":"uaa","name":"uaa","version":3,"active":true,"aliasId":null,"aliasZid":null}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 600
{
"type" : "uaa",
"config" : {
"emailDomain" : null,
"additionalConfiguration" : null,
"providerDescription" : null,
"passwordPolicy" : null,
"lockoutPolicy" : {
"lockoutPeriodSeconds" : 8,
"lockoutAfterFailures" : 8,
"countFailuresWithin" : 8
},
"disableInternalUserManagement" : false
},
"id" : "b6fa3bf1-84cc-491b-8629-1984142adb64",
"originKey" : "uaa",
"name" : "uaa",
"version" : 4,
"created" : 946684800000,
"last_modified" : 1760712929090,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Path Parameters
/identity-providers/{id}
Parameter | Description |
---|---|
id | Unique identifier for this provider - GUID generated by the UAA |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
rawConfig |
UAA 3.4.0 Flag indicating whether the response should use raw, unescaped JSON for the config field of the IDP, rather than the default behavior of encoding the JSON as a string. |
Request and Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
name | String | Required | Human-readable name for this provider |
config.providerDescription | String | Optional | Human readable name/description of this provider |
config.emailDomain | Array | Optional | List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active | Boolean | Optional | Defaults to true. |
config.addShadowUserOnLogin | Boolean | Optional (defaults to true ) |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes | Boolean | Optional (defaults to true ) |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type | String | Required | uaa |
originKey | String | Required | A unique identifier for the IDP. Cannot be updated. |
version | Number | Required | Version of the identity provider data. Clients can use this to protect against conflicting updates |
config.passwordPolicy.minLength | Number | Required when passwordPolicy in the config is not null |
Minimum number of characters required for password to be considered valid (defaults to 0). |
config.passwordPolicy.maxLength | Number | Required when passwordPolicy in the config is not null |
Maximum number of characters required for password to be considered valid (defaults to 255). |
config.passwordPolicy.requireUpperCaseCharacter | Number | Required when passwordPolicy in the config is not null |
Minimum number of uppercase characters required for password to be considered valid (defaults to 0). |
config.passwordPolicy.requireLowerCaseCharacter | Number | Required when passwordPolicy in the config is not null |
Minimum number of lowercase characters required for password to be considered valid (defaults to 0). |
config.passwordPolicy.requireDigit | Number | Required when passwordPolicy in the config is not null |
Minimum number of digits required for password to be considered valid (defaults to 0). |
config.passwordPolicy.requireSpecialCharacter | Number | Required when passwordPolicy in the config is not null |
Minimum number of special characters required for password to be considered valid (defaults to 0). |
config.passwordPolicy.expirePasswordInMonths | Number | Required when passwordPolicy in the config is not null |
Number of months after which current password expires (defaults to 0). |
config.passwordPolicy.passwordNewerThan | Number | Required when passwordPolicy in the config is not null |
This timestamp value can be used to force change password for every user. If the user's passwordLastModified is older than this value, the password is expired (defaults to null). |
config.lockoutPolicy.lockoutPeriodSeconds | Number | Required when LockoutPolicy in the config is not null |
Number of seconds in which lockoutAfterFailures failures must occur in order for account to be locked (defaults to 3600). |
config.lockoutPolicy.lockoutAfterFailures | Number | Required when LockoutPolicy in the config is not null |
Number of allowed failures before account is locked (defaults to 5). |
config.lockoutPolicy.countFailuresWithin | Number | Required when LockoutPolicy in the config is not null |
Number of seconds to lock out an account when lockoutAfterFailures failures is exceeded (defaults to 300). |
config.disableInternalUserManagement | Boolean | Optional | When set to true, user management is disabled for this provider, defaults to false |
aliasId | String | Optional | The ID of the alias IdP. The aliasId value of the existing identity provider must be left unchanged. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this IdP is maintained. Defaults to null . Only supported for identity providers of type "saml", "oidc1.0" and "oauth2.0". If set, the field must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias identity providers can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". If set and the identity provider did not reference an alias before, an alias identity provider is created in the referenced zone and aliasId is set accordingly. If the identity provider already referenced an alias identity provider before the update, this field must be left unchanged. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
422 | Unprocessable Entity - Invalid config or updating IdP with alias while aliasEntitiesEnabled is false |
Delete
$ curl 'http://localhost/identity-providers/8d7aa746-8a64-47a3-a939-725135f9446a' -i -X DELETE \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 0d62463e0dbb4e2f842cd32fd9aff1c9'
DELETE /identity-providers/8d7aa746-8a64-47a3-a939-725135f9446a HTTP/1.1
Content-Type: application/json
Authorization: Bearer 0d62463e0dbb4e2f842cd32fd9aff1c9
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 3263
{
"type" : "saml",
"config" : "{\"emailDomain\":null,\"additionalConfiguration\":null,\"providerDescription\":null,\"externalGroupsWhitelist\":[],\"attributeMappings\":{\"email_verified\":\"emailVerified\",\"external_groups\":[\"roles\"],\"user.attribute.department\":\"department\",\"phone_number\":\"telephone\",\"given_name\":\"first_name\",\"family_name\":\"last_name\",\"email\":\"emailAddress\"},\"addShadowUserOnLogin\":true,\"storeCustomAttributes\":true,\"metaDataLocation\":\"<?xml version=\\\"1.0\\\" encoding=\\\"UTF-8\\\"?><md:EntityDescriptor xmlns:md=\\\"urn:oasis:names:tc:SAML:2.0:metadata\\\" entityID=\\\"http://www.okta.com/saml-for-delete\\\"><md:IDPSSODescriptor WantAuthnRequestsSigned=\\\"true\\\" protocolSupportEnumeration=\\\"urn:oasis:names:tc:SAML:2.0:protocol\\\"><md:KeyDescriptor use=\\\"signing\\\"><ds:KeyInfo xmlns:ds=\\\"http://www.w3.org/2000/09/xmldsig#\\\"><ds:X509Data><ds:X509Certificate>MIICmTCCAgKgAwIBAgIGAUPATqmEMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG\\nA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU\\nMBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB1Bpdm90YWwxHDAaBgkqhkiG9w0BCQEWDWlu\\nZm9Ab2t0YS5jb20wHhcNMTQwMTIzMTgxMjM3WhcNNDQwMTIzMTgxMzM3WjCBjzELMAkGA1UEBhMC\\nVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM\\nBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAdQaXZvdGFsMRwwGgYJKoZIhvcN\\nAQkBFg1pbmZvQG9rdGEuY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCeil67/TLOiTZU\\nWWgW2XEGgFZ94bVO90v5J1XmcHMwL8v5Z/8qjdZLpGdwI7Ph0CyXMMNklpaR/Ljb8fsls3amdT5O\\nBw92Zo8ulcpjw2wuezTwL0eC0wY/GQDAZiXL59npE6U+fH1lbJIq92hx0HJSru/0O1q3+A/+jjZL\\n3tL/SwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAI5BoWZoH6Mz9vhypZPOJCEKa/K+biZQsA4Zqsuk\\nvvphhSERhqk/Nv76Vkl8uvJwwHbQrR9KJx4L3PRkGCG24rix71jEuXVGZUsDNM3CUKnARx4MEab6\\nGFHNkZ6DmoT/PFagngecHu+EwmuDtaG0rEkFrARwe+d8Ru0BN558abFb</ds:X509Certificate></ds:X509Data></ds:KeyInfo></md:KeyDescriptor><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat><md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/><md:SingleSignOnService Binding=\\\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\\\" Location=\\\"https://pivotal.oktapreview.com/app/pivotal_pivotalcfstaging_1/k2lw4l5bPODCMIIDBRYZ/sso/saml\\\"/></md:IDPSSODescriptor></md:EntityDescriptor>\\n\",\"idpEntityAlias\":\"saml-for-delete\",\"zoneId\":\"uaa\",\"nameID\":\"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\",\"assertionConsumerIndex\":0,\"metadataTrustCheck\":false,\"showSamlLink\":false,\"linkText\":\"IDPEndpointsMockTests Saml Provider:saml-for-delete\",\"iconUrl\":null,\"groupMappingMode\":\"EXPLICITLY_MAPPED\",\"skipSslValidation\":false,\"authnContext\":null,\"socketFactoryClassName\":null}",
"id" : "8d7aa746-8a64-47a3-a939-725135f9446a",
"originKey" : "saml-for-delete",
"name" : "saml-for-delete name",
"version" : 0,
"created" : 1760712929021,
"last_modified" : 1760712929021,
"active" : true,
"identityZoneId" : "uaa",
"aliasId" : null,
"aliasZid" : null
}
Path Parameters
/identity-providers/{id}
Parameter | Description |
---|---|
id | Unique identifier for this provider - GUID generated by the UAA |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
name |
String |
Human-readable name for this provider |
config.providerDescription |
String |
Human readable name/description of this provider |
config.emailDomain |
Array |
List of email domains associated with the provider for the purpose of associating users to the correct origin upon invitation. If empty list, no invitations are accepted. Wildcards supported. |
active |
Boolean |
Defaults to true. |
config.addShadowUserOnLogin |
Boolean |
Determines whether users should be allowed to authenticate without having a user pre-populated in the users database (if true), or whether shadow users must be created before login by an administrator (if false). |
config.storeCustomAttributes |
Boolean |
Set to true, to store custom user attributes to be fetched from the /userinfo endpoint |
type |
String |
Type of the identity provider. |
originKey |
String |
Unique identifier for the identity provider. |
config |
String |
Various configuration properties for the identity provider. |
config.additionalConfiguration |
Object |
(Unused.) |
version |
Number |
Version of the identity provider data. Clients can use this to protect against conflicting updates |
id |
String |
Unique identifier for this provider - GUID generated by the UAA |
identityZoneId |
String |
Set to the zone that this provider will be active in. Determined either by the Host header or the zone switch header. |
created |
Number |
UAA sets the creation date |
last_modified |
Number |
UAA sets the modification date |
aliasId |
String |
The ID of the alias IdP. |
aliasZid |
String |
The ID of the identity zone in which an alias of this IdP is maintained. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
422 | Unprocessable Entity (e.g., deleting IdP with alias while aliasEntitiesEnabled is false) |
Force password change for Users
$ curl 'http://localhost/identity-providers/b6fa3bf1-84cc-491b-8629-1984142adb64/status' -i -X PATCH \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a2d2b264e68b47519e9ec8b8982c9868' \
-d '{"requirePasswordChange":true}'
PATCH /identity-providers/b6fa3bf1-84cc-491b-8629-1984142adb64/status HTTP/1.1
Content-Type: application/json
Authorization: Bearer a2d2b264e68b47519e9ec8b8982c9868
Content-Length: 30
Host: localhost
{"requirePasswordChange":true}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 36
{
"requirePasswordChange" : true
}
Path Parameters
/identity-providers/{id}/status
Parameter | Description |
---|---|
id | Unique identifier for this provider - GUID generated by the UAA |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing zones.<zone id>.admin or uaa.admin or idps.write (only in the same zone that you are a user of) |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request and Response Fields
Path | Type | Constraints | Description |
---|---|---|---|
requirePasswordChange | Boolean | Required | Set to true in order to force password change for all users. The passwordNewerThan property in PasswordPolicy of the IdentityProvider will be updated with current system time. If the user's passwordLastModified is older than this value, the password is expired. |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
422 | Unprocessable Entity - Invalid config |
Users
Users can be queried, created and updated via the /Users
endpoint.
Get
$ curl 'http://localhost/Users/c320f255-554f-480d-83ac-591c57573f35' -i -X GET \
-H 'Accept: application/json' \
-H 'Authorization: Bearer dcd8ade90df04bf8bcf722d34592fe98' \
-H 'Content-Type: application/json' \
-H 'If-Match: 0'
GET /Users/c320f255-554f-480d-83ac-591c57573f35 HTTP/1.1
Accept: application/json
Authorization: Bearer dcd8ade90df04bf8bcf722d34592fe98
Content-Type: application/json
If-Match: 0
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "0"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2880
{
"id" : "c320f255-554f-480d-83ac-591c57573f35",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:37.650Z",
"lastModified" : "2025-10-17T14:55:37.650Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ {
"userId" : "c320f255-554f-480d-83ac-591c57573f35",
"clientId" : "client id",
"scope" : "scim.read",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:55:37.654Z",
"expiresAt" : "2025-10-17T14:55:47.654Z"
}, {
"userId" : "c320f255-554f-480d-83ac-591c57573f35",
"clientId" : "identity",
"scope" : "uaa.user",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:56:07.655Z",
"expiresAt" : "2025-10-17T14:56:07.655Z"
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"previousLogonTime" : 1760712937656,
"lastLogonTime" : 1760712937656,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scope scim.read , uaa.admin , or zones.uaa.admin required |
If-Match |
The version of the SCIM object to be deleted. Optional. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
id |
String |
A guid generated by the UAA to uniquely identity this user. |
userName |
String |
User name of the user, typically an email address. |
name |
Object |
A map with the user's first name and last name. |
name.familyName |
String |
The user's last name. |
name.givenName |
String |
The user's first name. |
phoneNumbers |
Array |
The user's phone numbers. |
phoneNumbers[].value |
String |
The phone number. |
emails |
Array |
The user's email addresses. |
emails[].value |
String |
The email address. |
emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
groups |
Array |
A list of groups the user belongs to. |
groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
groups[].display |
String |
The group display name, also referred to as scope during authorization. |
groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
approvals[].userId |
String |
The user id on the approval. Will be the same as the id field. |
approvals[].clientId |
String |
The client id on the approval. Represents the application this approval or denial was for. |
approvals[].scope |
String |
The scope on the approval. Will be a group display value. |
approvals[].status |
String |
The status of the approval. Status may be either APPROVED or DENIED . |
approvals[].lastUpdatedAt |
String |
Date this approval was last updated. |
approvals[].expiresAt |
String |
Date this approval will expire. |
active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
passwordLastModified |
String |
The timestamp when this user's password was last changed. |
lastLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
previousLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
externalId |
String |
External user ID if authenticated through an external identity provider. |
aliasId |
String |
The ID of the alias user. |
aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
meta |
Object |
SCIM object meta data. |
meta.version |
Number |
Object version. |
meta.lastModified |
String |
Object last modified date. |
meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.read is required to retrieve a user) |
404 | Not Found - User id not found |
Example using uaac to get users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac user get testuser
List
Listing users supports SCIM filtering on the available attributes.
By default, users are returned with their group memberships and approvals, a rather expensive operation.
To avoid this, perform the search by including the attributes
parameter to reduce the results.
$ curl 'http://localhost/Users?filter=id+eq+%224c3dfb7b-1b50-4325-b85b-d5d5d8d62573%22+or+email+eq+%22m66RnF%40test.org%22&sortBy=email&count=50&sortOrder=ascending&startIndex=1' -i -X GET \
-H 'Accept: application/json' \
-H 'Authorization: Bearer ad3c5a138a1640d38cf4ee352322cf1c'
GET /Users?filter=id+eq+%224c3dfb7b-1b50-4325-b85b-d5d5d8d62573%22+or+email+eq+%22m66RnF%40test.org%22&sortBy=email&count=50&sortOrder=ascending&startIndex=1 HTTP/1.1
Accept: application/json
Authorization: Bearer ad3c5a138a1640d38cf4ee352322cf1c
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2962
{
"resources" : [ {
"id" : "4c3dfb7b-1b50-4325-b85b-d5d5d8d62573",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:37.248Z",
"lastModified" : "2025-10-17T14:55:37.248Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ {
"userId" : "4c3dfb7b-1b50-4325-b85b-d5d5d8d62573",
"clientId" : "client id",
"scope" : "scim.read",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:55:37.254Z",
"expiresAt" : "2025-10-17T14:55:47.254Z"
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"previousLogonTime" : 1760712937256,
"lastLogonTime" : 1760712937256,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
} ],
"startIndex" : 1,
"itemsPerPage" : 5,
"totalResults" : 1,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.read or uaa.admin required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
filter |
SCIM filter for searching |
sortBy |
Sorting field name, like email or id |
sortOrder |
Sort order, ascending/descending |
startIndex |
The starting index of the search results when paginated. Index starts with 1. |
count |
Max number of results to be returned |
Response Fields
Path | Type | Description |
---|---|---|
startIndex |
Number |
The starting index of the search results when paginated. Index starts with 1. |
itemsPerPage |
Number |
The maximum number of items returned per request. |
totalResults |
Number |
Number of results in result set. |
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
resources |
Array |
A list of SCIM user objects retrieved by the search. |
resources[].schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
resources[].id |
String |
A guid generated by the UAA to uniquely identity this user. |
resources[].userName |
String |
User name of the user, typically an email address. |
resources[].name |
Object |
A map with the user's first name and last name. |
resources[].name.familyName |
String |
The user's last name. |
resources[].name.givenName |
String |
The user's first name. |
resources[].phoneNumbers |
Array |
The user's phone numbers. |
resources[].phoneNumbers[].value |
String |
The phone number. |
resources[].emails |
Array |
The user's email addresses. |
resources[].emails[].value |
String |
The email address. |
resources[].emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
resources[].groups |
Array |
A list of groups the user belongs to. |
resources[].groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
resources[].groups[].display |
String |
The group display name, also referred to as scope during authorization. |
resources[].groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
resources[].approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
resources[].approvals[].userId |
String |
The user id on the approval. Will be the same as the id field. |
resources[].approvals[].clientId |
String |
The client id on the approval. Represents the application this approval or denial was for. |
resources[].approvals[].scope |
String |
The scope on the approval. Will be a group display value. |
resources[].approvals[].status |
String |
The status of the approval. Status may be either APPROVED or DENIED . |
resources[].approvals[].lastUpdatedAt |
String |
Date this approval was last updated. |
resources[].approvals[].expiresAt |
String |
Date this approval will expire. |
resources[].active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
resources[].lastLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
resources[].previousLogonTime |
Number |
The unix epoch timestamp in milliseconds of 2nd to last successful user authentication. This field will only be included in the response once the user has authenticated two or more times. |
resources[].verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
resources[].origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
resources[].zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
resources[].passwordLastModified |
String |
The timestamp when this user's password was last changed. |
resources[].externalId |
String |
External user ID if authenticated through an external identity provider. |
resources[].aliasId |
String |
The ID of the alias user. |
resources[].aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
resources[].meta |
Object |
SCIM object meta data. |
resources[].meta.version |
Number |
Object version. |
resources[].meta.lastModified |
String |
Object last modified date. |
resources[].meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.read is required to search users) |
Example using uaac to view users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac users
List with Attribute Filtering
Listing users supports SCIM filtering on the available attributes.
When users are searched we can return only selected amount of data using filtering.
The attribute groups
will cause the UAA to query the group memberships and include them in the result making the operation more expensive.
The attribute approvals
will cause the UAA to query the user approvals and include them in the result making the operation more expensive.
$ curl 'http://localhost/Users?attributes=id%2CuserName%2Cemails%2Cactive&filter=id+eq+%222977c0f8-d9c4-41b9-a16b-75e556ff922c%22&sortBy=email&count=50&sortOrder=ascending&startIndex=1' -i -X GET \
-H 'Accept: application/json' \
-H 'Authorization: Bearer b31b8bd161854282a9a1c922401fa0d8'
GET /Users?attributes=id%2CuserName%2Cemails%2Cactive&filter=id+eq+%222977c0f8-d9c4-41b9-a16b-75e556ff922c%22&sortBy=email&count=50&sortOrder=ascending&startIndex=1 HTTP/1.1
Accept: application/json
Authorization: Bearer b31b8bd161854282a9a1c922401fa0d8
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 334
{
"resources" : [ {
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"active" : true,
"id" : "2977c0f8-d9c4-41b9-a16b-75e556ff922c",
"userName" : "[email protected]"
} ],
"startIndex" : 1,
"itemsPerPage" : 5,
"totalResults" : 1,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.read or uaa.admin required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
filter |
SCIM filter for searching |
sortBy |
Sorting field name, like email or id |
sortOrder |
Sort order, ascending/descending |
startIndex |
The starting index of the search results when paginated. Index starts with 1. |
count |
Max number of results to be returned |
attributes |
Comma separated list of attribute names to be returned. |
Response Fields
Path | Type | Description |
---|---|---|
startIndex |
Number |
The starting index of the search results when paginated. Index starts with 1. |
itemsPerPage |
Number |
The maximum number of items returned per request. |
totalResults |
Number |
Number of results in result set. |
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
resources |
Array |
A list of SCIM user objects retrieved by the search. |
resources[].id |
String |
A guid generated by the UAA to uniquely identity this user. |
resources[].userName |
String |
User name of the user, typically an email address. |
resources[].emails |
Array |
The user's email addresses. |
resources[].emails[].value |
String |
The email address. |
resources[].emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
resources[].active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
Create
$ curl 'http://localhost/Users' -i -X POST \
-H 'Accept: application/json' \
-H 'Authorization: Bearer 5c63701f784542559c5bca9701dd59c5' \
-H 'Content-Type: application/json' \
-d '{
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.914Z"
},
"userName" : "[email protected]",
"name" : {
"formatted" : "given name family name",
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : true
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "",
"password" : "secret",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}'
POST /Users HTTP/1.1
Accept: application/json
Authorization: Bearer 5c63701f784542559c5bca9701dd59c5
Content-Type: application/json
Content-Length: 537
Host: localhost
{
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.914Z"
},
"userName" : "[email protected]",
"name" : {
"formatted" : "given name family name",
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : true
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "",
"password" : "secret",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "0"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2327
{
"id" : "8227b136-d723-44fd-b8dc-5efd04bdd7a2",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.920Z",
"lastModified" : "2025-10-17T14:55:36.920Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write or uaa.admin scope required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
userName | String | Required | User name of the user, typically an email address. |
password | String | Optional | User's password, required if origin is set to uaa . May be be subject to validations if the UAA is configured with a password policy. |
name | Object | Required | A map with the user's first name and last name. |
name.familyName | String | Optional | The user's last name. |
name.givenName | String | Optional | The user's first name. |
phoneNumbers | Array | Optional | The user's phone numbers. |
phoneNumbers[].value | String | Optional | The phone number. |
emails | Array | Required | The user's email addresses. |
emails[].value | String | Required | The email address. |
emails[].primary | Boolean | Required | Set to true if this is the user's primary email address. |
active | Boolean | Optional (defaults to true ) |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified | Boolean | Optional (defaults to true ) |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin | String | Optional (defaults to "uaa" ) |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
externalId | String | Optional | External user ID if authenticated through an external identity provider. |
aliasId | String | Optional | The ID of the alias user. Must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this user is maintained. If set, an alias user is created in this zone and aliasId is set accordingly. Must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias users can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". Furthermore, alias users can only be created if the IdP referenced in origin also has an alias to the same zone as the user. |
Response Fields
Path | Type | Description |
---|---|---|
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
id |
String |
A guid generated by the UAA to uniquely identity this user. |
userName |
String |
User name of the user, typically an email address. |
name |
Object |
A map with the user's first name and last name. |
name.familyName |
String |
The user's last name. |
name.givenName |
String |
The user's first name. |
phoneNumbers |
Array |
The user's phone numbers. |
phoneNumbers[].value |
String |
The phone number. |
emails |
Array |
The user's email addresses. |
emails[].value |
String |
The email address. |
emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
groups |
Array |
A list of groups the user belongs to. |
groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
groups[].display |
String |
The group display name, also referred to as scope during authorization. |
groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
passwordLastModified |
String |
The timestamp when this user's password was last changed. |
externalId |
String |
External user ID if authenticated through an external identity provider. |
aliasId |
String |
The ID of the alias user. |
aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
meta |
Object |
SCIM object meta data. |
meta.version |
Number |
Object version. |
meta.lastModified |
String |
Object last modified date. |
meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write is required to create a user) |
409 | Conflict - Username already exists |
422 | Unprocessable Entity - alias_zid set, but error occurred during creation of alias |
Example using uaac to view users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac user add testuser --given_name About --family_name Schmidt --emails [email protected] --password secret
Update
$ curl 'http://localhost/Users/a71f4e03-13e0-4f49-a6a9-c49639f6ca86' -i -X PUT \
-H 'Accept: application/json' \
-H 'Authorization: Bearer fec764dc68b940188693696f27804a7f' \
-H 'Content-Type: application/json' \
-H 'If-Match: 0' \
-d '{
"id" : "a71f4e03-13e0-4f49-a6a9-c49639f6ca86",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.829Z",
"lastModified" : "2025-10-17T14:55:36.829Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ ],
"approvals" : [ ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}'
PUT /Users/a71f4e03-13e0-4f49-a6a9-c49639f6ca86 HTTP/1.1
Accept: application/json
Authorization: Bearer fec764dc68b940188693696f27804a7f
Content-Type: application/json
If-Match: 0
Content-Length: 684
Host: localhost
{
"id" : "a71f4e03-13e0-4f49-a6a9-c49639f6ca86",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.829Z",
"lastModified" : "2025-10-17T14:55:36.829Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ ],
"approvals" : [ ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2804
{
"id" : "a71f4e03-13e0-4f49-a6a9-c49639f6ca86",
"externalId" : "test-user",
"meta" : {
"version" : 1,
"created" : "2025-10-17T14:55:36.829Z",
"lastModified" : "2025-10-17T14:55:36.854Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ {
"userId" : "a71f4e03-13e0-4f49-a6a9-c49639f6ca86",
"clientId" : "client id",
"scope" : "scim.read",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:55:36.835Z",
"expiresAt" : "2025-10-17T14:55:46.835Z"
}, {
"userId" : "a71f4e03-13e0-4f49-a6a9-c49639f6ca86",
"clientId" : "identity",
"scope" : "uaa.user",
"status" : "DENIED",
"lastUpdatedAt" : "2025-10-17T14:56:06.837Z",
"expiresAt" : "2025-10-17T14:56:06.837Z"
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write , uaa.admin , or openid required. The openid scope only allows the user to update their own first and last name, when origin is uaa . |
If-Match |
The version of the SCIM object to be updated. Wildcard (*) accepted. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
userName | String | Required | User name of the user, typically an email address. |
name | Object | Required | A map with the user's first name and last name. |
name.familyName | String | Required | The user's last name. |
name.givenName | String | Required | The user's first name. |
phoneNumbers | Array | Optional | The user's phone numbers. |
phoneNumbers[].value | String | Optional | The phone number. |
emails | Array | Required | The user's email addresses. |
emails[].value | String | Required | The email address. |
emails[].primary | Boolean | Required | Set to true if this is the user's primary email address. |
active | Boolean | Optional (defaults to true ) |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified | Boolean | Optional (defaults to true ) |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin | String | Optional (defaults to "uaa" ) |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. The origin value cannot be changed in an update operation. |
externalId | String | Optional | External user ID if authenticated through an external identity provider. |
aliasId | String | Optional | The ID of the alias user. If the existing user had this field set, it must be set to the same value in the update request. If not, this field must be set to null . |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this user is maintained. If set, an alias user is created in this zone and aliasId is set accordingly. Must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias users can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". Furthermore, alias users can only be created if the IdP referenced in origin also has an alias to the same zone as the user. If the existing user had this field set, it must be set to the same value in the update request. |
Response Fields
Path | Type | Description |
---|---|---|
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
id |
String |
A guid generated by the UAA to uniquely identity this user. |
userName |
String |
User name of the user, typically an email address. |
name |
Object |
A map with the user's first name and last name. |
name.familyName |
String |
The user's last name. |
name.givenName |
String |
The user's first name. |
phoneNumbers |
Array |
The user's phone numbers. |
phoneNumbers[].value |
String |
The phone number. |
emails |
Array |
The user's email addresses. |
emails[].value |
String |
The email address. |
emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
groups |
Array |
A list of groups the user belongs to. |
groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
groups[].display |
String |
The group display name, also referred to as scope during authorization. |
groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
approvals[].userId |
String |
The user id on the approval. Will be the same as the id field. |
approvals[].clientId |
String |
The client id on the approval. Represents the application this approval or denial was for. |
approvals[].scope |
String |
The scope on the approval. Will be a group display value. |
approvals[].status |
String |
The status of the approval. Status may be either APPROVED or DENIED . |
approvals[].lastUpdatedAt |
String |
Date this approval was last updated. |
approvals[].expiresAt |
String |
Date this approval will expire. |
active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
passwordLastModified |
String |
The timestamp when this user's password was last changed. |
lastLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
previousLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
externalId |
String |
External user ID if authenticated through an external identity provider. |
aliasId |
String |
The ID of the alias user. |
aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
meta |
Object |
SCIM object meta data. |
meta.version |
Number |
Object version. |
meta.lastModified |
String |
Object last modified date. |
meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields; trying to update user with alias while aliasEntitiesEnabled is off |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write is required to update a user) |
404 | Not Found - User id not found |
422 | Unprocessable Entity - error occurred during creation or update of alias |
Example using uaac to view users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac user update testuser --given_name About --family_name Schmidt --emails [email protected] --phones 415-555-1212
Patch
$ curl 'http://localhost/Users/b3a0653f-b1d7-458f-a661-6b198ad3f1e3' -i -X PATCH \
-H 'Accept: application/json' \
-H 'Authorization: Bearer 5ecfdf4e49f24579b1a13d32cc9b23ba' \
-H 'Content-Type: application/json' \
-H 'If-Match: 0' \
-d '{
"id" : "b3a0653f-b1d7-458f-a661-6b198ad3f1e3",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:37.420Z",
"lastModified" : "2025-10-17T14:55:37.420Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ ],
"approvals" : [ ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}'
PATCH /Users/b3a0653f-b1d7-458f-a661-6b198ad3f1e3 HTTP/1.1
Accept: application/json
Authorization: Bearer 5ecfdf4e49f24579b1a13d32cc9b23ba
Content-Type: application/json
If-Match: 0
Content-Length: 684
Host: localhost
{
"id" : "b3a0653f-b1d7-458f-a661-6b198ad3f1e3",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:37.420Z",
"lastModified" : "2025-10-17T14:55:37.420Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ ],
"approvals" : [ ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2804
{
"id" : "b3a0653f-b1d7-458f-a661-6b198ad3f1e3",
"externalId" : "test-user",
"meta" : {
"version" : 1,
"created" : "2025-10-17T14:55:37.420Z",
"lastModified" : "2025-10-17T14:55:37.445Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ {
"userId" : "b3a0653f-b1d7-458f-a661-6b198ad3f1e3",
"clientId" : "client id",
"scope" : "scim.read",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:55:37.426Z",
"expiresAt" : "2025-10-17T14:55:47.426Z"
}, {
"userId" : "b3a0653f-b1d7-458f-a661-6b198ad3f1e3",
"clientId" : "identity",
"scope" : "uaa.user",
"status" : "DENIED",
"lastUpdatedAt" : "2025-10-17T14:56:07.428Z",
"expiresAt" : "2025-10-17T14:56:07.428Z"
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write , uaa.admin , or openid required. The openid scope only allows the user to update their own first and last name, when origin is uaa . |
If-Match |
The version of the SCIM object to be updated. Wildcard (*) accepted. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
userName | String | Required | User name of the user, typically an email address. |
name | Object | Required | A map with the user's first name and last name. |
name.familyName | String | Required | The user's last name. |
name.givenName | String | Required | The user's first name. |
phoneNumbers | Array | Optional | The user's phone numbers. |
phoneNumbers[].value | String | Optional | The phone number. |
emails | Array | Required | The user's email addresses. |
emails[].value | String | Required | The email address. |
emails[].primary | Boolean | Required | Set to true if this is the user's primary email address. |
active | Boolean | Optional (defaults to true ) |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified | Boolean | Optional (defaults to true ) |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin | String | Optional (defaults to "uaa" ) |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. The origin value cannot be changed in a patch operation. |
externalId | String | Optional | External user ID if authenticated through an external identity provider. |
aliasId | String | Optional | The ID of the alias user. If set, this field must have the same value as in the existing user. |
aliasZid | String | Optional | The ID of the identity zone in which an alias of this user is maintained. If set, an alias user is created in this zone and aliasId is set accordingly. Must reference an existing identity zone that is different to the one referenced in identityZoneId . Alias users can only be created from or to the "uaa" identity zone, i.e., one of identityZoneId or aliasZid must be set to "uaa". Furthermore, alias users can only be created if the IdP referenced in origin also has an alias to the same zone as the user. If the existing user had this field set, it must not be set to a different value in the patch request. |
meta.attributes | Array | Optional | Names of attributes that shall be deleted |
Response Fields
Path | Type | Description |
---|---|---|
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
id |
String |
A guid generated by the UAA to uniquely identity this user. |
userName |
String |
User name of the user, typically an email address. |
name |
Object |
A map with the user's first name and last name. |
name.familyName |
String |
The user's last name. |
name.givenName |
String |
The user's first name. |
phoneNumbers |
Array |
The user's phone numbers. |
phoneNumbers[].value |
String |
The phone number. |
emails |
Array |
The user's email addresses. |
emails[].value |
String |
The email address. |
emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
groups |
Array |
A list of groups the user belongs to. |
groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
groups[].display |
String |
The group display name, also referred to as scope during authorization. |
groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
approvals[].userId |
String |
The user id on the approval. Will be the same as the id field. |
approvals[].clientId |
String |
The client id on the approval. Represents the application this approval or denial was for. |
approvals[].scope |
String |
The scope on the approval. Will be a group display value. |
approvals[].status |
String |
The status of the approval. Status may be either APPROVED or DENIED . |
approvals[].lastUpdatedAt |
String |
Date this approval was last updated. |
approvals[].expiresAt |
String |
Date this approval will expire. |
active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
passwordLastModified |
String |
The timestamp when this user's password was last changed. |
lastLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
previousLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
externalId |
String |
External user ID if authenticated through an external identity provider. |
aliasId |
String |
The ID of the alias user. |
aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
meta |
Object |
SCIM object meta data. |
meta.version |
Number |
Object version. |
meta.lastModified |
String |
Object last modified date. |
meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields; trying to update user with alias while aliasEntitiesEnabled is off |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write is required to update a user) |
404 | Not Found - User id not found |
Example using uaac to patch users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac user update testuser --given_name About --family_name Schmidt --emails [email protected] --phones 415-555-1212
Delete
$ curl 'http://localhost/Users/c9fdec3a-082b-4c18-ad39-aec6dcfc92a3' -i -X DELETE \
-H 'Accept: application/json' \
-H 'Authorization: Bearer 473c8ea8a78649c88fa4e10dda8d1db5' \
-H 'Content-Type: application/json' \
-H 'If-Match: 0'
DELETE /Users/c9fdec3a-082b-4c18-ad39-aec6dcfc92a3 HTTP/1.1
Accept: application/json
Authorization: Bearer 473c8ea8a78649c88fa4e10dda8d1db5
Content-Type: application/json
If-Match: 0
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "0"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2806
{
"id" : "c9fdec3a-082b-4c18-ad39-aec6dcfc92a3",
"externalId" : "test-user",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.598Z",
"lastModified" : "2025-10-17T14:55:36.598Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "family name",
"givenName" : "given name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"groups" : [ {
"value" : "c3a8144a-91e8-4a6f-8692-cfefd32d5371",
"display" : "cloud_controller.write",
"type" : "DIRECT"
}, {
"value" : "5b7b21e2-5fc9-4b82-acef-16326b035b06",
"display" : "cloud_controller_service_permissions.read",
"type" : "DIRECT"
}, {
"value" : "263d5323-1584-4585-983e-f64eba9cf814",
"display" : "approvals.me",
"type" : "DIRECT"
}, {
"value" : "0c1a3a74-5836-4db3-89cf-09b9e42e6aab",
"display" : "profile",
"type" : "DIRECT"
}, {
"value" : "8497591e-7f5a-40fd-980d-5393d0a68db9",
"display" : "scim.userids",
"type" : "DIRECT"
}, {
"value" : "6b0c4e66-d98b-496b-8275-832158e5c80e",
"display" : "password.write",
"type" : "DIRECT"
}, {
"value" : "8fdebed1-92e9-456f-8c24-d093d56812fa",
"display" : "scim.me",
"type" : "DIRECT"
}, {
"value" : "eab4125a-8447-482a-a10c-e1081362104a",
"display" : "cloud_controller.read",
"type" : "DIRECT"
}, {
"value" : "cdc272d0-2973-4d79-95a5-5a4ba99021bc",
"display" : "uaa.user",
"type" : "DIRECT"
}, {
"value" : "9b6ea251-4277-4a8a-a8cf-8d323680141c",
"display" : "uaa.offline_token",
"type" : "DIRECT"
}, {
"value" : "35f6eda6-787d-4391-be9a-5c938dc150e5",
"display" : "oauth.approvals",
"type" : "DIRECT"
}, {
"value" : "e1b339ad-db80-47a2-9031-ed6bc249e87e",
"display" : "roles",
"type" : "DIRECT"
}, {
"value" : "bf5cea81-c28c-47a0-9168-d266e3a6e6e8",
"display" : "openid",
"type" : "DIRECT"
}, {
"value" : "e86aca5d-9587-4a71-b8c7-b1abf8470c10",
"display" : "user_attributes",
"type" : "DIRECT"
} ],
"approvals" : [ {
"userId" : "c9fdec3a-082b-4c18-ad39-aec6dcfc92a3",
"clientId" : "identity",
"scope" : "uaa.user",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:56:06.618Z",
"expiresAt" : "2025-10-17T14:56:06.618Z"
}, {
"userId" : "c9fdec3a-082b-4c18-ad39-aec6dcfc92a3",
"clientId" : "client id",
"scope" : "scim.read",
"status" : "APPROVED",
"lastUpdatedAt" : "2025-10-17T14:55:36.608Z",
"expiresAt" : "2025-10-17T14:55:46.608Z"
} ],
"phoneNumbers" : [ {
"value" : "5555555555"
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write or uaa.admin required |
If-Match |
The version of the SCIM object to be deleted. Optional. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
schemas |
Array |
SCIM schemas used, currently always set to [ "urn:scim:schemas:core:1.0" ] |
id |
String |
A guid generated by the UAA to uniquely identity this user. |
userName |
String |
User name of the user, typically an email address. |
name |
Object |
A map with the user's first name and last name. |
name.familyName |
String |
The user's last name. |
name.givenName |
String |
The user's first name. |
phoneNumbers |
Array |
The user's phone numbers. |
phoneNumbers[].value |
String |
The phone number. |
emails |
Array |
The user's email addresses. |
emails[].value |
String |
The email address. |
emails[].primary |
Boolean |
Set to true if this is the user's primary email address. |
groups |
Array |
A list of groups the user belongs to. |
groups[].value |
String |
A guid generated by the UAA to uniquely identity this group. |
groups[].display |
String |
The group display name, also referred to as scope during authorization. |
groups[].type |
String |
Membership type. DIRECT means the user is directly associated with the group. INDIRECT means that the membership is derived from a nested group. |
approvals |
Array |
A list of approval decisions made by this user. Approvals record the user's explicit approval or rejection for an application's request for delegated permissions. |
approvals[].userId |
String |
The user id on the approval. Will be the same as the id field. |
approvals[].clientId |
String |
The client id on the approval. Represents the application this approval or denial was for. |
approvals[].scope |
String |
The scope on the approval. Will be a group display value. |
approvals[].status |
String |
The status of the approval. Status may be either APPROVED or DENIED . |
approvals[].lastUpdatedAt |
String |
Date this approval was last updated. |
approvals[].expiresAt |
String |
Date this approval will expire. |
active |
Boolean |
Whether the user is allowed to log in. False acts as a soft delete; the user will not be able to log in. |
verified |
Boolean |
New users are automatically verified by default. Unverified users can be created by specifying verified: false. Becomes true when the user verifies their email address. |
origin |
String |
The alias of the Identity Provider that authenticated this user. The value uaa indicates a user from the UAA's internal user store. |
zoneId |
String |
The Identity Zone this user belongs to. The value uaa refers to the default zone. |
passwordLastModified |
String |
The timestamp when this user's password was last changed. |
lastLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
previousLogonTime |
Number |
The unix epoch timestamp in milliseconds of when the user last authenticated. This field will be omitted from the response if the user has never authenticated. |
externalId |
String |
External user ID if authenticated through an external identity provider. |
aliasId |
String |
The ID of the alias user. |
aliasZid |
String |
The ID of the identity zone in which an alias of this user is maintained. |
meta |
Object |
SCIM object meta data. |
meta.version |
Number |
Object version. |
meta.lastModified |
String |
Object last modified date. |
meta.created |
String |
Object created date. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields; trying to delete user with alias while aliasEntitiesEnabled is off |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write is required to delete a user) |
404 | Not Found - User id not found |
Example using uaac to delete users:
uaac target http://localhost:8080/uaa
uaac token client get admin -s adminsecret
uaac user delete testuser
User Info
An OAuth2 protected resource and an OpenID Connect endpoint. Given an appropriate access_token, returns information about a user. Defined fields include various standard user profile fields. The response may include other user information such as group membership.
$ curl 'http://localhost/userinfo' -i -X GET \
-H 'Authorization: Bearer 345f7c858b234c4181ae3464ad4970c2'
GET /userinfo HTTP/1.1
Authorization: Bearer 345f7c858b234c4181ae3464ad4970c2
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 411
{
"user_id" : "38b480cf-4614-4b06-8bcf-675be4b2157d",
"user_name" : "[email protected]",
"given_name" : "PasswordResetUserFirst",
"family_name" : "PasswordResetUserLast",
"phone_number" : "+15558880000",
"email" : "[email protected]",
"email_verified" : true,
"previous_logon_time" : null,
"name" : "PasswordResetUserFirst PasswordResetUserLast",
"sub" : "38b480cf-4614-4b06-8bcf-675be4b2157d"
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with openid required. If the user_attributes scope is in the token, the response object will contain custom attributes, if mapped to the external identity provider.If the roles scope is present, the response object will contain group memberships from the external identity provider. |
Response Fields
Path | Type | Description |
---|---|---|
sub |
String |
Subject Identifier. A locally unique and never reassigned identifier within the Issuer for the End-User, which is intended to be consumed by the Client. |
user_id |
String |
Unique user identifier. |
email |
String |
The user's email address. |
email_verified |
Boolean |
Indicates whether the user has verified their email address. |
user_name |
String |
User name of the user, typically an email address. |
given_name |
String |
The user's first name. |
family_name |
String |
The user's last name. |
name |
String |
A map with the user's first name and last name. |
phone_number |
String |
The user's phone number. |
previous_logon_time |
Null |
The unix epoch timestamp in milliseconds of 2nd to last successful user authentication. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (openid is required to get the user info) |
Example using uaac to view user info:
uaac target http://localhost:8080/uaa
uaac token authcode get admin -s adminsecret
uaac curl -X GET /userinfo -k
Change user password
$ curl 'http://localhost/Users/17a92a74-55b8-4a1d-a872-e6661f7ded10/password' -i -X PUT \
-H 'Accept: application/json' \
-H 'Authorization: Bearer 06560b1293394233beb89dfe82fc6694' \
-H 'Content-Type: application/json' \
-d '{
"oldPassword" : "secret",
"password" : "newsecret"
}'
PUT /Users/17a92a74-55b8-4a1d-a872-e6661f7ded10/password HTTP/1.1
Accept: application/json
Authorization: Bearer 06560b1293394233beb89dfe82fc6694
Content-Type: application/json
Content-Length: 58
Host: localhost
{
"oldPassword" : "secret",
"password" : "newsecret"
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 55
{
"status" : "ok",
"message" : "password updated"
}
Request Headers
Name | Description |
---|---|
Authorization |
Access token with password.write or uaa.admin required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
oldPassword | String | Required | Old password. Optional when resetting another users password as an admin with uaa.admin scope |
password | String | Required | New password. |
Response Fields
Path | Type | Description |
---|---|---|
status |
String |
Will be 'ok' if password changed successfully. |
message |
String |
Will be 'password updated' if password changed successfully. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Invalid JSON format or missing fields |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write or a token containing the user id is required) |
404 | Not Found - User id not found |
Example using uaac to view users:
uaac target http://localhost:8080/uaa
uaac token owner get cf testuser -s "" -p "secret"
uaac password change -o secret -p newsecret
Unlock Account
$ curl 'http://localhost/Users/fe791b83-abda-4d4d-8759-c3f4f71d901f/status' -i -X PATCH \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer b809ef45e4bb4da799916dd8f2fba081' \
-H 'Accept: application/json' \
-d '{
"locked" : false
}'
PATCH /Users/fe791b83-abda-4d4d-8759-c3f4f71d901f/status HTTP/1.1
Content-Type: application/json
Authorization: Bearer b809ef45e4bb4da799916dd8f2fba081
Accept: application/json
Content-Length: 22
Host: localhost
{
"locked" : false
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Language: en
Content-Type: application/json;charset=UTF-8
Cache-Control: no-store
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 22
{
"locked" : false
}
Path Parameters
/Users/{userId}/status
Parameter | Description |
---|---|
userId | A guid generated by the UAA to uniquely identity this user. |
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write , uaa.account_status.write , or uaa.admin required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
locked | Boolean | Optional | Set to false in order to unlock the user when they have been locked out according to the password lock-out policy. Setting to true will produce an error, as the user cannot be locked out via the API. |
Response Fields
Path | Type | Description |
---|---|---|
locked |
Boolean |
The locked value given in the request. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - invalid JSON format or illegal value |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write or uaa.account_status.write) |
404 | User id not found |
Force user password to expire
$ curl 'http://localhost/Users/fb900b48-02f1-4d20-a983-b1560c73d5f1/status' -i -X PATCH \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 57d448e3160e4471b1653b9a11e62932' \
-H 'Accept: application/json' \
-d '{
"passwordChangeRequired" : true
}'
PATCH /Users/fb900b48-02f1-4d20-a983-b1560c73d5f1/status HTTP/1.1
Content-Type: application/json
Authorization: Bearer 57d448e3160e4471b1653b9a11e62932
Accept: application/json
Content-Length: 37
Host: localhost
{
"passwordChangeRequired" : true
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Language: en
Content-Type: application/json;charset=UTF-8
Cache-Control: no-store
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 37
{
"passwordChangeRequired" : true
}
Path Parameters
/Users/{userId}/status
Parameter | Description |
---|---|
userId | A guid generated by the UAA to uniquely identity this user. |
Request Headers
Name | Description |
---|---|
Authorization |
Access token with scim.write , uaa.account_status.write , or uaa.admin required |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
passwordChangeRequired | Boolean | Optional | Set to true in order to force internal user’s password to expire |
Response Fields
Path | Type | Description |
---|---|---|
passwordChangeRequired |
Boolean |
The passwordChangeRequired value given in the request. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - invalid JSON format or illegal value |
401 | Unauthorized - Invalid token |
403 | Forbidden - Insufficient scope (scim.write or uaa.account_status.write required) |
404 | Not Found - User id not found |
Get user verification link
$ curl 'http://localhost/Users/aeb08cb1-6a96-46a1-af79-77b46a011510/verify-link?redirect_uri=http%3A%2F%2Fredirect.to%2Fapp' -i -X GET \
-H 'Authorization: Bearer 168188151fd64244a557d47fbaf9847a' \
-H 'Accept: application/json'
GET /Users/aeb08cb1-6a96-46a1-af79-77b46a011510/verify-link?redirect_uri=http%3A%2F%2Fredirect.to%2Fapp HTTP/1.1
Authorization: Bearer 168188151fd64244a557d47fbaf9847a
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 90
{
"verify_link" : "http://localhost/verify_user?code=EhVXtJZ9sFFeTF9c8bHz8ay7vr0JKWzQ"
}
Path Parameters
/Users/{userId}/verify-link
Parameter | Description |
---|---|
userId | The ID of the user to verify |
Request Headers
Name | Description |
---|---|
Authorization |
The bearer token, with a pre-amble of Bearer |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
redirect_uri |
Location where the user will be redirected after verifying by clicking the verification link |
Response Fields
Path | Type | Description |
---|---|---|
verify_link |
String |
Location the user must visit and authenticate to verify |
Error Codes
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope or internal user management disabled |
404 | Not Found - User not found |
Verify user
$ curl 'http://localhost/Users/505a22a7-d039-4a95-9403-361784a3bad1/verify' -i -X GET \
-H 'Authorization: Bearer 68bfe868503c4c289cb241ae0659ecc1' \
-H 'If-Match: 12' \
-H 'Accept: application/json'
GET /Users/505a22a7-d039-4a95-9403-361784a3bad1/verify HTTP/1.1
Authorization: Bearer 68bfe868503c4c289cb241ae0659ecc1
If-Match: 12
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "12"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 561
{
"id" : "505a22a7-d039-4a95-9403-361784a3bad1",
"meta" : {
"version" : 12,
"created" : "2025-10-17T14:55:37.004Z",
"lastModified" : "2025-10-17T14:55:37.004Z"
},
"userName" : "[email protected]",
"name" : {
"familyName" : "d'Orange",
"givenName" : "William"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:37.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Users/{userId}/verify
Parameter | Description |
---|---|
userId | The ID of the user to verify |
Request Headers
Name | Description |
---|---|
Authorization |
The bearer token, with a pre-amble of Bearer |
If-Match |
(Optional) The expected current version of the user, which will prevent update if the version does not match |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what Identity Zone this request goes to by supplying a subdomain. |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Incorrect version supplied in If-Match header |
403 | Forbidden - Insufficient scope or internal user management disabled |
404 | Not Found - User not found |
Lookup User IDs/Usernames
$ curl 'http://localhost/ids/Users?filter=userName+eq+%22bobXEttIH%40test.org%22+or+id+eq+%22c6e15872-7672-4f68-ba00-e9fab85d2f26%22&sortOrder=descending&startIndex=1&count=10&includeInactive=true' -i -X GET \
-H 'Authorization: Bearer 2068cdf772734445b241c41d0eb79aab'
GET /ids/Users?filter=userName+eq+%22bobXEttIH%40test.org%22+or+id+eq+%22c6e15872-7672-4f68-ba00-e9fab85d2f26%22&sortOrder=descending&startIndex=1&count=10&includeInactive=true HTTP/1.1
Authorization: Bearer 2068cdf772734445b241c41d0eb79aab
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 372
{
"resources" : [ {
"origin" : "uaa",
"id" : "c6e15872-7672-4f68-ba00-e9fab85d2f26",
"userName" : "[email protected]"
}, {
"origin" : "uaa",
"id" : "ebd179f5-a309-42d5-a68b-d957cada5e9a",
"userName" : "[email protected]"
} ],
"startIndex" : 1,
"itemsPerPage" : 5,
"totalResults" : 2,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with authorization for scim.userids scope |
Request Parameters
Parameter | Description |
---|---|
filter |
SCIM filter for users over userName , id , and origin , using only the eq comparison operator |
sortOrder |
sort by username in ascending or descending order |
startIndex |
display paged results beginning at specified index |
count |
number of results to return per page |
includeInactive |
include users from inactive identity providers |
Response Fields
Path | Type | Description |
---|---|---|
totalResults |
Number |
The number of results which matched the filter |
startIndex |
Number |
The index of the first item of this page of results |
itemsPerPage |
Number |
The page size used in producing this page of results |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
resources[].id |
String |
The globally unique identifier for this user |
resources[].userName |
String |
The username |
resources[].origin |
String |
The origin of the user, e.g. an identity provider alias |
Error Codes
Error Code | Description |
---|---|
400 | Bad Request - Request was invalid or unparseable |
403 | Forbidden - Insufficient scope |
Invite users
$ curl 'http://localhost/invite_users?client_id=8pf5aq&redirect_uri=example.com' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer c0a04f9ea32742709e5987e37fbc093d' \
-d '{
"emails" : [ "[email protected]", "[email protected]" ]
}'
POST /invite_users?client_id=8pf5aq&redirect_uri=example.com HTTP/1.1
Content-Type: application/json
Authorization: Bearer c0a04f9ea32742709e5987e37fbc093d
Content-Length: 59
Host: localhost
{
"emails" : [ "[email protected]", "[email protected]" ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 622
{
"new_invites" : [ {
"email" : "[email protected]",
"userId" : "72c2f56a-3cdd-4082-8b53-b2cf3d9e6a49",
"origin" : "uaa",
"success" : true,
"errorCode" : null,
"errorMessage" : null,
"inviteLink" : "http://localhost/invitations/accept?code=XhLCaUfO44wG07pINg-KgOFuoIIBF-SX"
}, {
"email" : "[email protected]",
"userId" : "4c912a67-1bdf-4343-bf88-7aa3f1beeb05",
"origin" : "uaa",
"success" : true,
"errorCode" : null,
"errorMessage" : null,
"inviteLink" : "http://localhost/invitations/accept?code=nltvUdYXBgq3aww_lkFnYRIgsHPaN4ir"
} ],
"failed_invites" : [ ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing scim.invite |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
emails | Array | Required | User is invited by providing an email address. More than one email addresses can be provided. |
Request Parameters
Parameter | Description |
---|---|
client_id |
A unique string representing the registration information provided by the client |
redirect_uri |
The user will be redirected to this uri, when user accepts the invitation. The redirect_uri will be validated against allowed redirect_uri for the client. |
Response Fields
Path | Type | Description |
---|---|---|
new_invites[].email |
String |
Primary email id of the invited user |
new_invites[].userId |
String |
A unique string for the invited user |
new_invites[].origin |
String |
Unique alias of the provider |
new_invites[].success |
Boolean |
Flag to determine whether the invitation was sent successfully |
new_invites[].errorCode |
String |
Error code in case of failure to send invitation |
new_invites[].errorMessage |
String |
Error message in case of failure to send invitation |
new_invites[].inviteLink |
String |
Invitation link to invite users |
failed_invites |
Array |
List of invites having exception in sending the invitation |
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
Groups
Create
$ curl 'http://localhost/Groups' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7' \
-d '{
"displayName" : "Cool Group Name",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}'
POST /Groups HTTP/1.1
Content-Type: application/json
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
Content-Length: 196
Host: localhost
{
"displayName" : "Cool Group Name",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "0"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 441
{
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.272Z"
},
"displayName" : "Cool Group Name",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
displayName | String | Required | An identifier, unique within the identity zone |
description | String | Optional | Human readable description of the group, displayed e.g. when approving scopes |
members | Array | Optional | Members to be included in the group |
members[].value | String | Required for each item in members |
The globally-unique ID of the member entity, either a user ID or another group ID |
members[].type | String | Optional (defaults to "USER" ) |
Either "USER" or "GROUP" |
members[].origin | String | Optional (defaults to "uaa" ) |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. This value will NOT change during an update (put request) if the membership already exists under a different origin. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
The globally unique group ID |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
members |
Array |
Array of group members |
members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
members[].type |
String |
Either "USER" or "GROUP" |
members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
zoneId |
String |
Identifier for the identity zone to which the group belongs |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group was created |
meta.lastModified |
String |
The time the group was last updated |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
400 | Bad Request - Invalid member ID |
403 | Forbidden - Insufficient scope |
Retrieve
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3' -i -X GET \
-H 'Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf'
GET /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3 HTTP/1.1
Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "2"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 454
{
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 2,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.321Z"
},
"displayName" : "Cooler Group Name for Update",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/{groupId}
Parameter | Description |
---|---|
groupId | Globally unique identifier of the group to retrieve |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.read |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
The globally unique group ID |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
members |
Array |
Array of group members |
members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
members[].type |
String |
Either "USER" or "GROUP" |
members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
zoneId |
String |
Identifier for the identity zone to which the group belongs |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group was created |
meta.lastModified |
String |
The time the group was last updated |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
Update
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7' \
-H 'If-Match: 0' \
-d '{
"displayName" : "Cooler Group Name for Update",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}'
PUT /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3 HTTP/1.1
Content-Type: application/json
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
If-Match: 0
Content-Length: 209
Host: localhost
{
"displayName" : "Cooler Group Name for Update",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "1"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 454
{
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 1,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.297Z"
},
"displayName" : "Cooler Group Name for Update",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/{groupId}
Parameter | Description |
---|---|
groupId | Globally unique identifier of the group to update |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write or groups.update |
If-Match |
The version of the SCIM object to be updated. Wildcard (*) accepted. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
displayName | String | Required | An identifier, unique within the identity zone |
description | String | Optional | Human readable description of the group, displayed e.g. when approving scopes |
members | Array | Optional | Members to be included in the group |
members[].value | String | Required for each item in members |
The globally-unique ID of the member entity, either a user ID or another group ID |
members[].type | String | Optional (defaults to "USER" ) |
Either "USER" or "GROUP" |
members[].origin | String | Optional (defaults to "uaa" ) |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. This value will NOT change during an update (put request) if the membership already exists under a different origin. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
The globally unique group ID |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
members |
Array |
Array of group members |
members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
members[].type |
String |
Either "USER" or "GROUP" |
members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
zoneId |
String |
Identifier for the identity zone to which the group belongs |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group was created |
meta.lastModified |
String |
The time the group was last updated |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
400 | Bad Request - Incorrect version supplied in If-Match header |
403 | Forbidden - Insufficient scope |
409 | Conflict |
Patch
Updating partial elements of a group is documented at SCIM Specification
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3' -i -X PATCH \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7' \
-H 'If-Match: *' \
-d '{
"displayName" : "Cooler Group Name for Update",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}'
PATCH /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3 HTTP/1.1
Content-Type: application/json
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
If-Match: *
Content-Length: 209
Host: localhost
{
"displayName" : "Cooler Group Name for Update",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "2"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 454
{
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 2,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.321Z"
},
"displayName" : "Cooler Group Name for Update",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/{groupId}
Parameter | Description |
---|---|
groupId | Globally unique identifier of the group to update |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write or groups.update |
If-Match |
The version of the SCIM object to be updated. Wildcard (*) accepted. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
displayName | String | Required | An identifier, unique within the identity zone |
description | String | Optional | Human readable description of the group, displayed e.g. when approving scopes |
members | Array | Optional | Members to be included in the group |
members[].value | String | Required for each item in members |
The globally-unique ID of the member entity, either a user ID or another group ID |
members[].type | String | Optional (defaults to "USER" ) |
Either "USER" or "GROUP" |
members[].origin | String | Optional (defaults to "uaa" ) |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. This value will NOT change during an update (put request) if the membership already exists under a different origin. |
members[].operation | String | Optional | "delete" if the corresponding member shall be deleted |
meta.attributes | Array | Optional | Names of attributes that shall be deleted |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
The globally unique group ID |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
members |
Array |
Array of group members |
members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
members[].type |
String |
Either "USER" or "GROUP" |
members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
zoneId |
String |
Identifier for the identity zone to which the group belongs |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group was created |
meta.lastModified |
String |
The time the group was last updated |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
400 | Bad Request - Incorrect version supplied in If-Match header |
403 | Forbidden - Insufficient scope |
409 | Conflict |
Delete
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3' -i -X DELETE \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7'
DELETE /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3 HTTP/1.1
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
ETag: "2"
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 454
{
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 2,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.321Z"
},
"displayName" : "Cooler Group Name for Update",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/{groupId}
Parameter | Description |
---|---|
groupId | The globally unique identifier of the group |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write |
If-Match |
The version of the SCIM object to be updated. Wildcard (*) accepted. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
id |
String |
The globally unique group ID |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
members |
Array |
Array of group members |
members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
members[].type |
String |
Either "USER" or "GROUP" |
members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
zoneId |
String |
Identifier for the identity zone to which the group belongs |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group was created |
meta.lastModified |
String |
The time the group was last updated |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
400 | Bad Request - Incorrect version supplied in If-Match header |
403 | Forbidden - Insufficient scope |
409 | Conflict |
List
$ curl 'http://localhost/Groups?filter=id+eq+%2218bc3670-419a-4b9c-b6e9-7dd8212884f3%22+or+displayName+eq+%22Cooler+Group+Name+for+Update%22&sortBy=lastModified&count=50&sortOrder=descending&startIndex=1' -i -X GET \
-H 'Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf'
GET /Groups?filter=id+eq+%2218bc3670-419a-4b9c-b6e9-7dd8212884f3%22+or+displayName+eq+%22Cooler+Group+Name+for+Update%22&sortBy=lastModified&count=50&sortOrder=descending&startIndex=1 HTTP/1.1
Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 621
{
"resources" : [ {
"id" : "18bc3670-419a-4b9c-b6e9-7dd8212884f3",
"meta" : {
"version" : 2,
"created" : "2025-10-17T14:55:36.272Z",
"lastModified" : "2025-10-17T14:55:36.321Z"
},
"displayName" : "Cooler Group Name for Update",
"zoneId" : "uaa",
"description" : "the cool group",
"members" : [ {
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ],
"schemas" : [ "urn:scim:schemas:core:1.0" ]
} ],
"startIndex" : 1,
"itemsPerPage" : 5,
"totalResults" : 1,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.read |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
filter |
A SCIM filter over groups |
sortBy |
The field of the SCIM group to sort by |
sortOrder |
Sort in ascending or descending order |
startIndex |
The index of the first result of this page within all matches |
count |
Maximum number of results to return in a single page |
Response Fields
Path | Type | Description |
---|---|---|
resources[].id |
String |
The globally unique group ID |
resources[].displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
resources[].description |
String |
Human readable description of the group, displayed e.g. when approving scopes |
resources[].members |
Array |
Array of group members |
resources[].members[].value |
String |
Globally unique identifier of the member, either a user ID or another group ID |
resources[].members[].type |
String |
Either "USER" or "GROUP" |
resources[].members[].origin |
String |
The alias of the identity provider that authenticated this user. "uaa" is an internal UAA user. |
resources[].zoneId |
String |
Identifier for the identity zone to which the group belongs |
resources[].meta.version |
Number |
The version of the group entity |
resources[].meta.created |
String |
The time the group was created |
resources[].meta.lastModified |
String |
The time the group was last updated |
resources[].schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
itemsPerPage |
Number |
The page-size used to produce the current page of results |
startIndex |
Number |
The index of the first result of this page within all matches |
totalResults |
Number |
The number of groups that matched the given filter |
schemas |
Array |
[ "urn:scim:schemas:core:1.0" ] |
Error Code | Description |
---|---|
400 | Bad Request - Invalid attributes |
403 | Forbidden - Insufficient scope |
Check Membership
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members/9f4df094-4e21-4c3e-822b-c0251fae4389' -i -X GET \
-H 'Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf'
GET /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members/9f4df094-4e21-4c3e-822b-c0251fae4389 HTTP/1.1
Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 93
{
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
}
Path Parameters
/Groups/{groupId}/members/{memberId}
Parameter | Description |
---|---|
groupId | The globally unique identifier of the group |
memberId | The globally unique identifier the user or group which is a member of the specified by groupId |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.read |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
value |
String |
The globally unique identifier the user or group which is a member of the specified by groupId |
type |
String |
Either "USER" or "GROUP" , indicating what type of entity the group membership refers to, and whether value denotes a user ID or group ID |
origin |
String |
The originating IDP of the entity, or "uaa" for groups and internal users |
Error Code | Description |
---|---|
400 | Bad Request - Invalid member ID |
403 | Forbidden - Insufficient scope |
404 | Not Found - Group does not exist, or the entity is not a member |
Add Member
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7' \
-d '{"origin":"uaa","type":"USER","value":"9f4df094-4e21-4c3e-822b-c0251fae4389"}'
POST /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members HTTP/1.1
Content-Type: application/json
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
Content-Length: 77
Host: localhost
{"origin":"uaa","type":"USER","value":"9f4df094-4e21-4c3e-822b-c0251fae4389"}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 93
{
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
}
Path Parameters
/Groups/{groupId}/members
Parameter | Description |
---|---|
groupId | The globally unique identifier of the group |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
value | String | Required | The globally unique identifier the user or group which is a member of the specified by groupId |
type | String | Required | Either "USER" or "GROUP" , indicating what type of entity the group membership refers to, and whether value denotes a user ID or group ID |
origin | String | Required | The originating IDP of the entity, or "uaa" for groups and internal users |
Response Fields
Path | Type | Description |
---|---|---|
value |
String |
The globally unique identifier the user or group which is a member of the specified by groupId |
type |
String |
Either "USER" or "GROUP" , indicating what type of entity the group membership refers to, and whether value denotes a user ID or group ID |
origin |
String |
The originating IDP of the entity, or "uaa" for groups and internal users |
Error Code | Description |
---|---|
400 | Bad Request - Invalid member ID |
403 | Forbidden - Insufficient scope |
404 | Not Found - Specified group or member entity does not exist |
Remove Member
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members/9f4df094-4e21-4c3e-822b-c0251fae4389' -i -X DELETE \
-H 'Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7'
DELETE /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members/9f4df094-4e21-4c3e-822b-c0251fae4389 HTTP/1.1
Authorization: Bearer 25a27c3dc2a14979bd887596629f63e7
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 93
{
"origin" : "uaa",
"type" : "USER",
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
}
Path Parameters
/Groups/{groupId}/members/{memberId}
Parameter | Description |
---|---|
groupId | The globally unique identifier of the group |
memberId | The globally unique identifier of the entity, i.e. the user or group, to be removed from membership in the group specified by groupId |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.write |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
origin |
String |
The originating IDP of the entity |
type |
String |
Either "USER" or "GROUP" , indicating what type of entity the group membership refers to |
value |
String |
The globally unique identifier of the user or group which has been removed from the group specified by groupId |
Error Code | Description |
---|---|
400 | Bad Request - Incorrect version supplied in If-Match header |
403 | Forbidden - Insufficient scope |
404 | Not Found - Group does not exist, or the entity is not a member |
409 | Conflict |
List Members
$ curl 'http://localhost/Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members?returnEntities=true' -i -X GET \
-H 'Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf'
GET /Groups/18bc3670-419a-4b9c-b6e9-7dd8212884f3/members?returnEntities=true HTTP/1.1
Authorization: Bearer 9631980c8d9f4460829cb277c550b0cf
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 707
[ {
"origin" : "uaa",
"type" : "USER",
"entity" : {
"id" : "9f4df094-4e21-4c3e-822b-c0251fae4389",
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.261Z",
"lastModified" : "2025-10-17T14:55:36.261Z"
},
"userName" : "dOTQqF",
"name" : {
"familyName" : "cool-familyName",
"givenName" : "cool-name"
},
"emails" : [ {
"value" : "[email protected]",
"primary" : false
} ],
"active" : true,
"verified" : true,
"origin" : "uaa",
"zoneId" : "uaa",
"passwordLastModified" : "2025-10-17T14:55:36.000Z",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
},
"value" : "9f4df094-4e21-4c3e-822b-c0251fae4389"
} ]
Path Parameters
/Groups/{groupId}/members
Parameter | Description |
---|---|
groupId | The globally unique identifier of the group |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with scope scim.read |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
returnEntities |
Set to true to return the SCIM entities which have membership in the group |
Response Fields
Path | Type | Description |
---|---|---|
[].value |
String |
The globally unique identifier the user or group which is a member of the specified by groupId |
[].type |
String |
Either "USER" or "GROUP" , indicating what type of entity the group membership refers to, and whether value denotes a user ID or group ID |
[].origin |
String |
The originating IDP of the entity, or "uaa" for groups and internal users |
[].entity.* |
Varies |
Present only if requested with returnEntities ; user or group details for each entity that is a member of this group |
Error Code | Description |
---|---|
400 | Bad Request - Invalid attributes |
403 | Forbidden - Insufficient scope |
404 | Not Found - Specified group does not exist |
External Group Mappings
Map
$ curl 'http://localhost/Groups/External' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 0d3bb28a9c1342f5a63c620e80dcd520' \
-d '{
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.026Z"
},
"groupId" : "677ca953-bdaa-4b1c-8a02-904a4317250a",
"externalGroup" : "External group",
"origin" : "ldap",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}'
POST /Groups/External HTTP/1.1
Content-Type: application/json
Authorization: Bearer 0d3bb28a9c1342f5a63c620e80dcd520
Content-Length: 242
Host: localhost
{
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.026Z"
},
"groupId" : "677ca953-bdaa-4b1c-8a02-904a4317250a",
"externalGroup" : "External group",
"origin" : "ldap",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 362
{
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.032Z",
"lastModified" : "2025-10-17T14:55:36.032Z"
},
"groupId" : "677ca953-bdaa-4b1c-8a02-904a4317250a",
"externalGroup" : "external group",
"displayName" : "Group For Testing Creating External Group Mapping",
"origin" : "ldap",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with authorization for scim.write scope |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
groupId | String | Required | The globally unique group ID |
externalGroup | String | Required | The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
origin | String | Optional (defaults to "ldap" ) |
Unique alias of the identity provider |
meta.version | Number | Optional (defaults to 0 ) |
The version of the group entity |
Response Fields
Path | Type | Description |
---|---|---|
groupId |
String |
The globally unique group ID |
externalGroup |
String |
The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
origin |
String |
Unique alias of the identity provider |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group mapping was created |
meta.lastModified |
String |
The time the group mapping was last updated |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
Error Code | Description |
---|---|
400 | Bad Request - External group or origin should not be null |
403 | Forbidden - Insufficient scope |
404 | Not Found - Incorrect group ID provided |
Unmap
By group ID
$ curl 'http://localhost/Groups/External/groupId/d86be951-0496-4892-988c-4e94c84c6720/externalGroup/external%20group/origin/ldap' -i -X DELETE \
-H 'Authorization: Bearer a49860100a7c4bb880d5ccd6d7eb3f9b'
DELETE /Groups/External/groupId/d86be951-0496-4892-988c-4e94c84c6720/externalGroup/external%20group/origin/ldap HTTP/1.1
Authorization: Bearer a49860100a7c4bb880d5ccd6d7eb3f9b
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 362
{
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:35.864Z",
"lastModified" : "2025-10-17T14:55:35.864Z"
},
"groupId" : "d86be951-0496-4892-988c-4e94c84c6720",
"externalGroup" : "external group",
"displayName" : "Group For Testing Deleting External Group Mapping",
"origin" : "ldap",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/External/groupId/{groupId}/externalGroup/{externalGroup}/origin/{origin}
Parameter | Description |
---|---|
groupId | The globally unique group ID |
externalGroup | The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
origin | Unique alias of the identity provider |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with authorization for scim.write scope |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
Response Fields
Path | Type | Description |
---|---|---|
groupId |
String |
The globally unique group ID |
externalGroup |
String |
The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
origin |
String |
Unique alias of the identity provider |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group mapping was created |
meta.lastModified |
String |
The time the group mapping was last updated |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
404 | Not Found - No such group ID, external group, origin combination |
By group display name
$ curl 'http://localhost/Groups/External/displayName/Group%20For%20Testing%20Deleting%20External%20Group%20Mapping%20By%20Name/externalGroup/external%20group/origin/ldap' -i -X DELETE \
-H 'Authorization: Bearer 17aa0f309e5d452499ea42f1bc3544eb'
DELETE /Groups/External/displayName/Group%20For%20Testing%20Deleting%20External%20Group%20Mapping%20By%20Name/externalGroup/external%20group/origin/ldap HTTP/1.1
Authorization: Bearer 17aa0f309e5d452499ea42f1bc3544eb
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 370
{
"meta" : {
"version" : 0,
"created" : "2025-10-17T14:55:36.088Z",
"lastModified" : "2025-10-17T14:55:36.088Z"
},
"groupId" : "0a4a787d-a395-421e-aece-e005a910ff5f",
"externalGroup" : "external group",
"displayName" : "Group For Testing Deleting External Group Mapping By Name",
"origin" : "ldap",
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Path Parameters
/Groups/External/displayName/{displayName}/externalGroup/{externalGroup}/origin/{origin}
Parameter | Description |
---|---|
displayName | The identifier specified upon creation of the group, unique within the identity zone |
externalGroup | The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
origin | Unique alias of the identity provider |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with authorization for scim.write scope |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
Response Fields
Path | Type | Description |
---|---|---|
groupId |
String |
The globally unique group ID |
externalGroup |
String |
The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
origin |
String |
Unique alias of the identity provider |
meta.version |
Number |
The version of the group entity |
meta.created |
String |
The time the group mapping was created |
meta.lastModified |
String |
The time the group mapping was last updated |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
Error Code | Description |
---|---|
403 | Forbidden - Insufficient scope |
404 | Not Found - No such group display name, external group, origin combination |
List
$ curl 'http://localhost/Groups/External?startIndex=1&count=50&origin=ldap&externalGroup=&filter=' -i -X GET \
-H 'Authorization: Bearer 8d73bceb2d404e31af1f7bc854d5c8dc'
GET /Groups/External?startIndex=1&count=50&origin=ldap&externalGroup=&filter= HTTP/1.1
Authorization: Bearer 8d73bceb2d404e31af1f7bc854d5c8dc
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1284
{
"resources" : [ {
"displayName" : "internal.superuser",
"externalGroup" : "cn=superusers,ou=scopes,dc=test,dc=com",
"groupId" : "17e8dc0d-736a-4f68-aa65-bcd14997233c",
"origin" : "ldap"
}, {
"displayName" : "internal.read",
"externalGroup" : "cn=developers,ou=scopes,dc=test,dc=com",
"groupId" : "79be32b2-33dc-48f1-87c2-2fad317a3b2e",
"origin" : "ldap"
}, {
"displayName" : "Group For Testing Retrieving External Group Mappings",
"externalGroup" : "external group",
"groupId" : "b286b7d9-8ae9-43df-a3df-2792d5b4f404",
"origin" : "ldap"
}, {
"displayName" : "internal.write",
"externalGroup" : "cn=operators,ou=scopes,dc=test,dc=com",
"groupId" : "c900f4c0-5e90-4906-8277-73bed571f4fe",
"origin" : "ldap"
}, {
"displayName" : "internal.everything",
"externalGroup" : "cn=superusers,ou=scopes,dc=test,dc=com",
"groupId" : "e0e16271-7f52-4cd2-94c1-02bb1c492ca3",
"origin" : "ldap"
}, {
"displayName" : "organizations.acme",
"externalGroup" : "cn=test_org,ou=people,o=springsource,o=org",
"groupId" : "f0cafd9d-7f4f-4995-92be-e37b1dbc095c",
"origin" : "ldap"
} ],
"startIndex" : 1,
"itemsPerPage" : 6,
"totalResults" : 6,
"schemas" : [ "urn:scim:schemas:core:1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with authorization for scim.read scope |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zoneId>.admin or uaa.admin scope against the default UAA zone. |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
Response Fields
Path | Type | Description |
---|---|---|
resources[].groupId |
String |
The globally unique group ID |
resources[].displayName |
String |
The identifier specified upon creation of the group, unique within the identity zone |
resources[].externalGroup |
String |
The identifier for the group in external identity provider that needs to be mapped to internal UAA groups |
resources[].origin |
String |
Unique alias of the identity provider |
startIndex |
Number |
The index of the first item of this page of results |
itemsPerPage |
Number |
The page size used in producing this page of results |
totalResults |
Number |
The number of results which matched the filter |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
Error Code | Description |
---|---|
400 | Bad Request - Invalid request parameters |
403 | Forbidden - Insufficient scope |
Clients
Create
$ curl 'http://localhost/oauth/clients' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 19d9eb01e8084334a3acf12f47f0325e' \
-H 'Accept: application/json' \
-d '{
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "LLpKeW",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "G4BmZH",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}'
POST /oauth/clients HTTP/1.1
Content-Type: application/json
Authorization: Bearer 19d9eb01e8084334a3acf12f47f0325e
Accept: application/json
Content-Length: 468
Host: localhost
{
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "LLpKeW",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "G4BmZH",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 517
{
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "LLpKeW",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "G4BmZH",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712926089,
"required_user_groups" : [ ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
client_id | String | Required | Client identifier, unique within identity zone |
authorized_grant_types | Array | Optional | List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri | Array | Optional | Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope | Array | Optional (defaults to "uaa.none" ) |
Scopes allowed for the client |
resource_ids | Array | Optional (defaults to [] ) |
Resources the client is allowed access to |
authorities | Array | Optional (defaults to "uaa.none" ) |
Scopes which the client is able to grant when creating a client |
autoapprove | [Boolean, Array] | Optional (defaults to [] ) |
Scopes that do not require user approval |
allowpublic | Boolean | Optional (defaults to false ) |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity | Number | Optional | time in seconds to access token expiration after it is issued |
refresh_token_validity | Number | Optional | time in seconds to refresh token expiration after it is issued |
allowedproviders | Array | Optional | A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name | String | Optional | A human readable name for the client |
token_salt | String | Optional | A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith | String | Optional | What scope the bearer token had when client was created |
approvals_deleted | Boolean | Optional | Were the approvals deleted for the client, and an audit event sent |
required_user_groups | Array | Optional | A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
client_secret | String | Required if the client allows authorization_code or client_credentials grant type |
A secret string used for authenticating as this client. |
secondary_client_secret | String | Optional | An optional, secondary secret string used for authenticating as this client to support secret rotation. |
Response Fields
Path | Type | Description |
---|---|---|
client_id |
String |
Client identifier, unique within identity zone |
authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope |
Array |
Scopes allowed for the client |
resource_ids |
Array |
Resources the client is allowed access to |
authorities |
Array |
Scopes which the client is able to grant when creating a client |
autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name |
String |
A human readable name for the client |
token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith |
String |
What scope the bearer token had when client was created |
approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Retrieve
$ curl 'http://localhost/oauth/clients/RpWzq-' -i -X GET \
-H 'Authorization: Bearer 27b513b3a0a64084b9e026e50977873b' \
-H 'Accept: application/json'
GET /oauth/clients/RpWzq- HTTP/1.1
Authorization: Bearer 27b513b3a0a64084b9e026e50977873b
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 517
{
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "RpWzq-",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "lkZF7D",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712926247,
"required_user_groups" : [ ]
}
Path Parameters
/oauth/clients/{client_id}
Parameter | Description |
---|---|
client_id | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.read , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
client_id |
String |
Client identifier, unique within identity zone |
authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope |
Array |
Scopes allowed for the client |
resource_ids |
Array |
Resources the client is allowed access to |
authorities |
Array |
Scopes which the client is able to grant when creating a client |
autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name |
String |
A human readable name for the client |
token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith |
String |
What scope the bearer token had when client was created |
approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Update
$ curl 'http://localhost/oauth/clients/gHsrom' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 8387ad5a9b1b47cf892bd48327e2ac46' \
-H 'Accept: application/json' \
-d '{
"scope" : [ "clients.new", "clients.autoapprove" ],
"client_id" : "gHsrom",
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://redirect.url" ],
"autoapprove" : [ "clients.autoapprove" ]
}'
PUT /oauth/clients/gHsrom HTTP/1.1
Content-Type: application/json
Authorization: Bearer 8387ad5a9b1b47cf892bd48327e2ac46
Accept: application/json
Content-Length: 228
Host: localhost
{
"scope" : [ "clients.new", "clients.autoapprove" ],
"client_id" : "gHsrom",
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://redirect.url" ],
"autoapprove" : [ "clients.autoapprove" ]
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 498
{
"scope" : [ "clients.new", "clients.autoapprove" ],
"client_id" : "gHsrom",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://redirect.url" ],
"autoapprove" : [ "clients.autoapprove" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "AQI6cq",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925601,
"required_user_groups" : [ ]
}
Path Parameters
/oauth/clients/{client_id}
Parameter | Description |
---|---|
client_id | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
client_id | String | Required | Client identifier, unique within identity zone |
authorized_grant_types | Array | Optional | List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri | Array | Optional | Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope | Array | Optional (defaults to "uaa.none" ) |
Scopes allowed for the client |
resource_ids | Array | Optional (defaults to [] ) |
Resources the client is allowed access to |
authorities | Array | Optional (defaults to "uaa.none" ) |
Scopes which the client is able to grant when creating a client |
autoapprove | [Boolean, Array] | Optional (defaults to [] ) |
Scopes that do not require user approval |
allowpublic | Boolean | Optional (defaults to false ) |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity | Number | Optional | time in seconds to access token expiration after it is issued |
refresh_token_validity | Number | Optional | time in seconds to refresh token expiration after it is issued |
allowedproviders | Array | Optional | A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name | String | Optional | A human readable name for the client |
token_salt | String | Optional | A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith | String | Optional | What scope the bearer token had when client was created |
approvals_deleted | Boolean | Optional | Were the approvals deleted for the client, and an audit event sent |
required_user_groups | Array | Optional | A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
Response Fields
Path | Type | Description |
---|---|---|
client_id |
String |
Client identifier, unique within identity zone |
authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope |
Array |
Scopes allowed for the client |
resource_ids |
Array |
Resources the client is allowed access to |
authorities |
Array |
Scopes which the client is able to grant when creating a client |
autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name |
String |
A human readable name for the client |
token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith |
String |
What scope the bearer token had when client was created |
approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Delete
$ curl 'http://localhost/oauth/clients/Kvh7Rr' -i -X DELETE \
-H 'Authorization: Bearer df3a29e57aec4690841297ca173cbb14' \
-H 'Accept: application/json'
DELETE /oauth/clients/Kvh7Rr HTTP/1.1
Authorization: Bearer df3a29e57aec4690841297ca173cbb14
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 517
{
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "Kvh7Rr",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "Q1Wc4y",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925696,
"required_user_groups" : [ ]
}
Path Parameters
/oauth/clients/{client_id}
Parameter | Description |
---|---|
client_id | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Response Fields
Path | Type | Description |
---|---|---|
client_id |
String |
Client identifier, unique within identity zone |
authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
scope |
Array |
Scopes allowed for the client |
resource_ids |
Array |
Resources the client is allowed access to |
authorities |
Array |
Scopes which the client is able to grant when creating a client |
autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
name |
String |
A human readable name for the client |
token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
createdwith |
String |
What scope the bearer token had when client was created |
approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Change Secret
$ curl 'http://localhost/oauth/clients/4xu4Wp/secret' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 7f81b77cb7a44b9bbbc6accc85d9a826' \
-H 'Accept: application/json' \
-d '{
"clientId" : "4xu4Wp",
"secret" : "new_secret"
}'
PUT /oauth/clients/4xu4Wp/secret HTTP/1.1
Content-Type: application/json
Authorization: Bearer 7f81b77cb7a44b9bbbc6accc85d9a826
Accept: application/json
Content-Length: 54
Host: localhost
{
"clientId" : "4xu4Wp",
"secret" : "new_secret"
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 53
{
"status" : "ok",
"message" : "secret updated"
}
Path Parameters
/oauth/clients/{client_id}/secret
Parameter | Description |
---|---|
client_id | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
clientId | String | Required | Client identifier, unique within identity zone |
oldSecret | String | Optional if authenticated as an admin client. Required otherwise. | A valid client secret before updating |
secret | String | Required | The new client secret |
changeMode | String | Optional (defaults to "UPDATE" ) |
If change mode is set to ADD , the new secret will be added to the existing one and if the change mode is set to DELETE , the old secret will be deleted to support secret rotation. Currently only two client secrets are supported at any given time. |
Change Client JWT
This configuration can be done if client authentication is performed with method private_key_jwt instead of secret based client authentication. See details for client authentication with OAuth2. The authentication with a client JWT (parameter client_assertion) is similar to the user authentication with a user JWT (JWT bearer, e.g. RFC 7522). Client JWT is available and specified from either the OAuth2 standard, defined in RFC 7523, and from OpenID Connect.
UAA supports both standards for private_key_jwt, the OAuth2 and OpenID Connect standard.
The client can send a client_assertion for authentication instead of client_secret or Authorization header. The signature of the JWT from client_assertion is validated and assures the client authentication. The structure of the JWT sent with parameter client_assertion differentiates between the OAuth2 and OpenID Connect standard and with this, both standards can be supported in parallel.
The OpenID Connect standard is supported either with the jwks_uri or the internal jwks public keys. The JWT here has only a reference to the current client using the client_id for issuer and subject, therefore the trust anchor is only the key which can be retrieved or is set already.
The OAuth2 standard is supported either with plain issuer or a pre-configured Identity Provider object. The IdP must be from type OIDC (oidc1.0
).
If an Identity Provider is set up before, then the key material can be configured with tokenKey
or tokenKeyUrl
. If no Identity Provider is used, then
the configured issuer must support the discovery standard. If no audience (aud
) is set, then
the UAA own token endpoint URL is expected.
The limits are 10 keys and/or 10 external combinations of issuer and subject. Use jwks_uri/jwks for single entities and issuer/subject/audience for system entities, e.g. another UAA landscapes, external system integrations, work load identities or SPIFFE.
$ curl 'http://localhost/oauth/clients/Lpvill/clientjwt' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 607eed0b342047f79cac9e780aff65cb' \
-H 'Accept: application/json' \
-d '{
"jwks_uri" : "http://localhost:8080/uaa/token_keys",
"client_id" : "Lpvill"
}'
PUT /oauth/clients/Lpvill/clientjwt HTTP/1.1
Content-Type: application/json
Authorization: Bearer 607eed0b342047f79cac9e780aff65cb
Accept: application/json
Content-Length: 83
Host: localhost
{
"jwks_uri" : "http://localhost:8080/uaa/token_keys",
"client_id" : "Lpvill"
}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 72
{
"status" : "ok",
"message" : "Client jwt configuration is added"
}
Path Parameters
/oauth/clients/{client_id}/clientjwt
Parameter | Description |
---|---|
client_id | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.trust , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
client_id | String | Required | Client identifier, unique within identity zone |
jwks | String | Optional only, if jwks_uri is used. Required otherwise. OIDC standard. | A valid JSON string according JSON Web Key Set standard, see RFC 7517, e.g. content of /token_keys endpoint from UAA |
jwks_uri | String | Optional only, if jwks is used. Required otherwise. OIDC standard. | A valid URI to token keys endpoint. Must be compliant to jwks_uri from OpenID Discovery. |
iss | String | Optional only, if OIDC standard is used. Required otherwise. OAuth2 standard. | OIDC compliant issuer URI, matching the retrieved OAuth2 compliant JWT (iss claim). |
sub | String | Optional only, if OIDC standard is used. Required otherwise. OAuth2 standard. | A subject string, matching the retrieved OAuth2 compliant JWT (sub claim). |
aud | String | Optional. Otherwise UAA token endpoint is expected. OAuth2 standard. | An audience for the retreived OAuth2 compliant JWT (part of aud claim array). |
kid | String | Optional only, if a single JWK should be deleted, else ignored. OIDC standard. | If change mode is set to DELETE , it specifies the id of the key that will be deleted. The kid parameter is only applicable when jwks configuration is used. |
changeMode | String | Optional (defaults to "ADD" ) |
If change mode is set to ADD , a new entry of either JWKS or iss/sub/aud will be added to the existing configuration and if the change mode is set to DELETE , the old JWKS or iss/sub/aud will be deleted. The option UPDATE overwrites the existing trust setting and allows switching between JWKS and JWKS_URI . |
List
$ curl 'http://localhost/oauth/clients?filter=client_id+eq+%22yGlfI_%22&sortBy=client_id&sortOrder=descending&startIndex=1&count=10' -i -X GET \
-H 'Authorization: Bearer 6e6b1e692458424f90e5f8a3bda65db3' \
-H 'Accept: application/json'
GET /oauth/clients?filter=client_id+eq+%22yGlfI_%22&sortBy=client_id&sortOrder=descending&startIndex=1&count=10 HTTP/1.1
Authorization: Bearer 6e6b1e692458424f90e5f8a3bda65db3
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 672
{
"resources" : [ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "yGlfI_",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "uCQ42T",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712926158
} ],
"startIndex" : 1,
"itemsPerPage" : 1,
"totalResults" : 1,
"schemas" : [ "http://cloudfoundry.org/schema/scim/oauth-clients-1.0" ]
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.read , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
filter |
SCIM filter for querying clients |
sortBy |
Field to sort results by |
sortOrder |
Sort results in ascending or descending order |
startIndex |
Index of the first result on which to begin the page |
count |
Number of results per page |
Response Fields
Path | Type | Description |
---|---|---|
resources[].client_id |
String |
Client identifier, unique within identity zone |
resources[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
resources[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
resources[].scope |
Array |
Scopes allowed for the client |
resources[].resource_ids |
Array |
Resources the client is allowed access to |
resources[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
resources[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
resources[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
resources[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
resources[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
resources[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
resources[].name |
String |
A human readable name for the client |
resources[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
resources[].createdwith |
String |
What scope the bearer token had when client was created |
resources[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
resources[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
resources[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
startIndex |
Number |
Index of the first result on this page |
itemsPerPage |
Number |
Number of results per page |
totalResults |
Number |
Total number of results that matched the query |
schemas |
Array |
["urn:scim:schemas:core:1.0"] |
Batch Create
$ curl 'http://localhost/oauth/clients/tx' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea' \
-H 'Accept: application/json' \
-d '[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "Il4O9Y",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
} ]'
POST /oauth/clients/tx HTTP/1.1
Content-Type: application/json
Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea
Accept: application/json
Content-Length: 942
Host: localhost
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "Il4O9Y",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
} ]
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1040
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925790,
"required_user_groups" : [ ]
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "Il4O9Y",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925791,
"required_user_groups" : [ ]
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
[].client_id | String | Required | Client identifier, unique within identity zone |
[].authorized_grant_types | Array | Optional | List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri | Array | Optional | Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope | Array | Optional (defaults to "uaa.none" ) |
Scopes allowed for the client |
[].resource_ids | Array | Optional (defaults to [] ) |
Resources the client is allowed access to |
[].authorities | Array | Optional (defaults to "uaa.none" ) |
Scopes which the client is able to grant when creating a client |
[].autoapprove | [Boolean, Array] | Optional (defaults to [] ) |
Scopes that do not require user approval |
[].allowpublic | Boolean | Optional (defaults to false ) |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity | Number | Optional | time in seconds to access token expiration after it is issued |
[].refresh_token_validity | Number | Optional | time in seconds to refresh token expiration after it is issued |
[].allowedproviders | Array | Optional | A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name | String | Optional | A human readable name for the client |
[].token_salt | String | Optional | A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith | String | Optional | What scope the bearer token had when client was created |
[].approvals_deleted | Boolean | Optional | Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups | Array | Optional | A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].client_secret | String | Required if the client allows authorization_code or client_credentials grant type |
A secret string used for authenticating as this client. |
Response Fields
Path | Type | Description |
---|---|---|
[].client_id |
String |
Client identifier, unique within identity zone |
[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope |
Array |
Scopes allowed for the client |
[].resource_ids |
Array |
Resources the client is allowed access to |
[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name |
String |
A human readable name for the client |
[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith |
String |
What scope the bearer token had when client was created |
[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Batch Update
$ curl 'http://localhost/oauth/clients/tx' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea' \
-H 'Accept: application/json' \
-d '[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "new.authority", "clients.write" ],
"token_salt" : "Il4O9Y",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
} ]'
PUT /oauth/clients/tx HTTP/1.1
Content-Type: application/json
Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea
Accept: application/json
Content-Length: 899
Host: localhost
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"authorities" : [ "clients.read", "new.authority", "clients.write" ],
"token_salt" : "Il4O9Y",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name"
} ]
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1057
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925790,
"required_user_groups" : [ ]
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "new.authority", "clients.write" ],
"token_salt" : "Il4O9Y",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925791,
"required_user_groups" : [ ]
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
[].client_id | String | Required | Client identifier, unique within identity zone |
[].authorized_grant_types | Array | Optional | List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri | Array | Optional | Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope | Array | Optional (defaults to "uaa.none" ) |
Scopes allowed for the client |
[].resource_ids | Array | Optional (defaults to [] ) |
Resources the client is allowed access to |
[].authorities | Array | Optional (defaults to "uaa.none" ) |
Scopes which the client is able to grant when creating a client |
[].autoapprove | [Boolean, Array] | Optional (defaults to [] ) |
Scopes that do not require user approval |
[].allowpublic | Boolean | Optional (defaults to false ) |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity | Number | Optional | time in seconds to access token expiration after it is issued |
[].refresh_token_validity | Number | Optional | time in seconds to refresh token expiration after it is issued |
[].allowedproviders | Array | Optional | A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name | String | Optional | A human readable name for the client |
[].token_salt | String | Optional | A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith | String | Optional | What scope the bearer token had when client was created |
[].approvals_deleted | Boolean | Optional | Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups | Array | Optional | A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
Response Fields
Path | Type | Description |
---|---|---|
[].client_id |
String |
Client identifier, unique within identity zone |
[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope |
Array |
Scopes allowed for the client |
[].resource_ids |
Array |
Resources the client is allowed access to |
[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name |
String |
A human readable name for the client |
[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith |
String |
What scope the bearer token had when client was created |
[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
Batch Secret Change
$ curl 'http://localhost/oauth/clients/tx/secret' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea' \
-H 'Accept: application/json' \
-d '[ {
"clientId" : "5vl-eM",
"secret" : "new_secret"
}, {
"clientId" : "XYUJVw",
"secret" : "new_secret"
} ]'
POST /oauth/clients/tx/secret HTTP/1.1
Content-Type: application/json
Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea
Accept: application/json
Content-Length: 114
Host: localhost
[ {
"clientId" : "5vl-eM",
"secret" : "new_secret"
}, {
"clientId" : "XYUJVw",
"secret" : "new_secret"
} ]
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1117
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925847,
"required_user_groups" : [ ],
"approvals_deleted" : true
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "new.authority", "clients.write" ],
"token_salt" : "Il4O9Y",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925848,
"required_user_groups" : [ ],
"approvals_deleted" : true
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
[].clientId | String | Required | Client identifier, unique within identity zone |
[].oldSecret | String | Optional if authenticated as an admin client. Required otherwise. | A valid client secret before updating |
[].secret | String | Required | The new client secret |
[].changeMode | String | Optional (defaults to "UPDATE" ) |
If change mode is set to ADD , the new secret will be added to the existing one and if the change mode is set to DELETE , the old secret will be deleted to support secret rotation. Currently only two client secrets are supported at any given time. |
Response Fields
Path | Type | Description |
---|---|---|
[].client_id |
String |
Client identifier, unique within identity zone |
[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope |
Array |
Scopes allowed for the client |
[].resource_ids |
Array |
Resources the client is allowed access to |
[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name |
String |
A human readable name for the client |
[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith |
String |
What scope the bearer token had when client was created |
[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
[].approvals_deleted |
Boolean |
Indicates whether the approvals associated with the client were deleted as a result of this action |
Mixed Actions
$ curl 'http://localhost/oauth/clients/tx/modify' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea' \
-H 'Accept: application/json' \
-d '[ {
"action" : "secret",
"client_secret" : "new_secret",
"client_id" : "5vl-eM"
}, {
"action" : "delete",
"client_id" : "XYUJVw"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "nHdY77",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"action" : "add",
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "83Cdf0",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"approvals_deleted" : false
} ]'
POST /oauth/clients/tx/modify HTTP/1.1
Content-Type: application/json
Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea
Accept: application/json
Content-Length: 663
Host: localhost
[ {
"action" : "secret",
"client_secret" : "new_secret",
"client_id" : "5vl-eM"
}, {
"action" : "delete",
"client_id" : "XYUJVw"
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "nHdY77",
"client_secret" : "secret",
"resource_ids" : [ ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://test1.com", "http://ant.path.wildcard/**/passback/*" ],
"action" : "add",
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "83Cdf0",
"autoapprove" : true,
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"approvals_deleted" : false
} ]
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1343
[ {
"scope" : [ ],
"client_id" : "5vl-eM",
"resource_ids" : [ ],
"authorized_grant_types" : [ ],
"action" : "secret",
"authorities" : [ ],
"approvals_deleted" : false
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "XYUJVw",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"action" : "delete",
"authorities" : [ "clients.read", "new.authority", "clients.write" ],
"token_salt" : "Il4O9Y",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925848,
"required_user_groups" : [ ],
"approvals_deleted" : true
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "nHdY77",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"action" : "add",
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "83Cdf0",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"approvals_deleted" : false,
"lastModified" : 1760712925969,
"required_user_groups" : [ ]
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
[].client_id | String | Required | Client identifier, unique within identity zone |
[].authorized_grant_types | Array | Optional | List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri | Array | Optional | Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope | Array | Optional (defaults to "uaa.none" ) |
Scopes allowed for the client |
[].resource_ids | Array | Optional (defaults to [] ) |
Resources the client is allowed access to |
[].authorities | Array | Optional (defaults to "uaa.none" ) |
Scopes which the client is able to grant when creating a client |
[].autoapprove | [Boolean, Array] | Optional (defaults to [] ) |
Scopes that do not require user approval |
[].allowpublic | Boolean | Optional (defaults to false ) |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity | Number | Optional | time in seconds to access token expiration after it is issued |
[].refresh_token_validity | Number | Optional | time in seconds to refresh token expiration after it is issued |
[].allowedproviders | Array | Optional | A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name | String | Optional | A human readable name for the client |
[].token_salt | String | Optional | A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith | String | Optional | What scope the bearer token had when client was created |
[].approvals_deleted | Boolean | Optional | Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups | Array | Optional | A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].client_secret | String | Required if the client allows authorization_code or client_credentials grant type |
A secret string used for authenticating as this client. |
[].action | String | Always required. | Set to secret to change client secret, delete to delete the client or add to add the client |
Response Fields
Path | Type | Description |
---|---|---|
[].client_id |
String |
Client identifier, unique within identity zone |
[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope |
Array |
Scopes allowed for the client |
[].resource_ids |
Array |
Resources the client is allowed access to |
[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name |
String |
A human readable name for the client |
[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith |
String |
What scope the bearer token had when client was created |
[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
[].action |
String |
Set to secret to change client secret, delete to delete the client or add to add the client |
Batch Delete
$ curl 'http://localhost/oauth/clients/tx/delete' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea' \
-H 'Accept: application/json' \
-d '[ {
"client_id" : "5vl-eM"
}, {
"client_id" : "nHdY77"
} ]'
POST /oauth/clients/tx/delete HTTP/1.1
Content-Type: application/json
Authorization: Bearer a0ea388f6dc9411a96ac45859bab0bea
Accept: application/json
Content-Length: 62
Host: localhost
[ {
"client_id" : "5vl-eM"
}, {
"client_id" : "nHdY77"
} ]
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1100
[ {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "5vl-eM",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "BqklnQ",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"lastModified" : 1760712925847,
"required_user_groups" : [ ],
"approvals_deleted" : true
}, {
"scope" : [ "clients.read", "clients.write" ],
"client_id" : "nHdY77",
"resource_ids" : [ "none" ],
"authorized_grant_types" : [ "client_credentials" ],
"redirect_uri" : [ "http://ant.path.wildcard/**/passback/*", "http://test1.com" ],
"autoapprove" : [ "true" ],
"authorities" : [ "clients.read", "clients.write" ],
"token_salt" : "83Cdf0",
"allowedproviders" : [ "uaa", "ldap", "my-saml-provider" ],
"name" : "My Client Name",
"approvals_deleted" : true,
"lastModified" : 1760712925969,
"required_user_groups" : [ ]
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.write , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Fields
Path | Type | Constraints | Description |
---|---|---|---|
[].client_id | String | Required | Client identifier, unique within identity zone |
Response Fields
Path | Type | Description |
---|---|---|
[].client_id |
String |
Client identifier, unique within identity zone |
[].authorized_grant_types |
Array |
List of grant types that can be used to obtain a token with this client. Can include authorization_code , password , implicit , and/or client_credentials . |
[].redirect_uri |
Array |
Allowed URI pattern for redirect during authorization. Wildcard patterns can be specified using the Ant-style pattern. Null/Empty value is forbidden. |
[].scope |
Array |
Scopes allowed for the client |
[].resource_ids |
Array |
Resources the client is allowed access to |
[].authorities |
Array |
Scopes which the client is able to grant when creating a client |
[].autoapprove |
[Boolean, Array] |
Scopes that do not require user approval |
[].allowpublic |
Boolean |
If true, allow to omit client_secret for authorization_code flow in combination with PKCE |
[].access_token_validity |
Number |
time in seconds to access token expiration after it is issued |
[].refresh_token_validity |
Number |
time in seconds to refresh token expiration after it is issued |
[].allowedproviders |
Array |
A list of origin keys (alias) for identity providers the client is limited to. Null implies any identity provider is allowed. |
[].name |
String |
A human readable name for the client |
[].token_salt |
String |
A random string used to generate the client's revokation key. Change this value to revoke all active tokens for the client |
[].createdwith |
String |
What scope the bearer token had when client was created |
[].approvals_deleted |
Boolean |
Were the approvals deleted for the client, and an audit event sent |
[].required_user_groups |
Array |
A list of group names. If a user doesn't belong to all the required groups, the user will not be authenticated and no tokens will be issued to this client for that user. If this field is not set, authentication and token issuance will proceed normally. |
[].lastModified |
Number |
Epoch (milliseconds) of the moment the client information was last altered |
[].approvals_deleted |
Boolean |
Indicates whether the approvals associated with the client were deleted as a result of this action |
Metadata
Retrieve
$ curl 'http://localhost/oauth/clients/jCEqu3Xx/meta' -i -X GET \
-H 'Authorization: Bearer 34c50cf6eb9640a28de3b03573a586d5' \
-H 'Accept: application/json'
GET /oauth/clients/jCEqu3Xx/meta HTTP/1.1
Authorization: Bearer 34c50cf6eb9640a28de3b03573a586d5
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 199
{
"clientId" : "jCEqu3Xx",
"showOnHomePage" : true,
"appLaunchUrl" : "http://myloginpage.com",
"appIcon" : "aWNvbiBmb3IgY2xpZW50IDQ=",
"createdBy" : "408dc1e3-eaec-4ac4-94e5-f9f860203d13"
}
Path Parameters
/oauth/clients/{clientId}/meta
Parameter | Description |
---|---|
clientId | Client identifier, unique within identity zone |
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token |
Response Fields
Path | Type | Description |
---|---|---|
clientId |
String |
Client identifier, unique within identity zone |
showOnHomePage |
Boolean |
Flag to control visibility on home page |
appLaunchUrl |
String |
URL to which the app is linked to |
appIcon |
String |
Base64 encoded image file |
createdBy |
String |
The user guid of the resource owner who created this client |
Error Code | Description |
---|---|
404 | Not Found - clientId doesn't exists |
List
$ curl 'http://localhost/oauth/clients/meta' -i -X GET \
-H 'Authorization: Bearer 5be3e951ffa34407afd7f0a2150d2576' \
-H 'Accept: application/json'
GET /oauth/clients/meta HTTP/1.1
Authorization: Bearer 5be3e951ffa34407afd7f0a2150d2576
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 2854
[ {
"clientId" : "CnsVHEPk",
"showOnHomePage" : false,
"appLaunchUrl" : "http://client4.com/app",
"appIcon" : "aWNvbiBmb3IgY2xpZW50IDQ="
}, {
"clientId" : "admin",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "app",
"clientName" : "The Ultimate Oauth App",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "appspecial",
"clientName" : "The Ultimate Oauth App - Special",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "cf",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "client_federated_jwt_trust",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "client_with_allowpublic_and_jwks_uri_trust",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "client_with_bcrypt_prefix",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "client_with_jwks_trust",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "client_without_openid",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "dW8fxcLe",
"showOnHomePage" : false,
"appLaunchUrl" : "http://changed.app.launch/url",
"appIcon" : "",
"createdBy" : "408dc1e3-eaec-4ac4-94e5-f9f860203d13"
}, {
"clientId" : "dashboard",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "dwN9Qy20",
"showOnHomePage" : true,
"appLaunchUrl" : "http://myloginpage.com",
"appIcon" : "aWNvbiBmb3IgY2xpZW50IDQ=",
"createdBy" : "408dc1e3-eaec-4ac4-94e5-f9f860203d13"
}, {
"clientId" : "identity",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "jku_test",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "jku_test_without_autoapprove",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "login",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "nd0JoRV9",
"showOnHomePage" : true,
"appLaunchUrl" : "http://client3.com/app",
"appIcon" : "Y2xpZW50IDMgaWNvbg=="
}, {
"clientId" : "notifications",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_authorization_code",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_client_credentials",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_implicit_grant",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_password_grant",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_saml2_bearer",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_user_token",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "oauth_showcase_user_token_public",
"showOnHomePage" : false,
"appIcon" : ""
}, {
"clientId" : "some_client_that_contains_redirect_uri_matching_request_param",
"showOnHomePage" : false,
"appIcon" : ""
} ]
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token |
Response Fields
Path | Type | Description |
---|---|---|
[].clientId |
String |
Client identifier, unique within identity zone |
[].clientName |
String |
Human readable display name for the client |
[].showOnHomePage |
Boolean |
Flag to control visibility on home page |
[].appLaunchUrl |
String |
URL to which the app is linked to |
[].appIcon |
String |
Base64 encoded image file |
[].createdBy |
String |
The user guid of the resource owner who created this client |
Update
$ curl 'http://localhost/oauth/clients/dW8fxcLe/meta' -i -X PUT \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer 83d05c6226a2468090975ca6d130bb4d' \
-H 'If-Match: 0' \
-H 'Accept: application/json' \
-d '{"clientId":"dW8fxcLe","showOnHomePage":false,"appLaunchUrl":"http://changed.app.launch/url"}'
PUT /oauth/clients/dW8fxcLe/meta HTTP/1.1
Content-Type: application/json
Authorization: Bearer 83d05c6226a2468090975ca6d130bb4d
If-Match: 0
Accept: application/json
Content-Length: 93
Host: localhost
{"clientId":"dW8fxcLe","showOnHomePage":false,"appLaunchUrl":"http://changed.app.launch/url"}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 183
{
"clientId" : "dW8fxcLe",
"showOnHomePage" : false,
"appLaunchUrl" : "http://changed.app.launch/url",
"appIcon" : "",
"createdBy" : "408dc1e3-eaec-4ac4-94e5-f9f860203d13"
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token containing clients.read , clients.admin or zones.{zone.id}.admin |
X-Identity-Zone-Id |
May include this header to administer another zone if using zones.<zone.id>.admin or uaa.admin scope against the default UAA zone. |
Response Fields
Path | Type | Description |
---|---|---|
clientId |
String |
Client identifier, unique within identity zone |
showOnHomePage |
Boolean |
Flag to control visibility on home page |
appLaunchUrl |
String |
URL to which the app is linked to |
appIcon |
String |
Base64 encoded image file |
createdBy |
String |
The user guid of the resource owner who created this client |
Error Code | Description |
---|---|
404 | Not Found - clientId doesn't exists |
400 | Bad Request |
Server Information
The UAA provides several endpoints to describe the server as well as handle various login tasks.
Server Information
This endpoint has two identical endpoints
- /info
- /login
Both return the same result and both support both JSON and HTML output. The HTML output is intended for browser user agents to display a login page.
$ curl 'http://localhost/info?origin=oidc-provider' -i -X GET \
-H 'Accept: application/json'
GET /info?origin=oidc-provider HTTP/1.1
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Language: en
Content-Type: application/json;charset=UTF-8
Cache-Control: no-store
X-XSS-Protection: 0
X-Frame-Options: DENY
Content-Length: 852
{
"app" : {
"version" : "78.5.0"
},
"showLoginLinks" : true,
"links" : {
"uaa" : "http://localhost:8080/uaa",
"passwd" : "/forgot_password",
"login" : "http://localhost:8080/uaa",
"register" : "/create_account"
},
"zone_name" : "uaa",
"entityID" : "integration-saml-entity-id",
"commit_id" : "git-metadata-not-found",
"idpDefinitions" : {
"testsaml-redirect-binding" : "http://localhost:8080/uaa/saml2/authenticate/testsaml-redirect-binding",
"testsaml-post-binding" : "http://localhost:8080/uaa/saml2/authenticate/testsaml-post-binding"
},
"prompts" : {
"username" : [ "text", "Email" ],
"password" : [ "password", "Password" ],
"passcode" : [ "password", "Temporary Authentication Code ( Get one at http://localhost:8080/uaa/passcode )" ]
},
"timestamp" : "2025-10-17T14:52:16+0000"
}
Request Headers
Name | Description |
---|---|
Accept |
When set to accept application/json the server will return prompts and server info in JSON format. |
Request Parameters
Parameter | Description |
---|---|
origin |
Use the configured prompts of the OpenID Connect Provider with the given origin key in the response. Fallback to zone values if no prompts are configured or origin is invalid. |
Response Fields
Path | Type | Description |
---|---|---|
app.version |
String |
The UAA version |
commit_id |
String |
The GIT sha for the UAA version |
timestamp |
String |
JSON timestamp for the commit of the UAA version |
idpDefinitions |
Object |
A list of alias/url pairs of SAML IDP providers configured. Each url is the starting point to initiate the authentication process for the SAML identity provider. |
idpDefinitions.* |
Varies |
The URL to initiate the authentication process for the SAML identity provider. |
links |
Object |
A list of alias/url pairs of configured action URLs for the UAA |
links.login |
String |
The link to the login host alias of the UAA |
links.uaa |
String |
The link to the uaa alias host of the UAA |
links.passwd |
String |
The link to the 'Forgot Password' functionality. Can be external or internal to the UAA |
links.register |
String |
The link to the 'Create Account' functionality. Can be external or internal to the UAA |
entityID |
String |
The UAA is always a SAML service provider. This field contains the configured entityID |
prompts |
Object |
A list of name/value pairs of configured prompts that the UAA will login a user. Format for each prompt is [type, display name] where type can be 'text' or 'password' |
prompts.username |
Array |
Information about the username prompt. |
prompts.password |
Array |
Information about the password prompt. |
prompts.passcode |
Array |
If a SAML identity provider is configured, this prompt contains a URL to where the user can initiate the SAML authentication flow. |
zone_name |
String |
The name of the zone invoked |
showLoginLinks |
Boolean |
Set to true if there are SAML or OAUTH/OIDC providers with a visible link on the login page. |
OpenID Connect Discovery
Provide OpenID Connect metadata related to the specified server. This URI Discovery Mechanism for the Provider Configuration is defined in OpenID Discovery Configuration standard.
OpenID Well-Known Configuration
An OpenID Discovery Configuration Document MUST be queried using an HTTP GET request at path /.well-known/openid-configuration.
$ curl 'http://localhost/.well-known/openid-configuration' -i -X GET \
-H 'Accept: application/json'
GET /.well-known/openid-configuration HTTP/1.1
Accept: application/json
Host: localhost
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 1375
{
"issuer" : "http://localhost:8080/uaa/oauth/token",
"authorization_endpoint" : "http://localhost/oauth/authorize",
"token_endpoint" : "http://localhost/oauth/token",
"token_endpoint_auth_methods_supported" : [ "client_secret_basic", "client_secret_post", "private_key_jwt" ],
"token_endpoint_auth_signing_alg_values_supported" : [ "RS256", "HS256" ],
"userinfo_endpoint" : "http://localhost/userinfo",
"jwks_uri" : "http://localhost/token_keys",
"end_session_endpoint" : "http://localhost/logout.do",
"scopes_supported" : [ "openid", "profile", "email", "phone", "roles", "user_attributes" ],
"response_types_supported" : [ "code", "code id_token", "id_token", "token id_token" ],
"subject_types_supported" : [ "public" ],
"id_token_signing_alg_values_supported" : [ "RS256", "HS256" ],
"id_token_encryption_alg_values_supported" : [ "none" ],
"claim_types_supported" : [ "normal" ],
"claims_supported" : [ "sub", "user_name", "origin", "iss", "auth_time", "amr", "acr", "client_id", "aud", "zid", "grant_type", "user_id", "azp", "scope", "exp", "iat", "jti", "rev_sig", "cid", "given_name", "family_name", "phone_number", "email" ],
"claims_parameter_supported" : false,
"service_documentation" : "http://docs.cloudfoundry.org/api/uaa/",
"ui_locales_supported" : [ "en-US" ],
"code_challenge_methods_supported" : [ "S256", "plain" ]
}
Response Fields
Path | Type | Description |
---|---|---|
issuer |
String |
URL using the https scheme with no query or fragment component that the OP asserts as its Issuer Identifier. |
authorization_endpoint |
String |
URL of authorization endpoint. |
token_endpoint |
String |
URL of token endpoint. |
userinfo_endpoint |
String |
URL of the OP's UserInfo Endpoint. |
jwks_uri |
String |
URL of the OP's JSON Web Key Set document. |
end_session_endpoint |
String |
URL of the logout endpoint. |
scopes_supported |
Array |
JSON array containing a list of the OAuth 2.0 scope values that this server supports. |
subject_types_supported |
Array |
JSON array containing a list of the Subject Identifier types that this OP supports. |
token_endpoint_auth_methods_supported |
Array |
JSON array containing a list of Client Authentication methods supported by this Token Endpoint. |
token_endpoint_auth_signing_alg_values_supported |
Array |
JSON array containing a list of the JWS signing algorithms. |
response_types_supported |
Array |
JSON array containing a list of the OAuth 2.0 response_type values that this OP supports. |
id_token_signing_alg_values_supported |
Array |
JSON array containing a list of the JWS signing algorithms (alg values) supported by the OP for the ID Token to encode the Claims in a JWT. |
id_token_encryption_alg_values_supported |
Array |
JSON array containing a list of the JWE encryption algorithms (alg values) supported by the OP. |
claim_types_supported |
Array |
JSON array containing a list of the Claim Types that the OpenID Provider supports. |
claims_supported |
Array |
JSON array containing a list of the Claim Names of the Claims that the OpenID Provider MAY be able to supply values for. |
claims_parameter_supported |
Boolean |
Boolean value specifying whether the OP supports use of the claims parameter. |
service_documentation |
String |
URL of a page containing human-readable information that developers might want or need to know when using the OpenID Provider. |
code_challenge_methods_supported |
Array |
UAA 75.5.0JSON array containing a list of PKCE code challenge methods supported by this authorization endpoint. |
ui_locales_supported |
Array |
Languages and scripts supported for the user interface. |
Passcode
A user that has been authenticated, can request a one time authentication code, pass code, to be used during a token password grant. Password grants are often used in non browser environments, and authenticating a user with SAML, may be difficult.
$ curl 'http://localhost/passcode' -i -X GET \
-H 'Accept: application/json' \
-H 'Cookie: JSESSIONID=20'
GET /passcode HTTP/1.1
Accept: application/json
Cookie: JSESSIONID=20
Host: localhost
HTTP/1.1 200 OK
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: X-Uaa-Csrf=XZOu0fTJqXBgj4MuawcwLA; Path=/; Max-Age=86400; Expires=Sat, 18 Oct 2025 14:55:18 GMT; HttpOnly; SameSite=Lax
Content-Language: en
Content-Type: application/json;charset=UTF-8
Cache-Control: no-store
X-Frame-Options: DENY
Content-Length: 34
"cVK7-DtjVxsYFvGzHoxx7E0pfIeX4nZV"
Request Headers
Name | Description |
---|---|
Cookie |
JSESSIONID cookie to match the server side session of the authenticated user. |
Auto Login
Get authentication code
Similar to /passcode, the difference with an autologin authentication code, is that the authentication of the user takes place during the generation of the temporary authentication code. The autologin authentication code can be used to log the user in with an HTTP redirect. The UAA will establish an authenticated server side session and expire the code. To generate the temporary authentication code, a POST against /autologin is required.
$ curl 'http://localhost/autologin' -i -u 'admin:adminsecret' -X POST \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-d '{"username":"marissa","password":"koala"}'
POST /autologin HTTP/1.1
Content-Type: application/json
Authorization: Basic YWRtaW46YWRtaW5zZWNyZXQ=
Accept: application/json
Content-Length: 41
Host: localhost
{"username":"marissa","password":"koala"}
HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 80
{
"code" : "aS68OVU6HW0Tn_8imKyViPde5jyhGi0u",
"path" : "/oauth/authorize"
}
Request Headers
Name | Description |
---|---|
Authorization |
Basic authorization header for the client making the autologin request |
Content-Type |
Set to application/json |
Accept |
Set to application/json |
Request Body
Path | Type | Constraints | Description |
---|---|---|---|
username | String | Required | The username for the autologin request |
password | String | Required | The password for the autologin request |
Response Body
Path | Type | Description |
---|---|---|
code |
String |
The code used to authenticate the user. |
path |
String |
Not used. Hardcoded to /oauth/authorize |
Perform Login
To exchange the code for an authenticated session, simply issue a redirect to /autologin using the code and client_id. If successful the user will be redirected to the home page, unless the user had tried to access a protected URL and the UAA remembers the URL that was accessed.
$ curl 'http://localhost/autologin?code=b2g4o0kx0_UWFpD7zoQdZ1NOtpqm7z4W&client_id=admin' -i -X GET
GET /autologin?code=b2g4o0kx0_UWFpD7zoQdZ1NOtpqm7z4W&client_id=admin HTTP/1.1
Host: localhost
HTTP/1.1 302 Found
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Set-Cookie: Current-User=%7B%22userId%22%3A%2233f94fba-4367-4414-ab55-4ec7c051e391%22%7D; Path=/; Max-Age=1800; Expires=Fri, 17 Oct 2025 15:25:18 GMT; SameSite=Strict
Content-Language: en
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Location: home
Request Parameters
Parameter | Description |
---|---|
code |
The code generated from the POST /autologin |
client_id |
The client_id that generated the autologin code |
External Login Server
The UAA provides endpoints that facilitate the use of an external login server. A server that handles the UI for browser based actions.
Change Password Flow
Request Reset Password Code
This endpoint returns an onetime code that can be used to change a user's password.
The actual password change can take place by invoking an API endpoint, /password_change
, or by a UI flow through
the /reset_password
endpoint.
$ curl 'http://localhost/password_resets?client_id=login&redirect_uri=http%3A%2F%2Fgo.to.my.app%2Fafter%2Freset' -i -X POST \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJsb2dpbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJlbWFpbHMud3JpdGUiLCJzY2ltLnVzZXJpZHMiLCJwYXNzd29yZC53cml0ZSIsImlkcHMud3JpdGUiLCJub3RpZmljYXRpb25zLndyaXRlIiwib2F1dGgubG9naW4iLCJzY2ltLndyaXRlIiwiY3JpdGljYWxfbm90aWZpY2F0aW9ucy53cml0ZSJdLCJjbGllbnRfaWQiOiJsb2dpbiIsImF1ZCI6WyJlbWFpbHMiLCJzY2ltIiwicGFzc3dvcmQiLCJjcml0aWNhbF9ub3RpZmljYXRpb25zIiwiY2xpZW50cyIsImxvZ2luIiwib2F1dGgiLCJub3RpZmljYXRpb25zIiwiaWRwcyJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoibG9naW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJlbWFpbHMud3JpdGUiLCJzY2ltLnVzZXJpZHMiLCJwYXNzd29yZC53cml0ZSIsImlkcHMud3JpdGUiLCJub3RpZmljYXRpb25zLndyaXRlIiwib2F1dGgubG9naW4iLCJzY2ltLndyaXRlIiwiY3JpdGljYWxfbm90aWZpY2F0aW9ucy53cml0ZSJdLCJleHAiOjE3NjA3NTYxMjYsImlhdCI6MTc2MDcxMjkyNiwianRpIjoiMmVhNzA0MTFmYzQyNDJmMGIxNDFlNTA1M2ZhMmE4MWQiLCJyZXZfc2lnIjoiZTBlOTgxNjMiLCJjaWQiOiJsb2dpbiJ9.N_PN96_sBsPpt82whqZ7Rh8wls5XlRRrmZ5LKDwfzKJGRl11VESLpsMJxITl8wSWfFxmIYSBMYLe64EAzdumMEz8PcfAKkfkKCv-ClYIAlLer3wm-nYUrPqitJCFXMf9abH96diUd9qJ-b2-0j4kXCRZyzDkZZpjTv5xpbqbMGW1sewk6WTtDe_rvZHvQCAvhoWmqaCbG3Whaqwx1P3jpH_jyAs8o0iHhnE21whwX-5ZTprKpXpblkawsh76AanBfmYo6kzOK4a4YGRIrzStYygy-DDgeAYwRC8YMMR5ijb5e_PkhyNru-2oO-hfnLFvg3BNiVG1BA6u7Syu3-vIgw' \
-H 'Accept: application/json' \
-d '[email protected]'
POST /password_resets?client_id=login&redirect_uri=http%3A%2F%2Fgo.to.my.app%2Fafter%2Freset HTTP/1.1
Content-Type: application/json
Authorization: Bearer eyJqa3UiOiJodHRwczovL2xvY2FsaG9zdDo4MDgwL3VhYS90b2tlbl9rZXlzIiwia2lkIjoia2V5LWlkLTEiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJsb2dpbiIsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC91YWEvb2F1dGgvdG9rZW4iLCJhdXRob3JpdGllcyI6WyJjbGllbnRzLnJlYWQiLCJlbWFpbHMud3JpdGUiLCJzY2ltLnVzZXJpZHMiLCJwYXNzd29yZC53cml0ZSIsImlkcHMud3JpdGUiLCJub3RpZmljYXRpb25zLndyaXRlIiwib2F1dGgubG9naW4iLCJzY2ltLndyaXRlIiwiY3JpdGljYWxfbm90aWZpY2F0aW9ucy53cml0ZSJdLCJjbGllbnRfaWQiOiJsb2dpbiIsImF1ZCI6WyJlbWFpbHMiLCJzY2ltIiwicGFzc3dvcmQiLCJjcml0aWNhbF9ub3RpZmljYXRpb25zIiwiY2xpZW50cyIsImxvZ2luIiwib2F1dGgiLCJub3RpZmljYXRpb25zIiwiaWRwcyJdLCJ6aWQiOiJ1YWEiLCJncmFudF90eXBlIjoiY2xpZW50X2NyZWRlbnRpYWxzIiwiYXpwIjoibG9naW4iLCJzY29wZSI6WyJjbGllbnRzLnJlYWQiLCJlbWFpbHMud3JpdGUiLCJzY2ltLnVzZXJpZHMiLCJwYXNzd29yZC53cml0ZSIsImlkcHMud3JpdGUiLCJub3RpZmljYXRpb25zLndyaXRlIiwib2F1dGgubG9naW4iLCJzY2ltLndyaXRlIiwiY3JpdGljYWxfbm90aWZpY2F0aW9ucy53cml0ZSJdLCJleHAiOjE3NjA3NTYxMjYsImlhdCI6MTc2MDcxMjkyNiwianRpIjoiMmVhNzA0MTFmYzQyNDJmMGIxNDFlNTA1M2ZhMmE4MWQiLCJyZXZfc2lnIjoiZTBlOTgxNjMiLCJjaWQiOiJsb2dpbiJ9.N_PN96_sBsPpt82whqZ7Rh8wls5XlRRrmZ5LKDwfzKJGRl11VESLpsMJxITl8wSWfFxmIYSBMYLe64EAzdumMEz8PcfAKkfkKCv-ClYIAlLer3wm-nYUrPqitJCFXMf9abH96diUd9qJ-b2-0j4kXCRZyzDkZZpjTv5xpbqbMGW1sewk6WTtDe_rvZHvQCAvhoWmqaCbG3Whaqwx1P3jpH_jyAs8o0iHhnE21whwX-5ZTprKpXpblkawsh76AanBfmYo6kzOK4a4YGRIrzStYygy-DDgeAYwRC8YMMR5ijb5e_PkhyNru-2oO-hfnLFvg3BNiVG1BA6u7Syu3-vIgw
Accept: application/json
Content-Length: 20
Host: localhost
[email protected]
HTTP/1.1 201 Created
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self'
Content-Type: application/json
X-XSS-Protection: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 103
{
"code" : "OdYZ6rkVgfIO1KUkEm-xYOHRKxOzubNw",
"user_id" : "938687c9-f407-46b4-8a47-8899813b57c5"
}
Request Headers
Name | Description |
---|---|
Authorization |
Bearer token with the scope oauth.login present. |
X-Identity-Zone-Id |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a zone_id. |
X-Identity-Zone-Subdomain |
If using a zones.<zoneId>.admin scope/token, indicates what zone this request goes to by supplying a subdomain. |
Request Parameters
Parameter | Description |
---|---|
client_id |
Optional client_id |
redirect_uri |
Optional redirect_uri to be used if the /reset_password flow is completed. |
Request Body
The required request body of this request is the user's username, typically an email address, in form of a JSON string.
Response Body
Path | Type | Description |
---|---|---|
code |
String |
The code to used to invoke the /password_change endpoint with or to initiate the /reset_password flow. |
user_id |
String |
The UUID identifying the user. |