See our launch blog post for more information!
sso — lovingly known as the S.S. Octopus or octoboi — is the authentication and authorization system BuzzFeed developed to provide a secure, single sign-on experience for access to the many internal web apps used by our employees.
It depends on Google as its authoritative OAuth2 provider, and authenticates users against a specific email domain. Further authorization based on Google Group membership can be required on a per-upstream basis.
The main idea behind sso is a "double OAuth2" flow, where sso-auth is the
OAuth2 provider for sso-proxy and Google is the OAuth2 provider for sso-auth.
In a nutshell:
- If a user visits an sso-proxy-protected service (foo.sso.example.com) and does not have a session cookie, they are redirected tosso-auth(sso-auth.example.com).- If the user does not have a session cookie for sso-auth, they are prompted to log in via the usual Google OAuth2 flow, and then redirected back tosso-proxywhere they will now be logged in (tofoo.sso.example.com)
- If the user does have a session cookie for sso-auth(e.g. they have already logged intobar.sso.example.com), they are transparently redirected back toproxywhere they will be logged in, without needing to go through the Google OAuth2 flow
 
- If the user does not have a session cookie for 
- sso-proxytransparently re-validates & refreshes the user's session with- sso-auth
- Prebuilt binary releases
- Docker
- go get github.com/buzzfeed/sso/cmd/...
Follow our Quickstart guide to spin up a local deployment of sso to get a feel for how it works!
Help us keep sso open and inclusive. Please read and follow our Code of Conduct.
Contributions to sso are welcome! Please follow our contribution guideline.
Please file any issues you find in our issue tracker.
If you come across any security vulnerabilities with the sso repo or software, please email security@buzzfeed.com. In your email, please request access to our bug bounty program so we can compensate you for any valid issues reported.
sso is actively maintained by the BuzzFeed Infrastructure teams.
