Documentation ¶
Overview ¶
Package cli provides the interface for the command-line.
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var AutoCompleteCommand = cli.Command{ Name: "autocomplete", Aliases: []string{"ac"}, Usage: "Configure shell autocompletion (recommended)", Description: ` Set up auto-completion in your shell by downloading the relevant files and laying out what additional information must be loaded. Supported shells are as follows: bash, fish, fizsh & zsh. Example: abra autocomplete bash `, ArgsUsage: "<shell>", Flags: []cli.Flag{ internal.DebugFlag, }, Action: func(c *cli.Context) error { shellType := c.Args().First() if shellType == "" { internal.ShowSubcommandHelpAndError(c, errors.New("no shell provided")) } supportedShells := map[string]bool{ "bash": true, "zsh": true, "fizsh": true, "fish": true, } if _, ok := supportedShells[shellType]; !ok { logrus.Fatalf("%s is not a supported shell right now, sorry", shellType) } if shellType == "fizsh" { shellType = "zsh" } autocompletionDir := path.Join(config.ABRA_DIR, "autocompletion") if err := os.Mkdir(autocompletionDir, 0764); err != nil { if !os.IsExist(err) { logrus.Fatal(err) } logrus.Debugf("%s already created", autocompletionDir) } autocompletionFile := path.Join(config.ABRA_DIR, "autocompletion", shellType) if _, err := os.Stat(autocompletionFile); err != nil && os.IsNotExist(err) { url := fmt.Sprintf("https://git.coopcloud.tech/coop-cloud/abra/raw/branch/main/scripts/autocomplete/%s", shellType) logrus.Infof("fetching %s", url) if err := web.GetFile(autocompletionFile, url); err != nil { logrus.Fatal(err) } } switch shellType { case "bash": fmt.Println(fmt.Sprintf(` # Run the following commands to install auto-completion sudo mkdir /etc/bash_completion.d/ sudo cp %s /etc/bash_completion.d/abra echo "source /etc/bash_completion.d/abra" >> ~/.bashrc # To test, run the following: "abra app <hit tab key>" - you should see command completion! `, autocompletionFile)) case "zsh": fmt.Println(fmt.Sprintf(` # Run the following commands to install auto-completion sudo mkdir /etc/zsh/completion.d/ sudo cp %s /etc/zsh/completion.d/abra echo "PROG=abra\n_CLI_ZSH_AUTOCOMPLETE_HACK=1\nsource /etc/zsh/completion.d/abra" >> ~/.zshrc # To test, run the following: "abra app <hit tab key>" - you should see command completion! `, autocompletionFile)) case "fish": fmt.Println(fmt.Sprintf(` # Run the following commands to install auto-completion sudo mkdir -p /etc/fish/completions sudo cp %s /etc/fish/completions/abra echo "source /etc/fish/completions/abra" >> ~/.config/fish/config.fish # To test, run the following: "abra app <hit tab key>" - you should see command completion! `, autocompletionFile)) } return nil }, }
AutoCompleteCommand helps people set up auto-complete in their shells
View Source
var UpgradeCommand = cli.Command{ Name: "upgrade", Aliases: []string{"u"}, Usage: "Upgrade Abra itself", Description: ` Upgrade Abra in-place with the latest stable or release candidate. Pass "-r/--rc" to install the latest release candidate. Please bear in mind that it may contain catastrophic bugs. Thank you very much for the testing efforts! `, Flags: []cli.Flag{internal.RCFlag}, Action: func(c *cli.Context) error { mainURL := "https://install.abra.coopcloud.tech" cmd := exec.Command("bash", "-c", fmt.Sprintf("wget -q -O- %s | bash", mainURL)) if internal.RC { releaseCandidateURL := "https://git.coopcloud.tech/coop-cloud/abra/raw/branch/main/scripts/installer/installer" cmd = exec.Command("bash", "-c", fmt.Sprintf("wget -q -O- %s | bash -s -- --rc", releaseCandidateURL)) } logrus.Debugf("attempting to run %s", cmd) if err := internal.RunCmd(cmd); err != nil { logrus.Fatal(err) } return nil }, }
UpgradeCommand upgrades abra in-place.
Functions ¶
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.