1
0
mirror of https://github.com/oauth2-proxy/oauth2-proxy.git synced 2025-01-10 04:18:14 +02:00
A reverse proxy that provides authentication with Google, Azure, OpenID Connect and many more identity providers.
Go to file
Mitsuo Heijo c7bfbdecef
Implement graceful shutdown and propagate request context (#468)
* feature: Implement graceful shutdown

Propagate the request context to the Redis client.
It is possible to propagate a context cancel to Redis client if the connection is closed by the HTTP client.
The redis.Cmdable cannot use WithContext, so added the Client interface to handle redis.Client and redis.ClusterClient transparently.

Added handling of Unix signals to http server.

Upgrade go-redis/redis to v7.

* Update dependencies

- Upgrade golang/x/* and google-api-go
- Migrate fsnotify import from gopkg.in to github.com
- Replace bmizerany/assert with stretchr/testify/assert

* add doc for  wrapper interface

* Update CHANGELOG.md

* fix: upgrade fsnotify to v1.4.9

* fix: remove unnessary logging

* fix: wait until  all connections have been closed

* refactor: move chan to main for testing

* add assert to check if stop chan is empty

* add an idiomatic for sync.WaitGroup with timeout
2020-04-04 16:12:38 +01:00
.github Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
contrib Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
docs Allow html in banner message (#462) 2020-04-04 15:01:11 +01:00
pkg Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
providers Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
.dockerignore Ignore Dockerfile.dev 2019-01-22 02:54:17 +09:00
.gitignore Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
.golangci.yml Remove TODO vetshadow as it's part of govet 2019-07-01 16:27:19 +01:00
.travis.yml Update Go and GolangCI-Lint 2020-03-29 13:17:54 +01:00
CHANGELOG.md Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
configure Update Go and GolangCI-Lint 2020-03-29 13:17:54 +01:00
CONTRIBUTING.md Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
dist.sh Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
Dockerfile Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
Dockerfile.arm64 Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
Dockerfile.armv6 Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
env_options_test.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
env_options.go Some code improvements 2019-10-09 15:44:26 +03:00
go.mod Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
go.sum Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
htpasswd_test.go Lint for non-comment linter errors 2018-11-29 14:26:41 +00:00
htpasswd.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
http_test.go Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
http.go Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
LICENSE add MIT license for google_auth_proxy 2014-06-09 16:25:26 -04:00
logging_handler_test.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
logging_handler.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
main.go Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00
MAINTAINERS Add MAINTAINERS and update CODEOWNERS 2019-07-23 16:20:45 +01:00
Makefile Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
nsswitch.conf Add nsswitch.conf to Docker image (#400) 2020-02-23 18:16:18 +00:00
oauthproxy_test.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
oauthproxy.go Allow html in banner message (#462) 2020-04-04 15:01:11 +01:00
options_test.go Support Go 1.14 (#419) 2020-03-14 10:14:15 +00:00
options.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
README.md Update changelog and readme to reflect migration 2020-03-29 16:24:41 +01:00
RELEASE.md Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
string_array.go Implement Getter interface for StringArray (#104) 2019-03-20 13:58:14 +00:00
templates_test.go Swap out bmizerany/assert package that is deprecated in favor of stretchr/testify/assert 2017-10-23 12:24:17 -04:00
templates.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
validator_test.go remove unnecessary validator tests (#288) 2019-10-18 08:49:33 -07:00
validator.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
version.go Introduce Makefile 2019-01-04 10:58:30 +00:00
watcher_unsupported.go Migrate to oauth2-proxy/oauth2-proxy 2020-03-29 15:40:10 +01:00
watcher.go Implement graceful shutdown and propagate request context (#468) 2020-04-04 16:12:38 +01:00

OAuth2 Proxy

Build Status Go Report Card GoDoc MIT licensed

A reverse proxy and static file server that provides authentication using Providers (Google, GitHub, and others) to validate accounts by email, domain or group.

Note: This repository was forked from bitly/OAuth2_Proxy on 27/11/2018. Versions v3.0.0 and up are from this fork and will have diverged from any changes in the original fork. A list of changes can be seen in the CHANGELOG.

Note: This project was formerly hosted as pusher/oauth2_proxy but has been renamed as of 29/03/2020 to oauth2-proxy/oauth2-proxy. Going forward, all images shall be available at quay.io/oauth2-proxy/oauth2-proxy and binaries wiil been named oauth2-proxy.

Sign In Page

Installation

  1. Choose how to deploy:

    a. Download Prebuilt Binary (current release is v5.1.0)

    b. Build with $ go get github.com/oauth2-proxy/oauth2-proxy which will put the binary in $GOROOT/bin

    c. Using the prebuilt docker image quay.io/oauth2-proxy/oauth2-proxy (AMD64, ARMv6 and ARM64 tags available)

Prebuilt binaries can be validated by extracting the file and verifying it against the sha256sum.txt checksum file provided for each release starting with version v3.0.0.

sha256sum -c sha256sum.txt 2>&1 | grep OK
oauth2-proxy-x.y.z.linux-amd64: OK
  1. Select a Provider and Register an OAuth Application with a Provider
  2. Configure OAuth2 Proxy using config file, command line options, or environment variables
  3. Configure SSL or Deploy behind a SSL endpoint (example provided for Nginx)

Security

If you are running a version older than v5.0.0 we strongly recommend you please update to a current version. RE: open redirect vulnverability

Docs

Read the docs on our Docs site.

OAuth2 Proxy Architecture

Getting Involved

If you would like to reach out to the maintainers, come talk to us in the #oauth2_proxy channel in the Gophers slack.

Contributing

Please see our Contributing guidelines. For releasing see our release creation guide.