mirror of
https://github.com/dstotijn/hetty
synced 2024-12-12 13:12:30 +00:00
108 lines
2.4 KiB
Go
108 lines
2.4 KiB
Go
package api
|
|
|
|
//go:generate go run github.com/99designs/gqlgen
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/dstotijn/hetty/pkg/reqlog"
|
|
)
|
|
|
|
type Resolver struct {
|
|
RequestLogService *reqlog.Service
|
|
}
|
|
|
|
type queryResolver struct{ *Resolver }
|
|
|
|
func (r *Resolver) Query() QueryResolver { return &queryResolver{r} }
|
|
|
|
func (r *queryResolver) HTTPRequestLogs(ctx context.Context) ([]HTTPRequestLog, error) {
|
|
reqs := r.RequestLogService.FindAllRequests()
|
|
logs := make([]HTTPRequestLog, len(reqs))
|
|
|
|
for i, req := range reqs {
|
|
req, err := parseRequestLog(req)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
logs[i] = req
|
|
}
|
|
|
|
return logs, nil
|
|
}
|
|
|
|
func (r *queryResolver) HTTPRequestLog(ctx context.Context, id string) (*HTTPRequestLog, error) {
|
|
log, err := r.RequestLogService.FindRequestLogByID(id)
|
|
if err == reqlog.ErrRequestNotFound {
|
|
return nil, nil
|
|
}
|
|
if err != nil {
|
|
return nil, errors.New("could not get request by ID")
|
|
}
|
|
req, err := parseRequestLog(log)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &req, nil
|
|
}
|
|
|
|
func parseRequestLog(req reqlog.Request) (HTTPRequestLog, error) {
|
|
method := HTTPMethod(req.Request.Method)
|
|
if !method.IsValid() {
|
|
return HTTPRequestLog{}, fmt.Errorf("request has invalid method: %v", method)
|
|
}
|
|
|
|
log := HTTPRequestLog{
|
|
ID: req.ID.String(),
|
|
URL: req.Request.URL.String(),
|
|
Proto: req.Request.Proto,
|
|
Method: method,
|
|
Timestamp: req.Timestamp,
|
|
}
|
|
|
|
if len(req.Body) > 0 {
|
|
reqBody := string(req.Body)
|
|
log.Body = &reqBody
|
|
}
|
|
|
|
if req.Request.Header != nil {
|
|
log.Headers = make([]HTTPHeader, 0)
|
|
for key, values := range req.Request.Header {
|
|
for _, value := range values {
|
|
log.Headers = append(log.Headers, HTTPHeader{
|
|
Key: key,
|
|
Value: value,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
|
|
if req.Response != nil {
|
|
log.Response = &HTTPResponseLog{
|
|
RequestID: req.ID.String(),
|
|
Proto: req.Response.Response.Proto,
|
|
Status: req.Response.Response.Status,
|
|
StatusCode: req.Response.Response.StatusCode,
|
|
}
|
|
if len(req.Response.Body) > 0 {
|
|
resBody := string(req.Response.Body)
|
|
log.Response.Body = &resBody
|
|
}
|
|
if req.Response.Response.Header != nil {
|
|
log.Response.Headers = make([]HTTPHeader, 0)
|
|
for key, values := range req.Response.Response.Header {
|
|
for _, value := range values {
|
|
log.Response.Headers = append(log.Response.Headers, HTTPHeader{
|
|
Key: key,
|
|
Value: value,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return log, nil
|
|
}
|