providers/ibm/ibm_is_ipsec_policy.go (68 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" "log" "os" "github.com/GoogleCloudPlatform/terraformer/terraformutils" "github.com/IBM/go-sdk-core/v4/core" "github.com/IBM/vpc-go-sdk/vpcv1" ) // IpsecGenerator ... type IpsecGenerator struct { IBMService } func (g IpsecGenerator) createIpsecResources() func(ipsecID, ipsecName string) terraformutils.Resource { names := make(map[string]struct{}) random := false return func(ipsecID, ipsecName string) terraformutils.Resource { names, random = getRandom(names, ipsecName, random) resources := terraformutils.NewSimpleResource( ipsecID, normalizeResourceName(ipsecName, random), "ibm_is_ipsec_policy", "ibm", []string{}) return resources } } // InitResources ... func (g *IpsecGenerator) InitResources() error { region := g.Args["region"].(string) apiKey := os.Getenv("IC_API_KEY") if apiKey == "" { log.Fatal("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.IPsecPolicy for { options := &vpcv1.ListIpsecPoliciesOptions{} if start != "" { options.Start = &start } policies, response, err := vpcclient.ListIpsecPolicies(options) if err != nil { return fmt.Errorf("Error Fetching IPSEC Policies %s\n%s", err, response) } start = GetNext(policies.Next) allrecs = append(allrecs, policies.IpsecPolicies...) if start == "" { break } } fnObjt := g.createIpsecResources() for _, policy := range allrecs { g.Resources = append(g.Resources, fnObjt(*policy.ID, *policy.Name)) } return nil }