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>
47 lines
1.1 KiB
Go
47 lines
1.1 KiB
Go
package synchronizer
|
|
|
|
import (
|
|
"github.com/splitio/go-toolkit/v5/logging"
|
|
"github.com/splitio/go-toolkit/v5/sync"
|
|
)
|
|
|
|
// ManagerImpl struct
|
|
type ManagerRedisImpl struct {
|
|
synchronizer Synchronizer
|
|
running sync.AtomicBool
|
|
logger logging.LoggerInterface
|
|
}
|
|
|
|
// NewSynchronizerManagerRedis creates new sync manager for redis
|
|
func NewSynchronizerManagerRedis(synchronizer Synchronizer, logger logging.LoggerInterface) Manager {
|
|
return &ManagerRedisImpl{
|
|
synchronizer: synchronizer,
|
|
running: *sync.NewAtomicBool(false),
|
|
logger: logger,
|
|
}
|
|
}
|
|
|
|
func (m *ManagerRedisImpl) Start() {
|
|
if !m.running.TestAndSet() {
|
|
m.logger.Info("Manager is already running, skipping start")
|
|
return
|
|
}
|
|
m.synchronizer.StartPeriodicDataRecording()
|
|
}
|
|
|
|
func (m *ManagerRedisImpl) Stop() {
|
|
if !m.running.TestAndClear() {
|
|
m.logger.Info("sync manager not yet running, skipping shutdown.")
|
|
return
|
|
}
|
|
m.synchronizer.StopPeriodicDataRecording()
|
|
}
|
|
|
|
func (m *ManagerRedisImpl) IsRunning() bool {
|
|
return m.running.IsSet()
|
|
}
|
|
|
|
func (m *ManagerRedisImpl) StartBGSyng(mstatus chan int, shouldRetry bool, onReady func()) error {
|
|
return nil
|
|
}
|