mirror of
https://github.com/harness/drone.git
synced 2025-05-09 20:59:13 +08:00

This change introduces the concept of a principal (abstraction of call identity), and adds a new service account type principal. Also adds support for different tokens (session, PAT, SAT, OAuth2) and adds auth.Session which is being used to capture information about the caller and call method.
65 lines
1.8 KiB
Go
65 lines
1.8 KiB
Go
// Copyright 2021 Harness Inc. All rights reserved.
|
|
// Use of this source code is governed by the Polyform Free Trial License
|
|
// that can be found in the LICENSE.md file for this repository.
|
|
|
|
package authn
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/harness/gitness/internal/api/render"
|
|
"github.com/harness/gitness/internal/api/request"
|
|
"github.com/harness/gitness/internal/auth/authn"
|
|
|
|
"github.com/rs/zerolog"
|
|
"github.com/rs/zerolog/hlog"
|
|
)
|
|
|
|
// Attempt returns an http.HandlerFunc middleware that authenticates
|
|
// the http.Request if authentication payload is available.
|
|
func Attempt(authenticator authn.Authenticator) func(http.Handler) http.Handler {
|
|
return func(next http.Handler) http.Handler {
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
ctx := r.Context()
|
|
log := hlog.FromRequest(r)
|
|
|
|
session, err := authenticator.Authenticate(r)
|
|
|
|
if errors.Is(err, authn.ErrNoAuthData) {
|
|
// if there was no auth data in the request - continue as is
|
|
next.ServeHTTP(w, r)
|
|
return
|
|
}
|
|
|
|
if err != nil {
|
|
log.Warn().Msgf("Failed to authenticate request: %s", err)
|
|
|
|
// for any other error we fail
|
|
render.Unauthorized(w)
|
|
return
|
|
}
|
|
|
|
if session == nil {
|
|
// when err == nil session should never be nil!
|
|
log.Error().Msg("auth session is nil eventhough the authenticator didn't return any error!")
|
|
|
|
render.InternalError(w)
|
|
return
|
|
}
|
|
|
|
// Update the logging context and inject principal in context
|
|
log.UpdateContext(func(c zerolog.Context) zerolog.Context {
|
|
return c.
|
|
Int64("principal_id", session.Principal.ID).
|
|
Str("principal_type", string(session.Principal.Type)).
|
|
Bool("principal_admin", session.Principal.Admin)
|
|
})
|
|
|
|
next.ServeHTTP(w, r.WithContext(
|
|
request.WithAuthSession(ctx, session),
|
|
))
|
|
})
|
|
}
|
|
}
|