Skip to content

Commit 9d6ccb0

Browse files
authored
context propagation: appsec, docker, kafka, k8s datasources (#3284)
1 parent d00a6a6 commit 9d6ccb0

File tree

6 files changed

+196
-34
lines changed

6 files changed

+196
-34
lines changed

.github/codecov.yml

+164
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,164 @@
1+
# we measure coverage but don't enforce it
2+
# https://docs.codecov.com/docs/codecov-yaml
3+
codecov:
4+
require_ci_to_pass: false
5+
6+
coverage:
7+
status:
8+
patch:
9+
default:
10+
target: 0%
11+
project:
12+
default:
13+
target: 0%
14+
15+
# if a directory is ignored, there is no way to un-ignore files like pkg/models/helpers.go
16+
# so we make a full list
17+
ignore:
18+
- "./pkg/modelscapi/success_response.go"
19+
- "./pkg/modelscapi/get_decisions_stream_response_deleted.go"
20+
- "./pkg/modelscapi/login_request.go"
21+
- "./pkg/modelscapi/get_decisions_stream_response_links.go"
22+
- "./pkg/modelscapi/login_response.go"
23+
- "./pkg/modelscapi/add_signals_request_item.go"
24+
- "./pkg/modelscapi/blocklist_link.go"
25+
- "./pkg/modelscapi/get_decisions_stream_response_deleted_item.go"
26+
- "./pkg/modelscapi/decisions_sync_request.go"
27+
- "./pkg/modelscapi/get_decisions_stream_response.go"
28+
- "./pkg/modelscapi/metrics_request_machines_item.go"
29+
- "./pkg/modelscapi/metrics_request.go"
30+
- "./pkg/modelscapi/get_decisions_stream_response_new.go"
31+
- "./pkg/modelscapi/add_signals_request_item_decisions_item.go"
32+
- "./pkg/modelscapi/metrics_request_bouncers_item.go"
33+
- "./pkg/modelscapi/decisions_sync_request_item_decisions_item.go"
34+
- "./pkg/modelscapi/decisions_delete_request_item.go"
35+
- "./pkg/modelscapi/get_decisions_stream_response_new_item.go"
36+
- "./pkg/modelscapi/decisions_sync_request_item.go"
37+
- "./pkg/modelscapi/add_signals_request.go"
38+
- "./pkg/modelscapi/reset_password_request.go"
39+
- "./pkg/modelscapi/add_signals_request_item_decisions.go"
40+
- "./pkg/modelscapi/decisions_sync_request_item_source.go"
41+
- "./pkg/modelscapi/error_response.go"
42+
- "./pkg/modelscapi/decisions_delete_request.go"
43+
- "./pkg/modelscapi/decisions_sync_request_item_decisions.go"
44+
- "./pkg/modelscapi/enroll_request.go"
45+
- "./pkg/modelscapi/register_request.go"
46+
- "./pkg/modelscapi/add_signals_request_item_source.go"
47+
- "./pkg/models/success_response.go"
48+
- "./pkg/models/hub_items.go"
49+
- "./pkg/models/alert.go"
50+
- "./pkg/models/metrics_bouncer_info.go"
51+
- "./pkg/models/add_signals_request_item.go"
52+
- "./pkg/models/metrics_meta.go"
53+
- "./pkg/models/metrics_detail_item.go"
54+
- "./pkg/models/add_signals_request_item_decisions_item.go"
55+
- "./pkg/models/hub_item.go"
56+
- "./pkg/models/get_alerts_response.go"
57+
- "./pkg/models/metrics_labels.go"
58+
- "./pkg/models/watcher_auth_request.go"
59+
- "./pkg/models/add_alerts_request.go"
60+
- "./pkg/models/event.go"
61+
- "./pkg/models/decisions_delete_request_item.go"
62+
- "./pkg/models/meta.go"
63+
- "./pkg/models/detailed_metrics.go"
64+
- "./pkg/models/delete_alerts_response.go"
65+
- "./pkg/models/remediation_components_metrics.go"
66+
- "./pkg/models/console_options.go"
67+
- "./pkg/models/topx_response.go"
68+
- "./pkg/models/add_signals_request.go"
69+
- "./pkg/models/delete_decision_response.go"
70+
- "./pkg/models/get_decisions_response.go"
71+
- "./pkg/models/add_signals_request_item_decisions.go"
72+
- "./pkg/models/source.go"
73+
- "./pkg/models/decisions_stream_response.go"
74+
- "./pkg/models/error_response.go"
75+
- "./pkg/models/all_metrics.go"
76+
- "./pkg/models/o_sversion.go"
77+
- "./pkg/models/decision.go"
78+
- "./pkg/models/decisions_delete_request.go"
79+
- "./pkg/models/flush_decision_response.go"
80+
- "./pkg/models/watcher_auth_response.go"
81+
- "./pkg/models/lapi_metrics.go"
82+
- "./pkg/models/watcher_registration_request.go"
83+
- "./pkg/models/metrics_agent_info.go"
84+
- "./pkg/models/log_processors_metrics.go"
85+
- "./pkg/models/add_signals_request_item_source.go"
86+
- "./pkg/models/base_metrics.go"
87+
- "./pkg/models/add_alerts_response.go"
88+
- "./pkg/models/metrics.go"
89+
- "./pkg/protobufs/notifier.pb.go"
90+
- "./pkg/protobufs/notifier_grpc.pb.go"
91+
- "./pkg/database/ent/metric_update.go"
92+
- "./pkg/database/ent/machine_delete.go"
93+
- "./pkg/database/ent/decision_query.go"
94+
- "./pkg/database/ent/meta_query.go"
95+
- "./pkg/database/ent/metric/where.go"
96+
- "./pkg/database/ent/metric/metric.go"
97+
- "./pkg/database/ent/machine_create.go"
98+
- "./pkg/database/ent/alert.go"
99+
- "./pkg/database/ent/event_update.go"
100+
- "./pkg/database/ent/alert_create.go"
101+
- "./pkg/database/ent/alert_query.go"
102+
- "./pkg/database/ent/metric_delete.go"
103+
- "./pkg/database/ent/lock_create.go"
104+
- "./pkg/database/ent/bouncer_update.go"
105+
- "./pkg/database/ent/meta_update.go"
106+
- "./pkg/database/ent/decision_create.go"
107+
- "./pkg/database/ent/configitem_update.go"
108+
- "./pkg/database/ent/machine_query.go"
109+
- "./pkg/database/ent/client.go"
110+
- "./pkg/database/ent/predicate/predicate.go"
111+
- "./pkg/database/ent/lock/where.go"
112+
- "./pkg/database/ent/lock/lock.go"
113+
- "./pkg/database/ent/mutation.go"
114+
- "./pkg/database/ent/migrate/migrate.go"
115+
- "./pkg/database/ent/migrate/schema.go"
116+
- "./pkg/database/ent/configitem.go"
117+
- "./pkg/database/ent/metric_query.go"
118+
- "./pkg/database/ent/event.go"
119+
- "./pkg/database/ent/event_query.go"
120+
- "./pkg/database/ent/lock_update.go"
121+
- "./pkg/database/ent/meta.go"
122+
- "./pkg/database/ent/configitem_query.go"
123+
- "./pkg/database/ent/bouncer.go"
124+
- "./pkg/database/ent/alert_update.go"
125+
- "./pkg/database/ent/meta/meta.go"
126+
- "./pkg/database/ent/meta/where.go"
127+
- "./pkg/database/ent/decision_update.go"
128+
- "./pkg/database/ent/alert_delete.go"
129+
- "./pkg/database/ent/lock.go"
130+
- "./pkg/database/ent/runtime/runtime.go"
131+
- "./pkg/database/ent/alert/alert.go"
132+
- "./pkg/database/ent/alert/where.go"
133+
- "./pkg/database/ent/runtime.go"
134+
- "./pkg/database/ent/bouncer/bouncer.go"
135+
- "./pkg/database/ent/bouncer/where.go"
136+
- "./pkg/database/ent/hook/hook.go"
137+
- "./pkg/database/ent/metric.go"
138+
- "./pkg/database/ent/configitem_create.go"
139+
- "./pkg/database/ent/configitem_delete.go"
140+
- "./pkg/database/ent/tx.go"
141+
- "./pkg/database/ent/decision.go"
142+
- "./pkg/database/ent/lock_delete.go"
143+
- "./pkg/database/ent/decision_delete.go"
144+
- "./pkg/database/ent/machine/where.go"
145+
- "./pkg/database/ent/machine/machine.go"
146+
- "./pkg/database/ent/event_create.go"
147+
- "./pkg/database/ent/metric_create.go"
148+
- "./pkg/database/ent/decision/where.go"
149+
- "./pkg/database/ent/decision/decision.go"
150+
- "./pkg/database/ent/enttest/enttest.go"
151+
- "./pkg/database/ent/lock_query.go"
152+
- "./pkg/database/ent/bouncer_create.go"
153+
- "./pkg/database/ent/event_delete.go"
154+
- "./pkg/database/ent/bouncer_delete.go"
155+
- "./pkg/database/ent/event/event.go"
156+
- "./pkg/database/ent/event/where.go"
157+
- "./pkg/database/ent/machine.go"
158+
- "./pkg/database/ent/ent.go"
159+
- "./pkg/database/ent/meta_create.go"
160+
- "./pkg/database/ent/bouncer_query.go"
161+
- "./pkg/database/ent/meta_delete.go"
162+
- "./pkg/database/ent/machine_update.go"
163+
- "./pkg/database/ent/configitem/configitem.go"
164+
- "./pkg/database/ent/configitem/where.go"

.gitignore

-3
Original file line numberDiff line numberDiff line change
@@ -60,6 +60,3 @@ msi
6060
__pycache__
6161
*.py[cod]
6262
*.egg-info
63-
64-
# automatically generated before running codecov
65-
.github/codecov.yml

pkg/acquisition/modules/appsec/appsec.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -294,7 +294,7 @@ func (w *AppsecSource) StreamingAcquisition(ctx context.Context, out chan types.
294294
w.logger.Info("Shutting down Appsec server")
295295
// xx let's clean up the appsec runners :)
296296
appsec.AppsecRulesDetails = make(map[int]appsec.RulesDetails)
297-
w.server.Shutdown(context.TODO())
297+
w.server.Shutdown(ctx)
298298
return nil
299299
})
300300
return nil

