Commit b4729ca7 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

Merge pull request #848 from nebula/securityGroups

Support for Security Groups in Openstack
parents 5c5d6273 f48fc1e2
......@@ -91,6 +91,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
Name: b.config.ImageName,
Flavor: b.config.Flavor,
SourceImage: b.config.SourceImage,
SecurityGroups: b.config.SecurityGroups,
},
&StepAllocateIp{
FloatingIpPool: b.config.FloatingIpPool,
......
......@@ -19,6 +19,7 @@ type RunConfig struct {
UseFloatingIp bool `mapstructure:"use_floating_ip"`
FloatingIpPool string `mapstructure:"floating_ip_pool"`
FloatingIp string `mapstructure:"floating_ip"`
SecurityGroups []string `mapstructure:"security_groups"`
// Unexported fields that are calculated from others
sshTimeout time.Duration
......@@ -76,8 +77,7 @@ func (c *RunConfig) Prepare(t *packer.ConfigTemplate) []error {
var err error
*ptr, err = t.Process(*ptr, nil)
if err != nil {
errs = append(
errs, fmt.Errorf("Error processing %s: %s", n, err))
errs = append(errs, fmt.Errorf("Error processing %s: %s", n, err))
}
}
......
......@@ -12,6 +12,7 @@ type StepRunSourceServer struct {
Flavor string
Name string
SourceImage string
SecurityGroups []string
server *gophercloud.Server
}
......@@ -23,11 +24,18 @@ func (s *StepRunSourceServer) Run(state multistep.StateBag) multistep.StepAction
// XXX - validate image and flavor is available
securityGroups := make([]map[string]interface{}, len(s.SecurityGroups))
for i, groupName := range s.SecurityGroups {
securityGroups[i] = make(map[string]interface{})
securityGroups[i]["name"] = groupName
}
server := gophercloud.NewServer{
Name: s.Name,
ImageRef: s.SourceImage,
FlavorRef: s.Flavor,
KeyPairName: keyName,
SecurityGroup: securityGroups,
}
serverResp, err := csp.CreateServer(server)
......
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