Commit 56745e14 authored by Chris Bednarski's avatar Chris Bednarski

manifest_file can now be a folder or file.pp and we will upload it correctly in either case

parent 518ad704
...@@ -270,28 +270,43 @@ func (p *Provisioner) uploadManifests(ui packer.Ui, comm packer.Communicator) (s ...@@ -270,28 +270,43 @@ func (p *Provisioner) uploadManifests(ui packer.Ui, comm packer.Communicator) (s
return "", fmt.Errorf("Error creating manifests directory: %s", err) return "", fmt.Errorf("Error creating manifests directory: %s", err)
} }
// Upload the main manifest // NOTE! manifest_file may either be a directory or a file, as puppet apply
f, err := os.Open(p.config.ManifestFile) // now accepts either one.
fi, err := os.Stat(p.config.ManifestFile)
if err != nil { if err != nil {
return "", err return "", fmt.Errorf("Error inspecting manifest file: %s", err)
} }
defer f.Close()
manifestFilename := p.config.ManifestFile if fi.IsDir() {
if fi, err := os.Stat(p.config.ManifestFile); err != nil { // If manifest_file is a directory we'll upload the whole thing
return "", fmt.Errorf("Error inspecting manifest file: %s", err) ui.Message(fmt.Sprintf(
} else if !fi.IsDir() { "Uploading manifest directory from: %s", p.config.ManifestFile))
manifestFilename = filepath.Base(manifestFilename)
remoteManifestDir := fmt.Sprintf("%s/manifests", p.config.StagingDir)
err := p.uploadDirectory(ui, comm, remoteManifestDir, p.config.ManifestFile)
if err != nil {
return "", fmt.Errorf("Error uploading manifest dir: %s", err)
}
return remoteManifestDir, nil
} else { } else {
ui.Say("WARNING: manifest_file should be a file. Use manifest_dir for directories") // Otherwise manifest_file is a file and we'll upload it
ui.Message(fmt.Sprintf(
"Uploading manifest file from: %s", p.config.ManifestFile))
f, err := os.Open(p.config.ManifestFile)
if err != nil {
return "", err
} }
defer f.Close()
manifestFilename := filepath.Base(p.config.ManifestFile)
remoteManifestFile := fmt.Sprintf("%s/%s", remoteManifestsPath, manifestFilename) remoteManifestFile := fmt.Sprintf("%s/%s", remoteManifestsPath, manifestFilename)
if err := comm.Upload(remoteManifestFile, f, nil); err != nil { if err := comm.Upload(remoteManifestFile, f, nil); err != nil {
return "", err return "", err
} }
return remoteManifestFile, nil return remoteManifestFile, nil
}
} }
func (p *Provisioner) createDir(ui packer.Ui, comm packer.Communicator, dir string) error { func (p *Provisioner) createDir(ui packer.Ui, comm packer.Communicator, dir string) error {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment