|
@ -17,10 +17,10 @@ import ( |
|
|
|
|
|
|
|
|
type ( |
|
|
type ( |
|
|
Config struct { |
|
|
Config struct { |
|
|
Remote Remote |
|
|
|
|
|
Plan bool |
|
|
Plan bool |
|
|
Vars map[string]string |
|
|
Vars map[string]string |
|
|
Secrets map[string]string |
|
|
Secrets map[string]string |
|
|
|
|
|
InitOptions InitOptions |
|
|
Cacert string |
|
|
Cacert string |
|
|
Sensitive bool |
|
|
Sensitive bool |
|
|
RoleARN string |
|
|
RoleARN string |
|
@ -30,9 +30,10 @@ type ( |
|
|
VarFiles []string |
|
|
VarFiles []string |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Remote struct { |
|
|
InitOptions struct { |
|
|
Backend string `json:"backend"` |
|
|
BackendConfig string `json:"backend-config"` |
|
|
Config map[string]string `json:"config"` |
|
|
Lock *bool `json:"lock"` |
|
|
|
|
|
LockTimeout string `json:"lock-timeout"` |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Plugin struct { |
|
|
Plugin struct { |
|
@ -51,14 +52,14 @@ func (p Plugin) Exec() error { |
|
|
exportSecrets(p.Config.Secrets) |
|
|
exportSecrets(p.Config.Secrets) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
remote := p.Config.Remote |
|
|
|
|
|
if p.Config.Cacert != "" { |
|
|
if p.Config.Cacert != "" { |
|
|
commands = append(commands, installCaCert(p.Config.Cacert)) |
|
|
commands = append(commands, installCaCert(p.Config.Cacert)) |
|
|
} |
|
|
} |
|
|
if remote.Backend != "" { |
|
|
|
|
|
commands = append(commands, deleteCache()) |
|
|
commands = append(commands, deleteCache()) |
|
|
commands = append(commands, remoteConfigCommand(remote)) |
|
|
|
|
|
} |
|
|
commands = append(commands, initCommand(p.Config.InitOptions)) |
|
|
|
|
|
|
|
|
commands = append(commands, getModules()) |
|
|
commands = append(commands, getModules()) |
|
|
commands = append(commands, validateCommand()) |
|
|
commands = append(commands, validateCommand()) |
|
|
commands = append(commands, planCommand(p.Config)) |
|
|
commands = append(commands, planCommand(p.Config)) |
|
@ -116,15 +117,28 @@ func deleteCache() *exec.Cmd { |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func remoteConfigCommand(config Remote) *exec.Cmd { |
|
|
func initCommand(config InitOptions) *exec.Cmd { |
|
|
args := []string{ |
|
|
args := []string{ |
|
|
"remote", |
|
|
"init", |
|
|
"config", |
|
|
|
|
|
fmt.Sprintf("-backend=%s", config.Backend), |
|
|
|
|
|
} |
|
|
} |
|
|
for k, v := range config.Config { |
|
|
|
|
|
args = append(args, fmt.Sprintf("-backend-config=%s=%s", k, v)) |
|
|
if config.BackendConfig != "" { |
|
|
|
|
|
args = append(args, fmt.Sprintf("-backend-config=%s", config.BackendConfig)) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// True is default in TF
|
|
|
|
|
|
if config.Lock != nil { |
|
|
|
|
|
args = append(args, fmt.Sprintf("-lock=%t", *config.Lock)) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// "0s" is default in TF
|
|
|
|
|
|
if config.LockTimeout != "" { |
|
|
|
|
|
args = append(args, fmt.Sprintf("-lock-timeout=%s", config.LockTimeout)) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Fail Terraform execution on prompt
|
|
|
|
|
|
args = append(args, "-input=false") |
|
|
|
|
|
|
|
|
return exec.Command( |
|
|
return exec.Command( |
|
|
"terraform", |
|
|
"terraform", |
|
|
args..., |
|
|
args..., |
|
|