internal/scanners/synw/synw.go (136 lines of code) (raw):

// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. package synw import ( "github.com/Azure/azqr/internal/models" "github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/synapse/armsynapse" ) func init() { models.ScannerList["synw"] = []models.IAzureScanner{&SynapseWorkspaceScanner{}} } // SynapseWorkspaceScanner - Scanner for Synapse Analytics Workspace type SynapseWorkspaceScanner struct { config *models.ScannerConfig workspacesClient *armsynapse.WorkspacesClient sparkPoolClient *armsynapse.BigDataPoolsClient sqlPoolClient *armsynapse.SQLPoolsClient } // Init - Initializes the SynapseWorkspaceScanner Scanner func (a *SynapseWorkspaceScanner) Init(config *models.ScannerConfig) error { a.config = config var err error a.workspacesClient, err = armsynapse.NewWorkspacesClient(config.SubscriptionID, a.config.Cred, a.config.ClientOptions) if err != nil { return err } a.sparkPoolClient, err = armsynapse.NewBigDataPoolsClient(config.SubscriptionID, config.Cred, config.ClientOptions) if err != nil { return err } a.sqlPoolClient, err = armsynapse.NewSQLPoolsClient(config.SubscriptionID, config.Cred, config.ClientOptions) if err != nil { return err } return nil } // Scan - Scans all Synapse Workspaces in a Resource Group func (a *SynapseWorkspaceScanner) Scan(scanContext *models.ScanContext) ([]models.AzqrServiceResult, error) { models.LogSubscriptionScan(a.config.SubscriptionID, a.ResourceTypes()[0]) workspaces, err := a.listWorkspaces() if err != nil { return nil, err } engine := models.RecommendationEngine{} rules := a.getWorkspaceRules() sqlPoolRules := a.getSqlPoolRules() sparkPoolRules := a.getSparkPoolRules() results := []models.AzqrServiceResult{} for _, w := range workspaces { rr := engine.EvaluateRecommendations(rules, w, scanContext) resourceGroupName := models.GetResourceGroupFromResourceID(*w.ID) results = append(results, models.AzqrServiceResult{ SubscriptionID: a.config.SubscriptionID, SubscriptionName: a.config.SubscriptionName, ResourceGroup: resourceGroupName, Location: *w.Location, Type: *w.Type, ServiceName: *w.Name, Recommendations: rr, }) sqlPools, err := a.listSqlPools(resourceGroupName, *w.Name) if err != nil { return nil, err } for _, s := range sqlPools { var result models.AzqrServiceResult rr := engine.EvaluateRecommendations(sqlPoolRules, s, scanContext) result = models.AzqrServiceResult{ SubscriptionID: a.config.SubscriptionID, SubscriptionName: a.config.SubscriptionName, ResourceGroup: resourceGroupName, ServiceName: *s.Name, Type: *s.Type, Location: *w.Location, Recommendations: rr, } results = append(results, result) } sparkPools, err := a.listSparkPools(resourceGroupName, *w.Name) if err != nil { return nil, err } for _, s := range sparkPools { var result models.AzqrServiceResult rr := engine.EvaluateRecommendations(sparkPoolRules, s, scanContext) result = models.AzqrServiceResult{ SubscriptionID: a.config.SubscriptionID, SubscriptionName: a.config.SubscriptionName, ResourceGroup: resourceGroupName, ServiceName: *s.Name, Type: *s.Type, Location: *w.Location, Recommendations: rr, } results = append(results, result) } } return results, nil } func (a *SynapseWorkspaceScanner) listWorkspaces() ([]*armsynapse.Workspace, error) { pager := a.workspacesClient.NewListPager(nil) workspaces := make([]*armsynapse.Workspace, 0) for pager.More() { resp, err := pager.NextPage(a.config.Ctx) if err != nil { return nil, err } workspaces = append(workspaces, resp.Value...) } return workspaces, nil } func (a *SynapseWorkspaceScanner) listSqlPools(resourceGroupName string, workspace string) ([]*armsynapse.SQLPool, error) { pager := a.sqlPoolClient.NewListByWorkspacePager(resourceGroupName, workspace, nil) results := make([]*armsynapse.SQLPool, 0) for pager.More() { resp, err := pager.NextPage(a.config.Ctx) if err != nil { return nil, err } results = append(results, resp.Value...) } return results, nil } func (a *SynapseWorkspaceScanner) listSparkPools(resourceGroupName string, workspace string) ([]*armsynapse.BigDataPoolResourceInfo, error) { pager := a.sparkPoolClient.NewListByWorkspacePager(resourceGroupName, workspace, nil) results := make([]*armsynapse.BigDataPoolResourceInfo, 0) for pager.More() { resp, err := pager.NextPage(a.config.Ctx) if err != nil { return nil, err } results = append(results, resp.Value...) } return results, nil } func (a *SynapseWorkspaceScanner) ResourceTypes() []string { return []string{ "Microsoft.Synapse/workspaces", "Microsoft.Synapse workspaces/bigDataPools", "Microsoft.Synapse/workspaces/sqlPools", } }