/
service_wrangler.go
53 lines (43 loc) · 1.13 KB
/
service_wrangler.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
package service
import (
"context"
corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/labels"
"sigs.k8s.io/controller-runtime/pkg/client"
)
type ServiceWrangler struct {
client client.Client
service corev1.Service
}
func (sw *ServiceWrangler) ExistingIPs() []string {
var ips []string
for _, ingress := range sw.service.Status.LoadBalancer.Ingress {
if ingress.IP != "" {
ips = append(ips, ingress.IP)
}
}
return ips
}
func (sw *ServiceWrangler) FindPods() (*corev1.PodList, error) {
selector, err := labels.Parse(svcNameLabel + "=" + sw.service.Name)
if err != nil {
return nil, err
}
opts := &client.ListOptions{
Namespace: sw.service.Namespace,
LabelSelector: selector,
}
pods := &corev1.PodList{}
err = sw.client.List(context.TODO(), opts, pods)
return pods, err
}
func (sw *ServiceWrangler) UpdateAddresses(ips []string) error {
svc := sw.service.DeepCopy()
svc.Status.LoadBalancer.Ingress = nil
for _, ip := range ips {
svc.Status.LoadBalancer.Ingress = append(svc.Status.LoadBalancer.Ingress, corev1.LoadBalancerIngress{
IP: ip,
})
}
return sw.client.Status().Update(context.TODO(), svc)
}