2017-03-17 17:10:47 +01:00
|
|
|
package vcd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
|
|
types "github.com/ukcloud/govcloudair/types/v56"
|
2017-05-31 10:24:14 +02:00
|
|
|
"log"
|
2017-03-17 17:10:47 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func resourceVcdEdgeGatewayVpn() *schema.Resource {
|
|
|
|
return &schema.Resource{
|
|
|
|
Create: resourceVcdEdgeGatewayVpnCreate,
|
|
|
|
Read: resourceVcdEdgeGatewayVpnRead,
|
|
|
|
Delete: resourceVcdEdgeGatewayVpnDelete,
|
|
|
|
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
|
|
|
|
|
|
"edge_gateway": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"name": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"description": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Optional: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"encryption_protocol": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"local_ip_address": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"local_id": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"mtu": &schema.Schema{
|
|
|
|
Type: schema.TypeInt,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"peer_ip_address": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"peer_id": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"shared_secret": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"local_subnets": &schema.Schema{
|
|
|
|
Type: schema.TypeSet,
|
|
|
|
Optional: true,
|
|
|
|
ForceNew: true,
|
|
|
|
Elem: &schema.Resource{
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
|
|
"local_subnet_name": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"local_subnet_gateway": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"local_subnet_mask": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"peer_subnets": &schema.Schema{
|
|
|
|
Type: schema.TypeSet,
|
|
|
|
Optional: true,
|
|
|
|
ForceNew: true,
|
|
|
|
Elem: &schema.Resource{
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
|
|
"peer_subnet_name": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"peer_subnet_gateway": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"peer_subnet_mask": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceVcdEdgeGatewayVpnCreate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
vcdClient := meta.(*VCDClient)
|
|
|
|
log.Printf("[TRACE] CLIENT: %#v", vcdClient)
|
|
|
|
vcdClient.Mutex.Lock()
|
|
|
|
defer vcdClient.Mutex.Unlock()
|
|
|
|
|
|
|
|
edgeGateway, err := vcdClient.OrgVdc.FindEdgeGateway(d.Get("edge_gateway").(string))
|
|
|
|
|
|
|
|
localSubnetsList := d.Get("local_subnets").(*schema.Set).List()
|
|
|
|
peerSubnetsList := d.Get("peer_subnets").(*schema.Set).List()
|
|
|
|
|
|
|
|
localSubnets := make([]*types.IpsecVpnSubnet, len(localSubnetsList))
|
|
|
|
peerSubnets := make([]*types.IpsecVpnSubnet, len(peerSubnetsList))
|
|
|
|
|
|
|
|
for i, s := range localSubnetsList {
|
|
|
|
ls := s.(map[string]interface{})
|
|
|
|
localSubnets[i] = &types.IpsecVpnSubnet{
|
|
|
|
Name: ls["local_subnet_name"].(string),
|
|
|
|
Gateway: ls["local_subnet_gateway"].(string),
|
|
|
|
Netmask: ls["local_subnet_mask"].(string),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for i, s := range peerSubnetsList {
|
|
|
|
ls := s.(map[string]interface{})
|
|
|
|
peerSubnets[i] = &types.IpsecVpnSubnet{
|
|
|
|
Name: ls["peer_subnet_name"].(string),
|
|
|
|
Gateway: ls["peer_subnet_gateway"].(string),
|
|
|
|
Netmask: ls["peer_subnet_mask"].(string),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tunnel := &types.GatewayIpsecVpnTunnel{
|
|
|
|
Name: d.Get("name").(string),
|
|
|
|
Description: d.Get("description").(string),
|
|
|
|
IpsecVpnLocalPeer: &types.IpsecVpnLocalPeer{
|
|
|
|
ID: "",
|
|
|
|
Name: "",
|
|
|
|
},
|
|
|
|
EncryptionProtocol: d.Get("encryption_protocol").(string),
|
|
|
|
LocalIPAddress: d.Get("local_ip_address").(string),
|
|
|
|
LocalID: d.Get("local_id").(string),
|
|
|
|
LocalSubnet: localSubnets,
|
|
|
|
Mtu: d.Get("mtu").(int),
|
|
|
|
PeerID: d.Get("peer_id").(string),
|
|
|
|
PeerIPAddress: d.Get("peer_ip_address").(string),
|
|
|
|
PeerSubnet: peerSubnets,
|
|
|
|
SharedSecret: d.Get("shared_secret").(string),
|
|
|
|
IsEnabled: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
tunnels := make([]*types.GatewayIpsecVpnTunnel, 1)
|
|
|
|
tunnels[0] = tunnel
|
|
|
|
|
|
|
|
ipsecVPNConfig := &types.EdgeGatewayServiceConfiguration{
|
|
|
|
Xmlns: "http://www.vmware.com/vcloud/v1.5",
|
|
|
|
GatewayIpsecVpnService: &types.GatewayIpsecVpnService{
|
|
|
|
IsEnabled: true,
|
2017-05-23 13:24:53 +02:00
|
|
|
Tunnel: tunnels,
|
2017-03-17 17:10:47 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("[INFO] ipsecVPNConfig: %#v", ipsecVPNConfig)
|
|
|
|
|
|
|
|
err = retryCall(vcdClient.MaxRetryTimeout, func() *resource.RetryError {
|
|
|
|
edgeGateway.Refresh()
|
|
|
|
task, err := edgeGateway.AddIpsecVPN(ipsecVPNConfig)
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("[INFO] Error setting ipsecVPNConfig rules: %s", err)
|
|
|
|
return resource.RetryableError(
|
|
|
|
fmt.Errorf("Error setting ipsecVPNConfig rules: %#v", err))
|
|
|
|
}
|
|
|
|
|
|
|
|
return resource.RetryableError(task.WaitTaskCompletion())
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error completing tasks: %#v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId(d.Get("edge_gateway").(string))
|
|
|
|
|
|
|
|
return resourceVcdEdgeGatewayVpnRead(d, meta)
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceVcdEdgeGatewayVpnDelete(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
vcdClient := meta.(*VCDClient)
|
|
|
|
|
|
|
|
log.Printf("[TRACE] CLIENT: %#v", vcdClient)
|
|
|
|
|
|
|
|
vcdClient.Mutex.Lock()
|
|
|
|
defer vcdClient.Mutex.Unlock()
|
|
|
|
|
|
|
|
edgeGateway, err := vcdClient.OrgVdc.FindEdgeGateway(d.Get("edge_gateway").(string))
|
|
|
|
|
|
|
|
ipsecVPNConfig := &types.EdgeGatewayServiceConfiguration{
|
|
|
|
Xmlns: "http://www.vmware.com/vcloud/v1.5",
|
|
|
|
GatewayIpsecVpnService: &types.GatewayIpsecVpnService{
|
|
|
|
IsEnabled: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("[INFO] ipsecVPNConfig: %#v", ipsecVPNConfig)
|
|
|
|
|
|
|
|
err = retryCall(vcdClient.MaxRetryTimeout, func() *resource.RetryError {
|
|
|
|
edgeGateway.Refresh()
|
|
|
|
task, err := edgeGateway.AddIpsecVPN(ipsecVPNConfig)
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("[INFO] Error setting ipsecVPNConfig rules: %s", err)
|
|
|
|
return resource.RetryableError(
|
|
|
|
fmt.Errorf("Error setting ipsecVPNConfig rules: %#v", err))
|
|
|
|
}
|
|
|
|
|
|
|
|
return resource.RetryableError(task.WaitTaskCompletion())
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error completing tasks: %#v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId(d.Get("edge_gateway").(string))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error finding edge gateway: %#v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceVcdEdgeGatewayVpnRead(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
vcdClient := meta.(*VCDClient)
|
|
|
|
|
|
|
|
edgeGateway, err := vcdClient.OrgVdc.FindEdgeGateway(d.Get("edge_gateway").(string))
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error finding edge gateway: %#v", err)
|
|
|
|
}
|
|
|
|
|
2017-05-31 14:27:54 +02:00
|
|
|
egsc := edgeGateway.EdgeGateway.Configuration.EdgeGatewayServiceConfiguration.GatewayIpsecVpnService
|
|
|
|
for _, t := range egsc.Tunnel {
|
|
|
|
d.Set("name", t.Name)
|
|
|
|
d.Set("description", t.Description)
|
|
|
|
d.Set("encryption_protocol", t.EncryptionProtocol)
|
|
|
|
d.Set("local_ip_address", t.LocalIPAddress)
|
|
|
|
d.Set("local_id", t.LocalID)
|
|
|
|
d.Set("mtu", t.Mtu)
|
|
|
|
d.Set("peer_ip_address", t.PeerIPAddress)
|
|
|
|
d.Set("peer_id", t.PeerID)
|
|
|
|
d.Set("shared_secret", t.SharedSecret)
|
|
|
|
d.Set("local_subnets", t.LocalSubnet)
|
|
|
|
d.Set("peer_subnets", t.PeerSubnet)
|
2017-03-17 17:10:47 +01:00
|
|
|
|
2017-05-31 14:27:54 +02:00
|
|
|
}
|
2017-03-17 17:10:47 +01:00
|
|
|
// and all the others
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|