Skip to content

Commit

Permalink
Addresses PR feedback
Browse files Browse the repository at this point in the history
Signed-off-by: Darshit Chanpura <[email protected]>
  • Loading branch information
DarshitChanpura committed Jun 27, 2023
1 parent 66b8836 commit fbc179d
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 43 deletions.
144 changes: 103 additions & 41 deletions _security/access-control/api.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,34 +36,19 @@ plugins.security.restapi.endpoints_disabled.<role>.<endpoint>: ["<method>", ...]
```
{% include copy.html %}
You can also control access to specific rest APIs using roles. Here is an example list `cluster_permissions` that you can attach to a role which will allow access to all endpoints supported by this feature:
```yml
rest_api_admin_full_access:
reserved: true
cluster_permissions:
- 'restapi:admin/actiongroups'
- 'restapi:admin/allowlist'
- 'restapi:admin/internalusers'
- 'restapi:admin/nodesdn'
- 'restapi:admin/roles'
- 'restapi:admin/rolesmapping'
- 'restapi:admin/ssl/certs/info'
- 'restapi:admin/ssl/certs/reload'
- 'restapi:admin/tenants'
```
You can add/remove these as required to your role definition. It currently supports access control to these 9 endpoints:
```
/nodesdn
/allowlist
/actiongroups
/user
/internalusers
/roles
/rolesmapping
/ssl/certs/info
/ssl/certs/reload
/tenants
```
Roles also allow you to control access to specific REST APIs. You can add individual or multiple cluster permissions to a role and grant users access to associated APIs when they are mapped to the role. The following list of cluster permissions includes the endpoints that correspond to the Security REST APIs:
| **Permission** | **APIs Granted** | **Description** |
|:-------------------------------|:---------------------------------|:--------------------------------------------------------------------------------------------------------------------------------------------------|
| restapi:admin/actiongroups | `/actiongroup` & `/actiongroups` | Permission to get, delete, create, and patch actions groups (including bulk updates) |
| restapi:admin/allowlist | `/allowlist` | Permission to add any endpoints and HTTP requests to a list of allowed endpoints and requests. |
| restapi:admin/internalusers | `/internaluser` & `/user` | Permission to add, retrieve, modify and delete any user in the cluster |
| restapi:admin/nodesdn | `/nodesdn` | Permission to add, retrieve, update, or delete any distinguished names from an allow list and enable communication between clusters and/or nodes. |
| restapi:admin/roles | `/roles` | Permission to add, retrieve, modify and delete any roles in the cluster |
| restapi:admin/rolesmapping | `/rolesmapping` | Permission to add, retrieve, modify and delete any roles-mapping |
| restapi:admin/ssl/certs/info | `/ssl/certs/info` | Permission to view current Transport & HTTP certificates |
| restapi:admin/ssl/certs/reload | `/ssl/certs/reload` | Permission to view reload Transport & HTTP certificates |
| restapi:admin/tenants | `/tenants` | Permission to get, delete, create, and patch tenants |



Expand Down Expand Up @@ -179,20 +164,33 @@ Introduced 1.0

Changes the password for the current user.

#### Path and HTTP methods

#### Request
```json
PUT _plugins/_security/api/account
```
{% include copy-curl.html %}

#### Request fields

| Field | Data Type | Description | Required |
|:-------------------|:-----------|:-------------------------------|:----------|
| current_password | String | The current password. | Yes |
| password | String | The new password to set. | Yes |

##### Example request

```json
PUT _plugins/_security/api/account
{
"current_password" : "old-password",
"password" : "new-password"
"current_password": "old-password",
"password": "new-password"
}
```
{% include copy-curl.html %}


#### Example response
##### Example response

```json
{
Expand All @@ -201,6 +199,13 @@ PUT _plugins/_security/api/account
}
```

#### Response fields

| Field | Data Type | Description |
|:---------|:-----------|:------------------------------|
| status | String | The status of the operation. |
| message | String | A descriptive message. |


---

Expand Down Expand Up @@ -1370,10 +1375,29 @@ PUT _plugins/_security/api/nodesdn/<cluster-name>
```

