|  | @ -21,17 +21,18 @@ import ( | 
			
		
	
		
		
			
				
					|  |  | type ( |  |  | type ( | 
			
		
	
		
		
			
				
					|  |  | 	// Config holds input parameters for the plugin
 |  |  | 	// Config holds input parameters for the plugin
 | 
			
		
	
		
		
			
				
					|  |  | 	Config struct { |  |  | 	Config struct { | 
			
		
	
		
		
			
				
					
					|  |  | 		Actions     []string |  |  | 		Actions        []string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Vars        map[string]string |  |  | 		Vars           map[string]string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Secrets     map[string]string |  |  | 		Secrets        map[string]string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		InitOptions InitOptions |  |  | 		InitOptions    InitOptions | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Cacert      string |  |  | 		Cacert         string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Sensitive   bool |  |  | 		Sensitive      bool | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		RoleARN     string |  |  | 		TfInAutomation bool | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		RootDir     string |  |  | 		RoleARN        string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Parallelism int |  |  | 		RootDir        string | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		Targets     []string |  |  | 		Parallelism    int | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		VarFiles    []string |  |  | 		Targets        []string | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  | 		VarFiles       []string | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	Netrc struct { |  |  | 	Netrc struct { | 
			
		
	
	
		
		
			
				
					|  | @ -87,7 +88,7 @@ func (p Plugin) Exec() error { | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	commands = append(commands, deleteCache()) |  |  | 	commands = append(commands, deleteCache()) | 
			
		
	
		
		
			
				
					
					|  |  | 	commands = append(commands, initCommand(p.Config.InitOptions)) |  |  | 	commands = append(commands, initCommand(p.Config)) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 	commands = append(commands, getModules()) |  |  | 	commands = append(commands, getModules()) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	// Add commands listed from Actions
 |  |  | 	// Add commands listed from Actions
 | 
			
		
	
	
		
		
			
				
					|  | @ -186,30 +187,37 @@ func getModules() *exec.Cmd { | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  | func initCommand(config InitOptions) *exec.Cmd { |  |  | func initCommand(config Config) *exec.Cmd { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 	args := []string{ |  |  | 	args := []string{ | 
			
		
	
		
		
			
				
					|  |  | 		"init", |  |  | 		"init", | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  | 	for _, v := range config.BackendConfig { |  |  | 	for _, v := range config.InitOptions.BackendConfig { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args = append(args, fmt.Sprintf("-backend-config=%s", v)) |  |  | 		args = append(args, fmt.Sprintf("-backend-config=%s", v)) | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	// True is default in TF
 |  |  | 	// True is default in TF
 | 
			
		
	
		
		
			
				
					
					|  |  | 	if config.Lock != nil { |  |  | 	if config.InitOptions.Lock != nil { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		args = append(args, fmt.Sprintf("-lock=%t", *config.Lock)) |  |  | 		args = append(args, fmt.Sprintf("-lock=%t", *config.InitOptions.Lock)) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	// "0s" is default in TF
 |  |  | 	// "0s" is default in TF
 | 
			
		
	
		
		
			
				
					
					|  |  | 	if config.LockTimeout != "" { |  |  | 	if config.InitOptions.LockTimeout != "" { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.LockTimeout)) |  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	// Fail Terraform execution on prompt
 |  |  | 	// Fail Terraform execution on prompt
 | 
			
		
	
		
		
			
				
					|  |  | 	args = append(args, "-input=false") |  |  | 	args = append(args, "-input=false") | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	var command string | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	if config.TfInAutomation { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "TF_IN_AUTOMATION=true terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	return exec.Command( |  |  | 	return exec.Command( | 
			
		
	
		
		
			
				
					
					|  |  | 		"terraform", |  |  | 		command, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args..., |  |  | 		args..., | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | @ -242,8 +250,14 @@ func tfApply(config Config) *exec.Cmd { | 
			
		
	
		
		
			
				
					|  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) |  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	args = append(args, "plan.tfout") |  |  | 	args = append(args, "plan.tfout") | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	var command string | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	if config.TfInAutomation { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "TF_IN_AUTOMATION=true terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	return exec.Command( |  |  | 	return exec.Command( | 
			
		
	
		
		
			
				
					
					|  |  | 		"terraform", |  |  | 		command, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args..., |  |  | 		args..., | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | @ -265,8 +279,14 @@ func tfDestroy(config Config) *exec.Cmd { | 
			
		
	
		
		
			
				
					|  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) |  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	args = append(args, "-force") |  |  | 	args = append(args, "-force") | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	var command string | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	if config.TfInAutomation { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "TF_IN_AUTOMATION=true terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	return exec.Command( |  |  | 	return exec.Command( | 
			
		
	
		
		
			
				
					
					|  |  | 		"terraform", |  |  | 		command, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args..., |  |  | 		args..., | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | @ -301,8 +321,14 @@ func tfPlan(config Config, destroy bool) *exec.Cmd { | 
			
		
	
		
		
			
				
					|  |  | 	if config.InitOptions.LockTimeout != "" { |  |  | 	if config.InitOptions.LockTimeout != "" { | 
			
		
	
		
		
			
				
					|  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) |  |  | 		args = append(args, fmt.Sprintf("-lock-timeout=%s", config.InitOptions.LockTimeout)) | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	var command string | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	if config.TfInAutomation { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "TF_IN_AUTOMATION=true terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	return exec.Command( |  |  | 	return exec.Command( | 
			
		
	
		
		
			
				
					
					|  |  | 		"terraform", |  |  | 		command, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args..., |  |  | 		args..., | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | @ -318,8 +344,14 @@ func tfValidate(config Config) *exec.Cmd { | 
			
		
	
		
		
			
				
					|  |  | 		args = append(args, "-var") |  |  | 		args = append(args, "-var") | 
			
		
	
		
		
			
				
					|  |  | 		args = append(args, fmt.Sprintf("%s=%s", k, v)) |  |  | 		args = append(args, fmt.Sprintf("%s=%s", k, v)) | 
			
		
	
		
		
			
				
					|  |  | 	} |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	var command string | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	if config.TfInAutomation { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "TF_IN_AUTOMATION=true terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 		command = "terraform" | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					|  |  | 	return exec.Command( |  |  | 	return exec.Command( | 
			
		
	
		
		
			
				
					
					|  |  | 		"terraform", |  |  | 		command, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 		args..., |  |  | 		args..., | 
			
		
	
		
		
			
				
					|  |  | 	) |  |  | 	) | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | 
 |