mirror of
https://github.com/semaphoreui/semaphore.git
synced 2024-12-03 14:51:05 +01:00
155 lines
3.3 KiB
Go
155 lines
3.3 KiB
Go
|
package db_lib
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"github.com/ansible-semaphore/semaphore/db"
|
||
|
"github.com/ansible-semaphore/semaphore/pkg/task_logger"
|
||
|
"github.com/ansible-semaphore/semaphore/util"
|
||
|
"os"
|
||
|
"os/exec"
|
||
|
"path"
|
||
|
"strings"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
type TerraformAppName string
|
||
|
|
||
|
const (
|
||
|
TerraformAppTerraform TerraformAppName = "terraform"
|
||
|
TerraformAppTofu TerraformAppName = "tofu"
|
||
|
)
|
||
|
|
||
|
type TerraformApp struct {
|
||
|
Logger task_logger.Logger
|
||
|
Template db.Template
|
||
|
Repository db.Repository
|
||
|
reader terraformReader
|
||
|
Name TerraformAppName
|
||
|
}
|
||
|
|
||
|
type terraformLogger struct {
|
||
|
logger task_logger.Logger
|
||
|
reader *terraformReader
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) Log(msg string) {
|
||
|
l.logger.Log(msg)
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) Logf(format string, a ...any) {
|
||
|
l.logger.Logf(format, a...)
|
||
|
}
|
||
|
|
||
|
type terraformReader struct {
|
||
|
confirmed bool
|
||
|
logger *terraformLogger
|
||
|
}
|
||
|
|
||
|
func (r *terraformReader) Read(p []byte) (n int, err error) {
|
||
|
if r.confirmed {
|
||
|
copy(p, "\n")
|
||
|
return 1, nil
|
||
|
}
|
||
|
|
||
|
r.logger.SetStatus(task_logger.TaskWaitingConfirmation)
|
||
|
|
||
|
for {
|
||
|
time.Sleep(time.Second * 3)
|
||
|
if r.confirmed {
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
|
||
|
copy(p, "yes\n")
|
||
|
r.logger.SetStatus(task_logger.TaskRunningStatus)
|
||
|
return 4, nil
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) LogWithTime(now time.Time, msg string) {
|
||
|
l.logger.LogWithTime(now, msg)
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) LogfWithTime(now time.Time, format string, a ...any) {
|
||
|
l.logger.LogWithTime(now, fmt.Sprintf(format, a...))
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) LogCmd(cmd *exec.Cmd) {
|
||
|
l.logger.LogCmd(cmd)
|
||
|
}
|
||
|
|
||
|
func (l *terraformLogger) SetStatus(status task_logger.TaskStatus) {
|
||
|
if status == task_logger.TaskConfirmed {
|
||
|
l.reader.confirmed = true
|
||
|
}
|
||
|
|
||
|
l.logger.SetStatus(status)
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) makeCmd(command string, args []string, environmentVars *[]string) *exec.Cmd {
|
||
|
cmd := exec.Command(command, args...) //nolint: gas
|
||
|
cmd.Dir = t.GetFullPath()
|
||
|
|
||
|
cmd.Env = os.Environ()
|
||
|
cmd.Env = append(cmd.Env, fmt.Sprintf("HOME=%s", util.Config.TmpPath))
|
||
|
cmd.Env = append(cmd.Env, fmt.Sprintf("PWD=%s", cmd.Dir))
|
||
|
|
||
|
if environmentVars != nil {
|
||
|
cmd.Env = append(cmd.Env, *environmentVars...)
|
||
|
}
|
||
|
|
||
|
// Remove sensitive env variables from cmd process
|
||
|
for _, env := range getSensitiveEnvs() {
|
||
|
cmd.Env = append(cmd.Env, env+"=")
|
||
|
}
|
||
|
|
||
|
return cmd
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) runCmd(command string, args []string) error {
|
||
|
cmd := t.makeCmd(command, args, nil)
|
||
|
t.Logger.LogCmd(cmd)
|
||
|
return cmd.Run()
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) GetFullPath() string {
|
||
|
return path.Join(t.Repository.GetFullPath(t.Template.ID), strings.TrimPrefix(t.Template.Playbook, "/"))
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) SetLogger(logger task_logger.Logger) task_logger.Logger {
|
||
|
internalLogger := &terraformLogger{
|
||
|
logger: logger,
|
||
|
reader: &t.reader,
|
||
|
}
|
||
|
|
||
|
t.reader.logger = internalLogger
|
||
|
t.Logger = internalLogger
|
||
|
return internalLogger
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) InstallRequirements() error {
|
||
|
|
||
|
if _, ok := t.Logger.(*terraformLogger); !ok {
|
||
|
t.SetLogger(t.Logger)
|
||
|
}
|
||
|
|
||
|
cmd := t.makeCmd(string(t.Name), []string{"init"}, nil)
|
||
|
t.Logger.LogCmd(cmd)
|
||
|
err := cmd.Start()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return cmd.Wait()
|
||
|
}
|
||
|
|
||
|
func (t *TerraformApp) Run(args []string, environmentVars *[]string, inputs map[string]string, cb func(*os.Process)) error {
|
||
|
cmd := t.makeCmd(string(t.Name), args, environmentVars)
|
||
|
t.Logger.LogCmd(cmd)
|
||
|
cmd.Stdin = &t.reader
|
||
|
err := cmd.Start()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
cb(cmd.Process)
|
||
|
return cmd.Wait()
|
||
|
}
|