squadron/cmd/actions/up.go
Kevin Franklin Kim 4b88ffbd15
feat: bump linter
2025-10-10 11:54:31 +02:00

128 lines
3.8 KiB
Go

package actions
import (
"os"
"github.com/foomo/squadron"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/plumbing"
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
func NewUp(c *viper.Viper) *cobra.Command {
x := viper.New()
cmd := &cobra.Command{
Use: "up [SQUADRON] [UNIT...]",
Short: "installs the squadron or given units",
Example: " squadron up storefinder frontend backend --namespace demo --build --push -- --dry-run",
RunE: func(cmd *cobra.Command, args []string) error {
sq := squadron.New(cwd, x.GetString("namespace"), c.GetStringSlice("file"))
if err := sq.MergeConfigFiles(cmd.Context()); err != nil {
return errors.Wrap(err, "failed to merge config files")
}
args, helmArgs := parseExtraArgs(args)
squadronName, unitNames := parseSquadronAndUnitNames(args)
if err := sq.FilterConfig(cmd.Context(), squadronName, unitNames, x.GetStringSlice("tags")); err != nil {
return errors.Wrap(err, "failed to filter config")
}
if err := sq.RenderConfig(cmd.Context()); err != nil {
return errors.Wrap(err, "failed to render config")
}
if x.GetBool("bake") {
if err := sq.Bake(cmd.Context(), x.GetStringSlice("bake-args")); err != nil {
return errors.Wrap(err, "failed to bake units")
}
}
if x.GetBool("build") {
if err := sq.Build(cmd.Context(), x.GetStringSlice("build-args"), x.GetInt("parallel")); err != nil {
return errors.Wrap(err, "failed to build units")
}
}
if x.GetBool("push") {
if err := sq.Push(cmd.Context(), x.GetStringSlice("push-args"), x.GetInt("parallel")); err != nil {
return errors.Wrap(err, "failed to push units")
}
}
if err := sq.UpdateLocalDependencies(cmd.Context(), x.GetInt("parallel")); err != nil {
return err
}
status := squadron.Status{
Squadron: version,
User: "unknown",
}
if wd, err := os.Getwd(); err == nil {
if value := os.Getenv("GIT_DIR"); value != "" {
wd = value
}
if repo, err := git.PlainOpen(wd); err == nil {
if c, err := repo.Config(); err == nil {
status.User = c.User.Name
}
if ref, err := repo.Head(); err == nil {
status.Branch = ref.Name().Short()
status.Commit = ref.Hash().String()
if tags, err := repo.Tags(); err == nil {
_ = tags.ForEach(func(r *plumbing.Reference) error {
if r.Hash() == ref.Hash() {
status.Branch = r.Name().Short()
return errors.New("found tag")
}
return nil
})
}
}
}
}
return sq.Up(cmd.Context(), helmArgs, status, x.GetInt("parallel"))
},
}
flags := cmd.Flags()
flags.StringP("namespace", "n", "default", "set the namespace name or template (default, squadron-{{.Squadron}}-{{.Unit}})")
_ = x.BindPFlag("namespace", flags.Lookup("namespace"))
flags.Bool("bake", false, "bakes or rebakes units")
_ = x.BindPFlag("bake", flags.Lookup("bake"))
flags.Bool("build", false, "builds or rebuilds units")
_ = x.BindPFlag("build", flags.Lookup("build"))
flags.Bool("push", false, "pushes units to the registry")
_ = x.BindPFlag("push", flags.Lookup("push"))
flags.Int("parallel", 1, "run command in parallel")
_ = x.BindPFlag("parallel", flags.Lookup("parallel"))
flags.StringArray("bake-args", nil, "additional docker buildx bake args")
_ = x.BindPFlag("bake-args", flags.Lookup("bake-args"))
flags.StringArray("build-args", nil, "additional docker buildx build args")
_ = x.BindPFlag("build-args", flags.Lookup("build-args"))
flags.StringArray("push-args", nil, "additional docker push args")
_ = x.BindPFlag("push-args", flags.Lookup("push-args"))
flags.StringSlice("tags", nil, "list of tags to include or exclude (can specify multiple or separate values with commas: tag1,tag2,-tag3)")
_ = x.BindPFlag("tags", flags.Lookup("tags"))
return cmd
}