Azure IPAM Production Container Build #20
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 }} | |
prNumber: ${{ fromJson(steps.getPullRequestData.outputs.result).number }} | |
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 | |
- 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: Configure Git | |
id: configureGit | |
run: | | |
git config --global user.name "IPAM GitHub Actions" | |
git config --global user.email "[email protected]" | |
- name: Create Temporary Branch | |
id: createBranch | |
env: | |
prNumber: ${{ fromJson(steps.getPullRequestData.outputs.result).number }} | |
run: | | |
git checkout -b ipam-version-${prNumber} | |
git push origin ipam-version-${prNumber} | |
- 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 | |
env: | |
prNumber: ${{ fromJson(steps.getPullRequestData.outputs.result).number }} | |
run: | | |
git commit -a -m "Updated Azure IPAM Version" | |
git push origin ipam-version-${prNumber} | |
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: Create and Merge Pull Reuest | |
id: pullRequest | |
env: | |
GITHUB_TOKEN: ${{ secrets.PAT_TOKEN }} | |
prNumber: ${{ needs.version.outputs.prNumber }} | |
run: | | |
gh pr create --base main --head "ipam-version-${prNumber}" --title "Update Azure IPAM Version" --body "-Updated Version to v${{ needs.version.outputs.ipamVersion }}" | |
gh pr merge "ipam-version-${prNumber}" -t "Merge pull request from Azure/ipam-version-${prNumber} [skip ci]" -m | |
- name: Pull Merged Code from Main Branch | |
id: pullMainCode | |
run: | | |
git pull | |
- name: Delete Temporary Branch | |
id: deleteBranch | |
env: | |
prNumber: ${{ needs.version.outputs.prNumber }} | |
run: | | |
git push origin --delete "ipam-version-${prNumber}" | |
- 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" | |
build: | |
name: Build 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 |