api/plugins/http_proxy/init.go

48 lines
1.2 KiB
Go
Raw Normal View History

package http_proxy
2020-04-08 22:59:22 +00:00
import (
"github.com/baez90/inetmock/pkg/api"
2020-04-08 22:59:22 +00:00
"github.com/baez90/inetmock/pkg/logging"
"github.com/baez90/inetmock/pkg/metrics"
"github.com/prometheus/client_golang/prometheus"
2020-04-08 22:59:22 +00:00
"go.uber.org/zap"
"gopkg.in/elazarl/goproxy.v1"
2020-04-08 22:59:22 +00:00
)
var (
handlerNameLblName = "handler_name"
totalRequestCounter *prometheus.CounterVec
totalHttpsRequestCounter *prometheus.CounterVec
requestDurationHistogram *prometheus.HistogramVec
)
2020-04-08 22:59:22 +00:00
func init() {
var err error
var logger logging.Logger
if logger, err = logging.CreateLogger(); err != nil {
panic(err)
}
2020-04-08 22:59:22 +00:00
logger = logger.With(
zap.String("protocol_handler", name),
2020-04-08 22:59:22 +00:00
)
if totalRequestCounter, err = metrics.Counter(name, "total_requests", "", handlerNameLblName); err != nil {
panic(err)
}
if requestDurationHistogram, err = metrics.Histogram(name, "request_duration", "", nil, handlerNameLblName); err != nil {
panic(err)
}
if totalHttpsRequestCounter, err = metrics.Counter(name, "total_https_requests", "", handlerNameLblName); err != nil {
panic(err)
}
api.Registry().RegisterHandler(name, func() api.ProtocolHandler {
return &httpProxy{
logger: logger,
proxy: goproxy.NewProxyHttpServer(),
}
})
2020-04-08 22:59:22 +00:00
}