Azure IPAM Production Container Build #19
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Azure IPAM Build | |
run-name: Azure IPAM Production Container Build | |
on: | |
push: | |
branches: [ main ] | |
permissions: | |
id-token: write | |
contents: write | |
pull-requests: read | |
env: | |
ACR_NAME: ${{ vars.IPAM_PROD_ACR }} | |
jobs: | |
version: | |
name: Update Azure IPAM Version | |
runs-on: ubuntu-latest | |
outputs: | |
ipamVersion: ${{ steps.updateVersion.outputs.ipamVersion }} | |
steps: | |
- run: echo "Job triggered by a ${{ github.event_name }} event to main." | |
- name: "Setup NodeJS v18" | |
id: setupNode | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 18 | |
- name: Checkout Azure IPAM Code | |
uses: actions/checkout@v4 | |
with: | |
persist-credentials: false | |
- uses: actions/github-script@v7 | |
id: getPullRequestData | |
with: | |
script: | | |
return ( | |
await github.rest.repos.listPullRequestsAssociatedWithCommit({ | |
commit_sha: context.sha, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
}) | |
).data[0]; | |
- name: "Increment Azure IPAM Version" | |
id: updateVersion | |
working-directory: tools | |
env: | |
prBody: ${{ fromJson(steps.getPullRequestData.outputs.result).body }} | |
shell: pwsh | |
run: | | |
$version = [regex]::matches($env:prBody, '(?<=\[version:).*(?=])').value | |
$major = $env:prBody -match '(?<=\[)major(?=])' | |
$minor = $env:prBody -match '(?<=\[)minor(?=])' | |
$build = $env:prBody -match '(?<=\[)build(?=])' | |
try { | |
$version = [System.Version]$version | |
$newVersion = "{0}.{1}.{2}" -f $version.Major, $version.Minor, $version.Build | |
} catch { | |
$version = $null | |
} | |
if ($version) { | |
./version.ps1 -Version $newVersion | |
} elseif ($major) { | |
./version.ps1 -BumpMajor | |
} elseif ($minor) { | |
./version.ps1 -BumpMinor | |
} else { | |
./version.ps1 -BumpBuild | |
} | |
- name: Install NPM Packages | |
id: installNpmPackages | |
working-directory: ui | |
run: npm install | |
- name: "Create Azure IPAM ZIP Asset" | |
id: buildZipAsset | |
working-directory: tools | |
shell: pwsh | |
run: | | |
./build.ps1 -Path ../assets/ | |
- name: Commit Updated Azure IPAM Code | |
id: commitCode | |
run: | | |
git config --global user.name "GitHub Actions" | |
git config --global user.email "[email protected]" | |
git commit -a -m "Updated Azure IPAM Version" | |
git push | |
release: | |
name: Create Azure IPAM Release | |
runs-on: ubuntu-latest | |
needs: [ version ] | |
steps: | |
- name: Checkout Azure IPAM Code | |
uses: actions/checkout@v4 | |
with: | |
sparse-checkout: | | |
assets | |
- name: Publish Azure IPAM Release | |
id: publishRelease | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
tagName: v${{ needs.version.outputs.ipamVersion }} | |
run: | | |
gh release create "$tagName" \ | |
--repo="$GITHUB_REPOSITORY" \ | |
--title="$tagName" \ | |
--notes "Azure IPAM Release" | |
- name: Upload Azure IPAM Release Asset | |
id: uploadReleaseAsset | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
tagName: v${{ needs.version.outputs.ipamVersion }} | |
assetPath: ./assets/ipam.zip | |
run: | | |
gh release upload "$tagName" "$assetPath" | |
update: | |
name: Update Azure IPAM Containers | |
runs-on: ubuntu-latest | |
needs: [ version, release ] | |
steps: | |
- name: Azure login | |
uses: azure/login@v1 | |
with: | |
client-id: ${{ secrets.AZURE_CLIENT_ID }} | |
tenant-id: ${{ secrets.AZURE_TENANT_ID }} | |
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }} | |
enable-AzPSSession: true | |
- name: Checkout Azure IPAM Code | |
uses: actions/checkout@v4 | |
with: | |
sparse-checkout: | | |
engine | |
ui | |
lb | |
- name: Build Azure IPAM Containers | |
env: | |
IPAM_VERSION: ${{ needs.version.outputs.ipamVersion }} | |
run: | | |
az acr build -r $ACR_NAME -t ipam:$IPAM_VERSION -t ipam:latest -f ./Dockerfile.deb . | |
az acr build -r $ACR_NAME -t ipamfunc:$IPAM_VERSION -t ipamfunc:latest -f ./Dockerfile.func . | |
az acr build -r $ACR_NAME -t ipam-engine:$IPAM_VERSION -t ipam-engine:latest -f ./engine/Dockerfile.deb ./engine | |
az acr build -r $ACR_NAME -t ipam-func:$IPAM_VERSION -t ipam-func:latest -f ./engine/Dockerfile.func ./engine | |
az acr build -r $ACR_NAME -t ipam-ui:$IPAM_VERSION -t ipam-ui:latest -f ./ui/Dockerfile.deb ./ui | |
az acr build -r $ACR_NAME -t ipam-lb:$IPAM_VERSION -t ipam-lb:latest -f ./lb/Dockerfile ./lb |