mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-23 15:12:57 -06:00
815c8840a7
We have a curtesy function in place allowing you to specify both a `name` of `ID`. But in order for the graph to be build correctly when you recreate or taint stuff that other resources depend on, we need to reference the `ID` and *not* the `name`. So in order to enforce this and by that help people to not make this mistake unknowingly, I deprecated all the parameters this allies to and changed the logic, docs and tests accordingly.
130 lines
3.1 KiB
Go
130 lines
3.1 KiB
Go
package cloudstack
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"log"
|
|
"strings"
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
"github.com/xanzy/go-cloudstack/cloudstack"
|
|
)
|
|
|
|
func resourceCloudStackVPNConnection() *schema.Resource {
|
|
return &schema.Resource{
|
|
Create: resourceCloudStackVPNConnectionCreate,
|
|
Read: resourceCloudStackVPNConnectionRead,
|
|
Delete: resourceCloudStackVPNConnectionDelete,
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
"customer_gateway_id": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
Computed: true,
|
|
ForceNew: true,
|
|
},
|
|
|
|
"customergatewayid": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
ForceNew: true,
|
|
Deprecated: "Please use the `customer_gateway_id` field instead",
|
|
},
|
|
|
|
"vpn_gateway_id": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
Computed: true,
|
|
ForceNew: true,
|
|
},
|
|
|
|
"vpngatewayid": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
ForceNew: true,
|
|
Deprecated: "Please use the `vpn_gateway_id` field instead",
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func resourceCloudStackVPNConnectionCreate(d *schema.ResourceData, meta interface{}) error {
|
|
cs := meta.(*cloudstack.CloudStackClient)
|
|
|
|
customergatewayid, ok := d.GetOk("customer_gateway_id")
|
|
if !ok {
|
|
customergatewayid, ok = d.GetOk("customergatewayid")
|
|
}
|
|
if !ok {
|
|
return errors.New(
|
|
"Either `customer_gateway_id` or [deprecated] `customergatewayid` must be provided.")
|
|
}
|
|
|
|
vpngatewayid, ok := d.GetOk("vpn_gateway_id")
|
|
if !ok {
|
|
vpngatewayid, ok = d.GetOk("vpngatewayid")
|
|
}
|
|
if !ok {
|
|
return errors.New("Either `vpn_gateway_id` or [deprecated] `vpngatewayid` must be provided.")
|
|
}
|
|
|
|
// Create a new parameter struct
|
|
p := cs.VPN.NewCreateVpnConnectionParams(
|
|
customergatewayid.(string),
|
|
vpngatewayid.(string),
|
|
)
|
|
|
|
// Create the new VPN Connection
|
|
v, err := cs.VPN.CreateVpnConnection(p)
|
|
if err != nil {
|
|
return fmt.Errorf("Error creating VPN Connection: %s", err)
|
|
}
|
|
|
|
d.SetId(v.Id)
|
|
|
|
return resourceCloudStackVPNConnectionRead(d, meta)
|
|
}
|
|
|
|
func resourceCloudStackVPNConnectionRead(d *schema.ResourceData, meta interface{}) error {
|
|
cs := meta.(*cloudstack.CloudStackClient)
|
|
|
|
// Get the VPN Connection details
|
|
v, count, err := cs.VPN.GetVpnConnectionByID(d.Id())
|
|
if err != nil {
|
|
if count == 0 {
|
|
log.Printf("[DEBUG] VPN Connection does no longer exist")
|
|
d.SetId("")
|
|
return nil
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
d.Set("customer_gateway_id", v.S2scustomergatewayid)
|
|
d.Set("vpn_gateway_id", v.S2svpngatewayid)
|
|
|
|
return nil
|
|
}
|
|
|
|
func resourceCloudStackVPNConnectionDelete(d *schema.ResourceData, meta interface{}) error {
|
|
cs := meta.(*cloudstack.CloudStackClient)
|
|
|
|
// Create a new parameter struct
|
|
p := cs.VPN.NewDeleteVpnConnectionParams(d.Id())
|
|
|
|
// Delete the VPN Connection
|
|
_, err := cs.VPN.DeleteVpnConnection(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 VPN Connection: %s", err)
|
|
}
|
|
|
|
return nil
|
|
}
|