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>
54 lines
769 B
Go
54 lines
769 B
Go
package tasks
|
|
|
|
import (
|
|
"sync"
|
|
|
|
"github.com/splitio/go-toolkit/v5/logging"
|
|
)
|
|
|
|
// Task interface
|
|
type Task interface {
|
|
Start()
|
|
Stop(blocking bool) error
|
|
IsRunning() bool
|
|
}
|
|
|
|
// MultipleTask struct
|
|
type MultipleTask struct {
|
|
tasks []Task
|
|
logger logging.LoggerInterface
|
|
}
|
|
|
|
// IsRunning method
|
|
func (m MultipleTask) IsRunning() bool {
|
|
for _, t := range m.tasks {
|
|
if t.IsRunning() {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
// Start method
|
|
func (m MultipleTask) Start() {
|
|
for _, t := range m.tasks {
|
|
t.Start()
|
|
}
|
|
}
|
|
|
|
// Stop method
|
|
func (m MultipleTask) Stop(blocking bool) error {
|
|
wg := sync.WaitGroup{}
|
|
wg.Add(len(m.tasks))
|
|
for _, t := range m.tasks {
|
|
go func(t Task) {
|
|
t.Stop(blocking)
|
|
wg.Done()
|
|
}(t)
|
|
}
|
|
if blocking {
|
|
wg.Wait()
|
|
}
|
|
return nil
|
|
}
|