### Update all distinguished names
#### Request

Bulk updates the given list of distinguished names.

#### Path and HTTP methods

```json
PATCH _plugins/_security/api/nodesdn
```
{% include copy-curl.html %}

#### Request fields

| Field | Data Type | Description | Required |
|:----------------|:-----------|:-------------------------------------------------------------------------------------------------------------------|:---------|
| op | string | The operation to perform on the action group. Possible values: `remove`,`add`, `replace`, `move`, `copy`, `test`. | Yes |
| path | string | The path to the resource. | Yes |
| value | array | The new value to replace the property's value with. | Yes |


##### Example request

```
PATCH _plugins/_security/api/nodesdn
[
{
"op":"remove",
Expand All @@ -1383,7 +1407,7 @@ PATCH _plugins/_security/api/nodesdn
```
{% include copy-curl.html %}
#### Example response
##### Example response
```json
{
Expand All @@ -1392,6 +1416,13 @@ PATCH _plugins/_security/api/nodesdn
}
```

#### Response fields

| Field | Data Type | Description |
|:--------|:----------|:---------------------|
| status | string | The response status. |
| message | string | Response message. |


### Delete distinguished names

Expand Down Expand Up @@ -1460,14 +1491,21 @@ GET _plugins/_security/api/ssl/certs

Reload transport layer communication certificates. These REST APIs let a super admin (or a user with sufficient permissions to access this API) reload transport layer certificates.

#### Request
#### Path and HTTP methods

```json
GET _opendistro/_security/api/ssl/transport/reloadcerts
PUT /_plugins/_security/api/ssl/transport/reloadcerts
```
{% include copy-curl.html %}

#### Example response
##### Example request

```bash
curl -X PUT "https://your-opensearch-cluster/_plugins/_security/api/ssl/transport/reloadcerts"
```
{% include copy-curl.html %}

##### Example response

```json
{
Expand All @@ -1476,25 +1514,49 @@ GET _opendistro/_security/api/ssl/transport/reloadcerts
}
```

### Reload http certificates
#### Response fields

| Field | Data Type | Description |
|:--------|:----------|:----------------------------------------------------------------------------------|
| status | string | Indicates the status of the operation. Possible values: "OK" or an error message. |
| message | string | Additional information about the operation. |


#### Reload HTTP certificates

Reload HTTP layer communication certificates. These REST APIs let a super admin (or a user with sufficient permissions to access this API) reload HTTP layer certificates.

#### Request
#### Path and HTTP methods

```json
GET _opendistro/_security/api/ssl/http/reloadcerts
PUT /_plugins/_security/api/ssl/http/reloadcerts
```
{% include copy-curl.html %}

#### Example response

##### Example request

```
curl -X PUT "https://your-opensearch-cluster/_plugins/_security/api/ssl/http/reloadcerts"
```
{% include copy-curl.html %}

##### Example response

```json
{
"status": "OK",
"message": "updated http certs"
}
```

#### Response fields

| Field | Data Type | Description |
|:--------|:----------|:--------------------------------------------------------------------|
| status | string | The status of the API operation. Possible value: "OK". |
| message | string | A message indicating that the HTTP certificates have been updated. |

---

## Cache
Expand Down
5 changes: 3 additions & 2 deletions _security/access-control/permissions.md
Original file line number Diff line number Diff line change
Expand Up @@ -395,10 +395,11 @@ These permissions apply to an index or index pattern. You might want a user to h
- indices:monitor/upgrade


## Rest Permissions
## Security REST permissions

These permissions apply to rest APIs to control access to the endpoints. Granting access to any of these will allow access to change the crucial operational components of Security plugin.
NOTE: Allowing access to these endpoints can trigger operational changes in the cluster. Proceed with caution.
Allowing access to these endpoints has the potential to trigger operational changes in the cluster. Proceed with caution.
{: .warning }

- restapi:admin/actiongroups
- restapi:admin/allowlist
Expand Down

0 comments on commit fbc179d

Please sign in to comment.