No description
Find a file
Bobby Rullo ca18efb1fe client: load full clients w/ LoadableClient
The Client object on its own doesn't fully express everything about a
single client, and so when loading clients from a static configuration
it's not enough to just (de)serialize clients.

To that end, LoadableClient contains the full representation of a client
and associated entities.
2016-06-08 11:31:50 -07:00
admin admin: add trustedPeers bootstrap api 2016-06-07 17:16:11 -07:00
client client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
cmd db, client: add data model for trusted peers 2016-06-07 17:16:09 -07:00
connector Implement connection pooling for LDAP connections 2016-06-03 11:04:58 +02:00
contrib contrib/k8s: YAML brevity via references, add min. resource requests 2016-04-21 15:50:26 -07:00
db client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
Documentation Implement connection pooling for LDAP connections 2016-06-03 11:04:58 +02:00
email email: templatizer takes global context. 2015-10-30 14:53:52 -07:00
examples Improved error message when TLS config is specified, but listen/redirect URL are using wrong scheme 2016-06-03 20:04:13 -04:00
functional client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
integration client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
pkg *: remove unused code 2016-02-29 11:29:36 -08:00
refresh *: Client Repo now deals with custom Client object 2016-04-20 14:31:27 -07:00
repo *: remove in memory user repo 2016-02-12 13:19:05 -08:00
schema workerschema: move Client.Revoke to RefreshClient 2016-06-07 17:16:11 -07:00
scope server: CodeToken now does Cross-Client auth 2016-06-07 17:22:41 -07:00
server client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
session server: CodeToken now does Cross-Client auth 2016-06-07 17:22:41 -07:00
static examples: add sample for clients 2016-05-18 18:18:20 -07:00
user client: load full clients w/ LoadableClient 2016-06-08 11:31:50 -07:00
vendor vendor: update go-oidc 2016-05-27 00:22:27 +02:00
.gitignore examples: add sample for clients 2016-05-18 18:18:20 -07:00
.travis.yml *: Update Go versions used for Travis tests and test tip 2016-06-03 10:56:03 -07:00
build *: fix release script 2016-03-02 12:41:24 -08:00
build-docker allow local image building without pushing 2016-05-04 14:17:03 +02:00
CONTRIBUTING.md Create a proposal template. (#423) 2016-05-06 12:00:57 -07:00
cover *: move original project to dex 2015-08-18 11:26:57 -07:00
DCO *: move original project to dex 2015-08-18 11:26:57 -07:00
Dockerfile Dockerfile: use right env var for email templates 2015-10-22 12:07:07 -07:00
env *: allow builds with development versions of Go 2016-06-03 11:19:19 -07:00
git-version fix/git-version: Update git-version to use valid docker tag if "dirty" 2016-04-21 17:00:26 -07:00
glide.lock vendor: Add golang.org/x/net/context 2016-06-03 11:00:29 +02:00
glide.yaml vendor: Add golang.org/x/net/context 2016-06-03 11:00:29 +02:00
go-docker use go 1.6.2 for docker go build 2016-05-04 20:19:52 +02:00
LICENSE *: move original project to dex 2015-08-18 11:26:57 -07:00
MAINTAINERS *: update MAINTAINERS 2016-01-08 14:54:39 -08:00
NOTICE *: move original project to dex 2015-08-18 11:26:57 -07:00
proposal_link Create a proposal template. (#423) 2016-05-06 12:00:57 -07:00
PROPOSAL_TEMPLATE.md Create a proposal template. (#423) 2016-05-06 12:00:57 -07:00
README.md README: add note about roadmap and google group 2016-02-10 09:52:05 -08:00
release *: fix release script 2016-03-02 12:41:24 -08:00
test test: alphabetize tests 2016-06-07 16:47:30 -07:00
test-functional functional: test sample clients file is valid 2016-06-07 16:47:29 -07:00

dex

Build Status Docker Repository on Quay.io GoDoc

dex is a federated identity management service. It provides OpenID Connect (OIDC) and OAuth 2.0 to users, and can proxy to multiple remote identity providers (IdP) to drive actual authentication, as well as managing local username/password credentials.

We named the project 'dex' because it is a central index of users that other pieces of software can authenticate against.

Architecture

dex consists of multiple components:

  • dex-worker is the primary server component of dex
    • host a user-facing API that drives the OIDC protocol
    • proxy to remote identity providers via "connectors"
    • provides an API for administrators to manage users.
  • dex-overlord is an auxiliary process responsible for various administrative tasks:
    • rotation of keys used by the workers to sign identity tokens
    • garbage collection of stale data in the database
    • provides an API for bootstrapping the system.
  • dexctl is a CLI tool used to manage a dex deployment
    • configure identity provider connectors
    • administer OIDC client identities
  • database; a database is used to for persistent storage for keys, users, OAuth sessions and other data. Currently Postgres (9.4+) is the only supported database.

A typical dex deployment consists of N dex-workers behind a load balanacer, and one dex-overlord. The dex-workers directly handle user requests, so the loss of all workers can result in service downtime. The single dex-overlord runs its tasks periodically, so it does not need to maintain 100% uptime.

Who Should Use Dex?

A non-exhaustive list of those who would benefit from using dex:

  • Those who want a language/framework-agnostic way to manage authentication.
  • Those who want to federate authentication from mutiple providers of differing types.
  • Those who want to manage user credentials (eg. username and password) and perform authentication locally
  • Those who want to create an OIDC Identity Provider for multiple clients to authenticate against.
  • Those who want any or all of the above in a Free and Open Source project.

Getting help with dex

  • For bugs and feature requests (including documentation!), file an issue.
  • For general discussion about both using and developing dex, join the dex-dev mailing list.
  • For more details on dex development plans, check out the roadmap.

Connectors

Remote IdPs could implement any auth-N protocol. Connectors contain protocol-specific logic and are used to communicate with remote IdPs. Possible examples of connectors could be: OIDC, LDAP, Local credentials, Basic Auth, etc.

dex ships with an OIDC connector, useful for authenticating with services like Google and Salesforce (or even other dex instances!) and a "local" connector, in which dex itself presents a UI for users to authenticate via dex-stored credentials.

Future connectors can be developed and added as future interoperability requirements emerge.

Relevant Specifications

These specs are referenced and implemented to some degree in the jose package of this project.

OpenID Connect (OIDC) is broken up into several specifications. The following (amongst others) are relevant:

Example OIDC Discovery Endpoints

Next steps:

If you want to try out dex quickly with a single process and no database (do not run this way in production!) take a look at the dev guide.

For running the full stack check out the getting started guide.

Coming Soon

  • Multiple backing Identity Providers
  • Identity Management
  • Authorization

Similar Software

Auth0

Auth0 is a commercial product which implements the OpenID Connect protocol and JWT. It comes with built-in support for 30+ social providers (and provide extenibility points to add customs); enterprise providers like ADFS, SiteMinder, Ping, Tivoli, or any SAML provider; LDAP/AD connectors that can be run behind firewalls via an open source agent/connector; built-in user/password stores with email and phone verification; legacy user/password stores running Mongo, PG, MySQL, SQL Server among others; multi-factor auth; passwordless support; custom extensibility of the auth pipeline through node.js and many other things.

You could chain dex with Auth0, dex as RP and Auth0 as OpenId Connect Provider, and bring to dex all the providers that comes in Auth0 plus the user management capabilities.

CloudFoundry UAA

The UAA is a multi tenant identity management service, used in Cloud Foundry, but also available as a stand alone OAuth2 server.

OmniAuth

OmniAuth provides authentication federation at the language (Ruby) level, with a wide range of integrations available.

Okta

Okta is a commercial product which is similar to dex in that for it too, identity federation is a key feature. It connects to many more authentication providers than dex, and also does the federation in the oppposite direction - it can be used as a SSO to other identity providers.

Shibboleth

Shibboleth is an open source system implementing the SAML standard, and can federate from a variety of backends, most notably LDAP.