move wrapper definitions around.
This commit is contained in:
parent
8857358830
commit
837e641802
|
@ -37,6 +37,10 @@ type Config struct {
|
||||||
tpl *packer.ConfigTemplate
|
tpl *packer.ConfigTemplate
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type wrappedCommandTemplate struct {
|
||||||
|
Command string
|
||||||
|
}
|
||||||
|
|
||||||
type Builder struct {
|
type Builder struct {
|
||||||
config Config
|
config Config
|
||||||
runner multistep.Runner
|
runner multistep.Runner
|
||||||
|
@ -162,7 +166,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
|
||||||
ec2conn := ec2.New(auth, region)
|
ec2conn := ec2.New(auth, region)
|
||||||
|
|
||||||
wrappedCommand := func(command string) *exec.Cmd {
|
wrappedCommand := func(command string) *exec.Cmd {
|
||||||
wrapped, err := b.config.tpl.Process(b.config.CommandWrapper, &WrappedCommandTemplate{
|
wrapped, err := b.config.tpl.Process(b.config.CommandWrapper, &wrappedCommandTemplate{
|
||||||
Command: command,
|
Command: command,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -66,7 +66,7 @@ func (c *Communicator) Upload(dst string, r io.Reader) error {
|
||||||
}
|
}
|
||||||
defer os.Remove(tf.Name())
|
defer os.Remove(tf.Name())
|
||||||
io.Copy(tf, r)
|
io.Copy(tf, r)
|
||||||
cpCmd := fmt.Sprintf("cp %s %s", dst, tf.Name())
|
cpCmd := fmt.Sprintf("cp %s %s", tf.Name(), dst)
|
||||||
return (*c.ChrootCmd(cpCmd)).Run()
|
return (*c.ChrootCmd(cpCmd)).Run()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ func (c *Communicator) UploadDir(dst string, src string, exclude []string) error
|
||||||
|
|
||||||
chrootDest := filepath.Join(c.Chroot, dst, path)
|
chrootDest := filepath.Join(c.Chroot, dst, path)
|
||||||
log.Printf("Uploading to chroot dir: %s", dst)
|
log.Printf("Uploading to chroot dir: %s", dst)
|
||||||
cpCmd := fmt.Sprintf("cp %s %s", chrootDest, fullPath)
|
cpCmd := fmt.Sprintf("cp %s %s", fullPath, chrootDest)
|
||||||
return c.ChrootCmd(cpCmd).Run()
|
return c.ChrootCmd(cpCmd).Run()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ import (
|
||||||
"github.com/mitchellh/multistep"
|
"github.com/mitchellh/multistep"
|
||||||
"github.com/mitchellh/packer/packer"
|
"github.com/mitchellh/packer/packer"
|
||||||
"log"
|
"log"
|
||||||
|
"os/exec"
|
||||||
)
|
)
|
||||||
|
|
||||||
// StepChrootProvision provisions the instance within a chroot.
|
// StepChrootProvision provisions the instance within a chroot.
|
||||||
|
@ -11,16 +12,14 @@ type StepChrootProvision struct {
|
||||||
mounts []string
|
mounts []string
|
||||||
}
|
}
|
||||||
|
|
||||||
type WrappedCommandTemplate struct {
|
|
||||||
Command string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *StepChrootProvision) Run(state multistep.StateBag) multistep.StepAction {
|
func (s *StepChrootProvision) Run(state multistep.StateBag) multistep.StepAction {
|
||||||
hook := state.Get("hook").(packer.Hook)
|
hook := state.Get("hook").(packer.Hook)
|
||||||
mountPath := state.Get("mount_path").(string)
|
mountPath := state.Get("mount_path").(string)
|
||||||
ui := state.Get("ui").(packer.Ui)
|
ui := state.Get("ui").(packer.Ui)
|
||||||
wrappedCommand := state.Get("wrappedCommand").(Command)
|
wrappedCommand := state.Get("wrappedCommand").(Command)
|
||||||
chrootCmd := state.Get("chrootCmd").(Command)
|
chrootCmd := func(command string) *exec.Cmd {
|
||||||
|
return ChrootCommand(mountPath, command)
|
||||||
|
}
|
||||||
|
|
||||||
// Create our communicator
|
// Create our communicator
|
||||||
comm := &Communicator{
|
comm := &Communicator{
|
||||||
|
|
|
@ -31,7 +31,7 @@ func (s *StepCopyFiles) Run(state multistep.StateBag) multistep.StepAction {
|
||||||
chrootPath := filepath.Join(mountPath, path)
|
chrootPath := filepath.Join(mountPath, path)
|
||||||
log.Printf("Copying '%s' to '%s'", path, chrootPath)
|
log.Printf("Copying '%s' to '%s'", path, chrootPath)
|
||||||
|
|
||||||
cmd := fmt.Sprintf("cp %s %s", chrootPath, path)
|
cmd := fmt.Sprintf("cp %s %s", path, chrootPath)
|
||||||
if err := wrappedCommand(cmd); err != nil {
|
if err := wrappedCommand(cmd); err != nil {
|
||||||
err := fmt.Errorf("Error copying file: %s", err)
|
err := fmt.Errorf("Error copying file: %s", err)
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
|
|
|
@ -7,7 +7,6 @@ import (
|
||||||
"github.com/mitchellh/packer/packer"
|
"github.com/mitchellh/packer/packer"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -57,11 +56,6 @@ func (s *StepMountDevice) Run(state multistep.StateBag) multistep.StepAction {
|
||||||
return multistep.ActionHalt
|
return multistep.ActionHalt
|
||||||
}
|
}
|
||||||
|
|
||||||
chrootCmd := func(command string) *exec.Cmd {
|
|
||||||
return ChrootCommand(mountPath, command)
|
|
||||||
}
|
|
||||||
state.Put("chrootCmd", Command(chrootCmd))
|
|
||||||
|
|
||||||
ui.Say("Mounting the root device...")
|
ui.Say("Mounting the root device...")
|
||||||
stderr := new(bytes.Buffer)
|
stderr := new(bytes.Buffer)
|
||||||
mountCommand := fmt.Sprintf("mount %s %s", device, mountPath)
|
mountCommand := fmt.Sprintf("mount %s %s", device, mountPath)
|
||||||
|
|
Loading…
Reference in New Issue