Skip to content

Auth proxy using okta

Notifications You must be signed in to change notification settings

vhl/okta-auth-proxy

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Okta Auth Proxy

This is a fork of the original project that contains significant changes to its functionality. See the Git history for details.

The idea is that you run this along-side an nginx instance, and it'll handle authentication for you for an application or page that doesn't understand SAML or okta.

Configuration

Set the following environment variables

  • CALLBACK_URL: the callback url (https://$COOKIE_DOMAIN/auth/saml/callback)
  • SSO_TARGET_URL: the target url specified in okta
  • SSO_ISSUER: the accepted audience in okta
  • PROXY_TARGET: the address of the target application you are authing for
  • CERT_PATH: Path to the certificate provided by Okta
  • COOKIE_SECRET: a secure random secret for the cookie
  • COOKIE_DOMAIN: The domain to use for the cookie

If okta authentication succeeds, a cookie will be created and stored for the session. All requests are proxied through proxy target if authentication succeeds.

The proxy target should be set as an internal server in nginx, so that it can only be accessed through a local referral. See the example nginx configuration provided

The following variables are optional:

  • AUTH_DOMAIN: the local address of this authentication app (change if not 'localhost')
  • COOKIE_SECRET: a random secret will be generated at runtime if this is not set. If you need to avoid reauthenticating each time okta-auth-proxy is restarted for some reason, set this to a fixed value.
  • DEBUG: set this to anything to debug logging

Note: Ensure the protocol in okta matches the protocol of your app (http/https)

export SSO_TARGET_URL=https://company.okta.com/app/company_project_1/hXk5d47tkNkB0x7/sso/saml
export AUTH_DOMAIN=http://localhost:3311
export PROXY_TARGET=http://127.0.0.1:7000
bundle exec okta-auth-proxy serve

Credits

This was inspired by smashing the ideas from projects together:

About

Auth proxy using okta

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%