Files
diun/internal/provider/swarm/service.go
2019-12-22 19:04:56 +01:00

54 lines
1.5 KiB
Go

package swarm
import (
"fmt"
"reflect"
"github.com/crazy-max/diun/internal/model"
"github.com/crazy-max/diun/internal/provider"
"github.com/crazy-max/diun/pkg/docker"
"github.com/docker/docker/api/types/filters"
"github.com/rs/zerolog/log"
)
func (c *Client) listServiceImage(id string, elt model.PrdSwarm) []model.Image {
sublog := log.With().
Str("provider", fmt.Sprintf("swarm-%s", id)).
Logger()
cli, err := docker.NewClient(elt.Endpoint, elt.APIVersion, elt.TLSCertsPath, elt.TLSVerify)
if err != nil {
sublog.Error().Err(err).Msg("Cannot create Docker client")
return []model.Image{}
}
svcs, err := cli.ServiceList(filters.NewArgs())
if err != nil {
sublog.Error().Err(err).Msg("Cannot list Swarm services")
return []model.Image{}
}
var list []model.Image
for _, svc := range svcs {
local, err := cli.IsLocalImage(svc.Spec.TaskTemplate.ContainerSpec.Image)
if err != nil {
sublog.Error().Err(err).Msgf("Cannot inspect image from service %s", svc.ID)
continue
} else if local {
sublog.Debug().Msgf("Skip locally built image for service %s", svc.ID)
continue
}
image, err := provider.ValidateContainerImage(svc.Spec.TaskTemplate.ContainerSpec.Image, svc.Spec.Labels, elt.WatchByDefault)
if err != nil {
sublog.Error().Err(err).Msgf("Cannot get image from service %s", svc.ID)
continue
} else if reflect.DeepEqual(image, model.Image{}) {
sublog.Debug().Msgf("Watch disabled for service %s", svc.ID)
continue
}
list = append(list, image)
}
return list
}