examples: improve docs in README

Make the docs feel more like a tutorial and add some more context.
This commit is contained in:
Brandon Philips 2015-11-09 03:17:55 +01:00
parent 1ee7d6c5f4
commit 5dc95b20c7
2 changed files with 57 additions and 41 deletions

View file

@ -1,49 +1,60 @@
Running Examples # Running Examples
===
The quickest way to start experimenting with dex is to run a single dex-worker
locally, with an in-process database, and then interacting with it using the
example programs in this directory.
The quickest way to start experimenting with dex is to run a single dex-worker locally, with an in-process database, and then interact with it using the example programs in this directory.
## Build Everything and Start dex-worker ## Build Everything and Start dex-worker
This section is required for both the Example App and the Example CLI. First, build the example webapp client and example CLI client.
1. Build everything:
``` ```
./build ./build
``` ```
1. Copy the various example configurations. Now copy the example configurations into place to get dex configured.
You can customize these later but the defaults should work fine.
``` ```
cp static/fixtures/connectors.json.sample static/fixtures/connectors.json cp static/fixtures/connectors.json.sample static/fixtures/connectors.json
cp static/fixtures/users.json.sample static/fixtures/users.json cp static/fixtures/users.json.sample static/fixtures/users.json
cp static/fixtures/emailer.json.sample static/fixtures/emailer.json cp static/fixtures/emailer.json.sample static/fixtures/emailer.json
``` ```
1. Run dex_worker in local mode. With `dex-worker` configuration in place we can start dex in local mode.
``` ```
./bin/dex-worker --no-db & ./bin/dex-worker --no-db &
``` ```
## Example Webapp Client
## Example App Build and run the example app webserver by pointing the discovery URL to local Dex, and
1. Build and run example app webserver, pointing the discovery URL to local Dex, and
supplying the client information from `./static/fixtures/clients.json` into the flags. supplying the client information from `./static/fixtures/clients.json` into the flags.
``` ```
./bin/example-app --client-id=XXX --client-secret=secrete --discovery=http://127.0.0.1:5556 & ./bin/example-app \
--client-id=example-app \
--client-secret=example-app-secret \
--discovery=http://127.0.0.1:5556
``` ```
1. Navigate browser to `http://localhost:5555` and click "login" link Visit [http://localhost:5555](http://localhost:5555) in your browser and click "login" link.
1. Click "Login with Local" Next click "Login with Local" and enter the sample credentials from `static/fixtures/connectors.json`:
1. Enter in sample credentials from `static/fixtures/connectors.json`:
``` ```
email: elroy77@example.com email: elroy77@example.com
password: bones password: bones
``` ```
1. Observe user information in example app.
## Example CLI The example app will dump out details of the JWT issued by Dex which means that authentication was successful and the application has authenticated you as a valid user.
*TODO* You can play with adding additional users in connectors.json and users.json.
## Example CLI Client
The example CLI will start, connect to the Dex instance to gather discovery information, listen on `localhost:8000`, and then acquire a client credentials JWT and print it out.
```
./bin/example-cli \
--client-id example-cli
--client-secret examplie-cli-secret
--discovery=http://127.0.0.1:5556
```

View file

@ -5,8 +5,13 @@
"redirectURLs": ["http://127.0.0.1:5555/callback"] "redirectURLs": ["http://127.0.0.1:5555/callback"]
}, },
{ {
"id": "core-update", "id": "example-app",
"secret": "secrete", "secret": "example-app-secret",
"redirectURLs": ["http://127.0.0.1:5555/callback"]
},
{
"id": "example-cli",
"secret": "example-cli-secret",
"redirectURLs": ["http://127.0.0.1:8000/admin/v1/oauth/login"] "redirectURLs": ["http://127.0.0.1:8000/admin/v1/oauth/login"]
}, },
{ {