Merge remote-tracking branch 'origin/master' into 430

This commit is contained in:
Matthew Hooker 2013-09-26 16:24:28 -07:00
commit 6b1a7938d8
6 changed files with 69 additions and 10 deletions

View File

@ -3,6 +3,9 @@
BUG FIXES: BUG FIXES:
* core: default user variable values don't need to be strings. [GH-456] * core: default user variable values don't need to be strings. [GH-456]
* builder/amazon-chroot: Fix errors with waitin for state change. [GH-459]
* communicator/ssh: SCP uploads now work properly when directories
contain symlinks. [GH-449]
## 0.3.8 (September 22, 2013) ## 0.3.8 (September 22, 2013)

View File

@ -60,7 +60,8 @@ func (s *StepAttachVolume) Run(state multistep.StateBag) multistep.StepAction {
return nil, "", errors.New("No attachments on volume.") return nil, "", errors.New("No attachments on volume.")
} }
return nil, resp.Volumes[0].Attachments[0].Status, nil a := resp.Volumes[0].Attachments[0]
return a, a.Status, nil
}, },
} }
@ -111,12 +112,12 @@ func (s *StepAttachVolume) CleanupFunc(state multistep.StateBag) error {
return nil, "", err return nil, "", err
} }
state := "detached" v := resp.Volumes[0]
if len(resp.Volumes[0].Attachments) > 0 { if len(v.Attachments) > 0 {
state = resp.Volumes[0].Attachments[0].Status return v, v.Attachments[0].Status, nil
} else {
return v, "detached", nil
} }
return nil, state, nil
}, },
} }

View File

@ -75,7 +75,8 @@ func (s *StepCreateVolume) Run(state multistep.StateBag) multistep.StepAction {
return nil, "", err return nil, "", err
} }
return nil, resp.Volumes[0].Status, nil v := resp.Volumes[0]
return v, v.Status, nil
}, },
} }

View File

@ -51,7 +51,8 @@ func (s *StepSnapshot) Run(state multistep.StateBag) multistep.StepAction {
return nil, "", errors.New("No snapshots found.") return nil, "", errors.New("No snapshots found.")
} }
return nil, resp.Snapshots[0].Status, nil s := resp.Snapshots[0]
return s, s.Status, nil
}, },
} }

View File

@ -408,8 +408,27 @@ func scpUploadDir(root string, fs []os.FileInfo, w io.Writer, r *bufio.Reader) e
for _, fi := range fs { for _, fi := range fs {
realPath := filepath.Join(root, fi.Name()) realPath := filepath.Join(root, fi.Name())
if !fi.IsDir() { // Track if this is actually a symlink to a directory. If it is
// It is a regular file, just upload it // a symlink to a file we don't do any special behavior because uploading
// a file just works. If it is a directory, we need to know so we
// treat it as such.
isSymlinkToDir := false
if fi.Mode() & os.ModeSymlink == os.ModeSymlink {
symPath, err := filepath.EvalSymlinks(realPath)
if err != nil {
return err
}
symFi, err := os.Lstat(symPath)
if err != nil {
return err
}
isSymlinkToDir = symFi.IsDir()
}
if !fi.IsDir() && !isSymlinkToDir {
// It is a regular file (or symlink to a file), just upload it
f, err := os.Open(realPath) f, err := os.Open(realPath)
if err != nil { if err != nil {
return err return err

View File

@ -188,3 +188,37 @@ out of your AMI builds.
Packer properly obtains a process lock for the parallelism-sensitive parts Packer properly obtains a process lock for the parallelism-sensitive parts
of its internals such as finding an available device. of its internals such as finding an available device.
## Using an IAM Instance Profile
If AWS keys are not specified in the template or through environment variables
Packer will use credentials provided by the instance's IAM profile, if it has one.
The following policy document provides the minimal set permissions necessary for Packer to work:
<pre class="prettyprint">
{
"Statement": [{
"Effect": "Allow",
"Action" : [
"ec2:AttachVolume",
"ec2:CreateVolume",
"ec2:DeleteVolume",
"ec2:DescribeVolumes",
"ec2:DetachVolume",
"ec2:DescribeInstances",
"ec2:CreateSnapshot",
"ec2:DeleteSnapshot",
"ec2:DescribeSnapshots",
"ec2:DescribeImages",
"ec2:RegisterImage",
"ec2:CreateTags"
],
"Resource" : "*"
}]
}
</pre>