Files
sablier/pkg/provider/docker/container_list.go
Alexis Couvreur fad97d7901 fix(provider): add debug logging (#653)
* fix(provider): add debug logging

Add a bunch of debug logging calls

* return a swarm service pointer

* revert to service list with status true

* change trace to debug

* --no-verify
2025-07-30 22:44:20 -04:00

85 lines
2.3 KiB
Go

package docker
import (
"context"
"fmt"
"log/slog"
"strings"
"github.com/docker/docker/api/types/container"
"github.com/docker/docker/api/types/filters"
"github.com/sablierapp/sablier/pkg/provider"
"github.com/sablierapp/sablier/pkg/sablier"
)
func (p *Provider) InstanceList(ctx context.Context, options provider.InstanceListOptions) ([]sablier.InstanceConfiguration, error) {
args := filters.NewArgs()
args.Add("label", fmt.Sprintf("%s=true", "sablier.enable"))
p.l.DebugContext(ctx, "listing containers", slog.Group("options", slog.Bool("all", options.All), slog.Any("filters", args)))
containers, err := p.Client.ContainerList(ctx, container.ListOptions{
All: options.All,
Filters: args,
})
if err != nil {
return nil, fmt.Errorf("cannot list containers: %w", err)
}
p.l.DebugContext(ctx, "containers listed", slog.Int("count", len(containers)))
instances := make([]sablier.InstanceConfiguration, 0, len(containers))
for _, c := range containers {
instance := containerToInstance(c)
instances = append(instances, instance)
}
return instances, nil
}
func containerToInstance(c container.Summary) sablier.InstanceConfiguration {
var group string
if _, ok := c.Labels["sablier.enable"]; ok {
if g, ok := c.Labels["sablier.group"]; ok {
group = g
} else {
group = "default"
}
}
return sablier.InstanceConfiguration{
Name: strings.TrimPrefix(c.Names[0], "/"), // Containers name are reported with a leading slash
Group: group,
}
}
func (p *Provider) InstanceGroups(ctx context.Context) (map[string][]string, error) {
args := filters.NewArgs()
args.Add("label", fmt.Sprintf("%s=true", "sablier.enable"))
p.l.DebugContext(ctx, "listing containers", slog.Group("options", slog.Bool("all", true), slog.Any("filters", args)))
containers, err := p.Client.ContainerList(ctx, container.ListOptions{
All: true,
Filters: args,
})
if err != nil {
return nil, fmt.Errorf("cannot list containers: %w", err)
}
p.l.DebugContext(ctx, "containers listed", slog.Int("count", len(containers)))
groups := make(map[string][]string)
for _, c := range containers {
groupName := c.Labels["sablier.group"]
if len(groupName) == 0 {
groupName = "default"
}
group := groups[groupName]
group = append(group, strings.TrimPrefix(c.Names[0], "/"))
groups[groupName] = group
}
return groups, nil
}