From 2e8fc6ebfe99ef54e307f8df8ae77f0f1d40aba4 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Fri, 10 Jul 2020 09:07:12 -0700 Subject: [PATCH] cleanup STS docs (#10003) --- docs/sts/README.md | 55 ++++++++++++++++++----- docs/sts/assume-role.md | 10 ++++- docs/sts/client-grants.md | 9 +++- docs/sts/docker-compose.yml | 17 ------- docs/sts/keycloak.md | 61 +++++++++++++++++-------- docs/sts/ldap.md | 16 ++++--- docs/sts/opa.md | 88 ------------------------------------- docs/sts/putobject.rego | 10 ----- docs/sts/web-identity.md | 20 +++++---- 9 files changed, 123 insertions(+), 163 deletions(-) delete mode 100644 docs/sts/docker-compose.yml delete mode 100644 docs/sts/opa.md delete mode 100644 docs/sts/putobject.rego diff --git a/docs/sts/README.md b/docs/sts/README.md index 8a8a7c0e1..f5436880f 100644 --- a/docs/sts/README.md +++ b/docs/sts/README.md @@ -18,16 +18,28 @@ Following are advantages for using temporary credentials: | [**AssumeRole**](https://github.com/minio/minio/blob/master/docs/sts/assume-role.md) | Let MinIO users request temporary credentials using user access and secret keys. | | [**AD/LDAP**](https://github.com/minio/minio/blob/master/docs/sts/ldap.md) | Let AD/LDAP users request temporary credentials using AD/LDAP username and password. | +### Understanding JWT Claims +> NOTE: JWT claims are only meant for WebIdentity and ClientGrants. +> AssumeRole or LDAP users can skip the entire portion and directly visit one of the links below. +> - [**AssumeRole**](https://github.com/minio/minio/blob/master/docs/sts/assume-role.md) +> - [**AD/LDAP**](https://github.com/minio/minio/blob/master/docs/sts/ldap.md) + +The access token received is a signed JSON Web Token (JWT). Use a JWT decoder to decode the access token to access the payload of the token that includes following JWT claims, `policy` claim is mandatory and should be present as part of your JWT claim. Without this claim the generated credentials will not have access to any resources on the server, using these credentials application would receive 'Access Denied' errors. + +| Claim Name | Type | Claim Value | +|:----------:|:-------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------:| +| policy | _string_ or _[]string_ or _comma_separated_value_ | Canned policy name to be applied for STS credentials. (Mandatory) - This can be configured to any desired value such as `roles` or `groups` by setting the environment variable `MINIO_IDENTITY_OPENID_CLAIM_NAME` | + ## Get started In this document we will explain in detail on how to configure all the prerequisites. > NOTE: If you are interested in AssumeRole API only, skip to [here](https://github.com/minio/minio/blob/master/docs/sts/assume-role.md) -### 1. Prerequisites +### Prerequisites - [Configuring keycloak](https://github.com/minio/minio/blob/master/docs/sts/keycloak.md) - [Configuring etcd (optional needed only in gateway or federation mode)](https://github.com/minio/minio/blob/master/docs/sts/etcd.md) -### 2. Setup MinIO with Keycloak +### Setup MinIO with Keycloak Make sure we have followed the previous step and configured each software independently, once done we can now proceed to use MinIO STS API and MinIO server to use these credentials to perform object API operations. ``` @@ -38,7 +50,7 @@ export MINIO_IDENTITY_OPENID_CLIENT_ID="843351d4-1080-11ea-aa20-271ecba3924a" minio server /mnt/data ``` -### 3. Setup MinIO Gateway with Keycloak and Etcd +### Setup MinIO Gateway with Keycloak and Etcd Make sure we have followed the previous step and configured each software independently, once done we can now proceed to use MinIO STS API and MinIO gateway to use these credentials to perform object API operations. > NOTE: MinIO gateway requires etcd to be configured to use STS API. @@ -52,21 +64,42 @@ export MINIO_ETCD_ENDPOINTS=http://localhost:2379 minio gateway s3 ``` -### 4. Test using client-grants.go -On another terminal run `client-grants.go` a sample client application which obtains JWT access tokens from an identity provider, in our case its Keycloak. Uses the returned access token response to get new temporary credentials from the MinIO server using the STS API call `AssumeRoleWithClientGrants`. +### Using WebIdentiy API +On another terminal run `web-identity.go` a sample client application which obtains JWT access tokens from an identity provider, in our case its Keycloak. Uses the returned access token response to get new temporary credentials from the MinIO server using the STS API call `AssumeRoleWithWebIdentity`. ``` -go run client-grants.go -cid PoEgXP6uVO45IsENRngDXj5Au5Ya -csec eKsw6z8CtOJVBtrOWvhRWL4TUCga +$ go run docs/sts/web-identity.go -cid account -csec 072e7f00-4289-469c-9ab2-bbe843c7f5a8 -config-ep "http://localhost:8080/auth/realms/demo/.well-known/openid-configuration" -port 8888 +2018/12/26 17:49:36 listening on http://localhost:8888/ +``` -##### Credentials +This will open the login page of keycloak, upon successful login, STS credentials along with any buckets discovered using the credentials will be printed on the screen, for example: + +``` { - "accessKey": "NUIBORZYTV2HG2BMRSXR", - "secretKey": "qQlP5O7CFPc5m5IXf1vYhuVTFj7BRVJqh0FqZ86S", - "expiration": "2018-08-21T17:10:29-07:00", - "sessionToken": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3NLZXkiOiJOVUlCT1JaWVRWMkhHMkJNUlNYUiIsImF1ZCI6IlBvRWdYUDZ1Vk80NUlzRU5SbmdEWGo1QXU1WWEiLCJhenAiOiJQb0VnWFA2dVZPNDVJc0VOUm5nRFhqNUF1NVlhIiwiZXhwIjoxNTM0ODk2NjI5LCJpYXQiOjE1MzQ4OTMwMjksImlzcyI6Imh0dHBzOi8vbG9jYWxob3N0Ojk0NDMvb2F1dGgyL3Rva2VuIiwianRpIjoiNjY2OTZjZTctN2U1Ny00ZjU5LWI0MWQtM2E1YTMzZGZiNjA4In0.eJONnVaSVHypiXKEARSMnSKgr-2mlC2Sr4fEGJitLcJF_at3LeNdTHv0_oHsv6ZZA3zueVGgFlVXMlREgr9LXA" + "buckets": [ + "bucket-x" + ], + "credentials": { + "AccessKeyID": "6N2BALX7ELO827DXS3GK", + "SecretAccessKey": "23JKqAD+um8ObHqzfIh+bfqwG9V8qs9tFY6MqeFR+xxx", + "SessionToken": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3NLZXkiOiI2TjJCQUxYN0VMTzgyN0RYUzNHSyIsImFjciI6IjAiLCJhdWQiOiJhY2NvdW50IiwiYXV0aF90aW1lIjoxNTY5OTEwNTUyLCJhenAiOiJhY2NvdW50IiwiZW1haWxfdmVyaWZpZWQiOmZhbHNlLCJleHAiOjE1Njk5MTQ1NTQsImlhdCI6MTU2OTkxMDk1NCwiaXNzIjoiaHR0cDovL2xvY2FsaG9zdDo4MDgxL2F1dGgvcmVhbG1zL2RlbW8iLCJqdGkiOiJkOTk4YTBlZS01NDk2LTQ4OWYtYWJlMi00ZWE5MjJiZDlhYWYiLCJuYmYiOjAsInBvbGljeSI6InJlYWR3cml0ZSIsInByZWZlcnJlZF91c2VybmFtZSI6Im5ld3VzZXIxIiwic2Vzc2lvbl9zdGF0ZSI6IjJiYTAyYTI2LWE5MTUtNDUxNC04M2M1LWE0YjgwYjc4ZTgxNyIsInN1YiI6IjY4ZmMzODVhLTA5MjItNGQyMS04N2U5LTZkZTdhYjA3Njc2NSIsInR5cCI6IklEIn0._UG_-ZHgwdRnsp0gFdwChb7VlbPs-Gr_RNUz9EV7TggCD59qjCFAKjNrVHfOSVkKvYEMe0PvwfRKjnJl3A_mBA"", + "SignerType": 1 + } } ``` +> NOTE: You can use the `-cscopes` parameter to restrict the requested scopes, for example to `"openid,policy_role_attribute"`, being `policy_role_attribute` a client_scope / client_mapper that maps a role attribute called policy to a `policy` claim returned by Keycloak. + +These credentials can now be used to perform MinIO API operations. + +### Using MinIO Browser + +- Open MinIO URL on the browser, lets say http://localhost:9000 +- Click on `Log in with OpenID` +- Provide `Client ID` and press ENTER, if `client_id` is already configured for MinIO this page will automatically redirect to Keycloak user login page. +- User will be redirected to the Keycloak user login page, upon successful login the user will be redirected to MinIO page and logged in automatically, + the user should see now the buckets and objects they have access to. + ## Explore Further - [MinIO Admin Complete Guide](https://docs.min.io/docs/minio-admin-complete-guide.html) - [The MinIO documentation website](https://docs.min.io) diff --git a/docs/sts/assume-role.md b/docs/sts/assume-role.md index 0e24aa0d9..a72373cbc 100644 --- a/docs/sts/assume-role.md +++ b/docs/sts/assume-role.md @@ -12,8 +12,10 @@ - [Errors](#errors) - [Sample `POST` Request](#sample-post-request) - [Sample Response](#sample-response) -- [Testing](#testing) +- [Using AssumeRole API](#using-assumerole-api) +- [Explore Further](#explore-further) + ## Introduction @@ -87,7 +89,7 @@ http://minio:9000/?Action=AssumeRole&DurationSeconds=3600&Version=2011-06-15&Pol ``` -## Testing +## Using AssumeRole API ``` $ export MINIO_ACCESS_KEY=minio $ export MINIO_SECRET_KEY=minio123 @@ -122,3 +124,7 @@ $ aws --profile foobar --endpoint-url http://localhost:9000 sts assume-role --po } } ``` + +## Explore Further +- [MinIO Admin Complete Guide](https://docs.min.io/docs/minio-admin-complete-guide.html) +- [The MinIO documentation website](https://docs.min.io) diff --git a/docs/sts/client-grants.md b/docs/sts/client-grants.md index d944f2ee7..6cd0d69e3 100644 --- a/docs/sts/client-grants.md +++ b/docs/sts/client-grants.md @@ -12,7 +12,8 @@ - [Errors](#errors) - [Sample `POST` Request](#sample-post-request) - [Sample Response](#sample-response) -- [Testing](#testing) +- [Using ClientGrants API](#using-clientgrants-api) +- [Explore Further](#explore-further) ## Introduction @@ -89,7 +90,7 @@ http://minio.cluster:9000?Action=AssumeRoleWithClientGrants&DurationSeconds=3600 ``` -## Testing +## Using ClientGrants API ``` export MINIO_ACCESS_KEY=minio export MINIO_SECRET_KEY=minio123 @@ -112,3 +113,7 @@ $ go run client-grants.go -cid PoEgXP6uVO45IsENRngDXj5Au5Ya -csec eKsw6z8CtOJVBt "sessionToken": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3NLZXkiOiJOVUlCT1JaWVRWMkhHMkJNUlNYUiIsImF1ZCI6IlBvRWdYUDZ1Vk80NUlzRU5SbmdEWGo1QXU1WWEiLCJhenAiOiJQb0VnWFA2dVZPNDVJc0VOUm5nRFhqNUF1NVlhIiwiZXhwIjoxNTM0ODk2NjI5LCJpYXQiOjE1MzQ4OTMwMjksImlzcyI6Imh0dHBzOi8vbG9jYWxob3N0Ojk0NDMvb2F1dGgyL3Rva2VuIiwianRpIjoiNjY2OTZjZTctN2U1Ny00ZjU5LWI0MWQtM2E1YTMzZGZiNjA4In0.eJONnVaSVHypiXKEARSMnSKgr-2mlC2Sr4fEGJitLcJF_at3LeNdTHv0_oHsv6ZZA3zueVGgFlVXMlREgr9LXA" } ``` + +## Explore Further +- [MinIO Admin Complete Guide](https://docs.min.io/docs/minio-admin-complete-guide.html) +- [The MinIO documentation website](https://docs.min.io) diff --git a/docs/sts/docker-compose.yml b/docs/sts/docker-compose.yml deleted file mode 100644 index cac4c24e5..000000000 --- a/docs/sts/docker-compose.yml +++ /dev/null @@ -1,17 +0,0 @@ -version: '2' -services: - opa: - image: openpolicyagent/opa:0.11.0 - ports: - - 8181:8181 - command: - - "run" - - "--server" - - "--log-level=debug" - api_server: - image: openpolicyagent/demo-restful-api:0.2 - ports: - - 5000:5000 - environment: - - OPA_ADDR=http://opa:8181 - - POLICY_PATH=/v1/data/httpapi/authz diff --git a/docs/sts/keycloak.md b/docs/sts/keycloak.md index 61b37e91a..ff03cbf74 100644 --- a/docs/sts/keycloak.md +++ b/docs/sts/keycloak.md @@ -1,20 +1,42 @@ # Keycloak Quickstart Guide [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io) -Keycloak is an open source Identity and Access Management solution aimed at modern applications and services, this document covers configuring Keycloak to be used as an identity provider for MinIO server STS API. +Keycloak is an open source Identity and Access Management solution aimed at modern applications and services, this document covers configuring Keycloak identity provider support with MinIO. -## 1. Prerequisites +## Prerequisites -- JAVA 1.8 and above installed -- Download and start Keycloak server by following the [installation guide](https://www.keycloak.org/docs/latest/getting_started/index.html) (finish upto section 3.4) +Configure and install keycloak server by following [Keycloak Installation Guide](https://www.keycloak.org/docs/latest/getting_started/index.html) (finish upto section 3.4) -## 2. Configure Keycloak -- Go to Clients -> Click on account -> Settings -> Enable `Implicit Flow`, then Save. -- Go to Users -> Click on the user -> Attribute, add a new attribute `Key` is `policy`, `Value` is name of the policy in minio (ex: `readwrite`). Click Add and then Save. -- Go to Clients -> Click on `account` -> Settings, set `Valid Redirect URIs` to `*`, expand `Advanced Settings` and set `Access Token Lifespan` to `1 Hours`, then Save. -- Go to Clients -> Client on `account` -> Mappers -> Create, `Name` can be any text, `Mapper Type` is `User Attribute`, `User Attribute` is `policy`, `Token Claim Name` is `policy`, `Claim JSON Type` is `string`, then Save. -- Open http://localhost:8080/auth/realms/demo/.well-known/openid-configuration and see if it has `authorization_endpoint` and `jwks_uri` +### Configure Keycloak UI +- Go to Clients + -> Click on account + -> Settings + -> Enable `Implicit Flow` + -> Save -## 3. Configure MinIO +- Go to Users + -> Click on the user + -> Attribute, add a new attribute `Key` is `policy`, `Value` is name of the `policy` on MinIO (ex: `readwrite`) + -> Add and Save + +- Go to Clients + -> Click on `account` + -> Settings, set `Valid Redirect URIs` to `*`, expand `Advanced Settings` and set `Access Token Lifespan` to `1 Hours` + -> Save + +- Go to Clients + -> Client on `account` + -> Mappers + -> Create + - `Name` with any text + - `Mapper Type` is `User Attribute` + - `User Attribute` is `policy` + - `Token Claim Name` is `policy` + - `Claim JSON Type` is `string` + -> Save + +- Open http://localhost:8080/auth/realms/demo/.well-known/openid-configuration to verify OpenID discovery document, verify it has `authorization_endpoint` and `jwks_uri` + +### Configure MinIO ``` $ export MINIO_ACCESS_KEY=minio $ export MINIO_SECRET_KEY=minio123 @@ -37,7 +59,7 @@ scopes (csv) Comma separated list of OpenID scopes for server, defa comment (sentence) optionally add a comment to this setting ``` -and for ENV based options +and ENV based options ``` mc admin config set myminio/ identity_openid --env @@ -57,14 +79,14 @@ Set `identity_openid` config with `config_url`, `client_id` and restart MinIO ``` ~ mc admin config set myminio identity_openid config_url="http://localhost:8080/auth/realms/demo/.well-known/openid-configuration" client_id="account" ``` -> Note: You can configure the `scopes` parameter to restrict the OpenID scopes requested by minio to the IdP, for example, `"openid,policy_role_attribute"`, being `policy_role_attribute` a client_scope / client_mapper that maps a role attribute called policy to a `policy` claim returned by Keycloak +> NOTE: You can configure the `scopes` parameter to restrict the OpenID scopes requested by minio to the IdP, for example, `"openid,policy_role_attribute"`, being `policy_role_attribute` a client_scope / client_mapper that maps a role attribute called policy to a `policy` claim returned by Keycloak Once successfully set restart the MinIO instance. ``` mc admin service restart myminio ``` -## 4. Using WebIdentiy API +### Using WebIdentiy API Client ID can be found by clicking any of the clients listed [here](http://localhost:8080/auth/admin/master/console/#/realms/demo/clients). If you have followed the above steps docs, the default Client ID will be `account`. ``` @@ -88,16 +110,17 @@ This will open the login page of keycloak, upon successful login, STS credential } ``` -> Note: You can use the `-cscopes` parameter to restrict the requested scopes, for example to `"openid,policy_role_attribute"`, being `policy_role_attribute` a client_scope / client_mapper that maps a role attribute called policy to a `policy` claim returned by Keycloak. +> NOTE: You can use the `-cscopes` parameter to restrict the requested scopes, for example to `"openid,policy_role_attribute"`, being `policy_role_attribute` a client_scope / client_mapper that maps a role attribute called policy to a `policy` claim returned by Keycloak. These credentials can now be used to perform MinIO API operations. -## 5. Using MinIO Browser +### Using MinIO Browser -- Open MinIO url on the browser, for example `http://localhost:9000` +- Open MinIO URL on the browser, lets say http://localhost:9000 - Click on `Log in with OpenID` -- Provide `Client ID` and press ENTER -- Now the user will be redirected to the Keycloak login page, upon successful login the user will be redirected to MinIO page and logged in automatically +- Provide `Client ID` and press ENTER, if `client_id` is already configured for MinIO this page will automatically redirect to Keycloak user login page. +- User will be redirected to the Keycloak user login page, upon successful login the user will be redirected to MinIO page and logged in automatically, + the user should see now the buckets and objects they have access to. ## Explore Further diff --git a/docs/sts/ldap.md b/docs/sts/ldap.md index ec14e6a5a..8f31f80ad 100644 --- a/docs/sts/ldap.md +++ b/docs/sts/ldap.md @@ -1,4 +1,4 @@ -# MinIO AD/LDAP Integration [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io) +# AssumeRoleWithLDAPIdentity [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io) **Table of Contents** @@ -15,9 +15,8 @@ - [Response Elements](#response-elements) - [Errors](#errors) - [Sample `POST` Request](#sample-post-request) -- [Sample Response](#sample-response) -- [Testing](#testing) - +- [Using LDAP STS API](#using-ldap-sts-api) +- [Explore Further](#explore-further) ## Introduction @@ -212,7 +211,7 @@ http://minio.cluster:9000?Action=AssumeRoleWithLDAPIdentity&LDAPUsername=foouser ``` -## Testing +## Using LDAP STS API With multiple OU hierarchies for users, and multiple group search base DN's. ``` @@ -237,3 +236,10 @@ $ go run ldap.go -u foouser -p foopassword "sessionToken": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3NLZXkiOiJOVUlCT1JaWVRWMkhHMkJNUlNYUiIsImF1ZCI6IlBvRWdYUDZ1Vk80NUlzRU5SbmdEWGo1QXU1WWEiLCJhenAiOiJQb0VnWFA2dVZPNDVJc0VOUm5nRFhqNUF1NVlhIiwiZXhwIjoxNTM0ODk2NjI5LCJpYXQiOjE1MzQ4OTMwMjksImlzcyI6Imh0dHBzOi8vbG9jYWxob3N0Ojk0NDMvb2F1dGgyL3Rva2VuIiwianRpIjoiNjY2OTZjZTctN2U1Ny00ZjU5LWI0MWQtM2E1YTMzZGZiNjA4In0.eJONnVaSVHypiXKEARSMnSKgr-2mlC2Sr4fEGJitLcJF_at3LeNdTHv0_oHsv6ZZA3zueVGgFlVXMlREgr9LXA" } ``` + +## Caveats +**LDAP STS credentials are not yet supported on MinIO Browser UI, we may add this feature in future releases.** + +## Explore Further +- [MinIO Admin Complete Guide](https://docs.min.io/docs/minio-admin-complete-guide.html) +- [The MinIO documentation website](https://docs.min.io) diff --git a/docs/sts/opa.md b/docs/sts/opa.md deleted file mode 100644 index ffc4f68b0..000000000 --- a/docs/sts/opa.md +++ /dev/null @@ -1,88 +0,0 @@ -**Using OPA is optional with MinIO. We recommend using [`policy` JWT claims](https://github.com/minio/minio/blob/master/docs/sts/wso2.md#4-jwt-claims) instead, let MinIO manage your policies using `mc admin policy` and apply them on the STS credentials.** - -# OPA Quickstart Guide [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io) -OPA is a lightweight general-purpose policy engine that can be co-located with MinIO server, in this document we talk about how to use OPA HTTP API to authorize MinIO STS credentials. - -## Get started -### 1. Prerequisites -- Docker 18.03 or above, refer here for [installation](https://docs.docker.com/install/). -- Docker compose 1.20 or above, refere here for [installation](https://docs.docker.com/compose/install/#prerequisites). - -### 2. Start OPA -First, create a `docker-compose.yml` file that runs OPA and the demo web server. -``` -cat >docker-compose.yml < putobject.rego < ``` -## Testing +## Using WebIdentity API ``` export MINIO_ACCESS_KEY=minio export MINIO_SECRET_KEY=minio123 @@ -114,7 +115,7 @@ $ go run web-identity.go -cid 204367807228-ok7601k6gj1pgge7m09h7d79co8p35xx.apps 2018/12/26 17:49:36 listening on http://localhost:8080/ ``` -Note: For a reasonable test outcome, make sure the assumed user has at least permission/policy to list all buckets. That policy would look like below: +> NOTE: for a reasonable test outcome, make sure the assumed user has at least permission/policy to list all buckets. That policy would look like below: ``` { "version": "2012-10-17", @@ -140,11 +141,8 @@ Note: For a reasonable test outcome, make sure the assumed user has at least per - Once obtained the JWT id_token is further sent to STS endpoint i.e MinIO to retrive temporary credentials. - Temporary credentials are displayed on the browser upon successful retrieval. - -## MinIO Browser -To support WebIdentity login on MinIO Browser - -- Set openid configuration and restart MinIO +## Using MinIO Browser +To support WebIdentity login on MinIO Browser, set openid configuration and restart MinIO ``` mc admin config set myminio identity_openid config_url="" client_id="" @@ -164,3 +162,7 @@ JWT token returned by the Identity Provider should include a custom claim for th - Enter the `Client ID` obtained from Identity Provider and press ENTER, if not you can set a `client_id` on server to avoid this step. - The user will be redirected to the Identity Provider login page - Upon successful login on Identity Provider page the user will be automatically logged into MinIO Browser + +## Explore Further +- [MinIO Admin Complete Guide](https://docs.min.io/docs/minio-admin-complete-guide.html) +- [The MinIO documentation website](https://docs.min.io)