Commit 00543fe5 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

Merge pull request #1479 from jasonberanek/esxi-remote-cache

buidler/vmware-esxi: Add configuration options for the remote location to cache ISO and floppy files
parents 699561bf 8d398d15
...@@ -48,6 +48,8 @@ type config struct { ...@@ -48,6 +48,8 @@ type config struct {
RemoteType string `mapstructure:"remote_type"` RemoteType string `mapstructure:"remote_type"`
RemoteDatastore string `mapstructure:"remote_datastore"` RemoteDatastore string `mapstructure:"remote_datastore"`
RemoteCacheDatastore string `mapstructure:"remote_cache_datastore"`
RemoteCacheDirectory string `mapstructure:"remote_cache_directory"`
RemoteHost string `mapstructure:"remote_host"` RemoteHost string `mapstructure:"remote_host"`
RemotePort uint `mapstructure:"remote_port"` RemotePort uint `mapstructure:"remote_port"`
RemoteUser string `mapstructure:"remote_username"` RemoteUser string `mapstructure:"remote_username"`
...@@ -123,6 +125,14 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) { ...@@ -123,6 +125,14 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
b.config.RemoteDatastore = "datastore1" b.config.RemoteDatastore = "datastore1"
} }
if b.config.RemoteCacheDatastore == "" {
b.config.RemoteCacheDatastore = b.config.RemoteDatastore
}
if b.config.RemoteCacheDirectory == "" {
b.config.RemoteCacheDirectory = "packer_cache"
}
if b.config.RemotePort == 0 { if b.config.RemotePort == 0 {
b.config.RemotePort = 22 b.config.RemotePort = 22
} }
...@@ -139,6 +149,8 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) { ...@@ -139,6 +149,8 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
"remote_type": &b.config.RemoteType, "remote_type": &b.config.RemoteType,
"remote_host": &b.config.RemoteHost, "remote_host": &b.config.RemoteHost,
"remote_datastore": &b.config.RemoteDatastore, "remote_datastore": &b.config.RemoteDatastore,
"remote_cache_datastore": &b.config.RemoteCacheDatastore,
"remote_cache_directory": &b.config.RemoteCacheDirectory,
"remote_user": &b.config.RemoteUser, "remote_user": &b.config.RemoteUser,
"remote_password": &b.config.RemotePassword, "remote_password": &b.config.RemotePassword,
} }
......
...@@ -22,6 +22,8 @@ func NewDriver(config *config) (vmwcommon.Driver, error) { ...@@ -22,6 +22,8 @@ func NewDriver(config *config) (vmwcommon.Driver, error) {
Username: config.RemoteUser, Username: config.RemoteUser,
Password: config.RemotePassword, Password: config.RemotePassword,
Datastore: config.RemoteDatastore, Datastore: config.RemoteDatastore,
CacheDatastore: config.RemoteCacheDatastore,
CacheDirectory: config.RemoteCacheDirectory,
}, },
} }
......
...@@ -27,6 +27,8 @@ type ESX5Driver struct { ...@@ -27,6 +27,8 @@ type ESX5Driver struct {
Username string Username string
Password string Password string
Datastore string Datastore string
CacheDatastore string
CacheDirectory string
comm packer.Communicator comm packer.Communicator
outputDir string outputDir string
...@@ -84,13 +86,7 @@ func (d *ESX5Driver) Unregister(vmxPathLocal string) error { ...@@ -84,13 +86,7 @@ func (d *ESX5Driver) Unregister(vmxPathLocal string) error {
} }
func (d *ESX5Driver) UploadISO(localPath string, checksum string, checksumType string) (string, error) { func (d *ESX5Driver) UploadISO(localPath string, checksum string, checksumType string) (string, error) {
cacheRoot, _ := filepath.Abs(".") finalPath := d.cachePath(localPath)
targetFile, err := filepath.Rel(cacheRoot, localPath)
if err != nil {
return "", err
}
finalPath := d.datastorePath(targetFile)
if err := d.mkdir(filepath.ToSlash(filepath.Dir(finalPath))); err != nil { if err := d.mkdir(filepath.ToSlash(filepath.Dir(finalPath))); err != nil {
return "", err return "", err
} }
...@@ -300,6 +296,10 @@ func (d *ESX5Driver) datastorePath(path string) string { ...@@ -300,6 +296,10 @@ func (d *ESX5Driver) datastorePath(path string) string {
return filepath.ToSlash(filepath.Join("/vmfs/volumes", d.Datastore, baseDir, filepath.Base(path))) return filepath.ToSlash(filepath.Join("/vmfs/volumes", d.Datastore, baseDir, filepath.Base(path)))
} }
func (d *ESX5Driver) cachePath(path string) string {
return filepath.ToSlash(filepath.Join("/vmfs/volumes", d.CacheDatastore, d.CacheDirectory, filepath.Base(path)))
}
func (d *ESX5Driver) connect() error { func (d *ESX5Driver) connect() error {
address := fmt.Sprintf("%s:%d", d.Host, d.Port) address := fmt.Sprintf("%s:%d", d.Host, d.Port)
......
...@@ -151,6 +151,16 @@ each category, the available options are alphabetized and described. ...@@ -151,6 +151,16 @@ each category, the available options are alphabetized and described.
By default this is "output-BUILDNAME" where "BUILDNAME" is the name By default this is "output-BUILDNAME" where "BUILDNAME" is the name
of the build. of the build.
* `remote_cache_datastore` (string) - The path to the datastore where
supporting files will be stored during the build on the remote machine.
By default this is the same as the `remote_datastore` option. This only
has an effect if `remote_type` is enabled.
* `remote_cache_directory` (string) - The path where the ISO and/or floppy
files will be stored during the build on the remote machine. The path is
relative to the `remote_cache_datastore` on the remote machine. By default
this is "packer_cache". This only has an effect if `remote_type` is enabled.
* `remote_datastore` (string) - The path to the datastore where the resulting * `remote_datastore` (string) - The path to the datastore where the resulting
VM will be stored when it is built on the remote machine. By default this VM will be stored when it is built on the remote machine. By default this
is "datastore1". This only has an effect if `remote_type` is enabled. is "datastore1". This only has an effect if `remote_type` is enabled.
...@@ -375,6 +385,13 @@ have to modify as well: ...@@ -375,6 +385,13 @@ have to modify as well:
* `remote_datastore` - The path to the datastore where the VM will be * `remote_datastore` - The path to the datastore where the VM will be
stored on the ESXi machine. stored on the ESXi machine.
* `remote_cache_datastore` - The path to the datastore where
supporting files will be stored during the build on the remote machine.
* `remote_cache_directory` - The path where the ISO and/or floppy
files will be stored during the build on the remote machine. The path is
relative to the `remote_cache_datastore` on the remote machine.
* `remote_username` - The SSH username used to access the remote machine. * `remote_username` - The SSH username used to access the remote machine.
* `remote_password` - The SSH password for access to the remote machine. * `remote_password` - The SSH password for access to the remote machine.
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