forked from Azure/bicep-registry-modules
-
Notifications
You must be signed in to change notification settings - Fork 0
113 lines (98 loc) · 4.64 KB
/
platform.publish-module-index-json.yml
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# This publishes the list of all public bicep modules to an index file that the Bicep vscode extension can read for intellisense using pwsh
name: .Platform - Publish [moduleIndex.json]
on:
schedule:
- cron: 45 11 * * * # Run daily at 3:45 AM PST
workflow_dispatch:
inputs:
regenIndexFromBRM:
type: boolean
description: "regenIndexFromBRM | Regenerate the moduleIndex.json file from scratch based on what is in BRM at the time of the run, instead of integrating it with its previous version."
required: false
default: false
permissions:
id-token: write
contents: read
env:
workflowPath: ".github/workflows/avm.res.app.job.yml"
jobs:
upload-index-data:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 0 // Needed to fetch all history and tags
- name: "Set input parameter``s to output variables"
id: get-workflow-param
uses: ./.github/actions/templates/avm-getWorkflowInput
with:
workflowPath: "${{ env.workflowPath}}"
- name: Log in to Azure
uses: azure/login@v2
with:
client-id: ${{ secrets.PUBLISH_CLIENT_ID }}
tenant-id: ${{ secrets.PUBLISH_TENANT_ID }}
subscription-id: ${{ secrets.PUBLISH_SUBSCRIPTION_ID }}
enable-AzPSSession: true
- name: Install Azure Powershell Modules
shell: pwsh
run: |
if(-not (Get-Module 'Az.Storage' -ListAvailable)) {
Install-Module -Name 'Az.Storage' -Force
}
- name: Generate moduleIndex.json
shell: pwsh
run: |
# Load used functions
. (Join-Path $env:GITHUB_WORKSPACE 'avm' 'utilities' 'pipelines' 'platform' 'Invoke-AvmJsonModuleIndexGeneration.ps1')
$functionInput = @{
storageAccountName = 'biceplivedatasaprod'
storageAccountContainer = 'bicep-cdn-live-data-container'
storageBlobName = 'module-index'
moduleIndexJsonFilePath = 'moduleIndex.json'
prefixForLastModuleIndexJsonFile = 'last-'
prefixForCurrentGeneratedModuleIndexJsonFile = 'generated-'
ErrorAction = 'Continue'
}
if ('${{ (fromJson(steps.get-workflow-param.outputs.workflowInput)).regenIndexFromBRM }}' -eq $true ) {
$functionInput['doNotMergeWithLastModuleIndexJsonFileVersion'] = $true
}
Write-Verbose 'Invoke task with' -Verbose
Write-Verbose ($functionInput | ConvertTo-Json | Out-String) -Verbose
if (-not (Invoke-AvmJsonModuleIndexGeneration @functionInput)) {
Write-Output ('{0}={1}' -f 'anyErrorsOccurred', $true) >> $env:GITHUB_ENV
}
- name: Upload artifacts
uses: actions/upload-artifact@v4.4.0
with:
name: publish-module-index-json-artifacts
path: |
moduleIndex.json
last-moduleIndex.json
generated-moduleIndex.json
- name: Upload to blob storage
shell: pwsh
run: |
$storageAccountInfo = @{
storageAccountName = 'biceplivedatasaprod'
storageAccountContainer = 'bicep-cdn-live-data-container'
storageBlobName = 'module-index'
storageBlobContentType = @{'ContentType' = 'application/json'}
}
Write-Verbose ('Uploading [moduleIndex.json] to blob storage account [{0}] in container [{1}] as blob [{2}]' -f $storageAccountInfo.storageAccountName, $storageAccountInfo.storageAccountContainer, $storageAccountInfo.storageBlobName) -Verbose
$storageContext = New-AzStorageContext -StorageAccountName $storageAccountInfo.storageAccountName -UseConnectedAccount
$functionInput = @{
Context = $storageContext
Container = $storageAccountInfo.storageAccountContainer
Blob = $storageAccountInfo.storageBlobName
File = 'moduleIndex.json'
Properties = $storageAccountInfo.storageBlobContentType
}
Set-AzStorageBlobContent @functionInput -Force
Write-Verbose ('Upload of [{0}] complete.' -f $storageAccountInfo.storageBlobName) -Verbose
- name: Check if any errors occurred during 'Generate moduleIndex.json'
if: ${{ env.anyErrorsOccurred == 'true' }}
shell: pwsh
run: |
throw "Errors occurred during 'Generate moduleIndex.json' step. Please check the logs of that step in the workflow."