All checks were successful
continuous-integration/drone/push Build is passing
Closes coop-cloud/organising#212.
46 lines
1.1 KiB
Go
46 lines
1.1 KiB
Go
package app
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"coopcloud.tech/abra/cli/internal"
|
|
"coopcloud.tech/abra/pkg/config"
|
|
"github.com/sirupsen/logrus"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
var appDeployCommand = &cli.Command{
|
|
Name: "deploy",
|
|
Aliases: []string{"d"},
|
|
Usage: "Deploy an app",
|
|
Flags: []cli.Flag{
|
|
internal.ForceFlag,
|
|
internal.ChaosFlag,
|
|
},
|
|
Description: `
|
|
This command deploys a new instance of an app. It does not support changing the
|
|
version of an existing deployed app, for this you need to look at the "abra app
|
|
upgrade <app>" command.
|
|
|
|
You may pass "--force" to re-deploy the same version again. This can be useful
|
|
if the container runtime has gotten into a weird state.
|
|
|
|
Chas mode ("--chaos") will deploy your local checkout of a recipe as-is,
|
|
including unstaged changes and can be useful for live hacking and testing new
|
|
recipes.
|
|
`,
|
|
Action: internal.DeployAction,
|
|
BashComplete: func(c *cli.Context) {
|
|
appNames, err := config.GetAppNames()
|
|
if err != nil {
|
|
logrus.Warn(err)
|
|
}
|
|
if c.NArg() > 0 {
|
|
return
|
|
}
|
|
for _, a := range appNames {
|
|
fmt.Println(a)
|
|
}
|
|
},
|
|
}
|