Compare commits
	
		
			7 Commits
		
	
	
		
			main
			...
			upgrade-cl
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b81f5651d3 | |||
| 7d80f4d56b | |||
| 114bdc5ce9 | |||
| 8a7d17f37b | |||
| deb4293fba | |||
| ac39d6ab97 | |||
| 428426b6b7 | 
| @ -1,7 +1,7 @@ | ||||
| package app | ||||
|  | ||||
| import ( | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var AppCommand = cli.Command{ | ||||
| @ -10,28 +10,28 @@ var AppCommand = cli.Command{ | ||||
| 	Usage:       "Manage apps", | ||||
| 	ArgsUsage:   "<domain>", | ||||
| 	Description: "Functionality for managing the life cycle of your apps", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		appBackupCommand, | ||||
| 		appCheckCommand, | ||||
| 		appCmdCommand, | ||||
| 		appConfigCommand, | ||||
| 		appCpCommand, | ||||
| 		appDeployCommand, | ||||
| 		appErrorsCommand, | ||||
| 		appListCommand, | ||||
| 		appLogsCommand, | ||||
| 		appNewCommand, | ||||
| 		appPsCommand, | ||||
| 		appRemoveCommand, | ||||
| 		appRestartCommand, | ||||
| 		appRestoreCommand, | ||||
| 		appRollbackCommand, | ||||
| 		appRunCommand, | ||||
| 		appSecretCommand, | ||||
| 		appServicesCommand, | ||||
| 		appUndeployCommand, | ||||
| 		appUpgradeCommand, | ||||
| 		appVersionCommand, | ||||
| 		appVolumeCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&appBackupCommand, | ||||
| 		&appCheckCommand, | ||||
| 		&appCmdCommand, | ||||
| 		&appConfigCommand, | ||||
| 		&appCpCommand, | ||||
| 		&appDeployCommand, | ||||
| 		&appErrorsCommand, | ||||
| 		&appListCommand, | ||||
| 		&appLogsCommand, | ||||
| 		&appNewCommand, | ||||
| 		&appPsCommand, | ||||
| 		&appRemoveCommand, | ||||
| 		&appRestartCommand, | ||||
| 		&appRestoreCommand, | ||||
| 		&appRollbackCommand, | ||||
| 		&appRunCommand, | ||||
| 		&appSecretCommand, | ||||
| 		&appServicesCommand, | ||||
| 		&appUndeployCommand, | ||||
| 		&appUpgradeCommand, | ||||
| 		&appVersionCommand, | ||||
| 		&appVolumeCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/client" | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var snapshot string | ||||
| @ -287,10 +287,10 @@ var appBackupCommand = cli.Command{ | ||||
| 	Aliases:   []string{"b"}, | ||||
| 	Usage:     "Manage app backups", | ||||
| 	ArgsUsage: "<domain>", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		appBackupListCommand, | ||||
| 		appBackupSnapshotsCommand, | ||||
| 		appBackupDownloadCommand, | ||||
| 		appBackupCreateCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&appBackupListCommand, | ||||
| 		&appBackupSnapshotsCommand, | ||||
| 		&appBackupDownloadCommand, | ||||
| 		&appBackupCreateCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	recipePkg "coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appCheckCommand = cli.Command{ | ||||
|  | ||||
| @ -17,7 +17,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	recipePkg "coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appCmdCommand = cli.Command{ | ||||
| @ -45,10 +45,10 @@ Example: | ||||
| 		internal.ChaosFlag, | ||||
| 	}, | ||||
| 	Before:      internal.SubCommandBefore, | ||||
| 	Subcommands: []cli.Command{appCmdListCommand}, | ||||
| 	Subcommands: []*cli.Command{&appCmdListCommand}, | ||||
| 	BashComplete: func(ctx *cli.Context) { | ||||
| 		args := ctx.Args() | ||||
| 		switch len(args) { | ||||
| 		switch args.Len() { | ||||
| 		case 0: | ||||
| 			autocomplete.AppNameComplete(ctx) | ||||
| 		case 1: | ||||
| @ -84,7 +84,7 @@ Example: | ||||
| 			internal.ShowSubcommandHelpAndError(c, errors.New("cannot use --local & --user together")) | ||||
| 		} | ||||
|  | ||||
| 		hasCmdArgs, parsedCmdArgs := parseCmdArgs(c.Args(), internal.LocalCmd) | ||||
| 		hasCmdArgs, parsedCmdArgs := parseCmdArgs(c.Args().Slice()) | ||||
|  | ||||
| 		abraSh := path.Join(config.RECIPES_DIR, app.Recipe, "abra.sh") | ||||
| 		if _, err := os.Stat(abraSh); err != nil { | ||||
| @ -95,7 +95,7 @@ Example: | ||||
| 		} | ||||
|  | ||||
| 		if internal.LocalCmd { | ||||
| 			if !(len(c.Args()) >= 2) { | ||||
| 			if !(c.Args().Len() >= 2) { | ||||
| 				internal.ShowSubcommandHelpAndError(c, errors.New("missing arguments")) | ||||
| 			} | ||||
|  | ||||
| @ -131,7 +131,7 @@ Example: | ||||
| 				logrus.Fatal(err) | ||||
| 			} | ||||
| 		} else { | ||||
| 			if !(len(c.Args()) >= 3) { | ||||
| 			if !(c.Args().Len() >= 3) { | ||||
| 				internal.ShowSubcommandHelpAndError(c, errors.New("missing arguments")) | ||||
| 			} | ||||
|  | ||||
| @ -180,23 +180,16 @@ Example: | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| func parseCmdArgs(args []string, isLocal bool) (bool, string) { | ||||
| 	var ( | ||||
| 		parsedCmdArgs string | ||||
| 		hasCmdArgs    bool | ||||
| 	) | ||||
|  | ||||
| 	if isLocal { | ||||
| 		if len(args) > 2 { | ||||
| 			return true, fmt.Sprintf("%s ", strings.Join(args[2:], " ")) | ||||
| // Parse the command arguments from the cli args. | ||||
| // Arguments should look like this: | ||||
| // | ||||
| //	DOMAIN COMMAND -- ARGUMENT1 ARGUMENT2 ... | ||||
| func parseCmdArgs(args []string) (bool, string) { | ||||
| 	if len(args) < 4 { | ||||
| 		return false, "" | ||||
| 	} | ||||
| 	} else { | ||||
| 		if len(args) > 3 { | ||||
|  | ||||
| 	return true, fmt.Sprintf("%s ", strings.Join(args[3:], " ")) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return hasCmdArgs, parsedCmdArgs | ||||
| } | ||||
|  | ||||
| func cmdNameComplete(appName string) { | ||||
|  | ||||
| @ -20,7 +20,7 @@ func TestParseCmdArgs(t *testing.T) { | ||||
| 	} | ||||
|  | ||||
| 	for _, test := range tests { | ||||
| 		ok, parsed := parseCmdArgs(test.input, false) | ||||
| 		ok, parsed := parseCmdArgs(test.input) | ||||
| 		if ok != test.shouldParse { | ||||
| 			t.Fatalf("[%s] should not parse", strings.Join(test.input, " ")) | ||||
| 		} | ||||
|  | ||||
| @ -10,7 +10,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appConfigCommand = cli.Command{ | ||||
|  | ||||
| @ -22,7 +22,7 @@ import ( | ||||
| 	"github.com/docker/docker/errdefs" | ||||
| 	"github.com/docker/docker/pkg/archive" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appCpCommand = cli.Command{ | ||||
|  | ||||
| @ -17,7 +17,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"coopcloud.tech/abra/pkg/upstream/stack" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appDeployCommand = cli.Command{ | ||||
|  | ||||
| @ -17,7 +17,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types/filters" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appErrorsCommand = cli.Command{ | ||||
|  | ||||
| @ -13,19 +13,21 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"coopcloud.tech/tagcmp" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var status bool | ||||
| var statusFlag = &cli.BoolFlag{ | ||||
| 	Name:        "status, S", | ||||
| 	Name:        "status", | ||||
| 	Aliases:     []string{"S"}, | ||||
| 	Usage:       "Show app deployment status", | ||||
| 	Destination: &status, | ||||
| } | ||||
|  | ||||
| var recipeFilter string | ||||
| var recipeFlag = &cli.StringFlag{ | ||||
| 	Name:        "recipe, r", | ||||
| 	Name:        "recipe", | ||||
| 	Aliases:     []string{"r"}, | ||||
| 	Value:       "", | ||||
| 	Usage:       "Show apps of a specific recipe", | ||||
| 	Destination: &recipeFilter, | ||||
| @ -33,7 +35,8 @@ var recipeFlag = &cli.StringFlag{ | ||||
|  | ||||
| var listAppServer string | ||||
| var listAppServerFlag = &cli.StringFlag{ | ||||
| 	Name:        "server, s", | ||||
| 	Name:        "server", | ||||
| 	Aliases:     []string{"s"}, | ||||
| 	Value:       "", | ||||
| 	Usage:       "Show apps of a specific server", | ||||
| 	Destination: &listAppServer, | ||||
|  | ||||
| @ -19,7 +19,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types/swarm" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appLogsCommand = cli.Command{ | ||||
|  | ||||
| @ -16,7 +16,7 @@ import ( | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appNewDescription = ` | ||||
| @ -58,7 +58,7 @@ var appNewCommand = cli.Command{ | ||||
| 	ArgsUsage: "[<recipe>] [<version>]", | ||||
| 	BashComplete: func(ctx *cli.Context) { | ||||
| 		args := ctx.Args() | ||||
| 		switch len(args) { | ||||
| 		switch args.Len() { | ||||
| 		case 0: | ||||
| 			autocomplete.RecipeNameComplete(ctx) | ||||
| 		case 1: | ||||
|  | ||||
| @ -17,7 +17,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appPsCommand = cli.Command{ | ||||
|  | ||||
| @ -15,7 +15,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types" | ||||
| 	"github.com/docker/docker/api/types/volume" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appRemoveCommand = cli.Command{ | ||||
|  | ||||
| @ -11,7 +11,7 @@ import ( | ||||
| 	upstream "coopcloud.tech/abra/pkg/upstream/service" | ||||
| 	stack "coopcloud.tech/abra/pkg/upstream/stack" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appRestartCommand = cli.Command{ | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/client" | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var targetPath string | ||||
|  | ||||
| @ -15,7 +15,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/client" | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appRollbackCommand = cli.Command{ | ||||
|  | ||||
| @ -14,7 +14,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types" | ||||
| 	"github.com/docker/docker/api/types/filters" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var user string | ||||
| @ -45,11 +45,11 @@ var appRunCommand = cli.Command{ | ||||
| 	Action: func(c *cli.Context) error { | ||||
| 		app := internal.ValidateApp(c) | ||||
|  | ||||
| 		if len(c.Args()) < 2 { | ||||
| 		if c.Args().Len() < 2 { | ||||
| 			internal.ShowSubcommandHelpAndError(c, errors.New("no <service> provided?")) | ||||
| 		} | ||||
|  | ||||
| 		if len(c.Args()) < 3 { | ||||
| 		if c.Args().Len() < 3 { | ||||
| 			internal.ShowSubcommandHelpAndError(c, errors.New("no <args> provided?")) | ||||
| 		} | ||||
|  | ||||
| @ -68,7 +68,7 @@ var appRunCommand = cli.Command{ | ||||
| 			logrus.Fatal(err) | ||||
| 		} | ||||
|  | ||||
| 		cmd := c.Args()[2:] | ||||
| 		cmd := c.Args().Slice()[2:] | ||||
| 		execCreateOpts := types.ExecConfig{ | ||||
| 			AttachStderr: true, | ||||
| 			AttachStdin:  true, | ||||
|  | ||||
| @ -17,7 +17,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @ -76,7 +76,7 @@ var appSecretGenerateCommand = cli.Command{ | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if len(c.Args()) == 1 && !allSecrets { | ||||
| 		if c.Args().Len() == 1 && !allSecrets { | ||||
| 			err := errors.New("missing arguments <secret>/<version> or '--all'") | ||||
| 			internal.ShowSubcommandHelpAndError(c, err) | ||||
| 		} | ||||
| @ -175,7 +175,7 @@ Example: | ||||
| 	Action: func(c *cli.Context) error { | ||||
| 		app := internal.ValidateApp(c) | ||||
|  | ||||
| 		if len(c.Args()) != 4 { | ||||
| 		if c.Args().Len() != 4 { | ||||
| 			internal.ShowSubcommandHelpAndError(c, errors.New("missing arguments?")) | ||||
| 		} | ||||
|  | ||||
| @ -419,10 +419,10 @@ var appSecretCommand = cli.Command{ | ||||
| 	Aliases:   []string{"s"}, | ||||
| 	Usage:     "Manage app secrets", | ||||
| 	ArgsUsage: "<domain>", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		appSecretGenerateCommand, | ||||
| 		appSecretInsertCommand, | ||||
| 		appSecretRmCommand, | ||||
| 		appSecretLsCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&appSecretGenerateCommand, | ||||
| 		&appSecretInsertCommand, | ||||
| 		&appSecretRmCommand, | ||||
| 		&appSecretLsCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -13,7 +13,7 @@ import ( | ||||
| 	stack "coopcloud.tech/abra/pkg/upstream/stack" | ||||
| 	"github.com/docker/docker/api/types" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appServicesCommand = cli.Command{ | ||||
|  | ||||
| @ -14,7 +14,7 @@ import ( | ||||
| 	"github.com/docker/docker/api/types/filters" | ||||
| 	dockerClient "github.com/docker/docker/client" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var prune bool | ||||
|  | ||||
| @ -15,7 +15,7 @@ import ( | ||||
| 	"coopcloud.tech/tagcmp" | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appUpgradeCommand = cli.Command{ | ||||
|  | ||||
| @ -13,7 +13,7 @@ import ( | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/olekukonko/tablewriter" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| func sortServiceByName(versions [][]string) func(i, j int) bool { | ||||
|  | ||||
| @ -10,7 +10,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/upstream/stack" | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var appVolumeListCommand = cli.Command{ | ||||
| @ -150,8 +150,8 @@ var appVolumeCommand = cli.Command{ | ||||
| 	Aliases:   []string{"vl"}, | ||||
| 	Usage:     "Manage app volumes", | ||||
| 	ArgsUsage: "<domain>", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		appVolumeListCommand, | ||||
| 		appVolumeRemoveCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&appVolumeListCommand, | ||||
| 		&appVolumeRemoveCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -15,7 +15,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/go-git/go-git/v5" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var catalogueGenerateCommand = cli.Command{ | ||||
| @ -217,7 +217,7 @@ var CatalogueCommand = cli.Command{ | ||||
| 	Aliases:     []string{"c"}, | ||||
| 	ArgsUsage:   "<recipe>", | ||||
| 	Description: "This command helps recipe packagers interact with the recipe catalogue", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		catalogueGenerateCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&catalogueGenerateCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
							
								
								
									
										16
									
								
								cli/cli.go
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								cli/cli.go
									
									
									
									
									
								
							| @ -18,7 +18,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"coopcloud.tech/abra/pkg/web" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // AutoCompleteCommand helps people set up auto-complete in their shells | ||||
| @ -153,13 +153,13 @@ func newAbraApp(version, commit string) *cli.App { | ||||
|                          |_| | ||||
| `, | ||||
| 		Version: fmt.Sprintf("%s-%s", version, commit[:7]), | ||||
| 		Commands: []cli.Command{ | ||||
| 			app.AppCommand, | ||||
| 			server.ServerCommand, | ||||
| 			recipe.RecipeCommand, | ||||
| 			catalogue.CatalogueCommand, | ||||
| 			UpgradeCommand, | ||||
| 			AutoCompleteCommand, | ||||
| 		Commands: []*cli.Command{ | ||||
| 			&app.AppCommand, | ||||
| 			&server.ServerCommand, | ||||
| 			&recipe.RecipeCommand, | ||||
| 			&catalogue.CatalogueCommand, | ||||
| 			&UpgradeCommand, | ||||
| 			&AutoCompleteCommand, | ||||
| 		}, | ||||
| 		BashComplete: autocomplete.SubcommandComplete, | ||||
| 	} | ||||
|  | ||||
| @ -5,7 +5,7 @@ import ( | ||||
|  | ||||
| 	logrusStack "github.com/Gurpartap/logrus-stack" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // Secrets stores the variable from SecretsFlag | ||||
| @ -13,7 +13,8 @@ var Secrets bool | ||||
|  | ||||
| // SecretsFlag turns on/off automatically generating secrets | ||||
| var SecretsFlag = &cli.BoolFlag{ | ||||
| 	Name:        "secrets, S", | ||||
| 	Name:        "secrets", | ||||
| 	Aliases:     []string{"S"}, | ||||
| 	Usage:       "Automatically generate secrets", | ||||
| 	Destination: &Secrets, | ||||
| } | ||||
| @ -23,7 +24,8 @@ var Pass bool | ||||
|  | ||||
| // PassFlag turns on/off storing generated secrets in pass | ||||
| var PassFlag = &cli.BoolFlag{ | ||||
| 	Name:        "pass, p", | ||||
| 	Name:        "pass", | ||||
| 	Aliases:     []string{"p"}, | ||||
| 	Usage:       "Store the generated secrets in a local pass store", | ||||
| 	Destination: &Pass, | ||||
| } | ||||
| @ -33,7 +35,8 @@ var PassRemove bool | ||||
|  | ||||
| // PassRemoveFlag turns on/off removing generated secrets from pass | ||||
| var PassRemoveFlag = &cli.BoolFlag{ | ||||
| 	Name:        "pass, p", | ||||
| 	Name:        "pass", | ||||
| 	Aliases:     []string{"p"}, | ||||
| 	Usage:       "Remove generated secrets from a local pass store", | ||||
| 	Destination: &PassRemove, | ||||
| } | ||||
| @ -43,7 +46,8 @@ var Force bool | ||||
|  | ||||
| // ForceFlag turns on/off force functionality. | ||||
| var ForceFlag = &cli.BoolFlag{ | ||||
| 	Name:        "force, f", | ||||
| 	Name:        "force", | ||||
| 	Aliases:     []string{"f"}, | ||||
| 	Usage:       "Perform action without further prompt. Use with care!", | ||||
| 	Destination: &Force, | ||||
| } | ||||
| @ -53,7 +57,8 @@ var Chaos bool | ||||
|  | ||||
| // ChaosFlag turns on/off chaos functionality. | ||||
| var ChaosFlag = &cli.BoolFlag{ | ||||
| 	Name:        "chaos, C", | ||||
| 	Name:        "chaos", | ||||
| 	Aliases:     []string{"C"}, | ||||
| 	Usage:       "Proceed with uncommitted recipes changes. Use with care!", | ||||
| 	Destination: &Chaos, | ||||
| } | ||||
| @ -63,24 +68,29 @@ var Tty bool | ||||
|  | ||||
| // TtyFlag turns on/off tty mode. | ||||
| var TtyFlag = &cli.BoolFlag{ | ||||
| 	Name:        "tty, T", | ||||
| 	Name:        "tty", | ||||
| 	Aliases:     []string{"T"}, | ||||
| 	Usage:       "Disables TTY mode to run this command from a script.", | ||||
| 	Destination: &Tty, | ||||
| } | ||||
|  | ||||
| var NoInput bool | ||||
| var NoInputFlag = &cli.BoolFlag{ | ||||
| 	Name:        "no-input, n", | ||||
| var ( | ||||
| 	NoInput     bool | ||||
| 	NoInputFlag = &cli.BoolFlag{ | ||||
| 		Name:        "no-input", | ||||
| 		Aliases:     []string{"n"}, | ||||
| 		Usage:       "Toggle non-interactive mode", | ||||
| 		Destination: &NoInput, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| // Debug stores the variable from DebugFlag. | ||||
| var Debug bool | ||||
|  | ||||
| // DebugFlag turns on/off verbose logging down to the DEBUG level. | ||||
| var DebugFlag = &cli.BoolFlag{ | ||||
| 	Name:        "debug, d", | ||||
| 	Name:        "debug", | ||||
| 	Aliases:     []string{"d"}, | ||||
| 	Destination: &Debug, | ||||
| 	Usage:       "Show DEBUG messages", | ||||
| } | ||||
| @ -90,7 +100,8 @@ var Offline bool | ||||
|  | ||||
| // DebugFlag turns on/off offline mode. | ||||
| var OfflineFlag = &cli.BoolFlag{ | ||||
| 	Name:        "offline, o", | ||||
| 	Name:        "offline", | ||||
| 	Aliases:     []string{"o"}, | ||||
| 	Destination: &Offline, | ||||
| 	Usage:       "Prefer offline & filesystem access when possible", | ||||
| } | ||||
| @ -100,7 +111,8 @@ var MachineReadable bool | ||||
|  | ||||
| // MachineReadableFlag turns on/off machine readable output where supported | ||||
| var MachineReadableFlag = &cli.BoolFlag{ | ||||
| 	Name:        "machine, m", | ||||
| 	Name:        "machine", | ||||
| 	Aliases:     []string{"m"}, | ||||
| 	Destination: &MachineReadable, | ||||
| 	Usage:       "Output in a machine-readable format (where supported)", | ||||
| } | ||||
| @ -110,133 +122,185 @@ var RC bool | ||||
|  | ||||
| // RCFlag chooses the latest release candidate for install | ||||
| var RCFlag = &cli.BoolFlag{ | ||||
| 	Name:        "rc, r", | ||||
| 	Name:        "rc", | ||||
| 	Aliases:     []string{"c"}, | ||||
| 	Destination: &RC, | ||||
| 	Usage:       "Install the latest release candidate", | ||||
| } | ||||
|  | ||||
| var Major bool | ||||
| var MajorFlag = &cli.BoolFlag{ | ||||
| 	Name:        "major, x", | ||||
| var ( | ||||
| 	Major     bool | ||||
| 	MajorFlag = &cli.BoolFlag{ | ||||
| 		Name:        "major", | ||||
| 		Aliases:     []string{"x"}, | ||||
| 		Usage:       "Increase the major part of the version", | ||||
| 		Destination: &Major, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Minor bool | ||||
| var MinorFlag = &cli.BoolFlag{ | ||||
| 	Name:        "minor, y", | ||||
| var ( | ||||
| 	Minor     bool | ||||
| 	MinorFlag = &cli.BoolFlag{ | ||||
| 		Name:        "minor", | ||||
| 		Aliases:     []string{"y"}, | ||||
| 		Usage:       "Increase the minor part of the version", | ||||
| 		Destination: &Minor, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Patch bool | ||||
| var PatchFlag = &cli.BoolFlag{ | ||||
| 	Name:        "patch, z", | ||||
| var ( | ||||
| 	Patch     bool | ||||
| 	PatchFlag = &cli.BoolFlag{ | ||||
| 		Name:        "patch", | ||||
| 		Aliases:     []string{"z"}, | ||||
| 		Usage:       "Increase the patch part of the version", | ||||
| 		Destination: &Patch, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Dry bool | ||||
| var DryFlag = &cli.BoolFlag{ | ||||
| 	Name:        "dry-run, r", | ||||
| var ( | ||||
| 	Dry     bool | ||||
| 	DryFlag = &cli.BoolFlag{ | ||||
| 		Name:        "dry-run", | ||||
| 		Aliases:     []string{"r"}, | ||||
| 		Usage:       "Only reports changes that would be made", | ||||
| 		Destination: &Dry, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Publish bool | ||||
| var PublishFlag = &cli.BoolFlag{ | ||||
| 	Name:        "publish, p", | ||||
| var ( | ||||
| 	Publish     bool | ||||
| 	PublishFlag = &cli.BoolFlag{ | ||||
| 		Name:        "publish", | ||||
| 		Aliases:     []string{"p"}, | ||||
| 		Usage:       "Publish changes to git.coopcloud.tech", | ||||
| 		Destination: &Publish, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Domain string | ||||
| var DomainFlag = &cli.StringFlag{ | ||||
| 	Name:        "domain, D", | ||||
| var ( | ||||
| 	Domain     string | ||||
| 	DomainFlag = &cli.StringFlag{ | ||||
| 		Name:        "domain", | ||||
| 		Aliases:     []string{"D"}, | ||||
| 		Value:       "", | ||||
| 		Usage:       "Choose a domain name", | ||||
| 		Destination: &Domain, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var NewAppServer string | ||||
| var NewAppServerFlag = &cli.StringFlag{ | ||||
| 	Name:        "server, s", | ||||
| var ( | ||||
| 	NewAppServer     string | ||||
| 	NewAppServerFlag = &cli.StringFlag{ | ||||
| 		Name:        "server", | ||||
| 		Aliases:     []string{"s"}, | ||||
| 		Value:       "", | ||||
| 		Usage:       "Show apps of a specific server", | ||||
| 		Destination: &NewAppServer, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var NoDomainChecks bool | ||||
| var NoDomainChecksFlag = &cli.BoolFlag{ | ||||
| 	Name:        "no-domain-checks, D", | ||||
| var ( | ||||
| 	NoDomainChecks     bool | ||||
| 	NoDomainChecksFlag = &cli.BoolFlag{ | ||||
| 		Name:        "no-domain-checks", | ||||
| 		Aliases:     []string{"D"}, | ||||
| 		Usage:       "Disable app domain sanity checks", | ||||
| 		Destination: &NoDomainChecks, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var StdErrOnly bool | ||||
| var StdErrOnlyFlag = &cli.BoolFlag{ | ||||
| 	Name:        "stderr, s", | ||||
| var ( | ||||
| 	StdErrOnly     bool | ||||
| 	StdErrOnlyFlag = &cli.BoolFlag{ | ||||
| 		Name:        "stderr", | ||||
| 		Aliases:     []string{"s"}, | ||||
| 		Usage:       "Only tail stderr", | ||||
| 		Destination: &StdErrOnly, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var SinceLogs string | ||||
| var SinceLogsFlag = &cli.StringFlag{ | ||||
| 	Name:        "since, S", | ||||
| var ( | ||||
| 	SinceLogs     string | ||||
| 	SinceLogsFlag = &cli.StringFlag{ | ||||
| 		Name:        "since", | ||||
| 		Aliases:     []string{"S"}, | ||||
| 		Value:       "", | ||||
| 		Usage:       "tail logs since YYYY-MM-DDTHH:MM:SSZ", | ||||
| 		Destination: &SinceLogs, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var DontWaitConverge bool | ||||
| var DontWaitConvergeFlag = &cli.BoolFlag{ | ||||
| 	Name:        "no-converge-checks, c", | ||||
| var ( | ||||
| 	DontWaitConverge     bool | ||||
| 	DontWaitConvergeFlag = &cli.BoolFlag{ | ||||
| 		Name:        "no-converge-checks", | ||||
| 		Aliases:     []string{"c"}, | ||||
| 		Usage:       "Don't wait for converge logic checks", | ||||
| 		Destination: &DontWaitConverge, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var Watch bool | ||||
| var WatchFlag = &cli.BoolFlag{ | ||||
| 	Name:        "watch, w", | ||||
| var ( | ||||
| 	Watch     bool | ||||
| 	WatchFlag = &cli.BoolFlag{ | ||||
| 		Name:        "watch", | ||||
| 		Aliases:     []string{"w"}, | ||||
| 		Usage:       "Watch status by polling repeatedly", | ||||
| 		Destination: &Watch, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var OnlyErrors bool | ||||
| var OnlyErrorFlag = &cli.BoolFlag{ | ||||
| 	Name:        "errors, e", | ||||
| var ( | ||||
| 	OnlyErrors    bool | ||||
| 	OnlyErrorFlag = &cli.BoolFlag{ | ||||
| 		Name:        "errors", | ||||
| 		Aliases:     []string{"e"}, | ||||
| 		Usage:       "Only show errors", | ||||
| 		Destination: &OnlyErrors, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var SkipUpdates bool | ||||
| var SkipUpdatesFlag = &cli.BoolFlag{ | ||||
| 	Name:        "skip-updates, s", | ||||
| var ( | ||||
| 	SkipUpdates     bool | ||||
| 	SkipUpdatesFlag = &cli.BoolFlag{ | ||||
| 		Name:        "skip-updates", | ||||
| 		Aliases:     []string{"s"}, | ||||
| 		Usage:       "Skip updating recipe repositories", | ||||
| 		Destination: &SkipUpdates, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var AllTags bool | ||||
| var AllTagsFlag = &cli.BoolFlag{ | ||||
| 	Name:        "all-tags, a", | ||||
| var ( | ||||
| 	AllTags     bool | ||||
| 	AllTagsFlag = &cli.BoolFlag{ | ||||
| 		Name:        "all-tags", | ||||
| 		Aliases:     []string{"a"}, | ||||
| 		Usage:       "List all tags, not just upgrades", | ||||
| 		Destination: &AllTags, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var LocalCmd bool | ||||
| var LocalCmdFlag = &cli.BoolFlag{ | ||||
| 	Name:        "local, l", | ||||
| var ( | ||||
| 	LocalCmd     bool | ||||
| 	LocalCmdFlag = &cli.BoolFlag{ | ||||
| 		Name:        "local", | ||||
| 		Aliases:     []string{"l"}, | ||||
| 		Usage:       "Run command locally", | ||||
| 		Destination: &LocalCmd, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| var RemoteUser string | ||||
| var RemoteUserFlag = &cli.StringFlag{ | ||||
| 	Name:        "user, u", | ||||
| var ( | ||||
| 	RemoteUser     string | ||||
| 	RemoteUserFlag = &cli.StringFlag{ | ||||
| 		Name:        "user", | ||||
| 		Aliases:     []string{"u"}, | ||||
| 		Value:       "", | ||||
| 		Usage:       "User to run command within a service context", | ||||
| 		Destination: &RemoteUser, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| // SubCommandBefore wires up pre-action machinery (e.g. --debug handling). | ||||
| func SubCommandBefore(c *cli.Context) error { | ||||
|  | ||||
| @ -4,7 +4,7 @@ import ( | ||||
| 	"os" | ||||
|  | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // ShowSubcommandHelpAndError exits the program on error, logs the error to the | ||||
|  | ||||
| @ -9,7 +9,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // ValidateRecipe ensures the recipe arg is valid. | ||||
| @ -120,9 +120,9 @@ func ValidateDomain(c *cli.Context) string { | ||||
|  | ||||
| // ValidateSubCmdFlags ensures flag order conforms to correct order | ||||
| func ValidateSubCmdFlags(c *cli.Context) bool { | ||||
| 	for argIdx, arg := range c.Args() { | ||||
| 	for argIdx, arg := range c.Args().Slice() { | ||||
| 		if !strings.HasPrefix(arg, "--") { | ||||
| 			for _, flag := range c.Args()[argIdx:] { | ||||
| 			for _, flag := range c.Args().Slice()[argIdx:] { | ||||
| 				if strings.HasPrefix(flag, "--") { | ||||
| 					return false | ||||
| 				} | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	gitPkg "coopcloud.tech/abra/pkg/git" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeDiffCommand = cli.Command{ | ||||
|  | ||||
| @ -6,7 +6,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/formatter" | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeFetchCommand = cli.Command{ | ||||
|  | ||||
| @ -9,7 +9,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/lint" | ||||
| 	recipePkg "coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeLintCommand = cli.Command{ | ||||
|  | ||||
| @ -10,7 +10,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/formatter" | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var pattern string | ||||
|  | ||||
| @ -13,7 +13,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"coopcloud.tech/abra/pkg/git" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // recipeMetadata is the recipe metadata for the README.md | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| package recipe | ||||
|  | ||||
| import ( | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // RecipeCommand defines all recipe related sub-commands. | ||||
| @ -21,16 +21,16 @@ sure the recipe is in good working order and the config upgraded in a timely | ||||
| manner. Abra supports convenient automation for recipe maintainenace, see the | ||||
| "abra recipe upgrade", "abra recipe sync" and "abra recipe release" commands. | ||||
| `, | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		recipeFetchCommand, | ||||
| 		recipeLintCommand, | ||||
| 		recipeListCommand, | ||||
| 		recipeNewCommand, | ||||
| 		recipeReleaseCommand, | ||||
| 		recipeSyncCommand, | ||||
| 		recipeUpgradeCommand, | ||||
| 		recipeVersionCommand, | ||||
| 		recipeResetCommand, | ||||
| 		recipeDiffCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&recipeFetchCommand, | ||||
| 		&recipeLintCommand, | ||||
| 		&recipeListCommand, | ||||
| 		&recipeNewCommand, | ||||
| 		&recipeReleaseCommand, | ||||
| 		&recipeSyncCommand, | ||||
| 		&recipeUpgradeCommand, | ||||
| 		&recipeVersionCommand, | ||||
| 		&recipeResetCommand, | ||||
| 		&recipeDiffCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -20,7 +20,7 @@ import ( | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/go-git/go-git/v5" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeReleaseCommand = cli.Command{ | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"github.com/go-git/go-git/v5" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeResetCommand = cli.Command{ | ||||
|  | ||||
| @ -14,7 +14,7 @@ import ( | ||||
| 	"github.com/go-git/go-git/v5" | ||||
| 	"github.com/go-git/go-git/v5/plumbing" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var recipeSyncCommand = cli.Command{ | ||||
|  | ||||
| @ -20,7 +20,7 @@ import ( | ||||
| 	"github.com/AlecAivazis/survey/v2" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| type imgPin struct { | ||||
|  | ||||
| @ -10,7 +10,7 @@ import ( | ||||
| 	recipePkg "coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/olekukonko/tablewriter" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| func sortServiceByName(versions [][]string) func(i, j int) bool { | ||||
|  | ||||
| @ -13,12 +13,13 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/server" | ||||
| 	sshPkg "coopcloud.tech/abra/pkg/ssh" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var local bool | ||||
| var localFlag = &cli.BoolFlag{ | ||||
| 	Name:        "local, l", | ||||
| 	Name:        "local", | ||||
| 	Aliases:     []string{"l"}, | ||||
| 	Usage:       "Use local server", | ||||
| 	Destination: &local, | ||||
| } | ||||
| @ -122,7 +123,7 @@ developer machine. | ||||
| 	Before:    internal.SubCommandBefore, | ||||
| 	ArgsUsage: "<domain>", | ||||
| 	Action: func(c *cli.Context) error { | ||||
| 		if len(c.Args()) > 0 && local || !internal.ValidateSubCmdFlags(c) { | ||||
| 		if c.Args().Len() > 0 && local || !internal.ValidateSubCmdFlags(c) { | ||||
| 			err := errors.New("cannot use <domain> and --local together") | ||||
| 			internal.ShowSubcommandHelpAndError(c, err) | ||||
| 		} | ||||
|  | ||||
| @ -9,7 +9,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/formatter" | ||||
| 	"github.com/docker/cli/cli/connhelper/ssh" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var problemsFilter bool | ||||
|  | ||||
| @ -9,7 +9,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/formatter" | ||||
| 	"github.com/docker/docker/api/types/filters" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var allFilter bool | ||||
|  | ||||
| @ -9,7 +9,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/client" | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| var serverRemoveCommand = cli.Command{ | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| package server | ||||
|  | ||||
| import ( | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // ServerCommand defines the `abra server` command and its subcommands | ||||
| @ -9,10 +9,10 @@ var ServerCommand = cli.Command{ | ||||
| 	Name:    "server", | ||||
| 	Aliases: []string{"s"}, | ||||
| 	Usage:   "Manage servers", | ||||
| 	Subcommands: []cli.Command{ | ||||
| 		serverAddCommand, | ||||
| 		serverListCommand, | ||||
| 		serverRemoveCommand, | ||||
| 		serverPruneCommand, | ||||
| 	Subcommands: []*cli.Command{ | ||||
| 		&serverAddCommand, | ||||
| 		&serverListCommand, | ||||
| 		&serverRemoveCommand, | ||||
| 		&serverPruneCommand, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| @ -21,24 +21,28 @@ import ( | ||||
| 	dockerclient "github.com/docker/docker/client" | ||||
|  | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| const SERVER = "localhost" | ||||
|  | ||||
| var majorUpdate bool | ||||
| var majorFlag = &cli.BoolFlag{ | ||||
| 	Name:        "major, m", | ||||
| var ( | ||||
| 	majorUpdate bool | ||||
| 	majorFlag   = &cli.BoolFlag{ | ||||
| 		Name:        "major", | ||||
| 		Aliases:     []string{"m"}, | ||||
| 		Usage:       "Also check for major updates", | ||||
| 		Destination: &majorUpdate, | ||||
| } | ||||
| 	} | ||||
|  | ||||
| var updateAll bool | ||||
| var allFlag = &cli.BoolFlag{ | ||||
| 	Name:        "all, a", | ||||
| 	updateAll bool | ||||
| 	allFlag   = &cli.BoolFlag{ | ||||
| 		Name:        "all", | ||||
| 		Aliases:     []string{"a"}, | ||||
| 		Usage:       "Update all deployed apps", | ||||
| 		Destination: &updateAll, | ||||
| } | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| // Notify checks for available upgrades | ||||
| var Notify = cli.Command{ | ||||
| @ -271,7 +275,8 @@ func getDeployedVersion(cl *dockerclient.Client, stackName string, recipeName st | ||||
| // than the deployed version. It only includes major upgrades if the "--major" | ||||
| // flag is set. | ||||
| func getAvailableUpgrades(cl *dockerclient.Client, stackName string, recipeName string, | ||||
| 	deployedVersion string) ([]string, error) { | ||||
| 	deployedVersion string, | ||||
| ) ([]string, error) { | ||||
| 	catl, err := recipe.ReadRecipeCatalogue(internal.Offline) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -429,7 +434,8 @@ func tryUpgrade(cl *dockerclient.Client, stackName, recipeName string) error { | ||||
|  | ||||
| // upgrade performs all necessary steps to upgrade an app. | ||||
| func upgrade(cl *dockerclient.Client, stackName, recipeName, | ||||
| 	upgradeVersion string) error { | ||||
| 	upgradeVersion string, | ||||
| ) error { | ||||
| 	env, err := getEnv(cl, stackName) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| @ -474,9 +480,9 @@ func newAbraApp(version, commit string) *cli.App { | ||||
|                          |_| | ||||
| `, | ||||
| 		Version: fmt.Sprintf("%s-%s", version, commit[:7]), | ||||
| 		Commands: []cli.Command{ | ||||
| 			Notify, | ||||
| 			UpgradeApp, | ||||
| 		Commands: []*cli.Command{ | ||||
| 			&Notify, | ||||
| 			&UpgradeApp, | ||||
| 		}, | ||||
| 	} | ||||
|  | ||||
|  | ||||
							
								
								
									
										6
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								go.mod
									
									
									
									
									
								
							| @ -25,7 +25,7 @@ require ( | ||||
| require ( | ||||
| 	dario.cat/mergo v1.0.0 // indirect | ||||
| 	github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 // indirect | ||||
| 	github.com/BurntSushi/toml v1.0.0 // indirect | ||||
| 	github.com/BurntSushi/toml v1.3.2 // indirect | ||||
| 	github.com/Microsoft/go-winio v0.6.1 // indirect | ||||
| 	github.com/Microsoft/hcsshim v0.9.2 // indirect | ||||
| 	github.com/ProtonMail/go-crypto v0.0.0-20230828082145-3c4c8a2d2371 // indirect | ||||
| @ -33,7 +33,7 @@ require ( | ||||
| 	github.com/beorn7/perks v1.0.1 // indirect | ||||
| 	github.com/cespare/xxhash/v2 v2.2.0 // indirect | ||||
| 	github.com/cloudflare/circl v1.3.3 // indirect | ||||
| 	github.com/cpuguy83/go-md2man/v2 v2.0.1 // indirect | ||||
| 	github.com/cpuguy83/go-md2man/v2 v2.0.3 // indirect | ||||
| 	github.com/cyphar/filepath-securejoin v0.2.4 // indirect | ||||
| 	github.com/davecgh/go-spew v1.1.1 // indirect | ||||
| 	github.com/distribution/reference v0.5.0 // indirect | ||||
| @ -75,9 +75,11 @@ require ( | ||||
| 	github.com/russross/blackfriday/v2 v2.1.0 // indirect | ||||
| 	github.com/skeema/knownhosts v1.2.0 // indirect | ||||
| 	github.com/spf13/pflag v1.0.5 // indirect | ||||
| 	github.com/urfave/cli/v2 v2.27.1 // indirect | ||||
| 	github.com/xanzy/ssh-agent v0.3.3 // indirect | ||||
| 	github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415 // indirect | ||||
| 	github.com/xeipuuv/gojsonschema v1.2.0 // indirect | ||||
| 	github.com/xrash/smetrics v0.0.0-20231213231151-1d8dd44e695e // indirect | ||||
| 	golang.org/x/crypto v0.14.0 // indirect | ||||
| 	golang.org/x/mod v0.12.0 // indirect | ||||
| 	golang.org/x/net v0.17.0 // indirect | ||||
|  | ||||
							
								
								
									
										9
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								go.sum
									
									
									
									
									
								
							| @ -74,6 +74,8 @@ github.com/Azure/go-autorest/tracing v0.6.0/go.mod h1:+vhtPC754Xsa23ID7GlGsrdKBp | ||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||
| github.com/BurntSushi/toml v1.0.0 h1:dtDWrepsVPfW9H/4y7dDgFc2MBUSeJhlaDtK13CxFlU= | ||||
| github.com/BurntSushi/toml v1.0.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= | ||||
| github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8= | ||||
| github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= | ||||
| github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | ||||
| github.com/DataDog/datadog-go v3.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ= | ||||
| github.com/Gurpartap/logrus-stack v0.0.0-20170710170904-89c00d8a28f4 h1:vdT7QwBhJJEVNFMBNhRSFDRCB6O16T28VhvqRgqFyn8= | ||||
| @ -311,6 +313,8 @@ github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:ma | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.1 h1:r/myEWzV9lfsM1tFLgDyu0atFtJ1fXn261LKYj/3DxU= | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.1/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.3 h1:qMCsGGgs+MAzDFyp9LpAe1Lqy/fY/qCovCm0qnXZOBM= | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.3/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | ||||
| github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY= | ||||
| github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= | ||||
| github.com/creack/pty v1.1.17/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4= | ||||
| @ -893,6 +897,7 @@ github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6L | ||||
| github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= | ||||
| github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M= | ||||
| github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA= | ||||
| github.com/russross/blackfriday v1.6.0 h1:KqfZb0pUVN2lYqZUYRddxF4OR8ZMURnJIG5Y3VRLtww= | ||||
| github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY= | ||||
| github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | ||||
| github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= | ||||
| @ -992,6 +997,8 @@ github.com/urfave/cli v1.22.2/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtX | ||||
| github.com/urfave/cli v1.22.4/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= | ||||
| github.com/urfave/cli v1.22.9 h1:cv3/KhXGBGjEXLC4bH0sLuJ9BewaAbpk5oyMOveu4pw= | ||||
| github.com/urfave/cli v1.22.9/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= | ||||
| github.com/urfave/cli/v2 v2.27.1 h1:8xSQ6szndafKVRmfyeUMxkNUJQMjL1F2zmsZ+qHpfho= | ||||
| github.com/urfave/cli/v2 v2.27.1/go.mod h1:8qnjx1vcq5s2/wpsqoZFndg2CE5tNFyrTvS6SinrnYQ= | ||||
| github.com/vbatts/tar-split v0.11.2/go.mod h1:vV3ZuO2yWSVsz+pfFzDG/upWH1JhjOiEaWq6kXyQ3VI= | ||||
| github.com/vishvananda/netlink v0.0.0-20181108222139-023a6dafdcdf/go.mod h1:+SR5DhBJrl6ZM7CoCKvpw5BKroDKQ+PJqOg65H/2ktk= | ||||
| github.com/vishvananda/netlink v1.1.0/go.mod h1:cTgwzPIzzgDAYoQrMm0EdrjRUBkTqKYppBueQtXaqoE= | ||||
| @ -1013,6 +1020,8 @@ github.com/xeipuuv/gojsonschema v1.2.0 h1:LhYJRs+L4fBtjZUfuSZIKGeVu0QRy8e5Xi7D17 | ||||
| github.com/xeipuuv/gojsonschema v1.2.0/go.mod h1:anYRn/JVcOK2ZgGU+IjEV4nwlhoK5sQluxsYJ78Id3Y= | ||||
| github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= | ||||
| github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= | ||||
| github.com/xrash/smetrics v0.0.0-20231213231151-1d8dd44e695e h1:+SOyEddqYF09QP7vr7CgJ1eti3pY9Fn3LHO1M1r/0sI= | ||||
| github.com/xrash/smetrics v0.0.0-20231213231151-1d8dd44e695e/go.mod h1:N3UwUGtsrSj3ccvlPHLoLsHnpR27oXr4ZE984MbSER8= | ||||
| github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
|  | ||||
| @ -6,7 +6,7 @@ import ( | ||||
| 	"coopcloud.tech/abra/pkg/config" | ||||
| 	"coopcloud.tech/abra/pkg/recipe" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/urfave/cli" | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // AppNameComplete copletes app names. | ||||
|  | ||||
| @ -1,17 +1,18 @@ | ||||
| #!/usr/bin/env bash | ||||
|  | ||||
| _new_app() { | ||||
|   run $ABRA app new "$TEST_RECIPE" \ | ||||
|   run $ABRA app new \ | ||||
|     --no-input \ | ||||
|     --server "$TEST_SERVER" \ | ||||
|     --domain "$TEST_APP_DOMAIN" \ | ||||
|     --secrets | ||||
|     --secrets \ | ||||
|     "$TEST_RECIPE" | ||||
|   assert_success | ||||
|   assert_exists "$ABRA_DIR/servers/$TEST_SERVER/$TEST_APP_DOMAIN.env" | ||||
| } | ||||
|  | ||||
| _deploy_app() { | ||||
|   run $ABRA app deploy "$TEST_APP_DOMAIN" --no-input | ||||
|   run $ABRA app deploy --no-input "$TEST_APP_DOMAIN" | ||||
|   assert_success | ||||
|  | ||||
|   run $ABRA app ls --server "$TEST_SERVER" --status | ||||
| @ -21,7 +22,7 @@ _deploy_app() { | ||||
| } | ||||
|  | ||||
| _undeploy_app() { | ||||
|   run $ABRA app undeploy "$TEST_APP_DOMAIN" --no-input | ||||
|   run $ABRA app undeploy --no-input "$TEST_APP_DOMAIN" | ||||
|   assert_success | ||||
|  | ||||
|   run $ABRA app ls --server "$TEST_SERVER" --status | ||||
| @ -34,10 +35,10 @@ _rm_app() { | ||||
|   # NOTE(d1): not asserting outcomes on teardown here since some might fail | ||||
|   # depending on what the test created. all commands run through anyway | ||||
|   if [[ -f "$ABRA_DIR/servers/$TEST_SERVER/$TEST_APP_DOMAIN.env" ]]; then | ||||
|     run $ABRA app undeploy "$TEST_APP_DOMAIN" --no-input | ||||
|     run $ABRA app secret remove "$TEST_APP_DOMAIN" --all --no-input | ||||
|     run $ABRA app volume remove "$TEST_APP_DOMAIN" --no-input | ||||
|     run $ABRA app remove "$TEST_APP_DOMAIN" --no-input | ||||
|     run $ABRA app undeploy --no-input "$TEST_APP_DOMAIN" | ||||
|     run $ABRA app secret remove --all --no-input "$TEST_APP_DOMAIN" | ||||
|     run $ABRA app volume remove --no-input "$TEST_APP_DOMAIN" | ||||
|     run $ABRA app remove --no-input "$TEST_APP_DOMAIN" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| @ -46,10 +47,11 @@ _reset_app(){ | ||||
|   assert_success | ||||
|   assert_not_exists "$ABRA_DIR/servers/$TEST_SERVER/$TEST_APP_DOMAIN.env" | ||||
|  | ||||
|   run $ABRA app new "$TEST_RECIPE" \ | ||||
|   run $ABRA app new \ | ||||
|     --no-input \ | ||||
|     --server "$TEST_SERVER" \ | ||||
|     --domain "$TEST_APP_DOMAIN" | ||||
|     --domain "$TEST_APP_DOMAIN" \ | ||||
|     "$TEST_RECIPE" | ||||
|   assert_success | ||||
|   assert_exists "$ABRA_DIR/servers/$TEST_SERVER/$TEST_APP_DOMAIN.env" | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user