2019-01-23 08:04:05 -05:00
|
|
|
package hyperone
|
|
|
|
|
|
|
|
import (
|
2019-02-05 10:20:42 -05:00
|
|
|
"bytes"
|
2019-04-03 11:14:55 -04:00
|
|
|
"context"
|
2019-01-23 08:04:05 -05:00
|
|
|
"fmt"
|
2019-02-05 10:20:42 -05:00
|
|
|
"log"
|
|
|
|
"strings"
|
2019-01-23 08:04:05 -05:00
|
|
|
|
2019-01-28 06:30:15 -05:00
|
|
|
"github.com/hashicorp/packer/packer"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2020-11-11 13:21:37 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/template/interpolate"
|
2019-03-22 09:53:28 -04:00
|
|
|
openapi "github.com/hyperonecom/h1-client-go"
|
2019-01-23 08:04:05 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func formatOpenAPIError(err error) string {
|
|
|
|
openAPIError, ok := err.(openapi.GenericOpenAPIError)
|
|
|
|
if !ok {
|
|
|
|
return err.Error()
|
|
|
|
}
|
|
|
|
|
|
|
|
return fmt.Sprintf("%s (body: %s)", openAPIError.Error(), openAPIError.Body())
|
|
|
|
}
|
2019-01-28 06:30:15 -05:00
|
|
|
|
2019-03-29 11:50:02 -04:00
|
|
|
func runCommands(commands []string, ictx interpolate.Context, state multistep.StateBag) error {
|
2019-04-03 11:14:55 -04:00
|
|
|
ctx := context.TODO()
|
2019-01-28 06:30:15 -05:00
|
|
|
ui := state.Get("ui").(packer.Ui)
|
|
|
|
wrappedCommand := state.Get("wrappedCommand").(CommandWrapper)
|
|
|
|
comm := state.Get("communicator").(packer.Communicator)
|
|
|
|
|
|
|
|
for _, rawCmd := range commands {
|
2019-03-29 11:50:02 -04:00
|
|
|
intCmd, err := interpolate.Render(rawCmd, &ictx)
|
2019-01-28 06:30:15 -05:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error interpolating: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
command, err := wrappedCommand(intCmd)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error wrapping command: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
remoteCmd := &packer.RemoteCmd{
|
|
|
|
Command: command,
|
|
|
|
}
|
|
|
|
|
|
|
|
ui.Say(fmt.Sprintf("Executing command: %s", command))
|
|
|
|
|
2019-04-03 11:14:55 -04:00
|
|
|
err = remoteCmd.RunWithUi(ctx, comm, ui)
|
2019-01-28 06:30:15 -05:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error running remote cmd: %s", err)
|
|
|
|
}
|
|
|
|
|
2019-04-03 11:14:55 -04:00
|
|
|
if remoteCmd.ExitStatus() != 0 {
|
2019-01-28 06:30:15 -05:00
|
|
|
return fmt.Errorf(
|
|
|
|
"received non-zero exit code %d from command: %s",
|
2019-04-03 11:14:55 -04:00
|
|
|
remoteCmd.ExitStatus(),
|
2019-01-28 06:30:15 -05:00
|
|
|
command)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2019-02-05 10:20:42 -05:00
|
|
|
|
|
|
|
func captureOutput(command string, state multistep.StateBag) (string, error) {
|
2019-04-03 11:14:55 -04:00
|
|
|
ctx := context.TODO()
|
2019-02-05 10:20:42 -05:00
|
|
|
comm := state.Get("communicator").(packer.Communicator)
|
|
|
|
|
|
|
|
var stdout bytes.Buffer
|
|
|
|
remoteCmd := &packer.RemoteCmd{
|
|
|
|
Command: command,
|
|
|
|
Stdout: &stdout,
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Println(fmt.Sprintf("Executing command: %s", command))
|
|
|
|
|
2019-04-03 11:14:55 -04:00
|
|
|
err := comm.Start(ctx, remoteCmd)
|
2019-02-05 10:20:42 -05:00
|
|
|
if err != nil {
|
|
|
|
return "", fmt.Errorf("error running remote cmd: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
remoteCmd.Wait()
|
2019-04-03 11:14:55 -04:00
|
|
|
if remoteCmd.ExitStatus() != 0 {
|
2019-02-05 10:20:42 -05:00
|
|
|
return "", fmt.Errorf(
|
|
|
|
"received non-zero exit code %d from command: %s",
|
2019-04-03 11:14:55 -04:00
|
|
|
remoteCmd.ExitStatus(),
|
2019-02-05 10:20:42 -05:00
|
|
|
command)
|
|
|
|
}
|
|
|
|
|
|
|
|
return strings.TrimSpace(stdout.String()), nil
|
|
|
|
}
|