pkg/acquisition/modules/docker/docker.go

+24-23
Original file line numberDiff line numberDiff line change
@@ -287,8 +287,9 @@ func (d *DockerSource) SupportedModes() []string {
287287

288288
// OneShotAcquisition reads a set of file and returns when done
289289
func (d *DockerSource) OneShotAcquisition(out chan types.Event, t *tomb.Tomb) error {
290+
ctx := context.TODO()
290291
d.logger.Debug("In oneshot")
291-
runningContainer, err := d.Client.ContainerList(context.Background(), dockerTypes.ContainerListOptions{})
292+
runningContainer, err := d.Client.ContainerList(ctx, dockerTypes.ContainerListOptions{})
292293
if err != nil {
293294
return err
294295
}
@@ -298,10 +299,10 @@ func (d *DockerSource) OneShotAcquisition(out chan types.Event, t *tomb.Tomb) er
298299
d.logger.Debugf("container with id %s is already being read from", container.ID)
299300
continue
300301
}
301-
if containerConfig := d.EvalContainer(container); containerConfig != nil {
302+
if containerConfig := d.EvalContainer(ctx, container); containerConfig != nil {
302303
d.logger.Infof("reading logs from container %s", containerConfig.Name)
303304
d.logger.Debugf("logs options: %+v", *d.containerLogsOptions)
304-
dockerReader, err := d.Client.ContainerLogs(context.Background(), containerConfig.ID, *d.containerLogsOptions)
305+
dockerReader, err := d.Client.ContainerLogs(ctx, containerConfig.ID, *d.containerLogsOptions)
305306
if err != nil {
306307
d.logger.Errorf("unable to read logs from container: %+v", err)
307308
return err
@@ -372,26 +373,26 @@ func (d *DockerSource) CanRun() error {
372373
return nil
373374
}
374375

375-
func (d *DockerSource) getContainerTTY(containerId string) bool {
376-
containerDetails, err := d.Client.ContainerInspect(context.Background(), containerId)
376+
func (d *DockerSource) getContainerTTY(ctx context.Context, containerId string) bool {
377+
containerDetails, err := d.Client.ContainerInspect(ctx, containerId)
377378
if err != nil {
378379
return false
379380
}
380381
return containerDetails.Config.Tty
381382
}
382383

383-
func (d *DockerSource) getContainerLabels(containerId string) map[string]interface{} {
384-
containerDetails, err := d.Client.ContainerInspect(context.Background(), containerId)
384+
func (d *DockerSource) getContainerLabels(ctx context.Context, containerId string) map[string]interface{} {
385+
containerDetails, err := d.Client.ContainerInspect(ctx, containerId)
385386
if err != nil {
386387
return map[string]interface{}{}
387388
}
388389
return parseLabels(containerDetails.Config.Labels)
389390
}
390391

391-
func (d *DockerSource) EvalContainer(container dockerTypes.Container) *ContainerConfig {
392+
func (d *DockerSource) EvalContainer(ctx context.Context, container dockerTypes.Container) *ContainerConfig {
392393
for _, containerID := range d.Config.ContainerID {
393394
if containerID == container.ID {
394-
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: d.Config.Labels, Tty: d.getContainerTTY(container.ID)}
395+
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: d.Config.Labels, Tty: d.getContainerTTY(ctx, container.ID)}
395396
}
396397
}
397398

@@ -401,27 +402,27 @@ func (d *DockerSource) EvalContainer(container dockerTypes.Container) *Container
401402
name = name[1:]
402403
}
403404
if name == containerName {
404-
return &ContainerConfig{ID: container.ID, Name: name, Labels: d.Config.Labels, Tty: d.getContainerTTY(container.ID)}
405+
return &ContainerConfig{ID: container.ID, Name: name, Labels: d.Config.Labels, Tty: d.getContainerTTY(ctx, container.ID)}
405406
}
406407
}
407408
}
408409

409410
for _, cont := range d.compiledContainerID {
410411
if matched := cont.MatchString(container.ID); matched {
411-
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: d.Config.Labels, Tty: d.getContainerTTY(container.ID)}
412+
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: d.Config.Labels, Tty: d.getContainerTTY(ctx, container.ID)}
412413
}
413414
}
414415

415416
for _, cont := range d.compiledContainerName {
416417
for _, name := range container.Names {
417418
if matched := cont.MatchString(name); matched {
418-
return &ContainerConfig{ID: container.ID, Name: name, Labels: d.Config.Labels, Tty: d.getContainerTTY(container.ID)}
419+
return &ContainerConfig{ID: container.ID, Name: name, Labels: d.Config.Labels, Tty: d.getContainerTTY(ctx, container.ID)}
419420
}
420421
}
421422
}
422423

423424
if d.Config.UseContainerLabels {
424-
parsedLabels := d.getContainerLabels(container.ID)
425+
parsedLabels := d.getContainerLabels(ctx, container.ID)
425426
if len(parsedLabels) == 0 {
426427
d.logger.Tracef("container has no 'crowdsec' labels set, ignoring container: %s", container.ID)
427428
return nil
@@ -458,13 +459,13 @@ func (d *DockerSource) EvalContainer(container dockerTypes.Container) *Container
458459
}
459460
d.logger.Errorf("label %s is not a string", k)
460461
}
461-
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: labels, Tty: d.getContainerTTY(container.ID)}
462+
return &ContainerConfig{ID: container.ID, Name: container.Names[0], Labels: labels, Tty: d.getContainerTTY(ctx, container.ID)}
462463
}
463464

