mirror of
https://github.com/harness/drone.git
synced 2025-05-06 08:20:34 +08:00

This change adds the initial stepping stones for harness integration: - Authentication: JWT/PAT/SAT support - Authorization: ACL integration (acl currently denies requests as gitness hasn't been integrated yet) - Remote Clients for Token, User, ServiceAccount, ACL - User Integration: Syncs harness users during authentication if unknown - SA integration: syncs harness service accounts during authentication if unknown - Initial harness API: THIS WILL BE CHANGED IN THE FUTURE! - single harness subpackage (all marked with harness build flag) - harness & standalone wire + make build commands
28 lines
695 B
Go
28 lines
695 B
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 accesslog
|
|
|
|
import (
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/rs/zerolog/hlog"
|
|
)
|
|
|
|
/*
|
|
* A simple middleware that logs completed requests using the default hlog access handler.
|
|
*/
|
|
func HlogHandler() func(http.Handler) http.Handler {
|
|
return hlog.AccessHandler(
|
|
func(r *http.Request, status, size int, duration time.Duration) {
|
|
hlog.FromRequest(r).Info().
|
|
Int("status_code", status).
|
|
Int("response_size_bytes", size).
|
|
Dur("elapsed_ms", duration).
|
|
Msg("request completed.")
|
|
},
|
|
)
|
|
}
|