* feat(backend): try a new approach for logs formatting (http) * feat(backend): added logger module * feat(backend): added project/session info to /i endpoint * feat(backend): found a solution for correct caller information * feat(backend): finished logs for http handlers * feat(backend): finished logs for mobile http handlers * feat(backend): finished ender * feat(backend): finished assets * feat(backend): finished heuristics * feat(backend): finished image-storage * feat(backend): finished sink * feat(backend): finished storage * feat(backend): formatted logs in all services * feat(backend): finished foss part * feat(backend): added missed foss part * feat(backend): fixed panic in memory manager and sink service * feat(backend): connectors
67 lines
1.9 KiB
Go
67 lines
1.9 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
config "openreplay/backend/internal/config/heuristics"
|
|
"openreplay/backend/internal/heuristics"
|
|
"openreplay/backend/pkg/builders"
|
|
"openreplay/backend/pkg/handlers"
|
|
"openreplay/backend/pkg/handlers/custom"
|
|
"openreplay/backend/pkg/handlers/ios"
|
|
"openreplay/backend/pkg/handlers/web"
|
|
"openreplay/backend/pkg/logger"
|
|
"openreplay/backend/pkg/memory"
|
|
"openreplay/backend/pkg/messages"
|
|
"openreplay/backend/pkg/metrics"
|
|
heuristicsMetrics "openreplay/backend/pkg/metrics/heuristics"
|
|
"openreplay/backend/pkg/queue"
|
|
"openreplay/backend/pkg/terminator"
|
|
)
|
|
|
|
func main() {
|
|
ctx := context.Background()
|
|
log := logger.New()
|
|
cfg := config.New(log)
|
|
metrics.New(log, heuristicsMetrics.List())
|
|
|
|
// HandlersFabric returns the list of message handlers we want to be applied to each incoming message.
|
|
handlersFabric := func() []handlers.MessageProcessor {
|
|
return []handlers.MessageProcessor{
|
|
custom.NewPageEventBuilder(),
|
|
web.NewDeadClickDetector(),
|
|
&web.ClickRageDetector{},
|
|
&web.CpuIssueDetector{},
|
|
&web.MemoryIssueDetector{},
|
|
&web.NetworkIssueDetector{},
|
|
&web.PerformanceAggregator{},
|
|
web.NewAppCrashDetector(),
|
|
&ios.TapRageDetector{},
|
|
ios.NewViewComponentDurations(),
|
|
}
|
|
}
|
|
|
|
eventBuilder := builders.NewBuilderMap(log, handlersFabric)
|
|
producer := queue.NewProducer(cfg.MessageSizeLimit, true)
|
|
consumer := queue.NewConsumer(
|
|
cfg.GroupHeuristics,
|
|
[]string{
|
|
cfg.TopicRawWeb,
|
|
cfg.TopicRawIOS,
|
|
},
|
|
messages.NewMessageIterator(log, eventBuilder.HandleMessage, nil, true),
|
|
false,
|
|
cfg.MessageSizeLimit,
|
|
)
|
|
|
|
// Init memory manager
|
|
memoryManager, err := memory.NewManager(log, cfg.MemoryLimitMB, cfg.MaxMemoryUsage)
|
|
if err != nil {
|
|
log.Fatal(ctx, "can't init memory manager: %s", err)
|
|
return
|
|
}
|
|
|
|
// Run service and wait for TERM signal
|
|
service := heuristics.New(log, cfg, producer, consumer, eventBuilder, memoryManager)
|
|
log.Info(ctx, "Heuristics service started")
|
|
terminator.Wait(log, service)
|
|
}
|