mattermost-community-enterp.../vendor/github.com/splitio/go-split-commons/v7/tasks/impressionsync.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
Full Mattermost server source with integrated Community Enterprise features.
Includes vendor directory for offline/air-gapped builds.

Structure:
- enterprise-impl/: Enterprise feature implementations
- enterprise-community/: Init files that register implementations
- enterprise/: Bridge imports (community_imports.go)
- vendor/: All dependencies for offline builds

Build (online):
  go build ./cmd/mattermost

Build (offline/air-gapped):
  go build -mod=vendor ./cmd/mattermost

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:59:07 +09:00

51 lines
1.4 KiB
Go

package tasks
import (
"fmt"
"github.com/splitio/go-split-commons/v7/synchronizer/worker/impression"
"github.com/splitio/go-toolkit/v5/asynctask"
"github.com/splitio/go-toolkit/v5/logging"
)
// NewRecordImpressionsTask creates a new splits fetching and storing task
func NewRecordImpressionsTask(
recorder impression.ImpressionRecorder,
period int,
logger logging.LoggerInterface,
bulkSize int64,
) Task {
record := func(logger logging.LoggerInterface) error {
return recorder.SynchronizeImpressions(bulkSize)
}
onStop := func(logger logging.LoggerInterface) {
// All this function does is flush impressions which will clear the storage
recorder.FlushImpressions(bulkSize)
}
return asynctask.NewAsyncTask("SubmitImpressions", record, period, nil, onStop, logger)
}
// NewRecordImpressionsTasks creates a new splits fetching and storing task
func NewRecordImpressionsTasks(
recorder impression.ImpressionRecorder,
period int,
logger logging.LoggerInterface,
bulkSize int64,
totalTasks int) Task {
record := func(logger logging.LoggerInterface) error {
return recorder.SynchronizeImpressions(bulkSize)
}
tasks := make([]Task, 0, totalTasks)
for i := 0; i < totalTasks; i++ {
logger.Info(fmt.Sprintf("Creating SubmitImpressions_%d", i))
tasks = append(tasks, asynctask.NewAsyncTask(fmt.Sprintf("SubmitImpressions_%d", i), record, period, nil, nil, logger))
}
return MultipleTask{
logger: logger,
tasks: tasks,
}
}