464465
return nil
465466
}
466467

467-
func (d *DockerSource) WatchContainer(monitChan chan *ContainerConfig, deleteChan chan *ContainerConfig) error {
468+
func (d *DockerSource) WatchContainer(ctx context.Context, monitChan chan *ContainerConfig, deleteChan chan *ContainerConfig) error {
468469
ticker := time.NewTicker(d.CheckIntervalDuration)
469470
d.logger.Infof("Container watcher started, interval: %s", d.CheckIntervalDuration.String())
470471
for {
@@ -475,7 +476,7 @@ func (d *DockerSource) WatchContainer(monitChan chan *ContainerConfig, deleteCha
475476
case <-ticker.C:
476477
// to track for garbage collection
477478
runningContainersID := make(map[string]bool)
478-
runningContainer, err := d.Client.ContainerList(context.Background(), dockerTypes.ContainerListOptions{})
479+
runningContainer, err := d.Client.ContainerList(ctx, dockerTypes.ContainerListOptions{})
479480
if err != nil {
480481
if strings.Contains(strings.ToLower(err.Error()), "cannot connect to the docker daemon at") {
481482
for idx, container := range d.runningContainerState {
@@ -501,7 +502,7 @@ func (d *DockerSource) WatchContainer(monitChan chan *ContainerConfig, deleteCha
501502
if _, ok := d.runningContainerState[container.ID]; ok {
502503
continue
503504
}
504-
if containerConfig := d.EvalContainer(container); containerConfig != nil {
505+
if containerConfig := d.EvalContainer(ctx, container); containerConfig != nil {
505506
monitChan <- containerConfig
506507
}
507508
}
@@ -524,10 +525,10 @@ func (d *DockerSource) StreamingAcquisition(ctx context.Context, out chan types.
524525
deleteChan := make(chan *ContainerConfig)
525526
d.logger.Infof("Starting docker acquisition")
526527
t.Go(func() error {
527-
return d.DockerManager(monitChan, deleteChan, out)
528+
return d.DockerManager(ctx, monitChan, deleteChan, out)
528529
})
529530

530-
return d.WatchContainer(monitChan, deleteChan)
531+
return d.WatchContainer(ctx, monitChan, deleteChan)
531532
}
532533

533534
func (d *DockerSource) Dump() interface{} {
@@ -541,9 +542,9 @@ func ReadTailScanner(scanner *bufio.Scanner, out chan string, t *tomb.Tomb) erro
541542
return scanner.Err()
542543
}
543544

544-
func (d *DockerSource) TailDocker(container *ContainerConfig, outChan chan types.Event, deleteChan chan *ContainerConfig) error {
545+
func (d *DockerSource) TailDocker(ctx context.Context, container *ContainerConfig, outChan chan types.Event, deleteChan chan *ContainerConfig) error {
545546
container.logger.Infof("start tail for container %s", container.Name)
546-
dockerReader, err := d.Client.ContainerLogs(context.Background(), container.ID, *d.containerLogsOptions)
547+
dockerReader, err := d.Client.ContainerLogs(ctx, container.ID, *d.containerLogsOptions)
547548
if err != nil {
548549
container.logger.Errorf("unable to read logs from container: %+v", err)
549550
return err
@@ -601,7 +602,7 @@ func (d *DockerSource) TailDocker(container *ContainerConfig, outChan chan types
601602
}
602603
}
603604

604-
func (d *DockerSource) DockerManager(in chan *ContainerConfig, deleteChan chan *ContainerConfig, outChan chan types.Event) error {
605+
func (d *DockerSource) DockerManager(ctx context.Context, in chan *ContainerConfig, deleteChan chan *ContainerConfig, outChan chan types.Event) error {
605606
d.logger.Info("DockerSource Manager started")
606607
for {
607608
select {
@@ -610,7 +611,7 @@ func (d *DockerSource) DockerManager(in chan *ContainerConfig, deleteChan chan *
610611
newContainer.t = &tomb.Tomb{}
611612
newContainer.logger = d.logger.WithField("container_name", newContainer.Name)
612613
newContainer.t.Go(func() error {
613-
return d.TailDocker(newContainer, outChan, deleteChan)
614+
return d.TailDocker(ctx, newContainer, outChan, deleteChan)
614615
})
615616
d.runningContainerState[newContainer.ID] = newContainer
616617
}

pkg/acquisition/modules/kafka/kafka.go

+6-6
Original file line numberDiff line numberDiff line change
@@ -147,12 +147,12 @@ func (k *KafkaSource) Dump() interface{} {
147147
return k
148148
}
149149

150-
func (k *KafkaSource) ReadMessage(out chan types.Event) error {
150+
func (k *KafkaSource) ReadMessage(ctx context.Context, out chan types.Event) error {
151151
// Start processing from latest Offset
152-
k.Reader.SetOffsetAt(context.Background(), time.Now())
152+
k.Reader.SetOffsetAt(ctx, time.Now())
153153
for {
154154
k.logger.Tracef("reading message from topic '%s'", k.Config.Topic)
155-
m, err := k.Reader.ReadMessage(context.Background())
155+
m, err := k.Reader.ReadMessage(ctx)
156156
if err != nil {
157157
if errors.Is(err, io.EOF) {
158158
return nil
@@ -184,10 +184,10 @@ func (k *KafkaSource) ReadMessage(out chan types.Event) error {
184184
}
185185
}
186186

187-
func (k *KafkaSource) RunReader(out chan types.Event, t *tomb.Tomb) error {
187+
func (k *KafkaSource) RunReader(ctx context.Context, out chan types.Event, t *tomb.Tomb) error {
188188
k.logger.Debugf("starting %s datasource reader goroutine with configuration %+v", dataSourceName, k.Config)
189189
t.Go(func() error {
190-
return k.ReadMessage(out)
190+
return k.ReadMessage(ctx, out)
191191
})
192192
//nolint //fp
193193
for {
@@ -207,7 +207,7 @@ func (k *KafkaSource) StreamingAcquisition(ctx context.Context, out chan types.E
207207

208208
t.Go(func() error {
209209
defer trace.CatchPanic("crowdsec/acquis/kafka/live")
210-
return k.RunReader(out, t)
210+
return k.RunReader(ctx, out, t)
211211
})
212212

213213
return nil

pkg/acquisition/modules/kubernetesaudit/k8s_audit.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -149,7 +149,7 @@ func (ka *KubernetesAuditSource) StreamingAcquisition(ctx context.Context, out c
149149
})
150150
<-t.Dying()
151151
ka.logger.Infof("Stopping k8s-audit server on %s:%d%s", ka.config.ListenAddr, ka.config.ListenPort, ka.config.WebhookPath)
152-
ka.server.Shutdown(context.TODO())
152+
ka.server.Shutdown(ctx)
153153
return nil
154154
})
155155
return nil

0 commit comments

Comments
 (0)