Skip to content

Commit

Permalink
Add help for terraform
Browse files Browse the repository at this point in the history
  • Loading branch information
samtholiya committed Dec 17, 2024
1 parent 922ba49 commit 0fe021a
Show file tree
Hide file tree
Showing 6 changed files with 341 additions and 93 deletions.
19 changes: 13 additions & 6 deletions cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -138,18 +138,25 @@ func init() {
func initConfig() {
styles := boa.DefaultStyles()
b := boa.New(boa.WithStyles(styles))

oldUsageFunc := RootCmd.UsageFunc()
RootCmd.SetUsageFunc(b.UsageFunc)

RootCmd.SetHelpFunc(func(command *cobra.Command, strings []string) {
// Print a styled Atmos logo to the terminal
fmt.Println()
err := tuiUtils.PrintStyledText("ATMOS")
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
if command.Use != "terraform" {
err := tuiUtils.PrintStyledText("ATMOS")
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
}
}
// TODO: find a better way to do this if possible
if command.Use == "terraform" {
oldUsageFunc(command)
return
} else {
b.HelpFunc(command, strings)
}

b.HelpFunc(command, strings)
command.Usage()
})
}
Expand Down
67 changes: 36 additions & 31 deletions cmd/terraform.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,42 +16,47 @@ var terraformCmd = &cobra.Command{
Short: "Execute Terraform commands",
Long: `This command executes Terraform commands`,
FParseErrWhitelist: struct{ UnknownFlags bool }{UnknownFlags: true},
Run: func(cmd *cobra.Command, args []string) {
// Check Atmos configuration
//checkAtmosConfig()

var argsAfterDoubleDash []string
var finalArgs = args

doubleDashIndex := lo.IndexOf(args, "--")
if doubleDashIndex > 0 {
finalArgs = lo.Slice(args, 0, doubleDashIndex)
argsAfterDoubleDash = lo.Slice(args, doubleDashIndex+1, len(args))
}
info, err := e.ProcessCommandLineArgs("terraform", cmd, finalArgs, argsAfterDoubleDash)
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
}

// Exit on help
if info.NeedHelp {
// Check for the latest Atmos release on GitHub and print update message
CheckForAtmosUpdateAndPrintMessage(cliConfig)
return
}
// Check Atmos configuration
checkAtmosConfig()

err = e.ExecuteTerraform(info)
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
}
},
Run: terraformRun,
}

func terraformRun(cmd *cobra.Command, args []string) {
// Check Atmos configuration
//checkAtmosConfig()

var argsAfterDoubleDash []string
var finalArgs = args

doubleDashIndex := lo.IndexOf(args, "--")
if doubleDashIndex > 0 {
finalArgs = lo.Slice(args, 0, doubleDashIndex)
argsAfterDoubleDash = lo.Slice(args, doubleDashIndex+1, len(args))
}
info, err := e.ProcessCommandLineArgs("terraform", cmd, finalArgs, argsAfterDoubleDash)
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
}

// Exit on help
if info.NeedHelp {
// Check for the latest Atmos release on GitHub and print update message
cmd.Help()
CheckForAtmosUpdateAndPrintMessage(cliConfig)
return
}
// Check Atmos configuration
checkAtmosConfig()

err = e.ExecuteTerraform(info)
if err != nil {
u.LogErrorAndExit(schema.CliConfiguration{}, err)
}

}

func init() {
// https://github.com/spf13/cobra/issues/739
terraformCmd.DisableFlagParsing = true
terraformCmd.PersistentFlags().StringP("stack", "s", "", "atmos terraform <terraform_command> <component> -s <stack>")
attachTerraformCommands(terraformCmd)
RootCmd.AddCommand(terraformCmd)
}
201 changes: 201 additions & 0 deletions cmd/terraform_native_commands.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
package cmd

import (
"github.com/spf13/cobra"
)

// getTerraformCommands returns an array of statically defined Terraform commands with flags
func getTerraformCommands() []*cobra.Command {
// List of Terraform commands
return []*cobra.Command{
{
Use: "plan",
Short: "Show changes required by the current configuration",
Long: "Generate an execution plan, which shows what actions Terraform will take to reach the desired state of the configuration.",
},
{
Use: "apply",
Short: "Apply changes to infrastructure",
Long: "Apply the changes required to reach the desired state of the configuration. This will prompt for confirmation before making changes.",
},
{
Use: "workspace",
Short: "Manage Terraform workspaces",
Long: "Create, list, select, or delete Terraform workspaces, which allow for separate states within the same configuration.",
},
{
Use: "clean",
Short: "Clean up resources",
Long: "Remove unused or outdated resources to keep the infrastructure clean and reduce costs.",
},
{
Use: "version",
Short: "Show the current Terraform version",
Long: "Displays the current version of Terraform installed on the system.",
},
{
Use: "varfile",
Short: "Load variables from a file",
Long: "Load variable definitions from a specified file and use them in the configuration.",
},
{
Use: "write varfile",
Short: "Write variables to a file",
Long: "Write the variables used in the configuration to a specified file for later use or modification.",
},
{
Use: "destroy",
Short: "Destroy previously-created infrastructure",
Long: "Destroy all the infrastructure managed by Terraform, removing resources as defined in the state file.",
},
{
Use: "import",
Short: "Associate existing infrastructure with a Terraform resource",
Long: "Import existing infrastructure into Terraform management by specifying the resource type and ID.",
},
{
Use: "refresh",
Short: "Update the state to match remote systems",
Long: "Refresh the Terraform state, reconciling the local state with the actual infrastructure state.",
},
{
Use: "init",
Short: "Prepare your working directory for other commands",
Long: "Initialize the working directory containing Terraform configuration files. It will download necessary provider plugins and set up the backend.",
},
{
Use: "validate",
Short: "Check whether the configuration is valid",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "console",
Short: "Try Terraform expressions at an interactive command prompt",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "fmt",
Short: "Reformat your configuration in the standard style",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "force-unlock",
Short: "Release a stuck lock on the current workspace",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "get",
Short: "Install or upgrade remote Terraform modules",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "graph",
Short: "Generate a Graphviz graph of the steps in an operation",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "import",
Short: "Associate existing infrastructure with a Terraform resource",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "login",
Short: "Obtain and save credentials for a remote host",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "logout",
Short: "Remove locally-stored credentials for a remote host",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "metadata",
Short: "Metadata related commands",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "modules",
Short: "Show all declared modules in a working directory",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "output",
Short: "Show output values from your root module",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "providers",
Short: "Show the providers required for this configuration",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "show",
Short: "Show the current state or a saved plan",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "state",
Short: "Advanced state management",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "taint",
Short: "Mark a resource instance as not fully functional",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "test",
Short: "Execute integration tests for Terraform modules",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
{
Use: "untaint",
Short: "Remove the 'tainted' state from a resource instance",
Annotations: map[string]string{
"IsNotSupported": "true",
},
},
}
}

// attachTerraformCommands attaches static Terraform commands to a provided parent command
func attachTerraformCommands(parentCmd *cobra.Command) {
commands := getTerraformCommands()
for _, cmd := range commands {
parentCmd.AddCommand(cmd)
}
}
Loading

0 comments on commit 0fe021a

Please sign in to comment.