126 lines
2.8 KiB
Go
126 lines
2.8 KiB
Go
package controller
|
|
|
|
import (
|
|
"k8s.io/client-go/pkg/api"
|
|
"k8s.io/client-go/pkg/api/v1"
|
|
"k8s.io/client-go/pkg/runtime"
|
|
"k8s.io/client-go/pkg/watch"
|
|
|
|
"github.bus.zalan.do/acid/postgres-operator/pkg/spec"
|
|
"github.bus.zalan.do/acid/postgres-operator/pkg/util"
|
|
)
|
|
|
|
func (c *Controller) podListFunc(options api.ListOptions) (runtime.Object, error) {
|
|
var labelSelector string
|
|
var fieldSelector string
|
|
|
|
if options.LabelSelector != nil {
|
|
labelSelector = options.LabelSelector.String()
|
|
}
|
|
|
|
if options.FieldSelector != nil {
|
|
fieldSelector = options.FieldSelector.String()
|
|
}
|
|
opts := v1.ListOptions{
|
|
LabelSelector: labelSelector,
|
|
FieldSelector: fieldSelector,
|
|
Watch: options.Watch,
|
|
ResourceVersion: options.ResourceVersion,
|
|
TimeoutSeconds: options.TimeoutSeconds,
|
|
}
|
|
|
|
return c.KubeClient.CoreV1().Pods(c.PodNamespace).List(opts)
|
|
}
|
|
|
|
func (c *Controller) podWatchFunc(options api.ListOptions) (watch.Interface, error) {
|
|
var labelSelector string
|
|
var fieldSelector string
|
|
|
|
if options.LabelSelector != nil {
|
|
labelSelector = options.LabelSelector.String()
|
|
}
|
|
|
|
if options.FieldSelector != nil {
|
|
fieldSelector = options.FieldSelector.String()
|
|
}
|
|
|
|
opts := v1.ListOptions{
|
|
LabelSelector: labelSelector,
|
|
FieldSelector: fieldSelector,
|
|
Watch: options.Watch,
|
|
ResourceVersion: options.ResourceVersion,
|
|
TimeoutSeconds: options.TimeoutSeconds,
|
|
}
|
|
|
|
return c.KubeClient.CoreV1Client.Pods(c.PodNamespace).Watch(opts)
|
|
}
|
|
|
|
func (c *Controller) podAdd(obj interface{}) {
|
|
pod, ok := obj.(*v1.Pod)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
podEvent := spec.PodEvent{
|
|
ClusterName: util.PodClusterName(pod),
|
|
PodName: util.NameFromMeta(pod.ObjectMeta),
|
|
CurPod: pod,
|
|
EventType: spec.PodEventAdd,
|
|
}
|
|
|
|
c.podCh <- podEvent
|
|
}
|
|
|
|
func (c *Controller) podUpdate(prev, cur interface{}) {
|
|
prevPod, ok := prev.(*v1.Pod)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
curPod, ok := cur.(*v1.Pod)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
podEvent := spec.PodEvent{
|
|
ClusterName: util.PodClusterName(curPod),
|
|
PodName: util.NameFromMeta(curPod.ObjectMeta),
|
|
PrevPod: prevPod,
|
|
CurPod: curPod,
|
|
EventType: spec.PodEventUpdate,
|
|
}
|
|
|
|
c.podCh <- podEvent
|
|
}
|
|
|
|
func (c *Controller) podDelete(obj interface{}) {
|
|
pod, ok := obj.(*v1.Pod)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
podEvent := spec.PodEvent{
|
|
ClusterName: util.PodClusterName(pod),
|
|
PodName: util.NameFromMeta(pod.ObjectMeta),
|
|
CurPod: pod,
|
|
EventType: spec.PodEventDelete,
|
|
}
|
|
|
|
c.podCh <- podEvent
|
|
}
|
|
|
|
func (c *Controller) podEventsDispatcher(stopCh <-chan struct{}) {
|
|
c.logger.Infof("Watching all Pod events")
|
|
for {
|
|
select {
|
|
case event := <-c.podCh:
|
|
if subscriber, ok := c.clusters[event.ClusterName]; ok {
|
|
c.logger.Debugf("Sending %s event of Pod '%s' to the '%s' cluster channel", event.EventType, event.PodName, event.ClusterName)
|
|
go subscriber.ReceivePodEvent(event)
|
|
}
|
|
case <-stopCh:
|
|
return
|
|
}
|
|
}
|
|
}
|