From f27e14cd62742ed6356aedc351876e0779542f8c Mon Sep 17 00:00:00 2001 From: David Khourshid Date: Mon, 22 Mar 2021 15:20:27 -0400 Subject: [PATCH 1/3] Add getBaseURI --- modules/azure/client_factory.go | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/modules/azure/client_factory.go b/modules/azure/client_factory.go index d871de180..2dc5dead7 100644 --- a/modules/azure/client_factory.go +++ b/modules/azure/client_factory.go @@ -45,7 +45,7 @@ type ClientType int // the Azure environment that is currently setup (or "Public", if none is setup). func CreateSubscriptionsClientE() (subscriptions.Client, error) { // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return subscriptions.Client{}, err } @@ -66,7 +66,7 @@ func CreateVirtualMachinesClientE(subscriptionID string) (compute.VirtualMachine } // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return compute.VirtualMachinesClient{}, err } @@ -87,7 +87,7 @@ func CreateManagedClustersClientE(subscriptionID string) (containerservice.Manag } // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return containerservice.ManagedClustersClient{}, err } @@ -106,7 +106,7 @@ func CreateCosmosDBAccountClientE(subscriptionID string) (*documentdb.DatabaseAc } // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return nil, err } @@ -127,7 +127,7 @@ func CreateCosmosDBSQLClientE(subscriptionID string) (*documentdb.SQLResourcesCl } // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return nil, err } @@ -148,7 +148,7 @@ func CreateKeyVaultManagementClientE(subscriptionID string) (*kvmng.VaultsClient } // Lookup environment URI - baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + baseURI, err := getBaseURI() if err != nil { return nil, err } @@ -197,3 +197,13 @@ func getFieldValue(env *autorestAzure.Environment, field string) string { fieldVal := reflect.Indirect(structValue).FieldByName(field) return fieldVal.String() } + +// getBaseURI gets the base URI endpoint. +func getBaseURI() (string, error) { + // Lookup environment URI + baseURI, err := getEnvironmentEndpointE(ResourceManagerEndpointName) + if err != nil { + return "", err + } + return baseURI, nil +} From 64d9826107863c5035aa177101b26df758a8bddf Mon Sep 17 00:00:00 2001 From: Engin Polat Date: Mon, 5 Apr 2021 20:47:52 +0300 Subject: [PATCH 2/3] Update ci.yml --- .github/workflows/ci.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 1be3b7c5b..27dc1dbe9 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -17,6 +17,8 @@ name: ci-workflow # target_pr: pr number on the source repo (e.g. 14, 25, etc.) on: + push: + branches: master workflow_dispatch: inputs: repo: From f85738d05d1151cfddeebb190b07929d7d61be16 Mon Sep 17 00:00:00 2001 From: David Khourshid Date: Tue, 13 Apr 2021 10:20:36 -0400 Subject: [PATCH 3/3] Add CreateStorageAccountClientE and CreateStorageBlobContainerClientE --- modules/azure/client_factory.go | 47 +++++++++++++++++++++++++++++++++ modules/azure/storage.go | 6 +++-- 2 files changed, 51 insertions(+), 2 deletions(-) diff --git a/modules/azure/client_factory.go b/modules/azure/client_factory.go index 2dc5dead7..906967976 100644 --- a/modules/azure/client_factory.go +++ b/modules/azure/client_factory.go @@ -19,6 +19,7 @@ import ( "github.com/Azure/azure-sdk-for-go/services/containerservice/mgmt/2019-11-01/containerservice" kvmng "github.com/Azure/azure-sdk-for-go/services/keyvault/mgmt/2016-10-01/keyvault" "github.com/Azure/azure-sdk-for-go/services/resources/mgmt/2019-06-01/subscriptions" + "github.com/Azure/azure-sdk-for-go/services/storage/mgmt/2019-06-01/storage" autorestAzure "github.com/Azure/go-autorest/autorest/azure" ) @@ -159,6 +160,52 @@ func CreateKeyVaultManagementClientE(subscriptionID string) (*kvmng.VaultsClient return &vaultClient, nil } +// CreateStorageAccountClientE creates a storage account client. +func CreateStorageAccountClientE(subscriptionID string) (*storage.AccountsClient, error) { + // Validate Azure subscription ID + subscriptionID, err := getTargetAzureSubscription(subscriptionID) + if err != nil { + return nil, err + } + + // Lookup environment URI + baseURI, err := getBaseURI() + if err != nil { + return nil, err + } + + storageAccountClient := storage.NewAccountsClientWithBaseURI(baseURI, subscriptionID) + authorizer, err := NewAuthorizer() + if err != nil { + return nil, err + } + storageAccountClient.Authorizer = *authorizer + return &storageAccountClient, nil +} + +// CreateStorageBlobContainerClientE creates a storage container client. +func CreateStorageBlobContainerClientE(subscriptionID string) (*storage.BlobContainersClient, error) { + subscriptionID, err := getTargetAzureSubscription(subscriptionID) + if err != nil { + return nil, err + } + + // Lookup environment URI + baseURI, err := getBaseURI() + if err != nil { + return nil, err + } + + blobContainerClient := storage.NewBlobContainersClientWithBaseURI(baseURI, subscriptionID) + authorizer, err := NewAuthorizer() + + if err != nil { + return nil, err + } + blobContainerClient.Authorizer = *authorizer + return &blobContainerClient, nil +} + // GetKeyVaultURISuffixE returns the proper KeyVault URI suffix for the configured Azure environment. // This function would fail the test if there is an error. func GetKeyVaultURISuffixE() (string, error) { diff --git a/modules/azure/storage.go b/modules/azure/storage.go index 7db176ee6..59c53f459 100644 --- a/modules/azure/storage.go +++ b/modules/azure/storage.go @@ -141,7 +141,7 @@ func GetStorageBlobContainerE(containerName, storageAccountName, resourceGroupNa if err2 != nil { return nil, err2 } - client, err := GetStorageBlobContainerClientE(subscriptionID) + client, err := CreateStorageBlobContainerClientE(subscriptionID) if err != nil { return nil, err } @@ -162,7 +162,7 @@ func GetStorageAccountPropertyE(storageAccountName, resourceGroupName, subscript if err2 != nil { return nil, err2 } - client, err := GetStorageAccountClientE(subscriptionID) + client, err := CreateStorageAccountClientE(subscriptionID) if err != nil { return nil, err } @@ -174,6 +174,7 @@ func GetStorageAccountPropertyE(storageAccountName, resourceGroupName, subscript } // GetStorageAccountClientE creates a storage account client. +// TODO: remove in next version func GetStorageAccountClientE(subscriptionID string) (*storage.AccountsClient, error) { // Validate Azure subscription ID subscriptionID, err := getTargetAzureSubscription(subscriptionID) @@ -191,6 +192,7 @@ func GetStorageAccountClientE(subscriptionID string) (*storage.AccountsClient, e } // GetStorageBlobContainerClientE creates a storage container client. +// TODO: remove in next version func GetStorageBlobContainerClientE(subscriptionID string) (*storage.BlobContainersClient, error) { subscriptionID, err := getTargetAzureSubscription(subscriptionID) if err != nil {