0
0
Fork 0
mirror of https://github.com/crazy-max/diun.git synced 2025-04-10 13:57:31 +00:00
crazy-max_diun/internal/provider/kubernetes/pod.go
CrazyMax 9b4e62474b
Handle digest based image reference ()
Co-authored-by: CrazyMax <crazy-max@users.noreply.github.com>
2021-04-25 00:28:20 +02:00

66 lines
1.7 KiB
Go

package kubernetes
import (
"reflect"
"github.com/crazy-max/diun/v4/internal/model"
"github.com/crazy-max/diun/v4/internal/provider"
"github.com/crazy-max/diun/v4/pkg/k8s"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
func (c *Client) listPodImage() []model.Image {
cli, err := k8s.New(k8s.Options{
Endpoint: c.config.Endpoint,
Token: c.config.Token,
TokenFile: c.config.TokenFile,
CertAuthFilePath: c.config.CertAuthFilePath,
TLSInsecure: c.config.TLSInsecure,
Namespaces: c.config.Namespaces,
})
if err != nil {
c.logger.Error().Err(err).Msg("Cannot create Kubernetes client")
return []model.Image{}
}
pods, err := cli.PodList(metav1.ListOptions{})
if err != nil {
c.logger.Error().Err(err).Msg("Cannot list Kubernetes pods")
return []model.Image{}
}
var list []model.Image
for _, pod := range pods {
for _, ctn := range pod.Spec.Containers {
c.logger.Debug().
Str("pod_name", pod.Name).
Interface("pod_annot", pod.Annotations).
Str("ctn_name", ctn.Name).
Str("ctn_image", ctn.Image).
Msg("Validate image")
image, err := provider.ValidateImage(ctn.Image, pod.Annotations, *c.config.WatchByDefault)
if err != nil {
c.logger.Error().Err(err).
Str("pod_name", pod.Name).
Interface("pod_annot", pod.Annotations).
Str("ctn_name", ctn.Name).
Str("ctn_image", ctn.Image).
Msg("Invalid image")
continue
} else if reflect.DeepEqual(image, model.Image{}) {
c.logger.Debug().
Str("pod_name", pod.Name).
Interface("pod_annot", pod.Annotations).
Str("ctn_name", ctn.Name).
Str("ctn_image", ctn.Image).
Msg("Watch disabled")
continue
}
list = append(list, image)
}
}
return list
}