mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-11 11:43:40 +00:00
48 lines
1.4 KiB
Go
48 lines
1.4 KiB
Go
package spooler
|
|
|
|
import (
|
|
"database/sql"
|
|
"net/http"
|
|
|
|
"github.com/zitadel/zitadel/internal/command"
|
|
"github.com/zitadel/zitadel/internal/crypto"
|
|
v1 "github.com/zitadel/zitadel/internal/eventstore/v1"
|
|
"github.com/zitadel/zitadel/internal/eventstore/v1/spooler"
|
|
"github.com/zitadel/zitadel/internal/notification/repository/eventsourcing/handler"
|
|
"github.com/zitadel/zitadel/internal/notification/repository/eventsourcing/view"
|
|
"github.com/zitadel/zitadel/internal/query"
|
|
)
|
|
|
|
type SpoolerConfig struct {
|
|
BulkLimit uint64
|
|
FailureCountUntilSkip uint64
|
|
ConcurrentWorkers int
|
|
Handlers handler.Configs
|
|
}
|
|
|
|
func StartSpooler(c SpoolerConfig,
|
|
es v1.Eventstore,
|
|
view *view.View,
|
|
sql *sql.DB,
|
|
command *command.Commands,
|
|
queries *query.Queries,
|
|
externalPort uint16,
|
|
externalSecure bool,
|
|
dir http.FileSystem,
|
|
assetsPrefix,
|
|
fileSystemPath string,
|
|
userEncryption crypto.EncryptionAlgorithm,
|
|
smtpEncryption crypto.EncryptionAlgorithm,
|
|
smsEncryption crypto.EncryptionAlgorithm,
|
|
) *spooler.Spooler {
|
|
spoolerConfig := spooler.Config{
|
|
Eventstore: es,
|
|
Locker: &locker{dbClient: sql},
|
|
ConcurrentWorkers: c.ConcurrentWorkers,
|
|
ViewHandlers: handler.Register(c.Handlers, c.BulkLimit, c.FailureCountUntilSkip, view, es, command, queries, externalPort, externalSecure, dir, assetsPrefix, fileSystemPath, userEncryption, smtpEncryption, smsEncryption),
|
|
}
|
|
spool := spoolerConfig.New()
|
|
spool.Start()
|
|
return spool
|
|
}
|