mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2025-12-31 01:10:20 -06:00
80 lines
2.0 KiB
Go
80 lines
2.0 KiB
Go
package middleware
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/opencloud-eu/opencloud/pkg/log"
|
|
"github.com/opencloud-eu/opencloud/pkg/oidc"
|
|
"github.com/opencloud-eu/opencloud/services/proxy/pkg/config"
|
|
"github.com/opencloud-eu/opencloud/services/proxy/pkg/proxy/policy"
|
|
"go.opentelemetry.io/otel/trace"
|
|
)
|
|
|
|
// SelectorCookie provides a middleware which
|
|
func SelectorCookie(optionSetters ...Option) func(next http.Handler) http.Handler {
|
|
options := newOptions(optionSetters...)
|
|
logger := options.Logger
|
|
policySelector := options.PolicySelector
|
|
tracer := getTraceProvider(options).Tracer("proxy.middleware.selector_cookie")
|
|
|
|
return func(next http.Handler) http.Handler {
|
|
return &selectorCookie{
|
|
next: next,
|
|
logger: logger,
|
|
tracer: tracer,
|
|
policySelector: policySelector,
|
|
}
|
|
}
|
|
}
|
|
|
|
type selectorCookie struct {
|
|
next http.Handler
|
|
logger log.Logger
|
|
tracer trace.Tracer
|
|
policySelector config.PolicySelector
|
|
}
|
|
|
|
func (m selectorCookie) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
|
ctx, span := m.tracer.Start(req.Context(), fmt.Sprintf("%s %s", req.Method, req.URL.Path), trace.WithSpanKind(trace.SpanKindServer))
|
|
req = req.WithContext(ctx)
|
|
defer span.End()
|
|
if m.policySelector.Regex == nil && m.policySelector.Claims == nil {
|
|
// only set selector cookie for regex and claim selectors
|
|
span.End()
|
|
m.next.ServeHTTP(w, req)
|
|
return
|
|
}
|
|
|
|
selectorCookieName := ""
|
|
if m.policySelector.Regex != nil {
|
|
selectorCookieName = m.policySelector.Regex.SelectorCookieName
|
|
} else if m.policySelector.Claims != nil {
|
|
selectorCookieName = m.policySelector.Claims.SelectorCookieName
|
|
}
|
|
|
|
// update cookie
|
|
if oidc.FromContext(req.Context()) != nil {
|
|
|
|
selectorFunc, err := policy.LoadSelector(&m.policySelector)
|
|
if err != nil {
|
|
m.logger.Err(err)
|
|
}
|
|
|
|
selector, err := selectorFunc(req)
|
|
if err != nil {
|
|
m.logger.Err(err)
|
|
}
|
|
|
|
cookie := http.Cookie{
|
|
Name: selectorCookieName,
|
|
Value: selector,
|
|
Path: "/",
|
|
}
|
|
http.SetCookie(w, &cookie)
|
|
}
|
|
|
|
defer span.End()
|
|
m.next.ServeHTTP(w, req)
|
|
}
|