1
0
mirror of https://github.com/go-kratos/kratos.git synced 2025-03-21 21:27:16 +02:00

38 lines
1.2 KiB
Go
Raw Normal View History

2021-03-05 23:49:25 +08:00
package server
import (
2021-03-11 23:42:28 +08:00
v1 "github.com/go-kratos/kratos/examples/blog/api/blog/v1"
"github.com/go-kratos/kratos/examples/blog/internal/conf"
"github.com/go-kratos/kratos/examples/blog/internal/service"
"github.com/go-kratos/kratos/v2/log"
2021-03-05 23:49:25 +08:00
"github.com/go-kratos/kratos/v2/middleware/logging"
"github.com/go-kratos/kratos/v2/middleware/recovery"
"github.com/go-kratos/kratos/v2/middleware/tracing"
"github.com/go-kratos/kratos/v2/middleware/validate"
2021-03-05 23:49:25 +08:00
"github.com/go-kratos/kratos/v2/transport/http"
"go.opentelemetry.io/otel/trace"
2021-03-05 23:49:25 +08:00
)
// NewHTTPServer new a HTTP server.
func NewHTTPServer(c *conf.Server, tracer trace.TracerProvider, blog *service.BlogService) *http.Server {
var opts []http.ServerOption
2021-03-05 23:49:25 +08:00
if c.Http.Network != "" {
opts = append(opts, http.Network(c.Http.Network))
}
if c.Http.Addr != "" {
opts = append(opts, http.Address(c.Http.Addr))
}
if c.Http.Timeout != nil {
opts = append(opts, http.Timeout(c.Http.Timeout.AsDuration()))
}
m := http.Middleware(
recovery.Recovery(),
2021-05-20 23:30:50 +08:00
tracing.Server(tracing.WithTracerProvider(tracer)),
logging.Server(log.DefaultLogger),
validate.Validator(),
2021-03-05 23:49:25 +08:00
)
srv := http.NewServer(opts...)
srv.HandlePrefix("/", v1.NewBlogServiceHandler(blog, m))
return srv
}