Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding explanation for editing permissions 20230825 #6606

Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
b574c9e
adding explination for editing permissions
leanneeliatra Mar 6, 2024
3f32e80
changed to a h3 to see if review dog will accept
leanneeliatra Mar 6, 2024
289943a
Update _security/access-control/document-level-security.md
leanneeliatra Mar 7, 2024
7195c42
Update _security/access-control/document-level-security.md
leanneeliatra Mar 7, 2024
a918857
Update _security/access-control/document-level-security.md
leanneeliatra Mar 7, 2024
5c88efa
Update _security/access-control/document-level-security.md
leanneeliatra Mar 11, 2024
b05db06
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 13, 2024
97ba3c9
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 15, 2024
e839012
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 19, 2024
9dde189
Updates to both the users roles and DLS sections to reflect need to a…
leanneeliatra Mar 19, 2024
7a29048
updating after reviewdog comments
leanneeliatra Mar 19, 2024
2864a8d
updating roles in OpenSearch updates
leanneeliatra Mar 19, 2024
7bfc487
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 20, 2024
0340211
Merge branch 'main' into 20230825-edit-document-level-permissions
Naarcha-AWS Mar 21, 2024
a33218b
Apply suggestions from code review
leanneeliatra Mar 22, 2024
09a6e06
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 22, 2024
c4cca6b
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 26, 2024
c4f265e
Apply suggestions from code review
Naarcha-AWS Mar 26, 2024
cb681ae
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 27, 2024
af79721
Apply suggestions from code review
Naarcha-AWS Mar 27, 2024
24afe20
Update document-level-security.md
Naarcha-AWS Mar 27, 2024
415786f
Update _security/access-control/document-level-security.md
leanneeliatra Mar 27, 2024
6afb195
Merge branch 'main' into 20230825-edit-document-level-permissions
leanneeliatra Mar 27, 2024
06065f6
Merge branch 'main' into 20230825-edit-document-level-permissions
Naarcha-AWS Mar 28, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
51 changes: 27 additions & 24 deletions _security/access-control/document-level-security.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,30 +10,33 @@ redirect_from:

# Document-level security (DLS)

Document-level security lets you restrict a role to a subset of documents in an index. The easiest way to get started with document- and field-level security is to open OpenSearch Dashboards and choose **Security**. Then choose **Roles**, create a new role, and review the **Index permissions** section.

![Document- and field-level security screen in OpenSearch Dashboards]({{site.url}}{{site.baseurl}}/images/security-dls.png)


## Simple roles

Document-level security uses the OpenSearch query DSL to define which documents a role grants access to. In OpenSearch Dashboards, choose an index pattern and provide a query in the **Document level security** section:

```json
{
"bool": {
"must": {
"match": {
"genres": "Comedy"
}
}
}
}
```

This query specifies that for the role to have access to a document, its `genres` field must include `Comedy`.

A typical request to the `_search` API includes `{ "query": { ... } }` around the query, but in this case, you only need to specify the query itself.
Document-level security lets you restrict a role to a subset of documents in an index.
For more information about users and roles in OpenSearch, see the [documentation](https://opensearch.org/docs/latest/security/access-control/users-roles/#create-roles).
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What documentation, specifically?


Use the following steps to get started with document-level and field-level security:
1. Open OpenSearch Dashboards.
2. Choose **Security** > **Roles**
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
3. Select **Create Role** and provide a name for the role.
4. Review the **Index permissions** section and any necessary [index permissions](https://opensearch.org/docs/latest/security/access-control/permissions/) for the role.
5. Add document-level security with the addition of a DSL query inside the `Document level security - optional` section. A typical request to the `_search` API includes the `{ "query": { ... } }` around the query, but when Document-level security in OpenSearch Dashboards, you only need to specify the query itself. For example, the following DSL query specifies that for the new role to have access to a document, the query's `genres` field must include `Comedy`:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should DSL be defined on first appearance?

- For example, the following DSL could be added in the `Document level security - optional` text box.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
- This query specifies that for the role to have access to a document, its `genres` field must include `Comedy`
- A typical request to the `_search` API includes `{ "query": { ... } }` around the query, but in this case, you only need to specify the query itself.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not following this bulleted list. It appears to contain content duplicated from above, and the structure doesn't work in terms of introducing the query.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
- A typical request to the `_search` API includes `{ "query": { ... } }` around the query, but in this case, you only need to specify the query itself.
- A typical request to the `_search` API includes `{ "query": { ... } }` around the query, but, in this case, you only need to specify the query itself.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can likely just remove this bulleted list.

```json
{
"bool": {
"must": {
"match": {
"genres": "Comedy"
}
}
}
}
```

- ![Document- and field-level security screen in OpenSearch Dashboards]({{site.url}}{{site.baseurl}}/images/security-dls.png)
leanneeliatra marked this conversation as resolved.
Show resolved Hide resolved

## Updating roles by accessing the Rest API
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

In the REST API, you provide the query as a string, so you must escape your quotes. This role allows a user to read any document in any index with the field `public` set to `true`:

Expand Down
35 changes: 35 additions & 0 deletions _security/access-control/users-roles.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,23 @@ The Security plugin includes an internal user database. Use this database in pla

Roles are the core way of controlling access to your cluster. Roles contain any combination of cluster-wide permissions, index-specific permissions, document- and field-level security, and tenants. Then you map users to these roles so that users gain those permissions.

## Creating and editing OpenSearch roles

OpenSearch can be updated using one of the following methods:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### Using the API

You can make HTTP requests to endpoints provided by OpenSearch to update security roles, permissions, and associated settings. This method offers granular control and automation capabilities for managing roles.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### Using the UI (OpenSearch Dashboards)

OpenSearch Dashboards provides a user-friendly interface for managing roles. Navigate to the Security section within OpenSearch Dashboards where the roles, permissions, and document-level security settings are configured. When updating the roles using the UI, OpenSearch Dashboards calls the API in the background to implement these changes.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Changed the second sentence to a narrative structure (rather than an instruction) for consistency.


### Editing the `roles.yml` file
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

If you using OpenSearch and want more granular control security configuration, you can edit roles and their associated permissions inside the `roles.yml` file. This method provides direct access to the underlying configuration and can be version-controlled for use in collaborative development environments.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Confirm that my changes retain the intended meaning.

For more information about creating roles, see the [Create Roles documentation][https://opensearch.org/docs/latest/security/access-control/users-roles/#create-roles).
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

Unless you need to create new [reserved or hidden users]({{site.url}}{{site.baseurl}}/security/access-control/api/#reserved-and-hidden-resources), we **highly** recommend using OpenSearch Dashboards or the REST API to create new users, roles, and role mappings. The `.yml` files are for initial setup, not ongoing use.
{: .warning }

Expand Down Expand Up @@ -75,6 +92,24 @@ See [YAML files]({{site.url}}{{site.baseurl}}/security/configuration/yaml/#roles

See [Create role]({{site.url}}{{site.baseurl}}/security/access-control/api/#create-role).

## Edit roles
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

You can edit roles using one of the following methods:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### OpenSearch Dashboards

1. Choose **Security** > **Roles**. Under the **Create role** section, select **Explore existing roles**.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
1. Select the role you would like to edit.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
1. Choose **edit role** on the upper right. Make any updates you need to the role.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Clarify: "on the upper right of the screen"?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
1. To save your changes, select **Update**.

### roles.yml

See [YAML files]({{site.url}}{{site.baseurl}}/security/configuration/yaml/#rolesyml).

### REST API

See [Create role]({{site.url}}{{site.baseurl}}/security/access-control/api/#create-role).

## Map users to roles

Expand Down
Loading