2020-05-14 23:44:08 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2025-01-03 16:22:00 +02:00
|
|
|
func launchHook(hook string, timeout time.Duration, meta map[string]string) error {
|
2020-05-14 23:44:08 +02:00
|
|
|
if hook == "" {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2025-01-03 16:22:00 +02:00
|
|
|
ctxCmd, cancel := context.WithTimeout(context.Background(), timeout)
|
2020-05-14 23:44:08 +02:00
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
parts := strings.Fields(hook)
|
|
|
|
|
|
|
|
cmdCtx := exec.CommandContext(ctxCmd, parts[0], parts[1:]...)
|
|
|
|
cmdCtx.Env = append(os.Environ(), metaToEnv(meta)...)
|
|
|
|
|
|
|
|
output, err := cmdCtx.CombinedOutput()
|
|
|
|
|
|
|
|
if len(output) > 0 {
|
|
|
|
fmt.Println(string(output))
|
|
|
|
}
|
|
|
|
|
2020-10-27 13:01:05 +02:00
|
|
|
if errors.Is(ctxCmd.Err(), context.DeadlineExceeded) {
|
2020-05-14 23:44:08 +02:00
|
|
|
return errors.New("hook timed out")
|
|
|
|
}
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func metaToEnv(meta map[string]string) []string {
|
|
|
|
var envs []string
|
|
|
|
|
|
|
|
for k, v := range meta {
|
|
|
|
envs = append(envs, k+"="+v)
|
|
|
|
}
|
|
|
|
|
|
|
|
return envs
|
|
|
|
}
|