grim/convey

Port from logrus to log/slog
default tip
5 months ago, Elliott Sales de Andrade
c588f9b3f559
Port from logrus to log/slog

This doesn't really take much advantage of structured logging beyond what is already done (`id` and `idColor`), and consequently the log handler does not try to do any handling of anything more than that (i.e., grouping, or arbitrary attributes beyond those defined).

One should maybe have a `Context` available to pass in, but there isn't one, and anyway, the log handler doesn't use it, so I've passed in a `TODO` instead.

Everything else is just normal import/rename changes.

Testing Done:
Ran `go run . run`

Reviewed at https://reviews.imfreedom.org/r/2871/
package docker
import (
"fmt"
"log/slog"
"keep.imfreedom.org/grim/convey/environment"
"keep.imfreedom.org/grim/convey/podman"
"keep.imfreedom.org/grim/convey/runtime"
"keep.imfreedom.org/grim/convey/yaml"
)
type Tag struct {
Source string `yaml:"source"`
Destination string `yaml:"destination"`
Destinations yaml.StringOrSlice `yaml:"destinations"`
realTag *podman.Tag
}
// New creates a new Tag task.
func (t *Tag) New() runtime.Task {
return &Tag{}
}
// Valid validates the Tag task.
func (t *Tag) Valid() error {
if t.Destination != "" {
t.Destinations = append([]string{t.Destination}, t.Destinations...)
}
t.realTag = &podman.Tag{
Image: t.Source,
Targets: t.Destinations,
}
return t.realTag.Valid()
}
// Execute runs the task.
func (t *Tag) Execute(name string, logger *slog.Logger, env environment.Environment, rt *runtime.Runtime) error {
return t.realTag.Execute(name, logger, env, rt)
}
func (t *Tag) Deprecated() error {
return fmt.Errorf("docker/tag has been deprecated in favor of podman/tag since 0.15.0")
}