forked from knative/serving
/
controller.go
83 lines (69 loc) · 3.07 KB
/
controller.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
/*
Copyright 2019 The Knative Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package gc
import (
"context"
"k8s.io/client-go/tools/cache"
"knative.dev/pkg/configmap"
"knative.dev/pkg/controller"
"knative.dev/pkg/logging"
v1 "knative.dev/serving/pkg/apis/serving/v1"
servingclient "knative.dev/serving/pkg/client/injection/client"
configurationinformer "knative.dev/serving/pkg/client/injection/informers/serving/v1/configuration"
revisioninformer "knative.dev/serving/pkg/client/injection/informers/serving/v1/revision"
configreconciler "knative.dev/serving/pkg/client/injection/reconciler/serving/v1/configuration"
gcconfig "knative.dev/serving/pkg/gc"
servingreconciler "knative.dev/serving/pkg/reconciler"
configns "knative.dev/serving/pkg/reconciler/gc/config"
)
const controllerAgentName = "revision-gc-controller"
// NewController creates a new Garbage Collection controller
func NewController(
ctx context.Context,
cmw configmap.Watcher,
) *controller.Impl {
ctx = servingreconciler.AnnotateLoggerWithName(ctx, controllerAgentName)
logger := logging.FromContext(ctx)
configurationInformer := configurationinformer.Get(ctx)
revisionInformer := revisioninformer.Get(ctx)
c := &reconciler{
client: servingclient.Get(ctx),
revisionLister: revisionInformer.Lister(),
}
return configreconciler.NewImpl(ctx, c, func(impl *controller.Impl) controller.Options {
logger.Info("Setting up event handlers")
// Since the gc controller came from the configuration controller, having event handlers
// on both configuration and revision matches the existing behaviors of the configuration
// controller. This is to minimize risk heading into v1.
// TODO (taragu): probably one or both of these event handlers are not needed
configurationInformer.Informer().AddEventHandler(controller.HandleAll(impl.Enqueue))
revisionInformer.Informer().AddEventHandler(cache.FilteringResourceEventHandler{
FilterFunc: controller.FilterGroupKind(v1.Kind("Configuration")),
Handler: controller.HandleAll(impl.EnqueueControllerOf),
})
logger.Info("Setting up ConfigMap receivers with resync func")
configsToResync := []interface{}{
&gcconfig.Config{},
}
resync := configmap.TypeFilter(configsToResync...)(func(string, interface{}) {
// Triggers syncs on all revisions when configuration changes.
impl.GlobalResync(revisionInformer.Informer())
})
logger.Info("Setting up ConfigMap receivers")
configStore := configns.NewStore(logging.WithLogger(ctx, logger.Named("config-store")), resync)
configStore.WatchConfigs(cmw)
return controller.Options{
ConfigStore: configStore,
}
})
}