* feat(server): moved an http server object into a pkg subdir to be reusable for http, spots, and integrations * feat(web): isolated web module (server, router, middleware, utils) used in spots and new integrations * feat(web): removed possible panic * feat(web): split all handlers from http service into different packages for better management. * feat(web): changed router's method signature * feat(web): added missing handlers interface * feat(web): added health middleware to remove unnecessary checks * feat(web): customizable middleware set for web servers * feat(web): simplified the handler's structure * feat(web): created an unified server.Run method for all web services (http, spot, integrations) * feat(web): fixed a json size limit issue * feat(web): removed Keys and PG connection from router * feat(web): simplified integration's main file * feat(web): simplified spot's main file * feat(web): simplified http's main file (builder) * feat(web): refactored audit trail functionality * feat(web): added ee version of audit trail * feat(web): added ee version of conditions module * feat(web): moved ee version of some web session structs * feat(web): new format of web metrics * feat(web): added new web metrics to all handlers * feat(web): added justExpired feature to web ingest handler * feat(web): added small integrations improvements
53 lines
1.6 KiB
Go
53 lines
1.6 KiB
Go
package spot
|
|
|
|
import (
|
|
"openreplay/backend/pkg/metrics/web"
|
|
"openreplay/backend/pkg/server/tracer"
|
|
"time"
|
|
|
|
"openreplay/backend/internal/config/spot"
|
|
"openreplay/backend/pkg/db/postgres/pool"
|
|
"openreplay/backend/pkg/flakeid"
|
|
"openreplay/backend/pkg/logger"
|
|
"openreplay/backend/pkg/objectstorage/store"
|
|
"openreplay/backend/pkg/server/api"
|
|
"openreplay/backend/pkg/server/auth"
|
|
"openreplay/backend/pkg/server/keys"
|
|
"openreplay/backend/pkg/server/limiter"
|
|
spotAPI "openreplay/backend/pkg/spot/api"
|
|
"openreplay/backend/pkg/spot/service"
|
|
"openreplay/backend/pkg/spot/transcoder"
|
|
)
|
|
|
|
type ServicesBuilder struct {
|
|
Auth auth.Auth
|
|
RateLimiter *limiter.UserRateLimiter
|
|
AuditTrail tracer.Tracer
|
|
SpotsAPI api.Handlers
|
|
}
|
|
|
|
func NewServiceBuilder(log logger.Logger, cfg *spot.Config, webMetrics web.Web, pgconn pool.Pool) (*ServicesBuilder, error) {
|
|
objStore, err := store.NewStore(&cfg.ObjectsConfig)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
flaker := flakeid.NewFlaker(cfg.WorkerID)
|
|
spots := service.NewSpots(log, pgconn, flaker)
|
|
transcoder := transcoder.NewTranscoder(cfg, log, objStore, pgconn, spots)
|
|
keys := keys.NewKeys(log, pgconn)
|
|
auditrail, err := tracer.NewTracer(log, pgconn)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
responser := api.NewResponser(webMetrics)
|
|
handlers, err := spotAPI.NewHandlers(log, cfg, responser, spots, objStore, transcoder, keys)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &ServicesBuilder{
|
|
Auth: auth.NewAuth(log, cfg.JWTSecret, cfg.JWTSpotSecret, pgconn, keys),
|
|
RateLimiter: limiter.NewUserRateLimiter(10, 30, 1*time.Minute, 5*time.Minute),
|
|
AuditTrail: auditrail,
|
|
SpotsAPI: handlers,
|
|
}, nil
|
|
}
|