-
Notifications
You must be signed in to change notification settings - Fork 22
/
wire_gen.go
90 lines (85 loc) · 2.93 KB
/
wire_gen.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Code generated by Wire. DO NOT EDIT.
//go:generate go run -mod=mod github.com/google/wire/cmd/wire
//go:build !wireinject
// +build !wireinject
package mylogical
import (
"github.com/cockroachdb/cdc-sink/internal/script"
"github.com/cockroachdb/cdc-sink/internal/sequencer/chaos"
"github.com/cockroachdb/cdc-sink/internal/sequencer/immediate"
script2 "github.com/cockroachdb/cdc-sink/internal/sequencer/script"
"github.com/cockroachdb/cdc-sink/internal/sinkprod"
"github.com/cockroachdb/cdc-sink/internal/staging/memo"
"github.com/cockroachdb/cdc-sink/internal/target/apply"
"github.com/cockroachdb/cdc-sink/internal/target/dlq"
"github.com/cockroachdb/cdc-sink/internal/target/schemawatch"
"github.com/cockroachdb/cdc-sink/internal/util/applycfg"
"github.com/cockroachdb/cdc-sink/internal/util/diag"
"github.com/cockroachdb/cdc-sink/internal/util/stopper"
)
// Injectors from injector.go:
// Start creates a MySQL/MariaDB logical replication loop using the
// provided configuration.
func Start(ctx *stopper.Context, config *Config) (*MYLogical, error) {
diagnostics := diag.New(ctx)
configs, err := applycfg.ProvideConfigs(diagnostics)
if err != nil {
return nil, err
}
scriptConfig := &config.Script
loader, err := script.ProvideLoader(ctx, configs, scriptConfig, diagnostics)
if err != nil {
return nil, err
}
eagerConfig, err := ProvideEagerConfig(config, loader)
if err != nil {
return nil, err
}
targetConfig := &eagerConfig.Target
targetPool, err := sinkprod.ProvideTargetPool(ctx, targetConfig, diagnostics)
if err != nil {
return nil, err
}
targetStatements, err := sinkprod.ProvideStatementCache(ctx, targetConfig, targetPool, diagnostics)
if err != nil {
return nil, err
}
dlqConfig := &eagerConfig.DLQ
watchers, err := schemawatch.ProvideFactory(ctx, targetPool, diagnostics)
if err != nil {
return nil, err
}
dlQs := dlq.ProvideDLQs(dlqConfig, targetPool, watchers)
acceptor, err := apply.ProvideAcceptor(ctx, targetStatements, configs, diagnostics, dlQs, targetPool, watchers)
if err != nil {
return nil, err
}
sequencerConfig := &eagerConfig.Sequencer
chaosChaos := &chaos.Chaos{
Config: sequencerConfig,
}
immediateImmediate := immediate.ProvideImmediate(targetPool)
stagingConfig := &eagerConfig.Staging
stagingPool, err := sinkprod.ProvideStagingPool(ctx, stagingConfig, diagnostics, targetConfig)
if err != nil {
return nil, err
}
stagingSchema, err := sinkprod.ProvideStagingDB(stagingConfig)
if err != nil {
return nil, err
}
memoMemo, err := memo.ProvideMemo(ctx, stagingPool, stagingSchema)
if err != nil {
return nil, err
}
sequencer := script2.ProvideSequencer(loader, targetPool, watchers)
mylogicalConn, err := ProvideConn(ctx, acceptor, chaosChaos, config, immediateImmediate, memoMemo, sequencer, stagingPool, targetPool, watchers)
if err != nil {
return nil, err
}
myLogical := &MYLogical{
Conn: mylogicalConn,
Diagnostics: diagnostics,
}
return myLogical, nil
}