2020-06-15 10:04:08 +00:00
|
|
|
package http_mock
|
2020-04-01 22:58:44 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/baez90/inetmock/pkg/api"
|
|
|
|
"github.com/baez90/inetmock/pkg/logging"
|
2020-10-02 09:56:48 +00:00
|
|
|
"github.com/baez90/inetmock/pkg/metrics"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
2020-04-01 22:58:44 +00:00
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
2020-10-02 09:56:48 +00:00
|
|
|
var (
|
|
|
|
totalRequestCounter *prometheus.CounterVec
|
|
|
|
requestDurationHistogram *prometheus.HistogramVec
|
|
|
|
)
|
|
|
|
|
2020-04-01 22:58:44 +00:00
|
|
|
func init() {
|
2020-10-02 09:56:48 +00:00
|
|
|
var err error
|
|
|
|
var logger logging.Logger
|
|
|
|
if logger, err = logging.CreateLogger(); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-04-01 22:58:44 +00:00
|
|
|
logger = logger.With(
|
2020-10-02 09:56:48 +00:00
|
|
|
zap.String("protocol_handler", name),
|
2020-04-01 22:58:44 +00:00
|
|
|
)
|
2020-10-02 09:56:48 +00:00
|
|
|
if totalRequestCounter, err = metrics.Counter(
|
|
|
|
name,
|
|
|
|
"total_requests",
|
|
|
|
"",
|
|
|
|
handlerNameLblName,
|
|
|
|
ruleMatchedLblName,
|
|
|
|
); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
if requestDurationHistogram, err = metrics.Histogram(
|
|
|
|
name,
|
|
|
|
"request_duration",
|
|
|
|
"",
|
|
|
|
nil,
|
|
|
|
handlerNameLblName,
|
|
|
|
); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-06-15 10:04:08 +00:00
|
|
|
api.Registry().RegisterHandler(name, func() api.ProtocolHandler {
|
2020-04-01 22:58:44 +00:00
|
|
|
return &httpHandler{
|
|
|
|
logger: logger,
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|