forked from toolshed/abra
		
	
		
			
				
	
	
		
			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)
 | |
| 		}
 | |
| 	},
 | |
| }
 |