mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-13 04:34:16 +00:00
32 lines
1011 B
Go
32 lines
1011 B
Go
|
package spooler
|
||
|
|
||
|
import (
|
||
|
"database/sql"
|
||
|
sd "github.com/caos/zitadel/internal/config/systemdefaults"
|
||
|
|
||
|
"github.com/caos/zitadel/internal/authz/repository/eventsourcing/handler"
|
||
|
"github.com/caos/zitadel/internal/authz/repository/eventsourcing/view"
|
||
|
|
||
|
"github.com/caos/zitadel/internal/eventstore"
|
||
|
"github.com/caos/zitadel/internal/eventstore/spooler"
|
||
|
)
|
||
|
|
||
|
type SpoolerConfig struct {
|
||
|
BulkLimit uint64
|
||
|
FailureCountUntilSkip uint64
|
||
|
ConcurrentTasks int
|
||
|
Handlers handler.Configs
|
||
|
}
|
||
|
|
||
|
func StartSpooler(c SpoolerConfig, es eventstore.Eventstore, view *view.View, sql *sql.DB, repos handler.EventstoreRepos, systemDefaults sd.SystemDefaults) *spooler.Spooler {
|
||
|
spoolerConfig := spooler.Config{
|
||
|
Eventstore: es,
|
||
|
Locker: &locker{dbClient: sql},
|
||
|
ConcurrentTasks: c.ConcurrentTasks,
|
||
|
ViewHandlers: handler.Register(c.Handlers, c.BulkLimit, c.FailureCountUntilSkip, view, es, repos, systemDefaults),
|
||
|
}
|
||
|
spool := spoolerConfig.New()
|
||
|
spool.Start()
|
||
|
return spool
|
||
|
}
|