providers/ibm/ibm_is_vpn_gateway.go (107 lines of code) (raw):
// Copyright 2019 The Terraformer Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package ibm
import (
"fmt"
"os"
"github.com/GoogleCloudPlatform/terraformer/terraformutils"
"github.com/IBM/go-sdk-core/v4/core"
"github.com/IBM/vpc-go-sdk/vpcv1"
)
// VPNGatewayGenerator ...
type VPNGatewayGenerator struct {
IBMService
}
func (g VPNGatewayGenerator) createVPNGatewayResources(vpngwID, vpngwName string) terraformutils.Resource {
resources := terraformutils.NewSimpleResource(
vpngwID,
normalizeResourceName(vpngwName, false),
"ibm_is_vpn_gateway",
"ibm",
[]string{})
return resources
}
func (g VPNGatewayGenerator) createVPNGatewayConnectionResources(vpngwID, vpngwConnectionID, vpngwConnectionName string) terraformutils.Resource {
resources := terraformutils.NewResource(
fmt.Sprintf("%s/%s", vpngwID, vpngwConnectionID),
normalizeResourceName(vpngwConnectionName, false),
"ibm_is_vpn_gateway_connection",
"ibm",
map[string]string{},
[]string{},
map[string]interface{}{})
return resources
}
// InitResources ...
func (g *VPNGatewayGenerator) InitResources() error {
region := g.Args["region"].(string)
apiKey := os.Getenv("IC_API_KEY")
if apiKey == "" {
return fmt.Errorf("no API key set")
}
isURL := GetVPCEndPoint(region)
iamURL := GetAuthEndPoint()
vpcoptions := &vpcv1.VpcV1Options{
URL: isURL,
Authenticator: &core.IamAuthenticator{
ApiKey: apiKey,
URL: iamURL,
},
}
vpcclient, err := vpcv1.NewVpcV1(vpcoptions)
if err != nil {
return err
}
start := ""
var allrecs []vpcv1.VPNGatewayIntf
for {
listVPNGatewaysOptions := &vpcv1.ListVPNGatewaysOptions{}
if start != "" {
listVPNGatewaysOptions.Start = &start
}
if rg := g.Args["resource_group"].(string); rg != "" {
rg, err = GetResourceGroupID(apiKey, rg, region)
if err != nil {
return fmt.Errorf("Error Fetching Resource Group Id %s", err)
}
listVPNGatewaysOptions.ResourceGroupID = &rg
}
vpngws, response, err := vpcclient.ListVPNGateways(listVPNGatewaysOptions)
if err != nil {
return fmt.Errorf("Error Fetching VPN Gateways %s\n%s", err, response)
}
start = GetNext(vpngws.Next)
allrecs = append(allrecs, vpngws.VPNGateways...)
if start == "" {
break
}
}
for _, gw := range allrecs {
vpngw := gw.(*vpcv1.VPNGateway)
g.Resources = append(g.Resources, g.createVPNGatewayResources(*vpngw.ID, *vpngw.Name))
listVPNGatewayConnectionsOptions := &vpcv1.ListVPNGatewayConnectionsOptions{
VPNGatewayID: vpngw.ID,
}
vpngwConnections, response, err := vpcclient.ListVPNGatewayConnections(listVPNGatewayConnectionsOptions)
if err != nil {
return fmt.Errorf("Error Fetching VPN Gateway Connections %s\n%s", err, response)
}
for _, connection := range vpngwConnections.Connections {
vpngwConnection := connection.(*vpcv1.VPNGatewayConnection)
g.Resources = append(g.Resources, g.createVPNGatewayConnectionResources(*vpngw.ID, *vpngwConnection.ID, *vpngwConnection.Name))
}
}
return nil
}
func (g *VPNGatewayGenerator) PostConvertHook() error {
for i, con := range g.Resources {
if con.InstanceInfo.Type != "ibm_is_vpn_gateway_connection" {
continue
}
for _, vpn := range g.Resources {
if vpn.InstanceInfo.Type != "ibm_is_vpn_gateway" {
continue
}
if con.InstanceState.Attributes["vpn_gateway"] == vpn.InstanceState.Attributes["id"] {
g.Resources[i].Item["vpn_gateway"] = "${ibm_is_vpn_gateway." + vpn.ResourceName + ".id}"
}
}
}
return nil
}