Document level security

Document level security

Document level security restricts the documents that users have read access to. In particular, it restricts which documents can be accessed from document-based read APIs.

To enable document level security, you use a query to specify the documents that each role can access. The document query is associated with a particular data stream, index, or wildcard (*) pattern and operates in conjunction with the privileges specified for the data streams and indices.

The specified document query:

Omitting the query parameter entirely disables document level security for the respective indices permission entry.

The following role definition grants read access only to documents that belong to the click category within all the events-* data streams and indices:

  1. resp = client.security.put_role(
  2. name="click_role",
  3. indices=[
  4. {
  5. "names": [
  6. "events-*"
  7. ],
  8. "privileges": [
  9. "read"
  10. ],
  11. "query": "{\"match\": {\"category\": \"click\"}}"
  12. }
  13. ],
  14. )
  15. print(resp)
  1. const response = await client.security.putRole({
  2. name: "click_role",
  3. indices: [
  4. {
  5. names: ["events-*"],
  6. privileges: ["read"],
  7. query: '{"match": {"category": "click"}}',
  8. },
  9. ],
  10. });
  11. console.log(response);
  1. POST /_security/role/click_role
  2. {
  3. "indices": [
  4. {
  5. "names": [ "events-*" ],
  6. "privileges": [ "read" ],
  7. "query": "{\"match\": {\"category\": \"click\"}}"
  8. }
  9. ]
  10. }

You can write this same query using nested JSON syntax:

  1. resp = client.security.put_role(
  2. name="click_role",
  3. indices=[
  4. {
  5. "names": [
  6. "events-*"
  7. ],
  8. "privileges": [
  9. "read"
  10. ],
  11. "query": {
  12. "match": {
  13. "category": "click"
  14. }
  15. }
  16. }
  17. ],
  18. )
  19. print(resp)
  1. const response = await client.security.putRole({
  2. name: "click_role",
  3. indices: [
  4. {
  5. names: ["events-*"],
  6. privileges: ["read"],
  7. query: {
  8. match: {
  9. category: "click",
  10. },
  11. },
  12. },
  13. ],
  14. });
  15. console.log(response);
  1. POST _security/role/click_role
  2. {
  3. "indices": [
  4. {
  5. "names": [ "events-*" ],
  6. "privileges": [ "read" ],
  7. "query": {
  8. "match": {
  9. "category": "click"
  10. }
  11. }
  12. }
  13. ]
  14. }

The following role grants read access only to the documents whose department_id equals 12:

  1. resp = client.security.put_role(
  2. name="dept_role",
  3. indices=[
  4. {
  5. "names": [
  6. "*"
  7. ],
  8. "privileges": [
  9. "read"
  10. ],
  11. "query": {
  12. "term": {
  13. "department_id": 12
  14. }
  15. }
  16. }
  17. ],
  18. )
  19. print(resp)
  1. const response = await client.security.putRole({
  2. name: "dept_role",
  3. indices: [
  4. {
  5. names: ["*"],
  6. privileges: ["read"],
  7. query: {
  8. term: {
  9. department_id: 12,
  10. },
  11. },
  12. },
  13. ],
  14. });
  15. console.log(response);
  1. POST /_security/role/dept_role
  2. {
  3. "indices" : [
  4. {
  5. "names" : [ "*" ],
  6. "privileges" : [ "read" ],
  7. "query" : {
  8. "term" : { "department_id" : 12 }
  9. }
  10. }
  11. ]
  12. }