forked from mystiq/dex
67 lines
2.6 KiB
Markdown
67 lines
2.6 KiB
Markdown
# Authentication through GitHub
|
|
|
|
## Overview
|
|
|
|
One of the login options for dex uses the GitHub OAuth2 flow to identify the end user through their GitHub account.
|
|
|
|
When a client redeems a refresh token through dex, dex will re-query GitHub to update user information in the ID Token. To do this, __dex stores a readonly GitHub access token in its backing datastore.__ Users that reject dex's access through GitHub will also revoke all dex clients which authenticated them through GitHub.
|
|
|
|
## Configuration
|
|
|
|
Register a new application with [GitHub][github-oauth2] ensuring the callback URL is `(dex issuer)/callback`. For example if dex is listening at the non-root path `https://auth.example.com/dex` the callback would be `https://auth.example.com/dex/callback`.
|
|
|
|
The following is an example of a configuration for `examples/config-dev.yaml`:
|
|
|
|
```yaml
|
|
connectors:
|
|
- type: github
|
|
# Required field for connector id.
|
|
id: github
|
|
# Required field for connector name.
|
|
name: GitHub
|
|
config:
|
|
# Credentials can be string literals or pulled from the environment.
|
|
clientID: $GITHUB_CLIENT_ID
|
|
clientSecret: $GITHUB_CLIENT_SECRET
|
|
redirectURI: http://127.0.0.1:5556/dex/callback
|
|
# Optional organization to pull teams from, communicate through the
|
|
# "groups" scope.
|
|
#
|
|
# NOTE: This is an EXPERIMENTAL config option and will likely change.
|
|
org: my-oranization
|
|
```
|
|
|
|
## GitHub Enterprise
|
|
|
|
Users can use their GitHub Enterprise account to login to dex. The following configuration can be used to enable a GitHub Enterprise connector on dex:
|
|
|
|
```yaml
|
|
connectors:
|
|
- type: github
|
|
# Required field for connector id.
|
|
id: github
|
|
# Required field for connector name.
|
|
name: GitHub
|
|
config:
|
|
# Required fields. Dex must be pre-registered with GitHub Enterprise
|
|
# to get the following values.
|
|
# Credentials can be string literals or pulled from the environment.
|
|
clientID: $GITHUB_CLIENT_ID
|
|
clientSecret: $GITHUB_CLIENT_SECRET
|
|
redirectURI: http://127.0.0.1:5556/dex/callback
|
|
# Optional organization to pull teams from, communicate through the
|
|
# "groups" scope.
|
|
#
|
|
# NOTE: This is an EXPERIMENTAL config option and will likely change.
|
|
org: my-oranization
|
|
|
|
# Required ONLY for GitHub Enterprise.
|
|
# This is the Hostname of the GitHub Enterprise account listed on the
|
|
# management console. Ensure this domain is routable on your network.
|
|
hostName: git.example.com
|
|
# ONLY for GitHub Enterprise. Optional field.
|
|
# Used to support self-signed or untrusted CA root certificates.
|
|
rootCA: /etc/dex/ca.crt
|
|
```
|
|
|
|
[github-oauth2]: https://github.com/settings/applications/new
|