/
azure.storageaccount.go
75 lines (60 loc) · 2.32 KB
/
azure.storageaccount.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package azuretpl
import (
"fmt"
"io"
"github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/storage/armstorage"
"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob"
"github.com/webdevops/go-common/azuresdk/armclient"
)
// azStorageAccountAccessKeys fetches container blob from StorageAccount
func (e *AzureTemplateExecutor) azStorageAccountAccessKeys(resourceID string) (interface{}, error) {
e.logger.Infof(`fetching Azure StorageAccount accesskey '%v'`, resourceID)
if val, enabled := e.lintResult(); enabled {
return val, nil
}
cacheKey := generateCacheKey(`azStorageAccountAccessKeys`, resourceID)
return e.cacheResult(cacheKey, func() (interface{}, error) {
resourceInfo, err := armclient.ParseResourceId(resourceID)
if err != nil {
return nil, fmt.Errorf(`unable to parse Azure resourceID '%v': %w`, resourceID, err)
}
client, err := armstorage.NewAccountsClient(resourceInfo.Subscription, e.azureClient().GetCred(), e.azureClient().NewArmClientOptions())
if err != nil {
return nil, err
}
result, err := client.ListKeys(e.ctx, resourceInfo.ResourceGroup, resourceInfo.ResourceName, nil)
if err != nil {
return nil, err
}
return transformToInterface(result.Keys)
})
}
// azStorageAccountContainerBlob fetches container blob from StorageAccount
func (e *AzureTemplateExecutor) azStorageAccountContainerBlob(containerBlobUrl string) (interface{}, error) {
e.logger.Infof(`fetching Azure StorageAccount container blob '%v'`, containerBlobUrl)
if val, enabled := e.lintResult(); enabled {
return val, nil
}
pathUrl, err := azblob.ParseURL(containerBlobUrl)
if err != nil {
return nil, err
}
cacheKey := generateCacheKey(`azStorageAccountContainerBlob`, containerBlobUrl)
return e.cacheResult(cacheKey, func() (interface{}, error) {
azblobOpts := azblob.ClientOptions{ClientOptions: *e.azureClient().NewAzCoreClientOptions()}
storageAccountUrl := fmt.Sprintf("%s://%s", pathUrl.Scheme, pathUrl.Host)
client, err := azblob.NewClient(storageAccountUrl, e.azureClient().GetCred(), &azblobOpts)
if err != nil {
return nil, err
}
response, err := client.DownloadStream(e.ctx, pathUrl.ContainerName, pathUrl.BlobName, nil)
if err != nil {
return nil, err
}
if content, err := io.ReadAll(response.Body); err == nil {
return string(content), nil
} else {
return nil, err
}
})
}