Role restriction

Role restriction

Role restriction can be used to specify conditions under which a role should be effective. When conditions are not met, the role will be disabled, which will result in access being denied. Not specifying restriction means the role is not restricted and thus always effective. This is the default behaviour.

Currently, the role restriction is only supported for API keys, with limitation that the API key can only have a single role descriptor.

Workflows

Workflows allow to restrict the role to be effective exclusively when calling certain REST APIs. Calling a REST API that is not allowed by a workflow, will result in the role being disabled. The below section lists workflows that you can restrict the role to:

search_application_query

This workflow restricts the role to the Search Application Search API only.

Workflow names are case-sensitive.

Examples

The following example creates an API key with a restriction to the search_application_query workflow, which allows to call only Search Application Search API:

  1. resp = client.security.create_api_key(
  2. name="my-restricted-api-key",
  3. role_descriptors={
  4. "my-restricted-role-descriptor": {
  5. "indices": [
  6. {
  7. "names": [
  8. "my-search-app"
  9. ],
  10. "privileges": [
  11. "read"
  12. ]
  13. }
  14. ],
  15. "restriction": {
  16. "workflows": [
  17. "search_application_query"
  18. ]
  19. }
  20. }
  21. },
  22. )
  23. print(resp)
  1. const response = await client.security.createApiKey({
  2. name: "my-restricted-api-key",
  3. role_descriptors: {
  4. "my-restricted-role-descriptor": {
  5. indices: [
  6. {
  7. names: ["my-search-app"],
  8. privileges: ["read"],
  9. },
  10. ],
  11. restriction: {
  12. workflows: ["search_application_query"],
  13. },
  14. },
  15. },
  16. });
  17. console.log(response);
  1. POST /_security/api_key
  2. {
  3. "name": "my-restricted-api-key",
  4. "role_descriptors": {
  5. "my-restricted-role-descriptor": {
  6. "indices": [
  7. {
  8. "names": ["my-search-app"],
  9. "privileges": ["read"]
  10. }
  11. ],
  12. "restriction": {
  13. "workflows": ["search_application_query"]
  14. }
  15. }
  16. }
  17. }