internal/scanners/vgw/vgw.go (63 lines of code) (raw):

// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. package vgw import ( "github.com/Azure/azqr/internal/models" "github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6" "github.com/rs/zerolog/log" ) func init() { models.ScannerList["vgw"] = []models.IAzureScanner{&VirtualNetworkGatewayScanner{}} } // VirtualNetworkGatewayScanner - Scanner for VPN Gateway type VirtualNetworkGatewayScanner struct { config *models.ScannerConfig client *armnetwork.VirtualNetworkGatewaysClient } // Init - Initializes the VPN Gateway func (c *VirtualNetworkGatewayScanner) Init(config *models.ScannerConfig) error { c.config = config var err error c.client, err = armnetwork.NewVirtualNetworkGatewaysClient(config.SubscriptionID, config.Cred, config.ClientOptions) return err } // Scan - Scans all VirtualNetwork in a Resource Group func (c *VirtualNetworkGatewayScanner) Scan(scanContext *models.ScanContext) ([]models.AzqrServiceResult, error) { models.LogSubscriptionScan(c.config.SubscriptionID, c.ResourceTypes()[0]) results := []models.AzqrServiceResult{} rgs, err := models.ListResourceGroup(c.config.Ctx, c.config.Cred, c.config.SubscriptionID, c.config.ClientOptions) if err != nil { log.Fatal().Err(err).Msg("Failed to check existence of Resource Group") } for _, rg := range rgs { vpns, err := c.listVirtualNetworkGateways(*rg.Name) if err != nil { return nil, err } engine := models.RecommendationEngine{} rules := c.GetVirtualNetworkGatewayRules() for _, w := range vpns { rr := engine.EvaluateRecommendations(rules, w, scanContext) results = append(results, models.AzqrServiceResult{ SubscriptionID: c.config.SubscriptionID, SubscriptionName: c.config.SubscriptionName, ResourceGroup: models.GetResourceGroupFromResourceID(*w.ID), ServiceName: *w.Name, Type: *w.Type, Location: *w.Location, Recommendations: rr, }) } } return results, nil } func (c *VirtualNetworkGatewayScanner) listVirtualNetworkGateways(resourceGroupName string) ([]*armnetwork.VirtualNetworkGateway, error) { pager := c.client.NewListPager(resourceGroupName, nil) vpns := make([]*armnetwork.VirtualNetworkGateway, 0) for pager.More() { resp, err := pager.NextPage(c.config.Ctx) if err != nil { return nil, err } vpns = append(vpns, resp.Value...) } return vpns, nil } func (a *VirtualNetworkGatewayScanner) ResourceTypes() []string { return []string{"Microsoft.Network/virtualNetworkGateways"} }