mirror of
https://github.com/dokku/dokku.git
synced 2025-12-16 20:17:44 +01:00
72 lines
2.0 KiB
Go
72 lines
2.0 KiB
Go
package common
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"io"
|
|
"os"
|
|
"strings"
|
|
)
|
|
|
|
// PlugnTriggerInput is the input for CallPlugnTrigger
|
|
type PlugnTriggerInput struct {
|
|
// Args are the arguments to pass to the trigger
|
|
Args []string
|
|
|
|
// DisableStdioBuffer disables the stdio buffer
|
|
DisableStdioBuffer bool
|
|
|
|
// Env is the environment variables to pass to the trigger
|
|
Env map[string]string
|
|
|
|
// PrintCommand prints the command before executing
|
|
PrintCommand bool
|
|
|
|
// Stdin is the stdin of the command
|
|
Stdin io.Reader
|
|
|
|
// StreamStdio determines whether to stream the stdio of the trigger
|
|
StreamStdio bool
|
|
|
|
// StreamStdout prints stdout directly to os.Stdout as the command runs.
|
|
StreamStdout bool
|
|
|
|
// StreamStderr prints stderr directly to os.Stderr as the command runs.
|
|
StreamStderr bool
|
|
|
|
// Trigger is the trigger to execute
|
|
Trigger string
|
|
}
|
|
|
|
// CallPlugnTrigger executes a trigger via plugn
|
|
func CallPlugnTrigger(input PlugnTriggerInput) (ExecCommandResponse, error) {
|
|
return CallPlugnTriggerWithContext(context.Background(), input)
|
|
}
|
|
|
|
// CallPlugnTriggerWithContext executes a trigger via plugn with the given context
|
|
func CallPlugnTriggerWithContext(ctx context.Context, input PlugnTriggerInput) (ExecCommandResponse, error) {
|
|
args := []string{"trigger", input.Trigger}
|
|
args = append(args, input.Args...)
|
|
result, err := CallExecCommandWithContext(ctx, ExecCommandInput{
|
|
Command: "plugn",
|
|
Args: args,
|
|
DisableStdioBuffer: input.DisableStdioBuffer,
|
|
Env: input.Env,
|
|
Stdin: input.Stdin,
|
|
StreamStdio: input.StreamStdio,
|
|
StreamStdout: input.StreamStdout,
|
|
StreamStderr: input.StreamStderr,
|
|
})
|
|
|
|
if input.PrintCommand || os.Getenv("DOKKU_TRACE") == "1" {
|
|
for _, line := range strings.Split(result.Stderr, "\n") {
|
|
LogDebug(fmt.Sprintf("plugn trigger %s stderr: %s", input.Trigger, line))
|
|
}
|
|
for _, line := range strings.Split(result.Stdout, "\n") {
|
|
LogDebug(fmt.Sprintf("plugn trigger %s stdout: %s", input.Trigger, line))
|
|
}
|
|
}
|
|
|
|
return result, err
|
|
}
|