174 lines
4.1 KiB
Go
174 lines
4.1 KiB
Go
|
package cloudstack
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"log"
|
||
|
"strings"
|
||
|
|
||
|
"github.com/hashicorp/terraform/helper/schema"
|
||
|
"github.com/xanzy/go-cloudstack/cloudstack"
|
||
|
)
|
||
|
|
||
|
func resourceCloudStackPrivateGateway() *schema.Resource {
|
||
|
return &schema.Resource{
|
||
|
Create: resourceCloudStackPrivateGatewayCreate,
|
||
|
Read: resourceCloudStackPrivateGatewayRead,
|
||
|
Update: resourceCloudStackPrivateGatewayUpdate,
|
||
|
Delete: resourceCloudStackPrivateGatewayDelete,
|
||
|
|
||
|
Schema: map[string]*schema.Schema{
|
||
|
"gateway": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"ip_address": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"netmask": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"vlan": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"physical_network_id": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Optional: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"network_offering": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Optional: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
|
||
|
"acl_id": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
},
|
||
|
|
||
|
"vpc_id": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
ForceNew: true,
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func resourceCloudStackPrivateGatewayCreate(d *schema.ResourceData, meta interface{}) error {
|
||
|
cs := meta.(*cloudstack.CloudStackClient)
|
||
|
|
||
|
ipaddress := d.Get("ip_address").(string)
|
||
|
networkofferingid := d.Get("network_offering").(string)
|
||
|
|
||
|
// Create a new parameter struct
|
||
|
p := cs.VPC.NewCreatePrivateGatewayParams(
|
||
|
d.Get("gateway").(string),
|
||
|
ipaddress,
|
||
|
d.Get("netmask").(string),
|
||
|
d.Get("vlan").(string),
|
||
|
d.Get("vpc_id").(string),
|
||
|
)
|
||
|
|
||
|
// Retrieve the network_offering ID
|
||
|
if networkofferingid != "" {
|
||
|
networkofferingid, e := retrieveID(cs, "network_offering", networkofferingid)
|
||
|
if e != nil {
|
||
|
return e.Error()
|
||
|
}
|
||
|
p.SetNetworkofferingid(networkofferingid)
|
||
|
}
|
||
|
|
||
|
// Check if we want to associate an ACL
|
||
|
if aclid, ok := d.GetOk("acl_id"); ok {
|
||
|
// Set the acl ID
|
||
|
p.SetAclid(aclid.(string))
|
||
|
}
|
||
|
|
||
|
// Create the new private gateway
|
||
|
r, err := cs.VPC.CreatePrivateGateway(p)
|
||
|
if err != nil {
|
||
|
return fmt.Errorf("Error creating private gateway for %s: %s", ipaddress, err)
|
||
|
}
|
||
|
|
||
|
d.SetId(r.Id)
|
||
|
|
||
|
return resourceCloudStackPrivateGatewayRead(d, meta)
|
||
|
}
|
||
|
|
||
|
func resourceCloudStackPrivateGatewayRead(d *schema.ResourceData, meta interface{}) error {
|
||
|
cs := meta.(*cloudstack.CloudStackClient)
|
||
|
|
||
|
// Get the private gateway details
|
||
|
gw, count, err := cs.VPC.GetPrivateGatewayByID(d.Id())
|
||
|
if err != nil {
|
||
|
if count == 0 {
|
||
|
log.Printf("[DEBUG] Private gateway %s does no longer exist", d.Id())
|
||
|
d.SetId("")
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
d.Set("gateway", gw.Gateway)
|
||
|
d.Set("ip_address", gw.Ipaddress)
|
||
|
d.Set("netmask", gw.Netmask)
|
||
|
d.Set("vlan", gw.Vlan)
|
||
|
d.Set("acl_id", gw.Aclid)
|
||
|
d.Set("vpc_id", gw.Vpcid)
|
||
|
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func resourceCloudStackPrivateGatewayUpdate(d *schema.ResourceData, meta interface{}) error {
|
||
|
cs := meta.(*cloudstack.CloudStackClient)
|
||
|
|
||
|
// Replace the ACL if the ID has changed
|
||
|
if d.HasChange("acl_id") {
|
||
|
p := cs.NetworkACL.NewReplaceNetworkACLListParams(d.Get("acl_id").(string))
|
||
|
p.SetNetworkid(d.Id())
|
||
|
|
||
|
_, err := cs.NetworkACL.ReplaceNetworkACLList(p)
|
||
|
if err != nil {
|
||
|
return fmt.Errorf("Error replacing ACL: %s", err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return resourceCloudStackNetworkRead(d, meta)
|
||
|
}
|
||
|
|
||
|
func resourceCloudStackPrivateGatewayDelete(d *schema.ResourceData, meta interface{}) error {
|
||
|
cs := meta.(*cloudstack.CloudStackClient)
|
||
|
|
||
|
// Create a new parameter struct
|
||
|
p := cs.VPC.NewDeletePrivateGatewayParams(d.Id())
|
||
|
|
||
|
// Delete the private gateway
|
||
|
_, err := cs.VPC.DeletePrivateGateway(p)
|
||
|
if err != nil {
|
||
|
// This is a very poor way to be told the ID does no longer exist :(
|
||
|
if strings.Contains(err.Error(), fmt.Sprintf(
|
||
|
"Invalid parameter id value=%s due to incorrect long value format, "+
|
||
|
"or entity does not exist", d.Id())) {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
return fmt.Errorf("Error deleting private gateway %s: %s", d.Id(), err)
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|