The Identity service generates authentication tokens that permit access to the OpenStack services REST APIs. Clients obtain this token and the URL endpoints for other service APIs by supplying their valid credentials to the authentication service.
Each time you make a REST API request to an OpenStack service, you supply your authentication token in the X-Auth-Token request header.
Like most OpenStack projects, OpenStack Identity protects its APIs by defining policy rules based on a role-based access control (RBAC) approach.
The Identity service configuration file sets the name and location of a JSON policy file that stores these rules.
Note that the V3 API implements HEAD for all GET requests. Each HEAD request contains the same headers and HTTP status code as the corresponding GET API.
For information about Identity API protection, see Identity API protection with role-based access control (RBAC) in the OpenStack Cloud Administrator Guide.
tags
attribute to project.tags
attribute.password_expires_at
query parameter to user list and users in
group list.password_expires_at
field to the user response object.is_domain
attribute enables a project to behave as
a domain.is_domain
field to project scoped token response that
represents whether a project is acting as a domain.admin project
.domain_id
filter to list user projectsenabled
and id
as optional attributes to filter identity
providers when listing.type
optional attribute to list credentials.region_id
optional attribute to list endpoints.is_domain
optional attribute to projects. Setting this
currently has no effect, it is reserved for future use.parent_id
optional attribute to projects. This enables the
construction of a hierarchy of projects.url
optional attribute for regions
. This attribute was
only used for the experimental phase of keystone-to-keystone federation and
has been superseded by making service provider entries have its own entry in
the service catalog.These features are considered stable as of September 4th, 2014.
name
optional variable to be included from service definition
into the service catalog.url
optional attribute for regions
.These features are considered stable as of January 23, 2014.
These features are considered stable as of July 18, 2013.
These features are considered stable as of February 20, 2013.
GET /tenants
) is now
explicitly based on your user ID: GET /users/{user_id}/projects
PATCH
methodThe entries within the operations below contain a relationship link, which appears as a valid URI, however these are actually URN (Uniform Resource Name), which are similar to GUID except it uses a URI syntax so that it is easier to be read. These links do not resolve to anything valid, but exist to show a relationship.
This page lists the Identity API operations in the following order:
The Identity service generates tokens in exchange for authentication credentials. A token represents the authenticated identity of a user and, optionally, grants authorization on a specific project, domain, or the deployment system.
The body of an authentication request must include a payload that
specifies the authentication method, which is password
or
token
, the credentials, and, optionally, the authorization
scope. You can scope a token to a project, domain, the deployment system, or
the token can be unscoped. You cannot scope a token to multiple scope targets.
Tokens have IDs, which the Identity API returns in the
X-Subject-Token
response header.
After you obtain an authentication token, you can:
X-Auth-Token
request
header.In v3.7 of the Identity API service, two new configuration options
were added: [resource] admin_project_name
and
[resource] admin_project_domain_name
. The options represent the
project that only the cloud administrator should be able to access.
When an authentication request for a token scoped to the admin project
is processed, it will have an additional field in the token
{is_admin_project: True}
. The additional field can be used when
writing policy rules that evaluate access control to APIs.
Alternatively, in v3.10 the Identity API service introduced the concept of system role assignments and system-scoped tokens. APIs that affect the deployment system require system-scoped tokens.
The Identity API considers expired tokens as invalid, which is determined by the deployment’s configuration.
These authentication errors can occur:
Authentication errors
Response code | Description |
Bad Request (400) |
The Identity service failed to parse the request as expected. One of the following errors occurred:
|
Unauthorized (401) |
One of the following errors occurred:
|
Forbidden (403) |
The identity was successfully authenticated but it is not authorized to perform the requested action. |
Not Found (404) |
An operation failed because a referenced entity cannot be found by ID. For a POST request, the referenced entity might be specified in the request body rather than in the resource path. |
Conflict (409) |
A POST or PATCH operation failed. For example, a client tried to update a unique attribute for an entity, which conflicts with that of another entity in the same collection. Or, a client issued a create operation twice on a collection with a
user-defined, unique attribute. For example, a client made a POST
|
Authenticates an identity and generates a token. Uses the password authentication method. Authorization is unscoped.
The request body must include a payload that specifies the
authentication method, which is password
, and the user, by ID
or name, and password credentials.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
domain | body | object | A domain object, containing: |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
auth | body | object | An auth object. |
user | body | object | A user object. |
password | body | object | The password object, contains the authentication information. |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
identity | body | object | An identity object. |
methods | body | array | The authentication method. For password
authentication, specify password . |
{
"auth": {
"identity": {
"methods": [
"password"
],
"password": {
"user": {
"name": "admin",
"domain": {
"name": "Default"
},
"password": "devstacker"
}
}
}
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
domain | body | object | A domain object, containing: |
methods | body | array | The authentication method. For password
authentication, specify password . |
expires_at | body | string | The date and time when the token expires. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, A |
token | body | object | A token object. |
user | body | object | A user object. |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
issued_at | body | string | The date and time when the token was issued. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"password"
],
"expires_at": "2015-11-06T15:32:17.893769Z",
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "423f19a4ac1e4f48bbb4180756e6eb6c",
"name": "admin",
"password_expires_at": null
},
"audit_ids": [
"ZzZwkUflQfygX7pdYDBCQQ"
],
"issued_at": "2015-11-06T14:32:17.893797Z"
}
}
Authenticates an identity and generates a token. Uses the password authentication method and scopes authorization to a project or domain.
The request body must include a payload that specifies the
password
authentication method, the credentials, and the
project
or domain
authorization scope.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
auth | body | object | An auth object. |
user | body | object | A user object. |
scope (Optional) | body | string | The authorization scope, including the system (Since v3.10), a
project, or a domain (Since v3.4). If both a domain and a project
are specified, an HTTP 400 Bad Request will be returned, as a
token cannot be simultaneously scoped to both a project
and a domain. An ID is sufficient to uniquely identify
a project but if a project is specified by name, then
the domain of the project must also be specified in order
to uniquely identify the project by name. A domain scope may be
specified by either the domain’s ID or name with
equivalent results. |
password | body | object | The password object, contains the authentication information. |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
identity | body | object | An identity object. |
methods | body | array | The authentication method. For password
authentication, specify password . |
{
"auth": {
"identity": {
"methods": [
"password"
],
"password": {
"user": {
"id": "ee4dfb6e5540447cb3741905149d9b6e",
"password": "devstacker"
}
}
},
"scope": {
"project": {
"id": "a6944d763bf64ee6a275f1263fae0352"
}
}
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
domain | body | object | A domain object, containing: |
region_id | body | string | (Since v3.2) The ID of the region that contains the service endpoint. |
methods | body | array | The authentication method. For password
authentication, specify password . |
roles | body | array | A list of role objects, each containing: |
url | body | string | The endpoint URL. |
region | body | string | (Deprecated in v3.2) The geographic location of the service endpoint. |
token | body | object | A token object. |
expires_at | body | string | The date and time when the token expires. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, A |
project | body | object | A project object, containing: |
system (Optional) | body | object | A system object. |
issued_at | body | string | The date and time when the token was issued. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, |
catalog | body | array | A catalog object. |
user | body | object | A user object. |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
interface | body | string | The interface type, which describes the
visibility of the endpoint. Value is: - public . Visible by
end users on a publicly available network interface. -
internal . Visible by end users on an unmetered internal
network interface. - admin . Visible by administrative users
on a secure network interface. |
endpoints | body | array | A list of endpoint objects. |
type | body | string | The endpoint type. |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"password"
],
"roles": [
{
"id": "51cc68287d524c759f47c811e6463340",
"name": "admin"
}
],
"expires_at": "2015-11-07T02:58:43.578887Z",
"project": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "a6944d763bf64ee6a275f1263fae0352",
"name": "admin"
},
"is_domain": false,
"catalog": [
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://example.com/identity/v2.0",
"region": "RegionOne",
"interface": "public",
"id": "068d1b359ee84b438266cb736d81de97"
},
{
"region_id": "RegionOne",
"url": "http://example.com/identity_v2_admin/v2.0",
"region": "RegionOne",
"interface": "admin",
"id": "8bfc846841ab441ca38471be6d164ced"
},
{
"region_id": "RegionOne",
"url": "http://example.com/identity/v2.0",
"region": "RegionOne",
"interface": "internal",
"id": "beb6d358c3654b4bada04d4663b640b9"
}
],
"type": "identity",
"id": "050726f278654128aba89757ae25950c",
"name": "keystone"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "admin",
"id": "ae36c0dbb0634e1dbf711f9fc2359975"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "d286b51530144d90a4de52d214d3ad1e"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "d6e681dd4aab4ae5a0937ed60bb4ae33"
}
],
"type": "compute_legacy",
"id": "1c4bfbabe3b346b1bbe27a4b3258964f",
"name": "nova_legacy"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "2dce7429526e44808235fe918063a914"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "a9a9929e6dc645c882ac1abd8bf73d38"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "admin",
"id": "c7d5f958df7f4c8da84db91094bdc198"
}
],
"type": "volumev2",
"id": "202382a1b8a94210bb3120af958092c4",
"name": "cinderv2"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080",
"region": "RegionOne",
"interface": "admin",
"id": "29b58f1406804c8180ccc01793ff8038"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080/v1/AUTH_a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "4c2c2968008c4e77973a5922e192d982"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080/v1/AUTH_a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "f6e7b28008bf41eaa114176a15ac1410"
}
],
"type": "object-store",
"id": "52fecdef9ad543779c1312392cc2b115",
"name": "swift"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "public",
"id": "6a2840dc63bf433592cd8bca2183eb3c"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "internal",
"id": "7967cf45f8ab439a80cf24420e5ffd0e"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "admin",
"id": "84943ce595264303bd44e5d6d79bea7b"
}
],
"type": "network",
"id": "67b993549db94296a853d635b48db3c9",
"name": "neutron"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "public",
"id": "2896609ef89741148bbd8c93babf5a12"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "internal",
"id": "30de385478fe4325849f98d1e45bc5e6"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "admin",
"id": "41256dc4b3c942daa383f940a9a56536"
}
],
"type": "messaging",
"id": "6fc9cc3e6b3843b899478554f9e297d3",
"name": "zaqar"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "admin",
"id": "07ea5fe3ae784001a73f131fb1764bf4"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "internal",
"id": "31e709ecb15d4881806dbced4eb3e60e"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "public",
"id": "a0c2a150a6ae4bbc85f1d428b9d78a1b"
}
],
"type": "messaging-websocket",
"id": "816031f798cc4ac7879eda0cf9cf033a",
"name": "zaqar-websocket"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "internal",
"id": "24df0277c2b6499ea6051bea8c59ff74"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "public",
"id": "438f4b3f3c314bbf988f1442cc3ddfa5"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "admin",
"id": "90a1c9fab54c452fa02a59ff87165029"
}
],
"type": "ec2",
"id": "915e2a8b1f314d55bba28432c9d5c1de",
"name": "ec2"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "admin",
"id": "2511589f262a407bb0071a814a480af4"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "9cf9209ae4fc4673a7295611001cf0ae"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "d200b2509e1343e3887dcc465b4fa534"
}
],
"type": "compute",
"id": "a226b3eeb5594f50bf8b6df94636ed28",
"name": "nova"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "bf2fe80c2a614e438d3e55b00e85b9ff"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "admin",
"id": "bfc9615fc24e4045aaf719f060984bf1"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "c76cf9930b0f4ccea6b1157f80119cfc"
}
],
"type": "orchestration",
"id": "a5f7070bda40443fa3819fbdf1689af1",
"name": "heat"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "internal",
"id": "3e321c2c6fa04152b3e86c18b91b93ae"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "admin",
"id": "55aef0f2557449d4946dc9461b73a63b"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/a6944d763bf64ee6a275f1263fae0352",
"region": "RegionOne",
"interface": "public",
"id": "7c91a66a200e458ca6e4e00fddf4d98b"
}
],
"type": "volume",
"id": "b6b5edc3fc384b6787149e91b3b31988",
"name": "cinder"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "public",
"id": "512c10d230874ad295662157eeab0135"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "internal",
"id": "614b1ab241da47a8b3a4e8f67b771446"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "admin",
"id": "9cef78a4286c42f3b977fbe4d5f927a6"
}
],
"type": "image",
"id": "d512f8860c0f45cf99b1c3cef86cfd97",
"name": "glance"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "internal",
"id": "7f776d5a83d346b48e519555362b1da6"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "public",
"id": "8303a7225a2d439fa39905c6a20202c3"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "admin",
"id": "942fa998d1c644e0b0c085d5a0995a13"
}
],
"type": "cloudformation",
"id": "ed0805af6ee54a19ad7e5add8465ac41",
"name": "heat-cfn"
}
],
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "ee4dfb6e5540447cb3741905149d9b6e",
"name": "admin",
"password_expires_at": "2016-11-06T15:32:17.000000"
},
"audit_ids": [
"3T2dc1CGQxyJsHdDu1xkcw"
],
"issued_at": "2015-11-07T01:58:43.578929Z"
}
}
Authenticates an identity and generates a token. Uses the password authentication method with explicit unscoped authorization.
The request body must include a payload that specifies the
password
authentication method, the credentials, and the
unscoped
authorization scope.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
auth | body | object | An auth object. |
user | body | object | A user object. |
scope (Optional) | body | string | The authorization scope (Since v3.4). Specify
unscoped to make an explicit unscoped token request, which
returns an unscoped response without any authorization. This
request behaves the same as a token request with no scope where
the user has no default project defined. If an explicit,
unscoped token request is not made and the user has
authorization to their default project, then the response will
return a project-scoped token. If a default project is not defined,
a token is issued without an explicit scope of authorization,
which is the same as asking for an explicit unscoped token. |
password | body | object | The password object, contains the authentication information. |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
identity | body | object | An identity object. |
methods | body | array | The authentication method. For password
authentication, specify password . |
{
"auth": {
"identity": {
"methods": [
"password"
],
"password": {
"user": {
"id": "ee4dfb6e5540447cb3741905149d9b6e",
"password": "devstacker"
}
}
},
"scope": "unscoped"
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
domain | body | object | A domain object, containing: |
methods | body | array | The authentication method. For password
authentication, specify password . |
roles | body | array | A list of role objects, each containing: |
expires_at | body | string | The date and time when the token expires. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, A |
token | body | object | A token object. |
user | body | object | A user object. |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
issued_at | body | string | The date and time when the token was issued. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"password"
],
"expires_at": "2015-11-09T01:42:57.527363Z",
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "ee4dfb6e5540447cb3741905149d9b6e",
"name": "admin",
"password_expires_at": null
},
"audit_ids": [
"lC2Wj1jbQe-dLjLyOx4qPQ"
],
"issued_at": "2015-11-09T00:42:57.527404Z"
}
}
Authenticates an identity and generates a token. Uses the token authentication method. Authorization is unscoped.
In the request body, provide the token ID.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
identity | body | object | An identity object. |
token | body | object | A token object. The token authentication
method is used. This method is typically used in combination with
a request to change authorization scope. |
id | body | string | A token ID. |
auth | body | object | An auth object. |
methods | body | array | The authentication method. For token
authentication, specify token . |
{
"auth": {
"identity": {
"methods": [
"token"
],
"token": {
"id": "'$OS_TOKEN'"
}
}
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"token"
],
"expires_at": "2015-11-05T22:00:11.000000Z",
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "10a2e6e717a245d9acad3e5f97aeca3d",
"name": "admin",
"password_expires_at": null
},
"audit_ids": [
"mAjXQhiYRyKwkB4qygdLVg"
],
"issued_at": "2015-11-05T21:00:33.819948Z"
}
}
Authenticates an identity and generates a token. Uses the token authentication method and scopes authorization to a project or domain.
In the request body, provide the token ID and the project
or
domain
authorization scope.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
methods | body | array | The authentication method. For token
authentication, specify token . |
auth | body | object | An auth object. |
token | body | object | A token object. The token authentication
method is used. This method is typically used in combination with
a request to change authorization scope. |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
scope (Optional) | body | string | The authorization scope, including the system (Since v3.10), a
project, or a domain (Since v3.4). If both a domain and a project
are specified, an HTTP 400 Bad Request will be returned, as a
token cannot be simultaneously scoped to both a project
and a domain. An ID is sufficient to uniquely identify
a project but if a project is specified by name, then
the domain of the project must also be specified in order
to uniquely identify the project by name. A domain scope may be
specified by either the domain’s ID or name with
equivalent results. |
id | body | string | A token ID. |
identity | body | object | An identity object. |
{
"auth": {
"identity": {
"methods": [
"token"
],
"token": {
"id": "'$OS_TOKEN'"
}
},
"scope": {
"project": {
"id": "5b50efd009b540559104ee3c03bbb2b7"
}
}
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"token"
],
"roles": [
{
"id": "5090055d6bd547dc83e0e8f070803708",
"name": "admin"
}
],
"expires_at": "2015-11-05T22:00:11.000000Z",
"project": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "5b50efd009b540559104ee3c03bbb2b7",
"name": "admin"
},
"is_domain": false,
"catalog": [
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "admin",
"id": "b2605da9b25943beb49b2bd86aca2202"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "public",
"id": "c4d1184caf8c4351bff4bf502a09684e"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9292",
"region": "RegionOne",
"interface": "internal",
"id": "cd73bda89e3948738c2721a8c3acac54"
}
],
"type": "image",
"id": "495df2483dc145dbb6b34bfbdd787aae",
"name": "glance"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "internal",
"id": "7d03218a7f4246e8b9e3992318bf5397"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "public",
"id": "9ad7f8ce438c4212b8aac930bca04c86"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8773/",
"region": "RegionOne",
"interface": "admin",
"id": "d84aad1a45c44e4da09b719167383049"
}
],
"type": "ec2",
"id": "54204024bb7d4665a8efc34fc758f1f7",
"name": "ec2"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "admin",
"id": "1077687c18514490a3ec980eadd1bd13"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "public",
"id": "1e86d8bef1514c3fba8d157a22ccce88"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9000",
"region": "RegionOne",
"interface": "internal",
"id": "f6a6b7bbba66443ead3a0e31a008c271"
}
],
"type": "messaging-websocket",
"id": "6b8655af7d044a15bec3cdca4f2919f8",
"name": "zaqar-websocket"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "admin",
"id": "083663fd231e40ad97384ad3efb9f1b7"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "0f4b7054ea27450eac43f685a4fc1d2c"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8004/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "5f3ea39df2e44378b1802a1a87ef9ac4"
}
],
"type": "orchestration",
"id": "6d6346ff2ca842e5968373fbb93e231f",
"name": "heat"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "bc2230a70d6a444e9fba75b85fbda41b"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "d8102dc2b9984d04b30b91b0a6037470"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2.1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "admin",
"id": "f8253a53edd749bf8b107a53a5d47a82"
}
],
"type": "compute",
"id": "75df965385cc4120a17110c1fde00182",
"name": "nova"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://example.com/identity_v2_admin/v2.0",
"region": "RegionOne",
"interface": "admin",
"id": "0ceeb58592274caea5bc942a07d5473f"
},
{
"region_id": "RegionOne",
"url": "http://example.com/identity/v2.0",
"region": "RegionOne",
"interface": "internal",
"id": "8126f2c7021d413e9c98ec3a0ba0fd58"
},
{
"region_id": "RegionOne",
"url": "http://example.com/identity/v2.0",
"region": "RegionOne",
"interface": "public",
"id": "c693879254544e3fb502e795a3f6acc8"
}
],
"type": "identity",
"id": "78aad571d38049e69c866c2abac76af6",
"name": "keystone"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "admin",
"id": "3654138dc64a45aeb5a8153f2a089c74"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "7a0d12d0b7314afd9b53d1618ab546ea"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v1/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "82b68ff3aedb43e2acc8307234d3fd0b"
}
],
"type": "volume",
"id": "80491007c0ab462daaa9087250325f59",
"name": "cinder"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "internal",
"id": "24dfa252fba64469b8b1a832f04bded9"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "public",
"id": "e0a01d6cd3be4f6abcc72367b2d87993"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8000/v1",
"region": "RegionOne",
"interface": "admin",
"id": "f33f79d42df247e1bf6daf43a548b014"
}
],
"type": "cloudformation",
"id": "ac5cc6e3c62840818ab338c981d5603f",
"name": "heat-cfn"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "admin",
"id": "3e78c357b3c8469fbea12eb681f88a0c"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "public",
"id": "89d2aad3dc8e478fbabb21dd7db0962a"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:9696/",
"region": "RegionOne",
"interface": "internal",
"id": "b6d4a8cf5e4042848a749a3116497e55"
}
],
"type": "network",
"id": "b33660edd1eb45e485f7e5f14401a739",
"name": "neutron"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "public",
"id": "1f8287cf963948778ab0eb109d9f857d"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "internal",
"id": "3adf5f9cc5184d92af5ff0fdef043e4a"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8888",
"region": "RegionOne",
"interface": "admin",
"id": "f747223060b3414f947fdcdca2ce8714"
}
],
"type": "messaging",
"id": "cf3e38e9aed54e2d84ea64485317d7a0",
"name": "zaqar"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "08f507ccb552476b98f3af7718f25557"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "admin",
"id": "d20091ba591347b2b419e5fbde9b7976"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8774/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "e6b667776e7245dea6e39f2820e080b0"
}
],
"type": "compute_legacy",
"id": "d442e96b273a48018567aeec5800c3e0",
"name": "nova_legacy"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "012c78a6694a494995c58d5955fb7822"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "admin",
"id": "802d5de210874f068ba31c7e27c29d70"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8776/v2/5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "b37ada66e02e44c9a9a7976d77365503"
}
],
"type": "volumev2",
"id": "d93e78c7967f49acbdd732b9dd97e0d0",
"name": "cinderv2"
},
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080/v1/AUTH_5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "public",
"id": "265ce88a0e1642fc90b2ec20ccb279ff"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080",
"region": "RegionOne",
"interface": "admin",
"id": "500b7f066d39492faff8a3f710fb5a2f"
},
{
"region_id": "RegionOne",
"url": "http://23.253.248.171:8080/v1/AUTH_5b50efd009b540559104ee3c03bbb2b7",
"region": "RegionOne",
"interface": "internal",
"id": "a33b0684f817405280df1f5600777a75"
}
],
"type": "object-store",
"id": "da1b1b5c529946fcb3ee3abdcf376fcb",
"name": "swift"
}
],
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "10a2e6e717a245d9acad3e5f97aeca3d",
"name": "admin",
"password_expires_at": "2016-11-06T15:32:17.000000"
},
"audit_ids": [
"wLc7nDMsQiKqf8VFU4ySpg"
],
"issued_at": "2015-11-05T21:32:30.505384Z"
}
}
Authenticates an identity and generates a token. Uses the token authentication method with explicit unscoped authorization.
In the request body, provide the token ID and the
unscoped
authorization scope.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
methods | body | array | The authentication method. For token
authentication, specify token . |
auth | body | object | An auth object. |
token | body | object | A token object. The token authentication
method is used. This method is typically used in combination with
a request to change authorization scope. |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
scope (Optional) | body | string | The authorization scope (Since v3.4). Specify
unscoped to make an explicit unscoped token request, which
returns an unscoped response without any authorization. This
request behaves the same as a token request with no scope where
the user has no default project defined. If an explicit,
unscoped token request is not made and the user has
authorization to their default project, then the response will
return a project-scoped token. If a default project is not defined,
a token is issued without an explicit scope of authorization,
which is the same as asking for an explicit unscoped token. |
id | body | string | A token ID. |
identity | body | object | An identity object. |
{
"auth": {
"identity": {
"methods": [
"token"
],
"token": {
"id": "'$OS_TOKEN'"
}
},
"scope": "unscoped"
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"token"
],
"expires_at": "2015-11-05T22:00:11.000000Z",
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "10a2e6e717a245d9acad3e5f97aeca3d",
"name": "admin",
"password_expires_at": null
},
"audit_ids": [
"mAjXQhiYRyKwkB4qygdLVg"
],
"issued_at": "2015-11-05T21:00:33.819948Z"
}
}
Validates and shows information for a token, including its expiration date and authorization scope.
Pass your own token in the X-Auth-Token
request header.
Pass the token that you want to validate in the X-Subject-Token
request header.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
nocatalog (Optional) | query | string | (Since v3.1) The authentication response excludes the service catalog. By default, the response includes the service catalog. |
allow_expired (Optional) | query | bool | (Since v3.8) Allow fetching a token that has expired. By default expired tokens return a 404 exception. |
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
domain | body | object | A domain object, containing: |
methods | body | array | The authentication method, which is password ,
token , or both methods. Indicates the accumulated set of
authentication methods that were used to obtain the token. For
example, if the token was obtained by password authentication, it
contains password . Later, if the token is exchanged by using
the token authentication method one or more times, the
subsequently created tokens contain both password and
token in their methods attribute. Unlike multi-factor
authentication, the methods attribute merely indicates the
methods that were used to authenticate the user in exchange for a
token. The client is responsible for determining the total number
of authentication factors. |
links | body | object | The links to the domain resource. |
user | body | object | A user object. |
token | body | object | A token object. |
expires_at | body | string | The date and time when the token expires. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, A |
project | body | object | A project object, containing: |
catalog | body | array | A catalog object. |
roles | body | array | A list of role objects, each containing: |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
issued_at | body | string | The date and time when the token was issued. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"token": {
"methods": [
"token"
],
"expires_at": "2015-11-05T22:00:11.000000Z",
"user": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "10a2e6e717a245d9acad3e5f97aeca3d",
"name": "admin",
"password_expires_at": null
},
"audit_ids": [
"mAjXQhiYRyKwkB4qygdLVg"
],
"issued_at": "2015-11-05T21:00:33.819948Z"
}
}
Validates a token.
This call is similar to GET /auth/tokens
but no response body
is provided even in the X-Subject-Token
header.
The Identity API returns the same response as when the subject
token was issued by POST /auth/tokens
even if an error occurs
because the token is not valid. An HTTP 204
response code
indicates that the X-Subject-Token
is valid.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
allow_expired (Optional) | query | bool | (Since v3.8) Allow fetching a token that has expired. By default expired tokens return a 404 exception. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Revokes a token.
This call is similar to the HEAD /auth/tokens
call except that
the X-Subject-Token
token is immediately not valid, regardless
of the expires_at
attribute value. An additional
X-Auth-Token
is not required.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
New in version 3.3
This call returns a service catalog for the X-Auth-Token provided in the request, even if the token does not contain a catalog itself (for example, if it was generated using ?nocatalog).
The structure of the catalog object is identical to that contained in a token.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_catalog
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
Name | In | Type | Description |
---|---|---|---|
endpoints | body | array | A list of endpoint objects. |
id | body | string | The UUID of the service to which the endpoint belongs. |
type | body | string | The service type, which describes the API
implemented by the service. Value is compute , ec2 ,
identity , image , network , or volume . |
name | body | string | The service name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"catalog": [
{
"endpoints": [
{
"id": "39dc322ce86c4111b4f06c2eeae0841b",
"interface": "public",
"region": "RegionOne",
"url": "http://localhost:5000"
},
{
"id": "ec642f27474842e78bf059f6c48f4e99",
"interface": "internal",
"region": "RegionOne",
"url": "http://localhost:5000"
},
{
"id": "c609fc430175452290b62a4242e8a7e8",
"interface": "admin",
"region": "RegionOne",
"url": "http://localhost:35357"
}
],
"id": "4363ae44bdf34a3981fde3b823cb9aa2",
"type": "identity",
"name": "keystone"
}
],
"links": {
"self": "https://example.com/identity/v3/catalog",
"previous": null,
"next": null
}
}
New in version 3.3
This call returns the list of projects that are available to be scoped to based on the X-Auth-Token provided in the request.
The structure of the response is exactly the same as listing projects for a user.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_projects
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
Name | In | Type | Description |
---|---|---|---|
domain_id | body | string | The ID of the domain for the project. |
enabled | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
id | body | string | The ID for the project. |
links | body | object | The links for the project resource. |
name | body | string | The name of the project. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"projects": [
{
"domain_id": "1789d1",
"enabled": true,
"id": "263fd9",
"links": {
"self": "https://example.com/identity/v3/projects/263fd9"
},
"name": "Test Group"
},
{
"domain_id": "1789d1",
"enabled": true,
"id": "50ef01",
"links": {
"self": "https://example.com/identity/v3/projects/50ef01"
},
"name": "Build Group"
}
],
"links": {
"self": "https://example.com/identity/v3/auth/projects",
"previous": null,
"next": null
}
}
New in version 3.3
This call returns the list of domains that are available to be scoped to based on the X-Auth-Token provided in the request.
The structure is the same as listing domains.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_domains
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
Name | In | Type | Description |
---|---|---|---|
description | body | string | The description of the domain. |
enabled | body | string | If set to true , domain is enabled. If set to
false , domain is disabled. |
id | body | string | The ID of the domain. |
links | body | object | The links to the domain resource. |
name | body | string | The name of the domain. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"domains": [
{
"description": "my domain description",
"enabled": true,
"id": "1789d1",
"links": {
"self": "https://example.com/identity/v3/domains/1789d1"
},
"name": "my domain"
},
{
"description": "description of my other domain",
"enabled": true,
"id": "43e8da",
"links": {
"self": "https://example.com/identity/v3/domains/43e8da"
},
"name": "another domain"
}
],
"links": {
"self": "https://example.com/identity/v3/auth/domains",
"previous": null,
"next": null
}
}
New in version 3.10
This call returns the list of systems that are available to be scoped to based on the X-Auth-Token provided in the request.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_system
Name | In | Type | Description |
---|---|---|---|
X-Auth-Token | header | string | A valid authentication token for an administrative user. |
Name | In | Type | Description |
---|---|---|---|
links | body | object | The links to the domain resource. |
system | body | array | A list of systems to access based on role assignments. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
400 - Bad Request |
Some content in the request was invalid. |
{
"system": [
{
"all": true
}
],
"links": {
"self": "https://example.com/identity/v3/auth/system"
}
}
Application credentials provide a way to delegate a user’s authorization to an application without sharing the user’s password authentication. This is a useful security measure, especially for situations where the user’s identification is provided by an external source, such as LDAP or a single-sign-on service. Instead of storing user passwords in config files, a user creates an application credential for a specific project, with all or a subset of the role assignments they have on that project, and then stores the application credential identifier and secret in the config file.
Multiple application credentials may be active at once, so you can easily rotate application credentials by creating a second one, converting your applications to use it one by one, and finally deleting the first one.
Application credentials are limited by the lifespan of the user that created them. If the user is deleted, disabled, or loses a role assignment on a project, the application credential is deleted.
To authenticate with an application credential, specify “application_credential” as the auth method. You are not allowed to request a scope, as the scope is retrieved from the application credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/auth_tokens
Name | In | Type | Description |
---|---|---|---|
identity | body | object | An identity object. |
methods | body | array | The authentication method. To authenticate with an application credential,
specify application_credential . |
application_credential | body | object | An application credential object. |
id (Optional) | body | string | The ID of the application credential used for authentication. If not provided, the application credential must be identified by its name and its owning user. |
name (Optional) | body | string | The name of the application credential used for authentication. If provided, must be accompanied by a user object. |
secret | body | string | The secret for authenticating the application credential. |
user (Optional) | body | object | A user object, required if an application credential is identified by
name and not ID. |
An application credential can be identified by an ID:
{
"auth": {
"identity": {
"methods": [
"application_credential"
],
"application_credential": {
"id": "423f19a4ac1e4f48bbb4180756e6eb6c",
"secret": "rEaqvJka48mpv"
}
}
}
}
It can also be identified by its name and a user object:
{
"auth": {
"identity": {
"methods": [
"application_credential"
],
"application_credential": {
"name": "monitoring",
"secret": "rEaqvJka48mpv",
"user": {
"id": "423f19a4ac1e4f48bbb4180756e6eb6c"
}
}
}
}
}
Name | In | Type | Description |
---|---|---|---|
X-Subject-Token | header | string | The authentication token. An authentication response returns the token ID in this header rather than in the response body. |
domain | body | object | A domain object, containing: |
methods | body | array | The authentication method, which is password ,
token , or both methods. Indicates the accumulated set of
authentication methods that were used to obtain the token. For
example, if the token was obtained by password authentication, it
contains password . Later, if the token is exchanged by using
the token authentication method one or more times, the
subsequently created tokens contain both password and
token in their methods attribute. Unlike multi-factor
authentication, the methods attribute merely indicates the
methods that were used to authenticate the user in exchange for a
token. The client is responsible for determining the total number
of authentication factors. |
user | body | object | A user object. |
token | body | object | A token object. |
expires_at | body | string | The date and time when the token expires. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, A |
project | body | object | A project object, containing: |
catalog | body | array | A catalog object. |
roles | body | array | A list of role objects, each containing: |
audit_ids | body | array | A list of one or two audit IDs. An audit ID is a unique, randomly generated, URL-safe string that you can use to track a token. The first audit ID is the current audit ID for the token. The second audit ID is present for only re-scoped tokens and is the audit ID from the token before it was re-scoped. A re- scoped token is one that was exchanged for another token of the same or different scope. You can use these audit IDs to track the use of a token or chain of tokens across multiple requests and endpoints without exposing the token ID to non-privileged users. |
issued_at | body | string | The date and time when the token was issued. The date and time stamp format is ISO 8601: CCYY-MM-DDThh:mm:ss.sssZ
For example, |
id (Optional) | body | string | The ID of the user. Required if you do not specify the user name. |
name (Optional) | body | string | The user name. Required if you do not specify the ID of the user. If you specify the user name, you must also specify the domain, by ID or name. |
application_credential_restricted | body | object | Whether the application credential is permitted to be used for creating and deleting additional application credentials and trusts. |
{
"token": {
"is_domain": false,
"methods": [
"application_credential"
],
"roles": [
{
"id": "df8b7e3bf6fb49e9ba19122da2bae916",
"name": "Member"
}
],
"expires_at": "2018-01-15T22:14:05.000000Z",
"project": {
"domain": {
"id": "default",
"name": "Default"
},
"id": "231c62fb0fbd485b995e8b060c3f0d98",
"name": "demo"
},
"catalog": [
{
"endpoints": [
{
"region_id": "RegionOne",
"url": "http://example.com/identity",
"region": "RegionOne",
"interface": "admin",
"id": "81737f23cd8f45169fcd700cb658c8ad"
},
{
"region_id": "RegionOne",
"url": "http://example.com/identity",
"region": "RegionOne",
"interface": "public",
"id": "a7b9155184ed4607853304408e7e8d32"
}
],
"type": "identity",
"id": "408af8b8554248fc8d686bef54ae3bf6",
"name": "keystone"
}
],
"application_credential_restricted": true,
"user": {
"password_expires_at": null,
"domain": {
"id": "default",
"name": "Default"
},
"id": "fd786d56402c4d1691372e7dee0d00b5",
"name": "demo"
},
"audit_ids": [
"9JsolhssRzKfyayTIiCRUg"
],
"issued_at": "2018-01-15T21:14:05.000000Z"
}
}
A token created with an application credential will have the scope and roles designated by the application credential.
Creates an application credential for a user on the project to which they are currently scoped.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/application_credentials
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The ID of the user who owns the application credential. |
application_credential | body | object | An application credential object. |
name | body | string | The name of the application credential. Must be unique to a user. |
secret (Optional) | body | string | The secret that the application credential will be created with. If not provided, one will be generated. |
description (Optional) | body | string | A description of the application credential’s purpose. |
expires_at (Optional) | body | string | An optional expiry time for the application credential. If unset, the application credential does not expire. |
roles (Optional) | body | array | An optional list of role objects, identified by ID or name. If not provided, the roles assigned to the application credential will be the same as the roles in the current token. |
unrestricted (Optional) | body | boolean | An optional flag to restrict whether the application credential may be used for the creation or destruction of other application credentials or trusts. Defaults to false. |
{
"application_credential": {
"name": "monitoring",
"secret": "rEaqvJka48mpv",
"description": "Application credential for monitoring.",
"expires_at": "2018-02-27T18:30:59Z",
"roles": [
{"name": "Reader"}
],
"unrestricted": false
}
}
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Name | In | Type | Description |
---|---|---|---|
application_credential | body | object | The application credential object. |
id | body | string | The ID of the application credential. |
name | body | string | The name of the application credential. |
secret | body | string | The secret for the application credential, either generated by the server or provided by the user. This is only ever shown once in the response to a create request. It is not stored nor ever shown again. If the secret is lost, a new application credential must be created. |
description | body | string | A description of the application credential’s purpose. |
expires_at | body | string | The expiration time of the application credential, if one was specified. |
project_id | body | string | The ID of the project the application credential was created for and that authentication requests using this application credential will be scoped to. |
roles | body | array | A list of one or more roles that this application credential has associated with its project. A token using this application credential will have these same roles. |
unrestricted | body | boolean | A flag indicating whether the application credential may be used for creation or destruction of other application credentials or trusts. |
links | body | object | The link to the resources in question. |
{
"application_credential": {
"description": "Application credential for monitoring.",
"roles": [
{
"id": "6aff702516544aeca22817fd3bc39683",
"domain_id": null,
"name": "Reader"
}
],
"links": {
"self": "http://example.com/identity/v3/users/fd786d56402c4d1691372e7dee0d00b5/application_credentials/58d61ff8e6e34accb35874016d1dba8b"
},
"expires_at": "2018-02-27T18:30:59.000000",
"unrestricted": false,
"secret": "rEaqvJka48mpv",
"project_id": "231c62fb0fbd485b995e8b060c3f0d98",
"id": "58d61ff8e6e34accb35874016d1dba8b",
"name": "monitoring"
}
}
List all application credentials for a user.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/application_credentials
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The ID of the user who owns the application credential. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Name | In | Type | Description |
---|---|---|---|
application_credential | body | object | The application credential object. |
id | body | string | The ID of the application credential. |
name | body | string | The name of the application credential. |
description | body | string | A description of the application credential’s purpose. |
expires_at | body | string | The expiration time of the application credential, if one was specified. |
project_id | body | string | The ID of the project the application credential was created for and that authentication requests using this application credential will be scoped to. |
roles | body | array | A list of one or more roles that this application credential has associated with its project. A token using this application credential will have these same roles. |
unrestricted | body | boolean | A flag indicating whether the application credential may be used for creation or destruction of other application credentials or trusts. |
links | body | object | The link to the collection of resources. |
{
"links": {
"self": "http://example.com/identity/v3/users/fd786d56402c4d1691372e7dee0d00b5/application_credentials",
"previous": null,
"next": null
},
"application_credentials": [
{
"description": "Application credential for backups.",
"roles": [
{
"domain_id": null,
"name": "Writer",
"id": "6aff702516544aeca22817fd3bc39683"
}
],
"links": {
"self": "http://example.com/identity/v3/users/fd786d56402c4d1691372e7dee0d00b5/application_credentials/308a7e905eee4071aac5971744c061f6"
},
"expires_at": "2018-02-27T18:30:59.000000",
"unrestricted": false,
"project_id": "231c62fb0fbd485b995e8b060c3f0d98",
"id": "308a7e905eee4071aac5971744c061f6",
"name": "backups"
},
{
"description": "Application credential for monitoring.",
"roles": [
{
"id": "6aff702516544aeca22817fd3bc39683",
"domain_id": null,
"name": "Reader"
}
],
"links": {
"self": "http://example.com/identity/v3/users/fd786d56402c4d1691372e7dee0d00b5/application_credentials/58d61ff8e6e34accb35874016d1dba8b"
},
"expires_at": "2018-02-27T18:30:59.000000",
"unrestricted": false,
"project_id": "231c62fb0fbd485b995e8b060c3f0d98",
"id": "58d61ff8e6e34accb35874016d1dba8b",
"name": "monitoring"
}
]
}
Show details of an application credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/application_credentials
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The ID of the user who owns the application credential. |
application_credential_id | path | string | The ID of the application credential. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Name | In | Type | Description |
---|---|---|---|
application_credential | body | object | The application credential object. |
id | body | string | The ID of the application credential. |
name | body | string | The name of the application credential. |
description | body | string | A description of the application credential’s purpose. |
expires_at | body | string | The expiration time of the application credential, if one was specified. |
project_id | body | string | The ID of the project the application credential was created for and that authentication requests using this application credential will be scoped to. |
roles | body | array | A list of one or more roles that this application credential has associated with its project. A token using this application credential will have these same roles. |
unrestricted | body | boolean | A flag indicating whether the application credential may be used for creation or destruction of other application credentials or trusts. |
links | body | object | The link to the resources in question. |
{
"application_credential": {
"description": "Application credential for monitoring.",
"roles": [
{
"id": "6aff702516544aeca22817fd3bc39683",
"domain_id": null,
"name": "Reader"
}
],
"links": {
"self": "http://example.com/identity/v3/users/fd786d56402c4d1691372e7dee0d00b5/application_credentials/58d61ff8e6e34accb35874016d1dba8b"
},
"expires_at": "2018-02-27T18:30:59.000000",
"unrestricted": false,
"project_id": "231c62fb0fbd485b995e8b060c3f0d98",
"id": "58d61ff8e6e34accb35874016d1dba8b",
"name": "monitoring"
}
}
Delete an application credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/application_credentials
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The ID of the user who owns the application credential. |
application_credential_id | path | string | The ID of the application credential. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
In exchange for a set of authentication credentials that the user submits, the Identity service generates and returns a token. A token represents the authenticated identity of a user and, optionally, grants authorization on a specific project or domain.
You can list all credentials, and create, show details for, update, and delete a credential.
Creates a credential.
The following example shows how to create an EC2-style credential.
The credential blob is a string that contains a JSON-serialized
dictionary with the access
and secret
keys. This format is
required when you specify the ec2
type. To specify other
credentials, such as access_key
, change the type and contents
of the data blob.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/credentials
Name | In | Type | Description |
---|---|---|---|
credential | body | object | A credential object. |
project_id | body | string | The ID for the project. |
type | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
blob | body | string | The credential itself, as a serialized blob. |
user_id | body | string | The ID of the user who owns the credential. |
{
"credential": {
"blob": "{\"access\":\"181920\",\"secret\":\"secretKey\"}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"user_id": "bb5476fd12884539b41d5a88f838d773"
}
}
Name | In | Type | Description |
---|---|---|---|
credential | body | object | A credential object. |
user_id | body | string | The ID of the user who owns the credential. |
links | body | object | The links for the credential resource. |
blob | body | string | The credential itself, as a serialized blob. |
project_id | body | string | The ID for the project. |
type | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
id | body | string | The UUID for the credential. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"credential": {
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/3d3367228f9c7665266604462ec60029bcd83ad89614021a80b2eb879c572510"
},
"blob": "{\"access\":\"181920\",\"secret\":\"secretKey\"}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"id": "3d3367228f9c7665266604462ec60029bcd83ad89614021a80b2eb879c572510"
}
}
Lists all credentials.
Optionally, you can include the user_id
or type
query parameter in the
URI to filter the response by a user or credential type.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/credentials
Name | In | Type | Description |
---|---|---|---|
user_id (Optional) | query | string | Filters the response by a user ID. |
type (Optional) | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
Name | In | Type | Description |
---|---|---|---|
user_id | body | string | The ID of the user who owns the credential. |
links | body | object | The links for the credentials resource. |
blob | body | string | The credential itself, as a serialized blob. |
credentials | body | array | A list of credential objects. |
project_id | body | string | The ID for the project. |
type | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
id | body | string | The UUID for the credential. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"credentials": [
{
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
},
"blob": "{\"access\": \"a42a27755ce6442596b049bd7dd8a563\", \"secret\": \"71faf1d40bb24c82b479b1c6fbbd9f0c\", \"trust_id\": null}",
"project_id": "6e01855f345f4c59812999b5e459137d",
"type": "ec2",
"id": "207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
},
{
"user_id": "6f556708d04b4ea6bc72d7df2296b71a",
"links": {
"self": "http://example.com/identity/v3/credentials/2441494e52ab6d594a34d74586075cb299489bdd1e9389e3ab06467a4f460609"
},
"blob": "{\"access\": \"7da79ff0aa364e1396f067e352b9b79a\", \"secret\": \"7a18d68ba8834b799d396f3ff6f1e98c\", \"trust_id\": null}",
"project_id": "1a1d14690f3c4ec5bf5f321c5fde3c16",
"type": "ec2",
"id": "2441494e52ab6d594a34d74586075cb299489bdd1e9389e3ab06467a4f460609"
},
{
"user_id": "c14107e65d5c4a7f8894fc4b3fc209ff",
"links": {
"self": "http://example.com/identity/v3/credentials/3397b204b5f04c495bcdc8f34c8a39996f280f9172658241873e15f070ec79d7"
},
"blob": "{\"access\": \"db9c58a558534a10a070110de4f9f20c\", \"secret\": \"973e790b88db447ba6f93bca02bc745b\", \"trust_id\": null}",
"project_id": "7396e43183db40dcbf40dd727637b548",
"type": "ec2",
"id": "3397b204b5f04c495bcdc8f34c8a39996f280f9172658241873e15f070ec79d7"
},
{
"user_id": "915cc5f8cca6466aba6c6be06cbabfdf",
"links": {
"self": "http://example.com/identity/v3/credentials/352d5dd7a4aa19c4f2f23ee288bf65dc23a0bc293f40ffd2128ffe6a8cf3e871"
},
"blob": "{\"access\": \"817c6c3487a440c1a0b1d3f92b30ca37\", \"secret\": \"47d681117d1c46e69a0c9ec811dae2e9\", \"trust_id\": null}",
"project_id": "2bf9767f9db949ee8364262a28a23062",
"type": "ec2",
"id": "352d5dd7a4aa19c4f2f23ee288bf65dc23a0bc293f40ffd2128ffe6a8cf3e871"
},
{
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/3d3367228f9c7665266604462ec60029bcd83ad89614021a80b2eb879c572510"
},
"blob": "{\"access\":\"181920\",\"secret\":\"secretKey\"}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"id": "3d3367228f9c7665266604462ec60029bcd83ad89614021a80b2eb879c572510"
},
{
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/6b7d803fc03b85866904b6b79e0a8fa1f4013b584163b4477eed96717eb402c0"
},
"blob": "{\"access\": \"f2ba45670b504a518b46e920d760fde2\", \"secret\": \"bf7fff2b3a844730b2db793411756e55\", \"trust_id\": null}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"id": "6b7d803fc03b85866904b6b79e0a8fa1f4013b584163b4477eed96717eb402c0"
},
{
"user_id": "2b657f6742ac416697e6821b3b2ee785",
"links": {
"self": "http://example.com/identity/v3/credentials/7d391b869631e5c4836708ea3bb3e0a5cbe0481201b5f0ddd5685ad3b3faa564"
},
"blob": "{\"access\": \"a1525da4e7c0438ebf3058372d637b59\", \"secret\": \"c9165d2542b141e8b2a1ff61a5f5487c\", \"trust_id\": null}",
"project_id": "2bf9767f9db949ee8364262a28a23062",
"type": "ec2",
"id": "7d391b869631e5c4836708ea3bb3e0a5cbe0481201b5f0ddd5685ad3b3faa564"
},
{
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/7ef4faa904ae7b8b4ddc7bad15b05ee359dad7d7a9b82861d4ad92fdbbb2eb4e"
},
"blob": "{\"access\": \"7d7559359b57419eb5f5f5dcd65ab57d\", \"secret\": \"570652bcf8c2483c86eb29e9734eed3c\", \"trust_id\": null}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"id": "7ef4faa904ae7b8b4ddc7bad15b05ee359dad7d7a9b82861d4ad92fdbbb2eb4e"
},
{
"user_id": "aedb193e9bb8400485f8d8426f7a031f",
"links": {
"self": "http://example.com/identity/v3/credentials/9c1c428d8e0e8338a5e16489ecfff9962f2b00f984ce4c7e9015e4003f478df8"
},
"blob": "{\"access\": \"b3a6e5f4427c47e9b202264d91a19e49\", \"secret\": \"d9eb470f503f4b46932de38db7a79402\", \"trust_id\": null}",
"project_id": "a2672ecf9dd34c6980448b25a47e0947",
"type": "ec2",
"id": "9c1c428d8e0e8338a5e16489ecfff9962f2b00f984ce4c7e9015e4003f478df8"
},
{
"user_id": "c14107e65d5c4a7f8894fc4b3fc209ff",
"links": {
"self": "http://example.com/identity/v3/credentials/e2c35ac2becb0fca3c3c2f035692a4f46a9cbf3b6e86c8a47f5aafe837d78a05"
},
"blob": "{\"access\": \"1ed843b1bd4a409f9562400085adbaa4\", \"secret\": \"236ab24db1f04ec995fcf618ed4fc0f5\", \"trust_id\": null}",
"project_id": "6e01855f345f4c59812999b5e459137d",
"type": "ec2",
"id": "e2c35ac2becb0fca3c3c2f035692a4f46a9cbf3b6e86c8a47f5aafe837d78a05"
}
],
"links": {
"self": "http://example.com/identity/v3/credentials",
"previous": null,
"next": null
}
}
Shows details for a credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/credential
Name | In | Type | Description |
---|---|---|---|
credential_id | path | string | The UUID for the credential. |
Name | In | Type | Description |
---|---|---|---|
credential | body | object | A credential object. |
user_id | body | string | The ID of the user who owns the credential. |
links | body | object | The links for the credential resource. |
blob | body | string | The credential itself, as a serialized blob. |
project_id | body | string | The ID for the project. |
type | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
id | body | string | The UUID for the credential. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"credential": {
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
},
"blob": "{\"access\": \"a42a27755ce6442596b049bd7dd8a563\", \"secret\": \"71faf1d40bb24c82b479b1c6fbbd9f0c\", \"trust_id\": null}",
"project_id": "6e01855f345f4c59812999b5e459137d",
"type": "ec2",
"id": "207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
}
}
Updates a credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/credential
Name | In | Type | Description |
---|---|---|---|
credential_id | path | string | The UUID for the credential. |
credential | body | object | A credential object. |
project_id | body | string | The ID for the project. |
type (Optional) | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
blob (Optional) | body | string | The credential itself, as a serialized blob. |
user_id (Optional) | body | string | The ID of the user who owns the credential. |
{
"credential": {
"blob": "{\"access\":\"181920\",\"secret\":\"secretKey\"}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"user_id": "bb5476fd12884539b41d5a88f838d773"
}
}
Name | In | Type | Description |
---|---|---|---|
credential | body | object | A credential object. |
user_id | body | string | The ID of the user who owns the credential. |
links | body | object | The links for the credential resource. |
blob | body | string | The credential itself, as a serialized blob. |
project_id | body | string | The ID for the project. |
type | body | string | The credential type, such as ec2 or cert .
The implementation determines the list of supported types. |
id | body | string | The UUID for the credential. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"credential": {
"user_id": "bb5476fd12884539b41d5a88f838d773",
"links": {
"self": "http://example.com/identity/v3/credentials/207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
},
"blob": "{\"access\":\"181920\",\"secret\":\"secretKey\"}",
"project_id": "731fc6f265cd486d900f16e84c5cb594",
"type": "ec2",
"id": "207e9b76935efc03804d3dd6ab52d22e9b22a0711e4ada4ff8b76165a07311d7"
}
}
Deletes a credential.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/credential
Name | In | Type | Description |
---|---|---|---|
credential_id | path | string | The UUID for the credential. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
A domain is a collection of users, groups, and projects. Each group and project is owned by exactly one domain.
Each domain defines a namespace where certain API-visible name attributes exist, which affects whether those names must be globally unique or unique within that domain. In the Identity API, the uniqueness of these attributes is as follows:
Lists all domains.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domains
Name | In | Type | Description |
---|---|---|---|
name (Optional) | query | string | Filters the response by a domain name. |
enabled (Optional) | query | string | If set to true, then only domains that are enabled will be returned, if set
to false only that are disabled will be returned. Any value other than
0 , including no value, will be interpreted as true. |
Name | In | Type | Description |
---|---|---|---|
domains | body | array | A list of domain objects, each containing: |
description | body | string | The description of the domain. |
enabled | body | string | If set to true , domain is enabled. If set to
false , domain is disabled. |
id | body | string | The ID of the domain. |
links | body | object | The links to the domain resource. |
name | body | string | The name of the domain. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"domains": [
{
"description": "Used for swift functional testing",
"enabled": true,
"id": "5a75994a383c449184053ff7270c4e91",
"links": {
"self": "http://example.com/identity/v3/domains/5a75994a383c449184053ff7270c4e91"
},
"name": "swift_test"
},
{
"description": "Owns users and tenants (i.e. projects) available on Identity API v2.",
"enabled": true,
"id": "default",
"links": {
"self": "http://example.com/identity/v3/domains/default"
},
"name": "Default"
}
],
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/domains"
}
}
Creates a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domains
Name | In | Type | Description |
---|---|---|---|
domain | body | object | A domain object, containing: |
enabled (Optional) | body | string | If set to Users can only authorize against an enabled domain (and any of its projects). In addition, users can only authenticate if the domain that owns them is also enabled. Disabling a domain prevents both of these things. |
description (Optional) | body | string | The description of the domain. |
name | body | string | The name of the domain. |
{
"domain": {
"description": "Domain description",
"enabled": true,
"name": "myDomain"
}
}
Name | In | Type | Description |
---|---|---|---|
domain | body | object | A domain object, containing: |
description | body | string | The description of the domain. |
enabled | body | string | If set to true , domain is enabled. If set to
false , domain is disabled. |
id | body | string | The ID of the domain. |
links | body | object | The links to the domain resource. |
name | body | string | The name of the domain. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Shows details for a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domains
Name | In | Type | Description |
---|---|---|---|
domain | body | object | A domain object, containing: |
description | body | string | The description of the domain. |
enabled | body | string | If set to true , domain is enabled. If set to
false , domain is disabled. |
id | body | string | The ID of the domain. |
links | body | object | The links to the domain resource. |
name | body | string | The name of the domain. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"domain": {
"description": "Owns users and tenants (i.e. projects) available on Identity API v2.",
"enabled": true,
"id": "default",
"links": {
"self": "http://example.com/identity/v3/domains/default"
},
"name": "Default"
}
}
Updates a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
domain | body | object | A domain object, containing: |
enabled (Optional) | body | string | If set to Users can only authorize against an enabled domain (and any of its projects). In addition, users can only authenticate if the domain that owns them is also enabled. Disabling a domain prevents both of these things. When you disable a domain, all tokens that are authorized for that domain become no longer valid. If you reenable the domain, these tokens are not re-enabled. |
description (Optional) | body | string | The new description of the domain. |
name (Optional) | body | string | The new name of the domain. |
{
"domain": {
"description": "Owns users and projects on Identity API v2."
}
}
Name | In | Type | Description |
---|---|---|---|
domain | body | object | A domain object, containing: |
description | body | string | The description of the domain. |
enabled | body | string | If set to true , domain is enabled. If set to
false , domain is disabled. |
id | body | string | The ID of the domain. |
links | body | object | The links to the domain resource. |
name | body | string | The name of the domain. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"domain": {
"links": {
"self": "http://example.com/identity/v3/domains/default"
},
"enabled": true,
"description": "Owns users and projects on Identity API v2.",
"name": "Default",
"id": "default"
}
}
Deletes a domain. To minimize the risk of accidentally deleting a domain, you must first disable the domain by using the update domain method.
When you delete a domain, this call also deletes all entities owned by it, such as users, groups, and projects, and any credentials and granted roles that relate to those entities.
If you try to delete an enabled domain, this call returns the
Forbidden (403)
response code.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
You can manage domain-specific configuration options.
Domain-specific configuration options are structured within their
group objects. The API supports only the identity
and ldap
groups. These groups override the default configuration settings
for the storage of users and groups by the Identity server.
You can create, update, and delete domain-specific configuration options by using the HTTP PUT , PATCH , and DELETE methods. When updating, it is only necessary to include those options that are being updated.
To create an option, use the PUT method. The Identity API does not
return options that are considered sensitive, although you can
create and update these options. The only option currently
considered sensitive is the password
option within the ldap
group.
The API enables you to include sensitive options as part of non-
sensitive options. For example, you can include the password as
part of the url
option.
If you try to create or update configuration options for groups
other than the identity
or ldap
groups, the Forbidden
(403)
response code is returned.
For information about how to integrate the Identity service with LDAP, see Integrate Identity with LDAP.
The default configuration settings for the options that can be overridden can be retrieved.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
config | body | object | A config object. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
url | body | string | The LDAP URL. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
driver | body | string | The Identity backend driver. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "ldap://localhost",
"user": "",
"suffix": "cn=example,cn=com",
....
}
}
}
Reads the default configuration settings for a specific group.
The API supports only the identity
and ldap
groups.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
url | body | string | The LDAP URL. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
driver | body | string | The Identity backend driver. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"ldap": {
"url": "ldap://localhost",
"user": "",
"suffix": "cn=example,cn=com".
....
}
}
Reads the default configuration setting for an option within a group.
The API supports only the identity
and ldap
groups. For the
ldap
group, a valid value is url
or user_tree_dn
. For
the identity
group, a valid value is driver
.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
group | path | string | The group ID. |
option | path | string | The option name. For the ldap group, a valid
value is url or user_tree_dn . For the identity group,
a valid value is driver . |
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"driver": "ldap"
}
Shows details for a domain group option configuration.
The API supports only the identity
and ldap
groups. For the
ldap
group, a valid value is url
or user_tree_dn
. For
the identity
group, a valid value is driver
.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
option | path | string | The option name. For the ldap group, a valid
value is url or user_tree_dn . For the identity group,
a valid value is driver . |
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"url": "http://myldap/root"
}
Updates a domain group option configuration.
The API supports only the identity
and ldap
groups. For the
ldap
group, a valid value is url
or user_tree_dn
. For
the identity
group, a valid value is driver
.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
option | path | string | The option name. For the ldap group, a valid
value is url or user_tree_dn . For the identity group,
a valid value is driver . |
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
{
"url": "http://myldap/my_other_root"
}
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "http://myldap/my_other_root",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Deletes a domain group option configuration.
The API supports only the identity
and ldap
groups. For the
ldap
group, a valid value is url
or user_tree_dn
. For
the identity
group, a valid value is driver
.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
option | path | string | The option name. For the ldap group, a valid
value is url or user_tree_dn . For the identity group,
a valid value is driver . |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Shows details for a domain group configuration.
The API supports only the identity
and ldap
groups.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"ldap": {
"url": "http://myldap/root",
"user_tree_dn": "ou=Users,dc=root,dc=org"
}
}
Updates a domain group configuration.
The API supports only the identity
and ldap
groups. If you
try to set configuration options for other groups, this call fails
with the Forbidden (403)
response code.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
{
"config": {
"ldap": {
"url": "http://myldap/my_new_root",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "http://myldap/my_new_root",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Deletes a domain group configuration.
The API supports only the identity
and ldap
groups.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config_default
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group | path | string | The group ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Creates a domain configuration.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "ldap://myldap.com:389/",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "ldap://myldap.com:389/",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Shows details for a domain configuration.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "http://myldap/root",
"user_tree_dn": "ou=Users,dc=root,dc=org"
}
}
}
Updates a domain configuration.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
{
"config": {
"ldap": {
"url": "http://myldap/my_new_root",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Name | In | Type | Description |
---|---|---|---|
url | body | string | The LDAP URL. |
driver | body | string | The Identity backend driver. |
ldap | body | object | An ldap object. Required to set the LDAP
group configuration options. |
config | body | object | A config object. |
user_tree_dn | body | string | The base distinguished name (DN) of LDAP, from
where all users can be reached. For example,
ou=Users,dc=root,dc=org . |
identity | body | object | An identity object. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"config": {
"identity": {
"driver": "ldap"
},
"ldap": {
"url": "http://myldap/my_new_root",
"user_tree_dn": "ou=Users,dc=my_new_root,dc=org"
}
}
}
Deletes a domain configuration.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_config
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
A group is a collection of users. Each group is owned by a domain.
You can use groups to ease the task of managing role assignments for users. Assigning a role to a group on a project or domain is equivalent to assigning the role to each group member on that project or domain.
When you unassign a role from a group, that role is automatically unassigned from any user that is a member of the group. Any tokens that authenticates those users to the relevant project or domain are revoked.
As with users, a group without any role assignments is useless from the perspective of an OpenStack service and has no access to resources. However, a group without role assignments is permitted as a way of acquiring or loading users and groups from external sources before mapping them to projects and domains.
Lists groups.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/groups
Name | In | Type | Description |
---|---|---|---|
name (Optional) | query | string | Filters the response by a group name. |
domain_id (Optional) | query | string | Filters the response by a domain ID. |
Name | In | Type | Description |
---|---|---|---|
links | body | object | The link to the collection of resources. |
groups | body | array | A list of group objects, each containing: |
description | body | string | The description of the group. |
domain_id | body | string | The ID of the domain of the group. |
id | body | string | The ID of the group. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the group. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"links": {
"self": "http://example.com/identity/v3/groups",
"previous": null,
"next": null
},
"groups": [
{
"description": "non-admin group",
"domain_id": "default",
"id": "96372bbb152f475aa37e9a76a25a029c",
"links": {
"self": "http://example.com/identity/v3/groups/96372bbb152f475aa37e9a76a25a029c"
},
"name": "nonadmins"
},
{
"description": "openstack admin group",
"domain_id": "default",
"id": "9ce0ad4e58a84d7a97b92f7955d10c92",
"links": {
"self": "http://example.com/identity/v3/groups/9ce0ad4e58a84d7a97b92f7955d10c92"
},
"name": "admins"
}
]
}
Creates a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/groups
Name | In | Type | Description |
---|---|---|---|
group | body | object | A group object, containing: |
description (Optional) | body | string | The description of the group. |
domain_id (Optional) | body | string | The ID of the domain of the group. If the domain ID is not provided in the request, the Identity service will attempt to pull the domain ID from the token used in the request. Note that this requires the use of a domain-scoped token. |
name | body | string | The name of the group. |
{
"group": {
"description": "Contract developers",
"domain_id": "default",
"name": "Contract developers"
}
}
Name | In | Type | Description |
---|---|---|---|
group | body | object | A group object, containing: |
description | body | string | The description of the group. |
domain_id | body | string | The ID of the domain of the group. |
id | body | string | The ID of the group. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the group. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
{
"group": {
"description": "Contract developers",
"domain_id": "default",
"id": "c0d675eac29945ad9dfd08aa1bb75751",
"links": {
"self": "http://example.com/identity/v3/groups/c0d675eac29945ad9dfd08aa1bb75751"
},
"name": "Contract developers"
}
}
Shows details for a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group
Name | In | Type | Description |
---|---|---|---|
group | body | object | A group object, containing: |
description | body | string | The description of the group. |
domain_id | body | string | The ID of the domain of the group. |
id | body | string | The ID of the group. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the group. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"group": {
"description": "Contract developers",
"domain_id": "default",
"id": "c0d675eac29945ad9dfd08aa1bb75751",
"links": {
"self": "http://example.com/identity/v3/groups/c0d675eac29945ad9dfd08aa1bb75751"
},
"name": "Contract developers"
}
}
Updates a group.
If the back-end driver does not support this functionality, the
call returns the Not Implemented (501)
response code.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
group | body | object | A group object, containing: |
description (Optional) | body | string | The new description of the group. |
domain_id (Optional) | body | string | The ID of the new domain for the group. The ability to change the domain of a group is now deprecated, and will be removed in subsequent release. It is already disabled by default in most Identity service implementations. |
name (Optional) | body | string | The new name of the group. |
{
"group": {
"description": "Contract developers 2016",
"name": "Contract developers 2016"
}
}
Name | In | Type | Description |
---|---|---|---|
group | body | object | A group object, containing: |
description | body | string | The description of the group. |
domain_id | body | string | The ID of the domain of the group. |
id | body | string | The ID of the group. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the group. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
501 - Not Implemented |
The server either does not recognize the request method, or it lacks the ability to fulfill the request. |
{
"group": {
"description": "Contract developers 2016",
"domain_id": "default",
"id": "c0d675eac29945ad9dfd08aa1bb75751",
"links": {
"self": "http://example.com/identity/v3/groups/c0d675eac29945ad9dfd08aa1bb75751"
},
"name": "Contract developers 2016"
}
}
Deletes a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists the users that belong to a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group_users
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
password_expires_at (Optional) | query | string | Filter results based on which user passwords have expired. The query should
include an password_expires_at={operator}:{timestamp}
For example: /v3/users?password_expires_at=lt:2016-12-08T22:02:00Z
The example would return a list of users whose password expired before the
timestamp ( |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"links": {
"self": "http://example.com/identity/v3/groups/9ce0ad4e58a84d7a97b92f7955d10c92/users",
"previous": null,
"next": null
},
"users": [
{
"domain_id": "default",
"description": null,
"enabled": true,
"id": "acd565a08293c1e48bc0dd0d72ad5d5d"
"name": "Henry",
"links": {
"self": "http://example.com/identity/v3/users/acd565a08293c1e48bc0dd0d72ad5d5d"
}
},
{
"domain_id": "default",
"description": null,
"enabled": true,
"id": "fff603a0829d41e48bc0dd0d72ad61ce",
"name": "Paul",
"links": {
"self": "http://example.com/identity/v3/users/fff603a0829d41e48bc0dd0d72ad61ce"
},
"password_expires_at": "2016-11-06T15:32:17.000000"
}
]
}
Adds a user to a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group_user
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
group_id | path | string | The group ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Validates that a user belongs to a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group_user
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
group_id | path | string | The group ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Removes a user from a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/group_user
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
group_id | path | string | The group ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Enables projects to inherit role assignments from either their owning domain or projects that are higher in the hierarchy.
(Since API v3.4) The OS-INHERIT extension allows inheritance from both projects and domains. To access project inheritance, the Identity service server must run at least API v3.4.
Assigns a role to a user in projects owned by a domain.
The inherited role is only applied to the owned projects (both existing and future projects), and will not appear as a role in a domain scoped token.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_user_role_inherited_to_projects
The inherited role is only applied to the owned projects (both existing and future projects), and will not appear as a role in a domain scoped token.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_group_role_inherited_to_projects
The list only contains those role assignments to the domain that were specified as being inherited to projects within that domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_user_roles_inherited_to_projects
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
user_id | path | string | The user ID. |
{
"roles": [
{
"id": "91011",
"links": {
"self": "http://example.com/identity/v3/roles/91011"
},
"name": "admin"
},
{
"id": "91011",
"links": {
"self": "http://example.com/identity/v3/roles/91011"
},
"name": "admin"
}
],
"links": {
"self": "http://example.com/identity/v3/OS-INHERIT/domains/1234/users/5678/roles/inherited_to_projects",
"previous": null,
"next": null
}
}
The list only contains those role assignments to the domain that were specified as being inherited to projects within that domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_group_roles_inherited_to_projects
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group_id | path | string | The group ID. |
{
"roles": [
{
"id": "91011",
"links": {
"self": "http://example.com/identity/v3/roles/91011"
},
"name": "admin"
},
{
"id": "91011",
"links": {
"self": "http://example.com/identity/v3/roles/91011"
},
"name": "admin"
}
],
"links": {
"self": "http://example.com/identity/v3/OS-INHERIT/domains/1234/groups/5678/roles/inherited_to_projects",
"previous": null,
"next": null
}
}
Checks whether a user has an inherited project role in a domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_user_role_inherited_to_projects
Checks whether a group has an inherited project role in a domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_group_role_inherited_to_projects
Revokes an inherited project role from a user in a domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_user_role_inherited_to_projects
Revokes an inherited project role from a group in a domain.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/domain_group_role_inherited_to_projects
The inherited role assignment is anchored to a project and applied to its subtree in the projects hierarchy (both existing and future projects).
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_user_role_inherited_to_projects
The inherited role assignment is anchored to a project and applied to its subtree in the projects hierarchy (both existing and future projects).
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_group_role_inherited_to_projects
Checks whether a user has a role assignment with the inherited_to_projects
flag in a project.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_user_role_inherited_to_projects
Checks whether a group has a role assignment with the inherited_to_projects
flag in a project.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_group_role_inherited_to_projects
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_user_role_inherited_to_projects
Relationship:
https://docs.openstack.org/api/openstack-identity/3/ext/OS-INHERIT/1.0/rel/project_group_role_inherited_to_projects
Get a list of role assignments.
If no query parameters are specified, then this API will return a list of all role assignments.
{
"role_assignments": [
{
"links": {
"assignment": "http://example.com/identity/v3/domains/161718/users/313233/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"domain": {
"id": "161718"
}
},
"user": {
"id": "313233"
}
},
{
"group": {
"id": "101112"
},
"links": {
"assignment": "http://example.com/identity/v3/projects/456789/groups/101112/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"project": {
"id": "456789"
}
}
}
],
"links": {
"self": "http://example.com/identity/v3/role_assignments",
"previous": null,
"next": null
}
}
Since this list is likely to be very long, this API would typically always be used with one of more of the filter queries. Some typical examples are:
GET /v3/role_assignments?user.id={user_id}
would list all role assignments
involving the specified user.
GET /v3/role_assignments?scope.project.id={project_id}
would list all role
assignments involving the specified project.
It is also possible to list all role assignments within
a tree of projects:
GET /v3/role_assignments?scope.project.id={project_id}&include_subtree=true
would list all role assignments involving the specified project and all
sub-projects. include_subtree=true
can only be specified in conjunction
with scope.project.id
, specifiying it without this will result in an
HTTP 400 Bad Request being returned.
Each role assignment entity in the collection contains a link to the assignment that gave rise to this entity.
The scope section in the list response is extended to allow the representation of role assignments that are inherited to projects.
{
"role_assignments": [
{
"links": {
"assignment": "http://example.com/identity/v3/OS-INHERIT/domains/161718/users/313233/roles/123456/inherited_to_projects"
},
"role": {
"id": "123456"
},
"scope": {
"domain": {
"id": "161718"
},
"OS-INHERIT:inherited_to": "projects"
},
"user": {
"id": "313233"
}
},
{
"group": {
"id": "101112-"
},
"links": {
"assignment": "http://example.com/identity/v3/projects/456789/groups/101112/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"project": {
"id": "456789"
}
}
}
],
"links": {
"self": "http://example.com/identity/v3/role_assignments",
"previous": null,
"next": null
}
}
The query filter scope.OS-INHERIT:inherited_to
can be used to filter based
on role assignments that are inherited. The only value of
scope.OS-INHERIT:inherited_to
that is currently supported is projects
,
indicating that this role is inherited to all projects of the owning domain or
parent project.
If the query parameter effective
is specified, rather than simply returning
a list of role assignments that have been made, the API returns a list of
effective assignments at the user, project and domain level, having allowed for
the effects of group membership, role inference rules as well as inheritance
from the parent domain or project. Since the effects of group membership have
already been allowed for, the group role assignment entities themselves will
not be returned in the collection. Likewise, since the effects of inheritance
have already been allowed for, the role assignment entities themselves that
specify the inheritance will also not be returned in the collection. This
represents the effective role assignments that would be included in a scoped
token. The same set of query parameters can also be used in combination with
the effective
parameter.
For example:
GET /v3/role_assignments?user.id={user_id}&effective
would, in other words,
answer the question “what can this user actually do?”.
GET
/v3/role_assignments?user.id={user_id}&scope.project.id={project_id}&effective
would return the equivalent set of role assignments that would be included in
the token response of a project scoped token.
An example response for an API call with the query parameter effective
specified is given below:
{
"role_assignments": [
{
"links": {
"assignment": "http://example.com/identity/v3/domains/161718/users/313233/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"domain": {
"id": "161718"
}
},
"user": {
"id": "313233"
}
},
{
"links": {
"assignment": "http://example.com/identity/v3/projects/456789/groups/101112/roles/123456",
"membership": "http://example.com/identity/v3/groups/101112/users/313233"
},
"role": {
"id": "123456"
},
"scope": {
"project": {
"id": "456789"
}
},
"user": {
"id": "313234"
}
}
],
"links": {
"self": "http://example.com/identity/v3/role_assignments?effective",
"previous": null,
"next": null
}
}
The entity links
section of a response using the effective
query
parameter also contains, for entities that are included by virtue of group
membership, a url that can be used to access the membership of the group.
If the query parameter include_names
is specified, rather than simply
returning the entity IDs in the role assignments, the collection will
additionally include the names of the entities. For example:
GET /v3/role_assignments?user.id={user_id}&effective&include_names=true
would return:
{
"role_assignments": [
{
"links": {
"assignment": "http://example.com/identity/v3/domains/161718/users/313233/roles/123456"
},
"role": {
"domain": {
"id": "161718",
"name": "Default"
},
"id": "123456",
"name": "admin"
},
"scope": {
"domain": {
"id": "161718",
"name": "Default"
}
},
"user": {
"domain": {
"id": "161718",
"name": "Default"
},
"id": "313233",
"name": "admin"
}
},
{
"links": {
"assignment": "http://example.com/identity/v3/projects/456789/groups/101112/roles/123456",
"membership": "http://example.com/identity/v3/groups/101112/users/313233"
},
"role": {
"domain": {
"id": "161718",
"name": "Default"
},
"id": "123456",
"name": "admin"
},
"scope": {
"project": {
"domain": {
"id": "161718",
"name": "Default"
}
"id": "456789",
"name": "admin"
}
},
"user": {
"domain": {
"id": "161718",
"name": "Default"
},
"id": "313233",
"name": "admin"
}
}
],
"links": {
"self": "http://example.com/identity/v3/role_assignments?effective&include_names=true",
"previous": null,
"next": null
}
}
Relationship:
https://docs.openstack.org/api/openstack-identity/3/rel/role_assignments
Optional query parameters:
Name | In | Type | Description |
---|---|---|---|
effective (Optional) | query | key-only (no value required) | Returns the effective assignments, including any assignments gained by virtue of group membership. |
include_names (Optional) | query | boolean | If set to true, then the names of any entities returned will be include as
well as their IDs. Any value other than New in version 3.6 |
include_subtree (Optional) | query | boolean | If set to true, then relevant assignments in the project hierarchy below
the project specified in the New in version 3.6 |
group.id (Optional) | query | string | Filters the response by a group ID. |
role.id (Optional) | query | string | Filters the response by a role ID. |
scope.domain.id (Optional) | query | string | Filters the response by a domain ID. |
scope.OS-INHERIT:inherited_to (Optional) | query | string | Filters based on role assignments that are inherited.
The only value of inherited_to that is currently
supported is projects . |
scope.project.id (Optional) | query | string | Filters the response by a project ID. |
user.id (Optional) | query | string | Filters the response by a user ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Lists revoked PKI tokens.
Relationship:
https://docs.openstack.org/api/openstack-identity/3/rel/tokens/OS-PKI/revoked
Name | In | Type | Description |
---|---|---|---|
signed | body | string | List of expired PKI tokens, signed by the cryptographic message syntax (CMS). |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
404 - Not Found |
The requested resource could not be found. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
401 - Unauthorized |
User must authenticate before making a request. |
400 - Bad Request |
Some content in the request was invalid. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
{
"signed": "-----BEGIN CMS-----\nMIICGwYJKoZIhvcNAQcCoIICDDCCAggCAQExDTALBglghkgBZQMEAgEwawYJKoZI\nhvcNAQcBoF4EXHsicmV2b2tlZCI6IFt7ImV4cGlyZXMiOiAiMjAxNC0xMi0wMlQx\nNzowMDowOVoiLCAiaWQiOiAiODhiMjRmOTI5OTk0NGU1ZjhkODE0MDNjYzMyY2M5\nMmUifV19MYIBhTCCAYECAQEwXDBXMQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVW5z\nZXQxDjAMBgNVBAcMBVVuc2V0MQ4wDAYDVQQKDAVVbnNldDEYMBYGA1UEAwwPd3d3\nLmV4YW1wbGUuY29tAgEBMAsGCWCGSAFlAwQCATANBgkqhkiG9w0BAQEFAASCAQA3\nc8EI58ZXtqkyuUWqLPJZdB5v7Ou978w22YkOsgL5ruUpQiWdhdgvL/sxqd7OPqi7\nZZV3N+io+z1m4uAiSbriumv7HOEnIUEAUhK4G0kw5kAAg4j50c0Omdiqdq75k0j/\nJPoRCXa8ieb0X87zhgfIq7ze/HZ7E2LoO20us3AEzmglNv023qgGcsSGPAUIHWN5\nloonPtgztiwVbmS2gs3Z9JB73mxEBviCX4CZEU/sNpchAzI/53tscKlqlzv+GBcm\n1dYP3hEZn3twFRI9zos4hTwFkUivn6D3qgQB684sVrvKlzOCIqOKVGGYVSy/FQLE\nWwQ5u58ZD8ohaJPu2Q6l\n-----END CMS-----\n"
}
Warning
The policies
API is deprecated. Keystone is not a policy management
service. Do not use this.
A policy is an arbitrarily serialized policy engine rule set to be consumed by a remote service.
You encode policy rule sets into a blob that remote services can
consume. To do so, set type
to application/json
and specify
policy rules as JSON strings in a blob
. For example:
{
"blob":{
"foobar_user":[
"role:compute-user"
]
}
}
Creates a policy.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/policies
Name | In | Type | Description |
---|---|---|---|
policy | body | object | A policy object. |
type | body | string | The MIME media type of the serialized policy blob. |
blob | body | string | The policy rule set itself, as a serialized blob. |
{
"policy": {
"blob": "{'foobar_user': 'role:compute-user'}",
"type": "application/json"
}
}
Name | In | Type | Description |
---|---|---|---|
links | body | object | The links for the policy resource. |
blob | body | string | The policy rule set itself, as a serialized blob. |
policy | body | object | A policy object. |
type | body | string | The MIME media type of the serialized policy blob. |
id | body | string | The policy ID. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Lists policies.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/policies
Name | In | Type | Description |
---|---|---|---|
type (Optional) | query | string | Filters the response by a MIME media type for the
serialized policy blob. For example, application/json . |
Name | In | Type | Description |
---|---|---|---|
links | body | object | The links for the policy resource. |
blob | body | object | The policy rule itself, as a serialized blob. |
policies | body | array | A policies object. |
type | body | string | The MIME media type of the serialized policy blob. |
id | body | string | The policy ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/policies"
},
"policies": [
{
"blob": {
"foobar_user": [
"role:compute-user"
]
},
"id": "717273",
"links": {
"self": "http://example.com/identity/v3/policies/717273"
},
"type": "application/json"
},
{
"blob": {
"foobar_user": [
"role:compute-user"
]
},
"id": "717274",
"links": {
"self": "http://example.com/identity/v3/policies/717274"
},
"type": "application/json"
}
]
}
Shows details for a policy.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/policy
Name | In | Type | Description |
---|---|---|---|
links | body | object | The links for the policy resource. |
blob | body | object | The policy rule itself, as a serialized blob. |
policy | body | object | A policy object. |
type | body | string | The MIME media type of the serialized policy blob. |
id | body | string | The policy ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"policy": {
"blob": {
"foobar_user": [
"role:compute-user"
]
},
"id": "717273",
"links": {
"self": "http://example.com/identity/v3/policies/717273"
},
"type": "application/json"
}
}
Updates a policy.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/policy
Name | In | Type | Description |
---|---|---|---|
policy_id | path | string | The policy ID. |
policy | body | object | A policy object. |
type | body | string | The MIME media type of the serialized policy blob. |
blob | body | object | The policy rule itself, as a serialized blob. |
{
"policy": {
"blob": {
"foobar_user": [
"role:compute-user"
]
},
"type": "application/json"
}
}
Name | In | Type | Description |
---|---|---|---|
links | body | object | The links for the policy resource. |
blob | body | object | The policy rule itself, as a serialized blob. |
policy | body | object | A policy object. |
type | body | string | The MIME media type of the serialized policy blob. |
id | body | string | The policy ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"policy": {
"blob": {
"foobar_user": [
"role:compute-user"
]
},
"id": "717273",
"links": {
"self": "http://example.com/identity/v3/policies/717273"
},
"type": "application/json"
}
}
Deletes a policy.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/policy
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
A project is the base unit of resource ownership. Resources are owned by a specific project. A project is owned by a specific domain.
(Since Identity API v3.4) You can create a hierarchy of projects by setting a
parent_id
when you create a project. All projects in a hierarchy must be
owned by the same domain.
(Since Identity API v3.6) Projects may, in addition to acting as containers for
OpenStack resources, act as a domain (by setting the attribute is_domain
to
true
), in which case it provides a namespace in which users, groups and
other projects can be created. In fact, a domain created using the
POST /domains
API will actually be represented as a project with
is_domain
set to true
with no parent (parent_id
is null).
Given this, all projects are considered part of a project hierarchy. Projects
created in a domain prior to v3.6 are represented as a two-level hierarchy,
with a project that has is_domain
set to true
as the root and all other
projects referencing the root as their parent.
A project acting as a domain can potentially also act as a container for OpenStack resources, although this depends on whether the policy rule for the relevant resource creation allows this.
Note
A project’s name must be unique within a domain and no more than 64 characters.
A project’s name must be able to be sent within valid JSON, which could be any
UTF-8 character. However, this is constrained to the given backend where project
names are stored. For instance, MySQL’s restrictions states that UTF-8 support
is constrained to the characters in the Basic Multilingual Plane (BMP).
Supplementary characters are not permitted. Note that this last restriction is
generally true for all names
within resources of the Identity API.
Lists projects.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
domain_id (Optional) | query | string | Filters the response by a domain ID. |
enabled (Optional) | query | boolean | If set to true, then only enabled projects will be returned. Any value
other than 0 (including no value) will be interpreted as true. |
is_domain (Optional) | query | boolean | If this is specified as true, then only projects acting as a domain are included. Otherwise, only projects that are not acting as a domain are included. New in version 3.6 |
name (Optional) | query | string | Filters the response by a project name. |
parent_id (Optional) | query | string | Filters the response by a parent ID. New in version 3.4 |
Name | In | Type | Description |
---|---|---|---|
links | body | object | The link to the collection of resources. |
projects | body | array | A list of project objects, each containing: |
is_domain | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description | body | string | The description of the project. |
domain_id | body | string | The ID of the domain for the project. |
enabled | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
id | body | string | The ID for the project. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the project. |
parent_id | body | string | The ID of the parent for the project. New in version 3.4 |
tags | body | array | A list of simple strings assigned to a project. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/projects"
},
"projects": [
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "0c4e939acacf4376bdcd1129f1a054ad",
"links": {
"self": "http://example.com/identity/v3/projects/0c4e939acacf4376bdcd1129f1a054ad"
},
"name": "admin",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "0cbd49cbf76d405d9c86562e1d579bd3",
"links": {
"self": "http://example.com/identity/v3/projects/0cbd49cbf76d405d9c86562e1d579bd3"
},
"name": "demo",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "2db68fed84324f29bb73130c6c2094fb",
"links": {
"self": "http://example.com/identity/v3/projects/2db68fed84324f29bb73130c6c2094fb"
},
"name": "swifttenanttest2",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "3d594eb0f04741069dbbb521635b21c7",
"links": {
"self": "http://example.com/identity/v3/projects/3d594eb0f04741069dbbb521635b21c7"
},
"name": "service",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "43ebde53fc314b1c9ea2b8c5dc744927",
"links": {
"self": "http://example.com/identity/v3/projects/43ebde53fc314b1c9ea2b8c5dc744927"
},
"name": "swifttenanttest1",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": "",
"domain_id": "1bc2169ca88e4cdaaba46d4c15390b65",
"enabled": true,
"id": "4b1eb781a47440acb8af9850103e537f",
"links": {
"self": "http://example.com/identity/v3/projects/4b1eb781a47440acb8af9850103e537f"
},
"name": "swifttenanttest4",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "5961c443439d4fcebe42643723755e9d",
"links": {
"self": "http://example.com/identity/v3/projects/5961c443439d4fcebe42643723755e9d"
},
"name": "invisible_to_admin",
"parent_id": null,
"tags": []
},
{
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "fdb8424c4e4f4c0ba32c52e2de3bd80e",
"links": {
"self": "http://example.com/identity/v3/projects/fdb8424c4e4f4c0ba32c52e2de3bd80e"
},
"name": "alt_demo",
"parent_id": null,
"tags": []
}
]
}
Creates a project, where the project may act as a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
project | body | object | A project object, containing: |
name | body | string | The name of the project, which must be unique within the owning domain. A project can have the same name as its domain. |
is_domain (Optional) | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description (Optional) | body | string | The description of the project. |
domain_id (Optional) | body | string | The ID of the domain for the project. For projects acting as a domain, the For regular projects (i.e. those not acing as a domain), if |
enabled (Optional) | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. The default is true . |
parent_id (Optional) | body | string | The ID of the parent of the project. If specified on project creation, this places the project within a
hierarchy and implicitly defines the owning domain, which will be the
same domain as the parent specified. If
New in version 3.4 |
tags (Optional) | body | array | A list of simple strings assigned to a project. Tags can be used to classify projects into groups. |
Sample for creating a regular project:
{
"project": {
"description": "My new project",
"domain_id": "default",
"enabled": true,
"is_domain": false,
"name": "myNewProject"
}
}
Sample for creating a project that also acts as a domain:
{
"project": {
"description": "My new domain",
"enabled": true,
"is_domain": true,
"name": "myNewDomain"
}
}
Name | In | Type | Description |
---|---|---|---|
project | body | object | A project object, containing: |
is_domain | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description | body | string | The description of the project. |
domain_id | body | string | The ID of the domain for the project. |
enabled | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
id | body | string | The ID for the project. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the project. |
parent_id | body | string | The ID of the parent for the project. New in version 3.4 |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Shows details for a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
parents_as_list (Optional) | query | key-only, no value expected | The parent hierarchy will be included as a list in the response. This list will contain the projects found by traversing up the hierarchy to the top-level project. The returned list will be filtered against the projects the user has an effective role assignment on. New in version 3.4 |
subtree_as_list (Optional) | query | key-only, no value expected | The child hierarchy will be included as a list in the response. This list will contain the projects found by traversing down the hierarchy. The returned list will be filtered against the projects the user has an effective role assignment on. New in version 3.4 |
parents_as_ids (Optional) | query | key-only, no value expected | The entire parent hierarchy will be included as nested dictionaries in the response. It will contain all projects ids found by traversing up the hierarchy to the top-level project. New in version 3.4 |
subtree_as_ids (Optional) | query | key-only, no value expected | The entire child hierarchy will be included as nested dictionaries in the response. It will contain all the projects ids found by traversing down the hierarchy. New in version 3.4 |
Name | In | Type | Description |
---|---|---|---|
project | body | object | A project object, containing: |
is_domain | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description | body | string | The description of the project. |
domain_id | body | string | The ID of the domain for the project. |
enabled | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
id | body | string | The ID for the project. |
links | body | object | The link to the resources in question. |
name | body | string | The name of the project. |
parent_id | body | string | The ID of the parent for the project. New in version 3.4 |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"project": {
"is_domain": false,
"description": null,
"domain_id": "default",
"enabled": true,
"id": "0c4e939acacf4376bdcd1129f1a054ad",
"links": {
"self": "http://example.com/identity/v3/projects/0c4e939acacf4376bdcd1129f1a054ad"
},
"name": "admin",
"parent_id": "default"
}
}
parents_as_list
¶{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "263fd9",
"links": {
"self": "http://example.com/identity/v3/projects/263fd9"
},
"name": "Dev Group A",
"parent_id": "183ab2",
"parents": [
{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "183ab2",
"links": {
"self": "http://example.com/identity/v3/projects/183ab2"
},
"name": "Dev Group A Parent",
"parent_id": null
}
}
]
}
}
subtree_as_list
¶{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "263fd9",
"links": {
"self": "http://example.com/identity/v3/projects/263fd9"
},
"name": "Dev Group A",
"parent_id": "183ab2",
"subtree": [
{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "9n1jhb",
"links": {
"self": "http://example.com/identity/v3/projects/9n1jhb"
},
"name": "Dev Group A Child 1",
"parent_id": "263fd9"
}
},
{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "4b6aa1",
"links": {
"self": "http://example.com/identity/v3/projects/4b6aa1"
},
"name": "Dev Group A Child 2",
"parent_id": "263fd9"
}
},
{
"project": {
"domain_id": "1789d1",
"enabled": true,
"id": "b76eq8",
"links": {
"self": "http://example.com/identity/v3/projects/b76xq8"
},
"name": "Dev Group A Grandchild",
"parent_id": "4b6aa1"
}
}
]
}
}
Updates a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
project | body | object | A project object, containing: |
name (Optional) | body | string | The name of the project, which must be unique within the owning domain. A project can have the same name as its domain. |
is_domain (Optional) | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description (Optional) | body | string | The description of the project. |
domain_id (Optional) | body | string | The ID of the new domain for the project. The ability to change the domain of a project is now deprecated, and will be removed in subequent release. It is already disabled by default in most Identity service implementations. |
enabled (Optional) | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
tags (Optional) | body | array | A list of simple strings assigned to a project. Tags can be used to classify projects into groups. |
{
"project": {
"description": "My updated project",
"name": "myUpdatedProject"
}
}
Name | In | Type | Description |
---|---|---|---|
project | body | object | A project object, containing: |
is_domain | body | boolean | Indicates whether the project also acts as a domain. If set to New in version 3.6 |
description | body | string | The description of the project. |
domain_id | body | string | The ID of the domain for the project. |
enabled | body | boolean | If set to true , project is enabled. If set to
false , project is disabled. |
id | body | string | The ID for the project. |
name | body | string | The name of the project. |
links | body | object | The link to the resources in question. |
parent_id | body | string | The ID of the parent for the project. New in version 3.4 |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
{
"project": {
"description": "My updated project",
"domain_id": null,
"links": {
"self": "http://example.com/identity/v3/projects/93ebbcc35335488b96ff9cd7d18cbb2e"
},
"enabled": true,
"id": "93ebbcc35335488b96ff9cd7d18cbb2e",
"is_domain": true,
"name": "myUpdatedProject",
"parent_id": null,
"tags": []
}
}
Deletes a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Projects within keystone can be tagged with one to many simple strings. Tags for projects follow the guidelines for resource tags set by the API Working Group.
Tags for projects have the following restrictions:
Note
Lists all tags within a project.
Note
HEAD can be used here as well
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
tags | body | array | A list of simple strings assigned to a project. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"tags": ["foo", "bar"]
}
Checks if a project contains the specified tag.
Note
HEAD can be used here as well
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
project_id | body | string | The ID for the project. |
tag | query | string | A simple string associated with a project. Can be used for assigning values to projects and filtering based on those values. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Creates the specified tag and adds it to the list of tags in the project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
project_id | body | string | The ID for the project. |
tag | query | string | A simple string associated with a project. Can be used for assigning values to projects and filtering based on those values. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Modifies the tags for a project. Any existing tags not specified will be deleted.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
project_id | body | string | The ID for the project. |
tags | body | array | A list of simple strings assigned to a project. |
{
"tags": ["foo", "bar"]
}
Name | In | Type | Description |
---|---|---|---|
tags | body | array | A list of simple strings assigned to a project. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"links": {
"next": null,
"previous": null,
"self": "http://identity:5000/v3/projects"
},
"projects": [
{
"description": "Test Project",
"domain_id": "default",
"enabled": true,
"id": "3d4c2c82bd5948f0bcab0cf3a7c9b48c",
"links": {
"self": "http://identity:5000/v3/projects/3d4c2c82bd5948f0bcab0cf3a7c9b48c"
},
"name": "demo",
"tags": ["foo", "bar"]
}
]
}
Remove a single tag from a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Name | In | Type | Description |
---|---|---|---|
project_id | body | string | The ID for the project. |
tag | query | string | A simple string associated with a project. Can be used for assigning values to projects and filtering based on those values. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Remove all tags from a given project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/projects
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Projects can be searched or filtered by tags. The following table and examples define how to filter projects by tags. Filters can also be combined for more complex searching.
Tag Query | Description |
---|---|
tags | Projects that contain all of the specified tags |
tags-any | Projects that contain at least one of the specified tags |
not-tags | Projects that do not contain exactly all of the specified tags |
not-tags-any | Projects that do not contain any one of the specified tags |
To request the list of projects that have a single tag, the tags
query
parameter should be set to the desired tag name. The following example returns
projects with the “foo” tag:
GET /v3/projects?tags=foo
To request the list of projects that have two or more tags, the tags
argument should be set to the list of tags, separated by commas. In this
situation, the tags given must all be present for a project to be included
in the query result. The following example returns projects that have the
“foo” and “bar” tags:
GET /v3/projects?tags=foo,bar
To request the list of projects that have at least one tag from a given list,
the tags-any
argument should be set to the list of tags, separated
by commas. In this situation as long as one of the given tags is present,
the project will be included in the query result. The following example returns
projects that have the “foo” OR “bar” tag:
GET /v3/projects?tags-any=foo,bar
To request the list of projects that do not have a list of tags, the
not-tags
argument should be set to the list of tags, separated by commas.
In this situation, the tags given must all be absent for a project to be
included in the query result. The following example returns projects that
do not have the “foo” nor the “bar” tag:
GET /v3/projects?not-tags=foo,bar
To request the list of projects that do not have at least one of a list of
tags, the not-tags-any
argument should be set to the list of tags,
separated by commas. In this situation, as long as one of the given tags
is absent, the project will be included in the query result. Example
The following example returns projects that do not have the “foo” tag or
do not have the “bar” tag:
GET /v3/projects?not-tags-any=foo,bar
The tags
, tags-any
, not-tags
and not-tags-any
arguments can
be combined to build more complex queries. The following example returns
projects that have the “foo” and “bar” tags, plus at least one of “red”
and “blue”:
GET /v3/projects?tags=foo,bar&tags-any=red,blue
A region is a general division of an OpenStack deployment. You can associate zero or more sub-regions with a region to create a tree- like structured hierarchy.
Although a region does not have a geographical connotation, a
deployment can use a geographical name for a region ID, such as us-
east
.
You can list, create, update, show details for, and delete regions.
Shows details for a region, by ID.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/regions
Name | In | Type | Description |
---|---|---|---|
region | body | object | A region object, containing the following: |
description | body | string | The region description. |
id | body | string | The ID for the region. |
links | body | object | The links for the region resource. |
parent_region_id | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"region": {
"description": "My subregion 3",
"id": "RegionThree",
"links": {
"self": "http://example.com/identity/v3/regions/RegionThree"
},
"parent_region_id": "RegionOne"
}
}
Updates a region.
You can update the description or parent region ID for a region. You cannot update the region ID.
The following error might occur:
Not Found (404)
. The parent region ID does not exist.Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/region
Name | In | Type | Description |
---|---|---|---|
region_id | path | string | The region ID. |
region | body | object | A region object, containing the following: |
description (Optional) | body | string | The region description. |
parent_region_id (Optional) | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
{
"region": {
"description": "My subregion 3"
}
}
Name | In | Type | Description |
---|---|---|---|
region | body | object | A region object, containing the following: |
description | body | string | The region description. |
id | body | string | The ID for the region. |
links | body | object | The links for the region resource. |
parent_region_id | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"region": {
"parent_region_id": "RegionOne",
"id": "RegionThree",
"links": {
"self": "http://example.com/identity/v3/regions/RegionThree"
},
"description": "My subregion 3"
}
}
Deletes a region.
The following error might occur:
Conflict (409)
. The region cannot be deleted because it has
child regions.Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/region
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
Lists regions.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/regions
Name | In | Type | Description |
---|---|---|---|
parent_region_id (Optional) | query | string | Filters the response by a parent region, by ID. |
Name | In | Type | Description |
---|---|---|---|
regions | body | array | A list of region object, each containing the following: |
description | body | string | The region description. |
id | body | string | The ID for the region. |
links | body | object | The links for the region resource. |
parent_region_id | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
{
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/regions"
},
"regions": [
{
"description": "",
"id": "RegionOne",
"links": {
"self": "http://example.com/identity/v3/regions/RegionOne"
},
"parent_region_id": null
}
]
}
Creates a region.
When you create the region, you can optionally specify a region ID. If you include characters in the region ID that are not allowed in a URI, you must URL-encode the ID. If you omit an ID, the API assigns an ID to the region.
The following errors might occur:
Not Found (404)
. The parent region ID does not exist.Conflict (409)
. The parent region ID would form a circular
relationship.Conflict (409)
. The user-defined region ID is not unique to
the OpenStack deployment.Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/regions
Name | In | Type | Description |
---|---|---|---|
region | body | object | A region object, containing the following: |
description (Optional) | body | string | The region description. |
id (Optional) | body | string | The ID for the region. |
parent_region_id (Optional) | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
{
"region": {
"description": "My subregion",
"id": "RegionOneSubRegion",
"parent_region_id": "RegionOne"
}
}
Name | In | Type | Description |
---|---|---|---|
region | body | object | A region object, containing the following: |
description | body | string | The region description. |
id | body | string | The ID for the region. |
links | body | object | The links for the region resource. |
parent_region_id | body | string | To make this region a child of another region, set this parameter to the ID of the parent region. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
405 - Method Not Allowed |
Method is not valid for this endpoint. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
413 - Request Entity Too Large |
The request is larger than the server is willing or able to process. |
415 - Unsupported Media Type |
The request entity has a media type which the server or resource does not support. |
503 - Service Unavailable |
Service is not available. This is mostly caused by service configuration errors which prevents the service from successful start up. |
OpenStack services typically determine whether a user’s API request should be allowed using Role Based Access Control (RBAC). For OpenStack this means the service compares the roles that user has on the project (as indicated by the roles in the token), against the roles required for the API in question (as defined in the service’s policy file). A user obtains roles on a project by having these assigned to them via the Identity service API.
Roles must initially be created as entities via the Identity services API and, once created, can then be assigned. You can assign roles to a user or group on a project, including projects owned by other domains. You can also assign roles to a user or group on a domain, although this is only currently relevant for using a domain scoped token to execute domain-level Identity service API requests.
The creation, checking and deletion of role assignments is done with each of the attributes being specified in the URL. For example to assign a role to a user on a project:
PUT /v3/projects/{project_id}/users/{user_id}/roles/{role_id}
You can also list roles assigned to the system, or to a specified domain, project, or user using this form of API, however a more generalized API for list assignments is provided where query parameters are used to filter the set of assignments returned in the collection. For example:
List role assignments for the specified user:
GET /role_assignments?user.id={user_id}
List role assignments for the specified project:
GET /role_assignments?scope.project.id={project_id}
List system role assignments for a specific user:
GET /role_assignments?scope.system=all?user.id={user_id}
List system role assignments for all users and groups:
GET /role_assignments?scope.system=all
Since Identity API v3.10, you can grant role assignments to users and groups on
an entity called the system
. The role assignment API also supports listing
and filtering role assignments on the system.
Since Identity API v3.6, you can also list all role assignments within a tree of projects, for example the following would list all role assignments for a specified project and its sub-projects:
GET /role_assignments?scope.project.id={project_id}&include_subtree=true
If you specify include_subtree=true
, you must also specify the
scope.project.id
. Otherwise, this call returns the Bad Request (400)
response code.
Each role assignment entity in the collection contains a link to the assignment that created the entity.
As mentioned earlier, role assignments can be made to a user or a group on a
particular project, domain, or the entire system. A user who is a member of a
group that has a role assignment, will also be treated as having that role
assignment by virtue of their group membership. The effective role
assignments of a user (on a given project or domain) therefore consists of any
direct assignments they have, plus any they gain by virtue of membership of
groups that also have assignments on the given project or domain. This set of
effective role assignments is what is placed in the token for reference by
services wishing to check policy. You can list the effective role assignments
using the effective
query parameter at the user, project, and domain level:
Determine what a user can actually do:
GET /role_assignments?user.id={user_id}&effective
Get the equivalent set of role assignments that are included in a project-scoped token response:
GET /role_assignments?user.id={user_id}&scope.project.id={project_id}&effective
When listing in effective mode, since the group assignments have been
effectively expanded out into assignments for each user, the group role
assignment entities themselves are not returned in the collection. However,
in the response, the links
entity section for each assignment gained by
virtue of group membership will contain a URL that enables access to the
membership of the group.
By default only the IDs of entities are returned in collections from the
role_assignment API calls. The names of entities may also be returned,
in addition to the IDs, by using the include_names
query parameter
on any of these calls, for example:
List role assignments including names:
GET /role_assignments?include_names
Lists roles.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/roles
Name | In | Type | Description |
---|---|---|---|
name (Optional) | query | string | Filters the response by a role name. |
domain_id (Optional) | query | string | Filters the response by a domain ID. |
Name | In | Type | Description |
---|---|---|---|
links | body | object | The link to the collection of resources. |
roles | body | array | A list of role objects, each containing: |
domain_id | body | string | The ID of the domain. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/roles"
},
"roles": [
{
"id": "5318e65d75574c17bf5339d3df33a5a3",
"links": {
"self": "http://example.com/identity/v3/roles/5318e65d75574c17bf5339d3df33a5a3"
},
"name": "admin"
},
{
"id": "642bcfc75c384fd181adf34d9b2df897",
"links": {
"self": "http://example.com/identity/v3/roles/642bcfc75c384fd181adf34d9b2df897"
},
"name": "anotherrole"
},
{
"id": "779a76d74f544224a7ef8762ca0de627",
"links": {
"self": "http://example.com/identity/v3/roles/779a76d74f544224a7ef8762ca0de627"
},
"name": "Member"
},
{
"id": "9fe2ff9ee4384b1894a90878d3e92bab",
"links": {
"self": "http://example.com/identity/v3/roles/9fe2ff9ee4384b1894a90878d3e92bab"
},
"name": "_member_"
},
{
"id": "ba2dfba61c934ee89e3110de36273229",
"links": {
"self": "http://example.com/identity/v3/roles/ba2dfba61c934ee89e3110de36273229"
},
"name": "ResellerAdmin"
},
{
"id": "f127b97616f24d3ebceb7be840210adc",
"links": {
"self": "http://example.com/identity/v3/roles/f127b97616f24d3ebceb7be840210adc"
},
"name": "service"
}
]
}
Creates a role.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/roles
Name | In | Type | Description |
---|---|---|---|
role | body | object | A role object, containing: |
name | body | string | The role name. |
domain_id (Optional) | body | string | The ID of the domain of the role. |
{
"role": {
"name": "developer"
}
}
{
"role": {
"domain_id": "92e782c4988642d783a95f4a87c3fdd7",
"name": "developer"
}
}
Name | In | Type | Description |
---|---|---|---|
role | body | object | A role object, containing: |
domain_id | body | string | The ID of the domain. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Shows details for a role.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/role
Name | In | Type | Description |
---|---|---|---|
role | body | object | A role object, containing: |
domain_id | body | string | The ID of the domain. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
{
"role": {
"domain_id": "d07792fd66ac4ed881723ab9f1c9925f",
"id": "1e443fa8cee3482a8a2b6954dd5c8f12",
"links": {
"self": "http://example.com/identity/v3/roles/1e443fa8cee3482a8a2b6954dd5c8f12"
},
"name": "Developer"
}
}
Updates a role.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/role
Name | In | Type | Description |
---|---|---|---|
role_id | path | string | The role ID. |
role | body | object | A role object, containing: |
name (Optional) | body | string | The new role name. |
{
"role": {
"name": "Developer"
}
}
Name | In | Type | Description |
---|---|---|---|
role | body | object | A role object, containing: |
domain_id | body | string | The ID of the domain. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
{
"role": {
"domain_id": "73748865fb964ded9e836d491d32dcfb",
"id": "1e443fa8cee3482a8a2b6954dd5c8f12",
"links": {
"self": "http://example.com/identity/v3/roles/1e443fa8cee3482a8a2b6954dd5c8f12"
},
"name": "Developer"
}
}
Deletes a role.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/role
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists role assignments for a group on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_group_roles
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group_id | path | string | The group ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"roles": [
{
"id": "123456",
"links": {
"self": "http://example.com/identity/v3/roles/123456"
},
"name": "admin"
},
{
"id": "123457",
"links": {
"self": "http://example.com/identity/v3/roles/123457"
},
"name": "manager"
}
],
"links": {
"self": "http://example.com/identity/v3/domains/161718/groups/101112/roles",
"previous": null,
"next": null
}
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?group.id={group_id}&scope.domain.id={domain_id}
Assigns a role to a group on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_group_role
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Validates that a group has a role assignment on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_group_role
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Unassigns a role from a group on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_group_role
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists role assignments for a user on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_user_roles
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
user_id | path | string | The user ID. |
Name | In | Type | Description |
---|---|---|---|
roles | body | array | A list of role objects, each containing: |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"roles": [
{
"id": "123456",
"links": {
"self": "http://example.com/identity/v3/roles/123456"
},
"name": "admin"
},
{
"id": "123457",
"links": {
"self": "http://example.com/identity/v3/roles/123457"
},
"name": "manager"
}
],
"links": {
"self": "http://example.com/identity/v3/domains/161718/users/313233/roles",
"previous": null,
"next": null
}
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?user.id={user_id}&scope.domain.id={domain_id}
Assigns a role to a user on a domain.
Relationship: https://developer.openstack.org/api-ref/identity/v3/index.html#assign-role-to-user-on-domain
Validates that a user has a role assignment on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_user_role
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Unassigns a role from a user on a domain.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/domain_user_role
Name | In | Type | Description |
---|---|---|---|
domain_id | path | string | The domain ID. |
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Lists role assignments for a group on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_user_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
group_id | path | string | The group ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"roles": [
{
"id": "123456",
"links": {
"self": "http://example.com/identity/v3/roles/123456"
},
"name": "admin"
},
{
"id": "123457",
"links": {
"self": "http://example.com/identity/v3/roles/123457"
},
"name": "manager"
}
],
"links": {
"self": "http://example.com/identity/v3/projects/456789/groups/101112/roles",
"previous": null,
"next": null
}
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?group.id={group_id}&scope.project.id={project_id}
Assigns a role to a group on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_group_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Validates that a group has a role assignment on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_group_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Unassigns a role from a group on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_group_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists role assignments for a user on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_user_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
user_id | path | string | The user ID. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"links": {
"self": "http://example.com/identity/v3/projects/9e5a15e2c0dd42aab0990a463e839ac1/users/b964a9e51c0046a4a84d3f83a135a97c/roles",
"previous": null,
"next": null
},
"roles": [
{
"id": "3b5347fa7a144008ba57c0acea469cc3",
"links": {
"self": "http://example.com/identity/v3/roles/3b5347fa7a144008ba57c0acea469cc3"
},
"name": "admin"
}
]
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?user.id={user_id}&scope.project.id={project_id}
Assigns a role to a user on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_user_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
409 - Conflict |
This operation conflicted with another operation on this resource. |
Validates that a user has a role on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_user_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Unassigns a role from a user on a project.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/project_user_role
Name | In | Type | Description |
---|---|---|---|
project_id | path | string | The project ID. |
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists implied (inference) roles for a role.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#list-implied-roles-for-role
Name | In | Type | Description |
---|---|---|---|
role_inference | body | object | Role inference object that contains prior_role object
and implies object. |
prior_role | body | object | A prior role object. |
implies | body | array | An array of implied role objects. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
404 - Not Found |
The requested resource could not be found. |
{
"role_inference": {
"prior_role": {
"id": "42c764f0c19146728dbfe73a49cc35c3",
"links": {
"self": "http://example.com/identity/v3/roles/42c764f0c19146728dbfe73a49cc35c3"
},
"name": "prior role name"
},
"implies": [
{
"id": "066fbfc8b3e54fb68784c9e7e92ab8d7",
"links": {
"self": "http://example.com/identity/v3/roles/066fbfc8b3e54fb68784c9e7e92ab8d7"
},
"name": "implied role1 name"
},
{
"id": "32a0df1cc22848aca3986adae9e0b9a0",
"links": {
"self": "http://example.com/identity/v3/roles/32a0df1cc22848aca3986adae9e0b9a0"
},
"name": "implied role2 name"
}
]
},
"links" : {
"self": "http://example.com/identity/v3/roles/42c764f0c19146728dbfe73a49cc35c3/implies"
}
}
Creates a role inference rule.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#create-role-inference-rule
Name | In | Type | Description |
---|---|---|---|
prior_role_id | path | string | Role ID for a prior role. |
implies_role_id | path | string | Role ID for an implied role. |
Name | In | Type | Description |
---|---|---|---|
role_inference | body | object | Role inference object that contains prior_role object
and implies object. |
prior_role | body | object | A prior role object. |
implies | body | object | An implied role object. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
201 - Created |
Resource was created and is ready to use. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
404 - Not Found |
The requested resource could not be found. |
{
"role_inference": {
"prior_role": {
"id": "7ceab6192ea34a548cc71b24f72e762c",
"links": {
"self": "http://example.com/identity/v3/roles/7ceab6192ea34a548cc71b24f72e762c"
},
"name": "prior role name"
},
"implies": {
"id": "97e2f5d38bc94842bc3da818c16762ed",
"links": {
"self": "http://example.com/identity/v3/roles/97e2f5d38bc94842bc3da818c16762ed"
},
"name": "implied role name"
}
},
"links": {
"self": "http://example.com/identity/v3/roles/7ceab6192ea34a548cc71b24f72e762c/implies/97e2f5d38bc94842bc3da818c16762ed"
}
}
Gets a role inference rule.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#get-role-inference-rule
Name | In | Type | Description |
---|---|---|---|
prior_role_id | path | string | Role ID for a prior role. |
implies_role_id | path | string | Role ID for an implied role. |
Name | In | Type | Description |
---|---|---|---|
role_inference | body | object | Role inference object that contains prior_role object
and implies object. |
prior_role | body | object | A prior role object. |
implies | body | object | An implied role object. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
404 - Not Found |
The requested resource could not be found. |
{
"role_inference": {
"prior_role": {
"id": "7ceab6192ea34a548cc71b24f72e762c",
"links": {
"self": "http://example.com/identity/v3/roles/7ceab6192ea34a548cc71b24f72e762c"
},
"name": "prior role name"
},
"implies": {
"id": "97e2f5d38bc94842bc3da818c16762ed",
"links": {
"self": "http://example.com/identity/v3/roles/97e2f5d38bc94842bc3da818c16762ed"
},
"name": "implied role name"
}
},
"links": {
"self": "http://example.com/identity/v3/roles/7ceab6192ea34a548cc71b24f72e762c/implies/97e2f5d38bc94842bc3da818c16762ed"
}
}
Checks a role role inference rule.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#confirm-role-inference-rule
Deletes a role inference rule.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#delete-role-inference-rule
Lists role assignments.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/role_assignments
Name | In | Type | Description |
---|---|---|---|
effective (Optional) | query | key-only (no value required) | Returns the effective assignments, including any assignments gained by virtue of group membership. |
include_names (Optional) | query | boolean | If set to true, then the names of any entities returned will be include as
well as their IDs. Any value other than New in version 3.6 |
include_subtree (Optional) | query | boolean | If set to true, then relevant assignments in the project hierarchy below
the project specified in the New in version 3.6 |
group.id (Optional) | query | string | Filters the response by a group ID. |
role.id (Optional) | query | string | Filters the response by a role ID. |
scope.system (Optional) | query | string | Filters the response by system assignments. |
scope.domain.id (Optional) | query | string | Filters the response by a domain ID. |
scope.project.id (Optional) | query | string | Filters the response by a project ID. |
user.id (Optional) | query | string | Filters the response by a user ID. |
Name | In | Type | Description |
---|---|---|---|
role_assignments | body | array | A list of role_assignment objects. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"role_assignments": [
{
"links": {
"assignment": "http://example.com/identity/v3/domains/161718/users/313233/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"domain": {
"id": "161718"
}
},
"user": {
"id": "313233"
}
},
{
"group": {
"id": "101112"
},
"links": {
"assignment": "http://example.com/identity/v3/projects/456789/groups/101112/roles/123456"
},
"role": {
"id": "123456"
},
"scope": {
"project": {
"id": "456789"
}
}
}
],
"links": {
"self": "http://example.com/identity/v3/role_assignments",
"previous": null,
"next": null
}
}
Lists all role inference rules.
Relationship:
https://developer.openstack.org/api-ref/identity/v3/#list-all-role-inference-rules
Name | In | Type | Description |
---|---|---|---|
role_inferences | body | array | An array of role_inference object. |
prior_role | body | object | A prior role object. |
implies | body | object | An implied role object. |
id | body | string | The role ID. |
links | body | object | The link to the resources in question. |
name | body | string | The role name. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
404 - Not Found |
The requested resource could not be found. |
{
"role_inferences": [
{
"prior_role": {
"id": "1acd3c5aa0e246b9a7427d252160dcd1",
"links": {
"self": "http://example.com/identity/v3/roles/1acd3c5aa0e246b9a7427d252160dcd1"
},
"name": "prior role name"
},
"implies": [
{
"id": "3602510e2e1f499589f78a0724dcf614",
"links": {
"self": "http://example.com/identity/v3/roles/3602510e2e1f499589f78a0724dcf614"
},
"name": "implied role1 name"
},
{
"id": "738289aeef684e73a987f7cf2ec6d925",
"links": {
"self": "http://example.com/identity/v3/roles/738289aeef684e73a987f7cf2ec6d925"
},
"name": "implied role2 name"
}
]
},
{
"prior_role": {
"id": "bbf7a5098bb34407b7164eb6ff9f144e",
"links": {
"self" : "http://example.com/identity/v3/roles/bbf7a5098bb34407b7164eb6ff9f144e"
},
"name": "prior role name"
},
"implies": [
{
"id": "872b20ad124c4c1bafaef2b1aae316ab",
"links": {
"self": "http://example.com/identity/v3/roles/872b20ad124c4c1bafaef2b1aae316ab"
},
"name": "implied role1 name"
},
{
"id": "1d865b1b2da14cb7b05254677e5f36a2",
"links": {
"self": "http://example.com/identity/v3/roles/1d865b1b2da14cb7b05254677e5f36a2"
},
"name": "implied role2 name"
}
]
}
],
"links": {
"self": "http://example.com/identity/v3/role_inferences"
}
}
A system role assignment ultimately controls access to system-level API calls. System role assignments are similar to project or domain role assignments, but are meant for a different target. Instead of giving a user or group a role on a project, they can be given a system role.
Good examples of system-level APIs include management of the service catalog and compute hypervisors.
Lists all system role assignment a user has.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_user_roles
Name | In | Type | Description |
---|---|---|---|
links | body | object | The link to the resources in question. |
roles | body | array | A list of role objects containing domain_id , id , links ,
and name attributes. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"roles": [
{
"domain_id": null,
"id": "6d550353899f4b0fbf3e410e1b6ddc05",
"links": {
"self": "http://example.com/identity/v3/roles/6d550353899f4b0fbf3e410e1b6ddc05"
},
"name": "admin"
}
],
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/system/users/0b916f1b1e51455cb24b3a051520c576/roles"
}
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?user.id={user_id}&scope.system
Grant a user a role on the system.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_user_role
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Check if a specific user has a role assignment on the system.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_user_role
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Get a specific system role assignment for a user. This is the same API as
HEAD /v3/system/users/{user_id}/roles/{role_id}
.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_user_role
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Remove a system role assignment from a user.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_user_role
Name | In | Type | Description |
---|---|---|---|
user_id | path | string | The user ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Lists all system role assignment a group has.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_group_roles
Name | In | Type | Description |
---|---|---|---|
links | body | object | The link to the resources in question. |
roles | body | array | A list of role objects containing domain_id , id , links ,
and name attributes. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"roles": [
{
"domain_id": null,
"id": "6d550353899f4b0fbf3e410e1b6ddc05",
"links": {
"self": "http://example.com/identity/v3/roles/6d550353899f4b0fbf3e410e1b6ddc05"
},
"name": "admin"
}
],
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/system/groups/934cc15c4d03479ebba167d67d47737f/roles"
}
}
The functionality of this request can also be achieved using the generalized list assignments API:
GET /role_assignments?group.id={group_id}&scope.system
Grant a group a role on the system.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_group_role
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Check if a specific group has a role assignment on the system.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_group_role
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Get a specific system role assignment for a group. This is the same API as
HEAD /v3/system/groups/{group_id}/roles/{role_id}
.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_group_role
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
Remove a system role assignment from a group.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/system_group_role
Name | In | Type | Description |
---|---|---|---|
group_id | path | string | The group ID. |
role_id | path | string | The role ID. |
Code | Reason |
---|---|
204 - No Content |
The server has fulfilled the request. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
404 - Not Found |
The requested resource could not be found. |
A service is an OpenStack web service that you can access through a URL, i.e. an endpoint.
A service catalog lists the services that are available to the caller based upon the current authorization.
You can create, list, show details for, update, and delete services. When you create or update a service, you can enable the service, which causes it and its endpoints to appear in the service catalog.
You can create, list, show details for, update, and delete endpoints.
Lists all services.
Relationship: https://docs.openstack.org/api/openstack-identity/3/rel/services
Name | In | Type | Description |
---|---|---|---|
type (Optional) | query | string | Filters the response by a service type. A valid
value is compute , ec2 , identity , image ,
network , or volume . |
Name | In | Type | Description |
---|---|---|---|
name | body | string | The service name. |
links | body | object | The links for the service resource. |
enabled (Optional) | body | boolean | Defines whether the service and its endpoints
appear in the service catalog: - false . The service and its
endpoints do not appear in the service catalog. - true . The
service and its endpoints appear in the service catalog. |
services | body | array | A list of service object. |
type | body | string | The service type, which describes the API
implemented by the service. Value is compute , ec2 ,
identity , image , network , or volume . |
id | body | string | The UUID of the service to which the endpoint belongs. |
description (Optional) | body | string | The service description. |
Code | Reason |
---|---|
200 - OK |
Request was successful. |
Code | Reason |
---|---|
400 - Bad Request |
Some content in the request was invalid. |
401 - Unauthorized |
User must authenticate before making a request. |
403 - Forbidden |
Policy does not allow current user to do this operation. |
{
"links": {
"next": null,
"previous": null,
"self": "http://example.com/identity/v3/services"
},
"services": [
{
"description": "Nova Compute Service",
"enabled": true,
"id": "1999c3a858c7408fb586817620695098",
"links": {
"self": "http://example.com/identity/v3/services/1999c3a858c7408fb586817620695098"
},
"name": "nova",
"type": "compute"
},
{
"description": "Cinder Volume Service V2",
"enabled": true,
"id": "39216610e75547f1883037e11976fc0f",
"links": {
"self": "http://example.com/identity/v3/services/39216610e75547f1883037e11976fc0f"
},
"name": "cinderv2",
"type": "volumev2"
},
{
"description": "Neutron Service",
"enabled": true,
"id": "4fe41a27de3341af9100123f765eac0d",
"links": {
"self": "http://example.com/identity/v3/services/4fe41a27de3341af9100123f765eac0d"
},
"name": "neutron",
"type": "network"
},
{
"description": "EC2 Compatibility Layer",
"enabled": true,
"id": "61d3d05bdd1449f18923c83f52a4d762",
"links": {
"self": "http://example.com/identity/v3/services/61d3d05bdd1449f18923c83f52a4d762"
},
"name": "ec2",
"type": "ec2"
},
{
"description": "Glance Image Service",
"enabled": true,
"id": "69afa3d57d1948ea988beeb252bbaa5d",
"links": {
"self": "http://example.com/identity/v3/services/69afa3d57d1948ea988beeb252bbaa5d"
},
"name": "glance",
"type": "image"
},
{
"description": "Nova Compute Service V2.1",
"enabled": true,
"id": "79b691ee7be649d9bf8613efc0960206",
"links": {
"self": "http://example.com/identity/v3/services/79b691ee7be649d9bf8613efc0960206"
},
"name": "novav21",
"type": "computev21"
},
{
"description": "Swift Service",
"enabled": true,
"id": "92419b70ebe64c6c873bd20b14360e6b",
"links": {
"self": "http://example.com/identity/v3/services/92419b70ebe64c6c873bd20b14360e6b"
},
"name": "swift",
"type": "object-store"
},
{
"description": "Keystone Identity Service",
"enabled": true,
"id": "b8f8454fc07b46b781204d2a436f9d1c",
"links": {
"self": "http://example.com/identity/v3/services/b8f8454fc07b46b781204d2a436f9d1c"
},
"name": "keystone",
"type": "identity"
},
{
"description": "Cinder Volume Service",
"enabled": true,
"id": "cdda3bea0742407f95e70f4758f46558",
"links": {
"self": "http://example.com/identity/v3/services/cdda3bea0742407f95e70f4758f46558"
},
"name": "cinder",
"type": "volume"
}
]
}