Commit a9f07bc3 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

Merge pull request #912 from nebula/populate_api

builder/openstack: added support for gophercloud's PopulateApi
parents 7e16d12b ee95fbbd
...@@ -60,13 +60,15 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe ...@@ -60,13 +60,15 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
if err != nil { if err != nil {
return nil, err return nil, err
} }
api := &gophercloud.ApiCriteria{ //fetches the api requisites from gophercloud for the appropriate
Name: "cloudServersOpenStack", //openstack variant
Region: b.config.AccessConfig.Region(), api, err := gophercloud.PopulateApi(b.config.RunConfig.OpenstackProvider)
VersionId: "2", if err != nil {
UrlChoice: gophercloud.PublicURL, return nil, err
} }
csp, err := gophercloud.ServersApi(auth, *api) api.Region = b.config.AccessConfig.Region()
csp, err := gophercloud.ServersApi(auth, api)
if err != nil { if err != nil {
log.Printf("Region: %s", b.config.AccessConfig.Region()) log.Printf("Region: %s", b.config.AccessConfig.Region())
return nil, err return nil, err
......
...@@ -15,6 +15,7 @@ type RunConfig struct { ...@@ -15,6 +15,7 @@ type RunConfig struct {
RawSSHTimeout string `mapstructure:"ssh_timeout"` RawSSHTimeout string `mapstructure:"ssh_timeout"`
SSHUsername string `mapstructure:"ssh_username"` SSHUsername string `mapstructure:"ssh_username"`
SSHPort int `mapstructure:"ssh_port"` SSHPort int `mapstructure:"ssh_port"`
OpenstackProvider string `mapstructure:"openstack_provider"`
// Unexported fields that are calculated from others // Unexported fields that are calculated from others
sshTimeout time.Duration sshTimeout time.Duration
......
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