mirror of
https://git.mirrors.martin98.com/https://github.com/SigNoz/signoz
synced 2025-07-27 15:12:02 +08:00

* feat(zeus): add zeus package * feat(signoz): add DI for zeus * feat(zeus): integrate with the codebase * ci(make): change makefile * ci: change workflows to point to the new zeus url * Update ee/query-service/usage/manager.go Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * Update ee/query-service/license/manager.go Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * fix: fix nil retriable * fix: fix zeus DI * fix: fix path of ldflag * feat(zeus): added zeus integration tests * feat(zeus): added zeus integration tests * feat(zeus): format the pytest --------- Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> Co-authored-by: vikrantgupta25 <vikrant.thomso@gmail.com> Co-authored-by: Vikrant Gupta <vikrant@signoz.io>
78 lines
2.2 KiB
Go
78 lines
2.2 KiB
Go
package plugin
|
|
|
|
import (
|
|
"bytes"
|
|
"io"
|
|
"log/slog"
|
|
"net"
|
|
"net/http"
|
|
|
|
"github.com/gojek/heimdall/v7"
|
|
semconv "go.opentelemetry.io/otel/semconv/v1.27.0"
|
|
)
|
|
|
|
type reqResLog struct {
|
|
logger *slog.Logger
|
|
}
|
|
|
|
func NewLog(logger *slog.Logger) heimdall.Plugin {
|
|
return &reqResLog{
|
|
logger: logger,
|
|
}
|
|
}
|
|
|
|
func (plugin *reqResLog) OnRequestStart(request *http.Request) {
|
|
host, port, _ := net.SplitHostPort(request.Host)
|
|
fields := []any{
|
|
string(semconv.HTTPRequestMethodKey), request.Method,
|
|
string(semconv.URLPathKey), request.URL.Path,
|
|
string(semconv.URLSchemeKey), request.URL.Scheme,
|
|
string(semconv.UserAgentOriginalKey), request.UserAgent(),
|
|
string(semconv.ServerAddressKey), host,
|
|
string(semconv.ServerPortKey), port,
|
|
string(semconv.HTTPRequestSizeKey), request.ContentLength,
|
|
"http.request.headers", request.Header,
|
|
}
|
|
|
|
plugin.logger.InfoContext(request.Context(), "::SENT-REQUEST::", fields...)
|
|
}
|
|
|
|
func (plugin *reqResLog) OnRequestEnd(request *http.Request, response *http.Response) {
|
|
fields := []any{
|
|
string(semconv.HTTPResponseStatusCodeKey), response.StatusCode,
|
|
string(semconv.HTTPResponseBodySizeKey), response.ContentLength,
|
|
}
|
|
|
|
bodybytes, err := io.ReadAll(response.Body)
|
|
if err != nil {
|
|
plugin.logger.DebugContext(request.Context(), "::UNABLE-TO-LOG-RESPONSE-BODY::", "error", err)
|
|
} else {
|
|
_ = response.Body.Close()
|
|
response.Body = io.NopCloser(bytes.NewBuffer(bodybytes))
|
|
|
|
if len(bodybytes) > 0 {
|
|
fields = append(fields, "http.response.body", string(bodybytes))
|
|
} else {
|
|
fields = append(fields, "http.response.body", "(empty)")
|
|
}
|
|
}
|
|
|
|
plugin.logger.InfoContext(request.Context(), "::RECEIVED-RESPONSE::", fields...)
|
|
}
|
|
|
|
func (plugin *reqResLog) OnError(request *http.Request, err error) {
|
|
host, port, _ := net.SplitHostPort(request.Host)
|
|
fields := []any{
|
|
"error", err,
|
|
string(semconv.HTTPRequestMethodKey), request.Method,
|
|
string(semconv.URLPathKey), request.URL.Path,
|
|
string(semconv.URLSchemeKey), request.URL.Scheme,
|
|
string(semconv.UserAgentOriginalKey), request.UserAgent(),
|
|
string(semconv.ServerAddressKey), host,
|
|
string(semconv.ServerPortKey), port,
|
|
string(semconv.HTTPRequestSizeKey), request.ContentLength,
|
|
}
|
|
|
|
plugin.logger.ErrorContext(request.Context(), "::UNABLE-TO-SEND-REQUEST::", fields...)
|
|
}
|