2020-05-26 20:53:10 +02:00
|
|
|
package upstream
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2021-03-06 19:27:16 +02:00
|
|
|
|
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/v7/pkg/apis/middleware"
|
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/v7/pkg/logger"
|
2020-05-26 20:53:10 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const defaultStaticResponseCode = 200
|
|
|
|
|
|
|
|
// newStaticResponseHandler creates a new staticResponseHandler that serves a
|
|
|
|
// a static response code.
|
|
|
|
func newStaticResponseHandler(upstream string, code *int) http.Handler {
|
|
|
|
return &staticResponseHandler{
|
2020-08-31 12:22:10 +02:00
|
|
|
code: derefStaticCode(code),
|
2020-05-26 20:53:10 +02:00
|
|
|
upstream: upstream,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// staticResponseHandler responds with a static response with the given response code.
|
|
|
|
type staticResponseHandler struct {
|
|
|
|
code int
|
|
|
|
upstream string
|
|
|
|
}
|
|
|
|
|
|
|
|
// ServeHTTP serves a static response.
|
|
|
|
func (s *staticResponseHandler) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
|
2021-03-06 19:27:16 +02:00
|
|
|
scope := middleware.GetRequestScope(req)
|
|
|
|
// If scope is nil, this will panic.
|
|
|
|
// A scope should always be injected before this handler is called.
|
|
|
|
scope.Upstream = s.upstream
|
|
|
|
|
2020-05-26 20:53:10 +02:00
|
|
|
rw.WriteHeader(s.code)
|
2021-03-06 19:27:16 +02:00
|
|
|
_, err := fmt.Fprintf(rw, "Authenticated")
|
|
|
|
if err != nil {
|
|
|
|
logger.Errorf("Error writing static response: %v", err)
|
|
|
|
}
|
2020-05-26 20:53:10 +02:00
|
|
|
}
|
2020-08-31 12:22:10 +02:00
|
|
|
|
|
|
|
// derefStaticCode returns the derefenced value, or the default if the value is nil
|
|
|
|
func derefStaticCode(code *int) int {
|
|
|
|
if code != nil {
|
|
|
|
return *code
|
|
|
|
}
|
|
|
|
return defaultStaticResponseCode
|
|
|
|
}
|