github.com/GoogleCloudPlatform/terraformer@v0.8.18/providers/azure/network_security_group.go (about) 1 // Copyright 2021 The Terraformer Authors. 2 // 3 // Licensed under the Apache License, Version 2.0 (the "License"); 4 // you may not use this file except in compliance with the License. 5 // You may obtain a copy of the License at 6 // 7 // http://www.apache.org/licenses/LICENSE-2.0 8 // 9 // Unless required by applicable law or agreed to in writing, software 10 // distributed under the License is distributed on an "AS IS" BASIS, 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 // See the License for the specific language governing permissions and 13 // limitations under the License. 14 15 package azure 16 17 import ( 18 "context" 19 "log" 20 21 "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2020-03-01/network" 22 ) 23 24 type NetworkSecurityGroupGenerator struct { 25 AzureService 26 } 27 28 func (az *NetworkSecurityGroupGenerator) listResources() ([]network.SecurityGroup, error) { 29 subscriptionID, resourceGroup, authorizer := az.getClientArgs() 30 client := network.NewSecurityGroupsClient(subscriptionID) 31 client.Authorizer = authorizer 32 var ( 33 iterator network.SecurityGroupListResultIterator 34 err error 35 ) 36 ctx := context.Background() 37 if resourceGroup != "" { 38 iterator, err = client.ListComplete(ctx, resourceGroup) 39 } else { 40 iterator, err = client.ListAllComplete(ctx) 41 } 42 if err != nil { 43 return nil, err 44 } 45 var resources []network.SecurityGroup 46 for iterator.NotDone() { 47 item := iterator.Value() 48 resources = append(resources, item) 49 if err := iterator.NextWithContext(ctx); err != nil { 50 log.Println(err) 51 return resources, err 52 } 53 } 54 return resources, nil 55 } 56 57 func (az *NetworkSecurityGroupGenerator) appendResource(resource *network.SecurityGroup) { 58 az.AppendSimpleResource(*resource.ID, *resource.Name, "azurerm_network_security_group") 59 } 60 61 func (az *NetworkSecurityGroupGenerator) appendRules(parent *network.SecurityGroup, resourceGroupID *ResourceID) error { 62 subscriptionID, _, authorizer := az.getClientArgs() 63 client := network.NewSecurityRulesClient(subscriptionID) 64 client.Authorizer = authorizer 65 ctx := context.Background() 66 iterator, err := client.ListComplete(ctx, resourceGroupID.ResourceGroup, *parent.Name) 67 if err != nil { 68 return err 69 } 70 for iterator.NotDone() { 71 item := iterator.Value() 72 az.AppendSimpleResource(*item.ID, *item.Name, "azurerm_network_security_rule") 73 if err := iterator.NextWithContext(ctx); err != nil { 74 log.Println(err) 75 return err 76 } 77 } 78 return nil 79 } 80 81 func (az *NetworkSecurityGroupGenerator) InitResources() error { 82 83 resources, err := az.listResources() 84 if err != nil { 85 return err 86 } 87 for _, resource := range resources { 88 az.appendResource(&resource) 89 resourceGroupID, err := ParseAzureResourceID(*resource.ID) 90 if err != nil { 91 return err 92 } 93 err = az.appendRules(&resource, resourceGroupID) 94 if err != nil { 95 return err 96 } 97 } 98 return nil 99 }