-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathingress.go
82 lines (73 loc) · 1.92 KB
/
ingress.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
package kube
import (
"context"
"fmt"
"github.com/hashicorp/go-version"
v1 "k8s.io/api/core/v1"
v12 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/clientcmd"
)
type client struct {
clientset kubernetes.Interface
}
func FindIngresses(kubeconfig string) []string {
// use the current context in kubeconfig
config, err := clientcmd.BuildConfigFromFlags("", kubeconfig)
if err != nil {
panic(err.Error())
}
// create the clientset
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
panic(err.Error())
}
return getIngresses(client{clientset: clientset})
}
func getIngresses(c client) []string {
var ret []string
serverVersion, err := c.clientset.Discovery().ServerVersion()
if err != nil {
panic(err.Error())
}
apiVersion := version.Must(version.NewVersion(serverVersion.String()))
hasExt, err := version.NewConstraint("< 1.22")
if err != nil {
panic(err.Error())
}
if hasExt.Check(apiVersion) {
ingressList, err := c.clientset.ExtensionsV1beta1().Ingresses(v1.NamespaceAll).List(context.TODO(), v12.ListOptions{})
if err != nil {
panic(err.Error())
}
ingresses := ingressList.Items
if len(ingresses) > 0 {
for _, ingress := range ingresses {
for _, rule := range ingress.Spec.Rules {
if rule.Host != "" {
for _, p := range rule.HTTP.Paths {
ret = append(ret, fmt.Sprintf("https://%s%s", rule.Host, p.Path))
}
}
}
}
}
}
ingressList, err := c.clientset.NetworkingV1().Ingresses(v1.NamespaceAll).List(context.TODO(), v12.ListOptions{})
if err != nil {
panic(err.Error())
}
ingresses := ingressList.Items
if len(ingresses) > 0 {
for _, ingress := range ingresses {
for _, rule := range ingress.Spec.Rules {
if rule.Host != "" && rule.HTTP != nil {
for _, p := range rule.HTTP.Paths {
ret = append(ret, fmt.Sprintf("https://%s%s", rule.Host, p.Path))
}
}
}
}
}
return ret
}