This is a fork of MuXiu1997 repository. This fork is mostly fixing some of the security concerns I wanted to address. This will be kept synced with the main repo.
This is a Traefik middleware plugin that allows users to authenticate using GitHub OAuth.
The plugin is intended to be used as a replacement for the BasicAuth middleware,
providing a more secure way for users to access protected routes.
Create a GitHub OAuth App
http://<traefik-github-oauth-server-host>/oauth/redirect
Run the Traefik GitHub OAuth server
docker run -d --name traefik-github-oauth-server \--network <traefik-proxy-network> \-e 'GITHUB_OAUTH_CLIENT_ID=<client-id>' \-e 'GITHUB_OAUTH_CLIENT_SECRET=<client-secret>' \-e 'API_BASE_URL=http://<traefik-github-oauth-server-host>' \-l 'traefik.http.services.traefik-github-oauth-server.loadbalancer.server.port=80' \-l 'traefik.http.routers.traefik-github-oauth-server.rule=Host(`<traefik-github-oauth-server-host>`)' \luizfonseca/traefik-github-oauth-server
Install the Traefik GitHub OAuth plugin
Add this snippet in the Traefik Static configuration
experimental:plugins:github-oauth:moduleName: "github.com/luizfonseca/traefik-github-oauth-plugin"version: <version>
Run your App
docker run -d --whoami test \--network <traefik-proxy-network> \--label 'traefik.http.middlewares.whoami-github-oauth.plugin.github-oauth.apiBaseUrl=http://traefik-github-oauth-server' \--label 'traefik.http.middlewares.whoami-github-oauth.plugin.github-oauth.whitelist.logins[0]=luizfonseca' \--label 'traefik.http.middlewares.whoami-github-oauth.plugin.github-oauth.whitelist.teams[0]=827726' \--label 'traefik.http.routers.whoami.rule=Host(`whoami.example.com`)' \--label 'traefik.http.routers.whoami.middlewares=whoami-github-oauth' \traefik/whoami
Environment Variable | Description | Default | Required |
---|---|---|---|
GITHUB_OAUTH_CLIENT_ID | The GitHub OAuth App client id | Yes | |
GITHUB_OAUTH_CLIENT_SECRET | The GitHub OAuth App client secret | Yes | |
API_BASE_URL | The base URL of the Traefik GitHub OAuth server | Yes | |
API_SECRET_KEY | The api secret key. You can ignore this if you are using the internal network | No | |
SERVER_ADDRESS | The server address | :80 | No |
DEBUG_MODE | Enable debug mode and set log level to debug | false | No |
LOG_LEVEL | The log level, Available values: debug, info, warn, error | info | No |
# The base URL of the Traefik GitHub OAuth serverapiBaseUrl: http://<traefik-github-oauth-server-host># The api secret key. You can ignore this if you are using the internal networkapiSecretKey: optional_secret_key_if_not_on_the_internal_network# The path to redirect to after the user has authenticated, defaults to /_auth# Note: This path is not GitHub OAuth App's Authorization callback URLauthPath: /_auth# optional jwt secret key, if not set, the plugin will generate a random keyjwtSecretKey: optional_secret_key# The log level, defaults to info# Available values: debug, info, warn, errorlogLevel: info# whitelistwhitelist:# The list of GitHub user ids that are whitelisted to access the resourcesids:- 996# The list of GitHub user logins that are whitelisted to access the resourceslogins:- luizfonseca# The list of Github Teams that are whitelisted to access the resourcesteams:- 988772