providers/aws/vgw.go (36 lines of code) (raw):

// Copyright 2018 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 aws import ( "context" "github.com/GoogleCloudPlatform/terraformer/terraformutils" "github.com/aws/aws-sdk-go-v2/service/ec2" ) var VpnAllowEmptyValues = []string{"tags."} type VpnGatewayGenerator struct { AWSService } func (VpnGatewayGenerator) createResources(vpnGws *ec2.DescribeVpnGatewaysOutput) []terraformutils.Resource { var resources []terraformutils.Resource for _, vpnGw := range vpnGws.VpnGateways { resources = append(resources, terraformutils.NewSimpleResource( StringValue(vpnGw.VpnGatewayId), StringValue(vpnGw.VpnGatewayId), "aws_vpn_gateway", "aws", VpnAllowEmptyValues, )) } return resources } // Generate TerraformResources from AWS API, // from each vpn gateway create 1 TerraformResource. // Need VpnGatewayId as ID for terraform resource func (g *VpnGatewayGenerator) InitResources() error { config, e := g.generateConfig() if e != nil { return e } svc := ec2.NewFromConfig(config) vpnGws, err := svc.DescribeVpnGateways(context.TODO(), &ec2.DescribeVpnGatewaysInput{}) if err != nil { return err } g.Resources = g.createResources(vpnGws) return nil }