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