Change workflow to use Cloudflare R2 #755
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: EarTrumpet | |
on: | |
push: | |
branches: | |
- master | |
- dev | |
- rafael/* | |
paths-ignore: | |
- '**/*.md' | |
- '.github/ISSUE_TEMPLATE/*' | |
- '.github/workflows/sponsors.yml' | |
- '.github/workflows/translators.yml' | |
- 'Graphics/*' | |
pull_request: | |
branches: | |
- dev | |
paths-ignore: | |
- '**/*.md' | |
- crowdin.yml | |
env: | |
DOTNET_SKIP_FIRST_TIME_EXPERIENCE: true | |
DOTNET_CLI_TELEMETRY_OPTOUT: true | |
GHA_HASH_PATHS: | | |
EarTrumpet/** | |
!EarTrumpet/**/bin/** | |
!EarTrumpet/**/obj/** | |
!EarTrumpet/**/.vs/** | |
EarTrumpet.Package/** | |
!EarTrumpet.Package/**/bin/** | |
!EarTrumpet.Package/**/obj/** | |
!EarTrumpet/**/.vs/** | |
Packaging/** | |
jobs: | |
# | |
# Base build | |
# | |
base: | |
name: 🔨 Build Base | |
runs-on: windows-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Check for existing base | |
uses: actions/cache/restore@v4 | |
id: base-exists | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
lookup-only: true | |
- name: Fetch all history for all tags and branches | |
run: git fetch --prune --unshallow | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Install GitVersion | |
uses: gittools/actions/gitversion/[email protected] | |
with: | |
versionSpec: '5.x' | |
includePrerelease: false | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Use GitVersion | |
id: gitversion | |
uses: gittools/actions/gitversion/[email protected] | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Create artifacts folder | |
shell: pwsh | |
run: | | |
New-Item -ItemType Directory -Force -Path .artifacts/ | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Generate versioning artifact | |
shell: pwsh | |
run: | | |
"${{ steps.gitversion.outputs.majorMinorPatch }}.${{ steps.gitversion.outputs.commitsSinceVersionSource }}" | | |
Out-File .artifacts/version_4.txt | |
"${{ steps.gitversion.outputs.majorMinorPatch }}.0" | | |
Out-File .artifacts/version_3.txt | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Restore packages | |
run: dotnet restore EarTrumpet.sln | |
shell: cmd | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Build EarTrumpet | |
shell: cmd | |
run: > | |
dotnet publish | |
/p:PublishProfile=x86 | |
/p:Platform=x86 | |
EarTrumpet\EarTrumpet.csproj | |
dotnet publish | |
/p:PublishProfile=x64 | |
/p:Platform=x64 | |
EarTrumpet\EarTrumpet.csproj | |
dotnet publish | |
/p:PublishProfile=arm64 | |
/p:Platform=arm64 | |
EarTrumpet\EarTrumpet.csproj | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Set Bugsnag API key | |
shell: pwsh | |
run: | | |
Get-ChildItem .artifacts\base\**\app.config | ForEach-Object { | |
$cfg = Get-Content $_ | |
$cfg | ForEach-Object { $_.Replace("{bugsnag.apikey}", "${{ secrets.bugsnag_api_key }}") } | Set-Content $_ | |
} | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Sign all files | |
uses: azure/[email protected] | |
with: | |
azure-tenant-id: ${{ secrets.azure_tenant_id }} | |
azure-client-id: ${{ secrets.azure_client_id }} | |
azure-client-secret: ${{ secrets.azure_client_secret }} | |
endpoint: https://wus2.codesigning.azure.net/ | |
trusted-signing-account-name: main | |
certificate-profile-name: profileTWN | |
files-catalog: packaging\catalog.txt | |
file-digest: SHA256 | |
timestamp-rfc3161: http://timestamp.acs.microsoft.com | |
timestamp-digest: SHA256 | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
- name: Add to cache | |
uses: actions/cache/save@v4 | |
with: | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
path: .artifacts | |
if: steps.base-exists.outputs.cache-hit != 'true' | |
# | |
# Packaging: AppInstaller | |
# | |
appinstaller: | |
name: 📦 Package for AppInstaller | |
runs-on: windows-latest | |
needs: base | |
env: | |
channel: 'AppInstaller' | |
publisher: 'CN=File-New-Project, O=File-New-Project, L=Purcellville, S=Virginia, C=US' | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Fetch all history for all tags and branches | |
run: git fetch --prune --unshallow | |
- name: Restore base | |
uses: actions/cache/restore@v4 | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
fail-on-cache-miss: true | |
- name: Configure manifest | |
uses: ./.github/actions/configure-manifest | |
with: | |
manifest: EarTrumpet.Package/Package.appxmanifest | |
store-association: EarTrumpet.Package/Package.StoreAssociation.xml | |
publisher: ${{ env.publisher }} | |
branch: ${{ github.ref_name }} | |
prefix: 'EarTrumpet' | |
version: .artifacts/version_4.txt | |
- name: Set up MSBuild | |
uses: microsoft/setup-msbuild@v2 | |
with: | |
msbuild-architecture: x64 | |
- name: Restore packages | |
shell: pwsh | |
run: > | |
dotnet restore | |
EarTrumpet.sln | |
- name: Create msixbundle | |
shell: pwsh | |
run: > | |
msbuild | |
/p:AppxBundle=Always | |
/p:AppxPackageSigningEnabled=false | |
/p:AppxPackageDir=..\.artifacts\sideload\ | |
/p:AppxPackageTestDir=..\.artifacts\sideload\ | |
/p:AppInstallerUri="https://install.eartrumpet.app" | |
/p:Configuration=Release | |
/p:Channel=AppInstaller | |
/p:GenerateAppInstallerFile=true | |
/p:Platform=x86 | |
/p:UapAppxPackageBuildMode=SideloadOnly | |
/p:WapAlwaysBuildDependentProjects=false | |
"/p:AppxBundlePlatforms=x86|x64|arm64" | |
EarTrumpet.Package/EarTrumpet.Package.wapproj | |
- name: Stage AppInstaller manifest | |
shell: pwsh | |
run: > | |
Copy-Item Packaging\AppInstaller\EarTrumpet.Package.appinstaller .artifacts\sideload\ | |
-Force | |
- name: Configure AppInstaller manifest | |
uses: ./.github/actions/configure-appinstaller | |
with: | |
manifest: .artifacts\sideload\EarTrumpet.Package.appinstaller | |
bundle: 'EarTrumpet.Package_*_x86_x64_arm64.msixbundle' | |
version: .artifacts/version_4.txt | |
branch: ${{ github.ref_name }} | |
- name: Sign package | |
uses: azure/[email protected] | |
with: | |
azure-tenant-id: ${{ secrets.azure_tenant_id }} | |
azure-client-id: ${{ secrets.azure_client_id }} | |
azure-client-secret: ${{ secrets.azure_client_secret }} | |
endpoint: https://wus2.codesigning.azure.net/ | |
trusted-signing-account-name: main | |
certificate-profile-name: profileTWN | |
files-folder: .artifacts/sideload/ | |
files-folder-filter: msixbundle | |
file-digest: SHA256 | |
timestamp-rfc3161: http://timestamp.acs.microsoft.com | |
timestamp-digest: SHA256 | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: AppInstaller | |
path: | | |
.artifacts/sideload/EarTrumpet.Package_*_x86_x64_arm64.msixbundle | |
.artifacts/sideload/EarTrumpet.Package.appinstaller | |
# | |
# Packaging: Chocolatey | |
# | |
chocolatey: | |
name: 📦 Package for Chocolatey | |
runs-on: windows-latest | |
needs: base | |
env: | |
channel: 'Chocolatey' | |
publisher: 'CN=File-New-Project, O=File-New-Project, L=Purcellville, S=Virginia, C=US' | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Restore base | |
uses: actions/cache/restore@v4 | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
fail-on-cache-miss: true | |
- name: Adjust nuspec | |
uses: ./.github/actions/configure-nuspec | |
with: | |
nuspec: Packaging\Chocolatey\eartrumpet.nuspec | |
version: .artifacts/version_4.txt | |
- name: Stage packaging | |
shell: pwsh | |
run: | | |
Copy-Item Packaging\Chocolatey -Recurse .artifacts | |
- name: Create release archive | |
shell: pwsh | |
run: > | |
Compress-Archive | |
-Path .artifacts\base\x86\** | |
-DestinationPath .artifacts\chocolatey\tools\release.zip | |
-CompressionLevel Optimal | |
- name: Create package | |
shell: pwsh | |
run: > | |
choco | |
pack ".artifacts\chocolatey\eartrumpet.nuspec" | |
--out ".artifacts\chocolatey" | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Chocolatey | |
path: | | |
.artifacts/chocolatey/eartrumpet.*.nupkg | |
# | |
# Packaging: Store | |
# | |
store: | |
name: 📦 Package for Microsoft Store | |
runs-on: windows-latest | |
needs: base | |
env: | |
channel: 'Store' | |
publisher: 'CN=6099D0EF-9374-47ED-BDFE-A82136831235' | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Fetch all history for all tags and branches | |
run: git fetch --prune --unshallow | |
- name: Restore base | |
uses: actions/cache/restore@v4 | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
fail-on-cache-miss: true | |
- name: Configure manifest | |
uses: ./.github/actions/configure-manifest | |
with: | |
manifest: EarTrumpet.Package/Package.appxmanifest | |
store-association: EarTrumpet.Package/Package.StoreAssociation.xml | |
publisher: ${{ env.publisher }} | |
branch: ${{ github.ref_name }} | |
prefix: 'EarTrumpet' | |
version: .artifacts/version_3.txt | |
- name: Set up MSBuild | |
uses: microsoft/setup-msbuild@v2 | |
with: | |
msbuild-architecture: x64 | |
- name: Restore packages | |
shell: pwsh | |
run: > | |
dotnet restore | |
EarTrumpet.sln | |
- name: Create msixbundle | |
shell: pwsh | |
run: > | |
msbuild | |
/p:AppxBundle=Always | |
/p:AppxPackageSigningEnabled=false | |
/p:AppxPackageDir=..\.artifacts\store\ | |
/p:Configuration=Release | |
/p:Channel=Store | |
/p:GenerateAppInstallerFile=false | |
/p:Platform=x86 | |
/p:UapAppxPackageBuildMode=CI | |
/p:WapAlwaysBuildDependentProjects=false | |
"/p:AppxBundlePlatforms=x86|x64|arm64" | |
EarTrumpet.Package/EarTrumpet.Package.wapproj | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: MicrosoftStore | |
path: | | |
.artifacts/store/EarTrumpet.Package_*_x86_x64_arm64.msixbundle | |
.artifacts/store/EarTrumpet.Package_*_x86_x64_arm64_bundle.msixupload | |
# | |
# Packaging: Loose | |
# | |
loose: | |
name: 📦 Package for Loose scenarios | |
runs-on: windows-latest | |
needs: base | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Restore base | |
uses: actions/cache/restore@v4 | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
fail-on-cache-miss: true | |
- name: Create release archives | |
shell: pwsh | |
run: > | |
New-Item | |
-ItemType Directory | |
-Path .artifacts\loose | |
-Force | |
@("x86", "x64", "arm64") | ForEach-Object { | |
Compress-Archive ` | |
-Path .artifacts\base\$_\* ` | |
-DestinationPath .artifacts\loose\EarTrumpet_$(Get-Content .artifacts/version_4.txt)_$($_).zip ` | |
-CompressionLevel Optimal | |
} | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Loose | |
path: | | |
.artifacts/loose/*.zip | |
# | |
# Deployment: AppInstaller | |
# | |
deploy-appinstaller: | |
name: Deploy AppInstaller package | |
runs-on: windows-latest | |
needs: appinstaller | |
if: | | |
github.event_name != 'pull_request' && | |
( | |
startsWith(github.ref, 'refs/heads/dev') || | |
startsWith(github.ref, 'refs/heads/master') || | |
startsWith(github.ref, 'refs/heads/feature') || | |
startsWith(github.ref, 'refs/heads/rafael') | |
) | |
steps: | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: AppInstaller | |
path: . | |
- name: Configure credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.R2_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.R2_SECRET_ACCESS_KEY }} | |
aws-region: auto | |
- name: Upload files to Cloudflare | |
shell: pwsh | |
run: | | |
# Upload MSIX bundle | |
Get-ChildItem -File EarTrumpet.Package_*_x86_x64_arm64.msixbundle | ForEach-Object { | |
aws s3 cp $_.FullName "s3://${{ secrets.R2_BUCKET_NAME }}/${{ github.ref_name }}/$($_.Name)" ` | |
--content-type "application/msixbundle" ` | |
--endpoint-url "https://${{ secrets.CLOUDFLARE_ACCOUNT_ID }}.r2.cloudflarestorage.com" | |
} | |
# Upload appinstaller file | |
aws s3 cp EarTrumpet.Package.appinstaller "s3://${{ secrets.R2_BUCKET_NAME }}/${{ github.ref_name }}/EarTrumpet.Package.appinstaller" ` | |
--content-type "application/appinstaller" ` | |
--endpoint-url "https://${{ secrets.CLOUDFLARE_ACCOUNT_ID }}.r2.cloudflarestorage.com" | |
# | |
# Deployment: Microsoft Store | |
# | |
deploy-store: | |
name: 🚀 Deploy Microsoft Store package | |
runs-on: windows-latest | |
needs: store | |
if: | | |
github.event_name != 'pull_request' && | |
( | |
startsWith(github.ref, 'refs/heads/master') | |
) | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: MicrosoftStore | |
path: . | |
- name: Push to Microsoft Store | |
shell: powershell | |
run: > | |
Set-PSRepository | |
-Name "PSGallery" | |
-InstallationPolicy Trusted | |
Install-Module | |
-Name StoreBroker | |
$Password = ConvertTo-SecureString '${{ secrets.partnercenter_client_secret }}' | |
-AsPlainText | |
-Force | |
$Credentials = New-Object System.Management.Automation.PSCredential ('${{ secrets.partnercenter_client_id }}', $Password) | |
Set-StoreBrokerAuthentication | |
-TenantId '${{ secrets.partnercenter_tenant_id }}' | |
-Credential $Credentials | |
-Verbose | |
$SubmissionRoot = "$env:Temp\Packaging\Submission" | |
$Bundle = Resolve-Path "EarTrumpet.Package_*_x86_x64_arm64_bundle.msixupload" | Split-Path -Leaf | |
New-SubmissionPackage | |
-ConfigPath "Packaging\MicrosoftStore\SBConfig.json" | |
-PDPRootPath "Packaging\MicrosoftStore\PDPs" | |
-ImagesRootPath "Packaging\MicrosoftStore\PDPs" | |
-AppxPath "$Bundle" | |
-MediaFallbackLanguage en-US | |
-OutPath "$SubmissionRoot" | |
-OutName EarTrumpet | |
-Verbose | |
$SubmissionId, $SubmissionUrl = | |
Update-ApplicationSubmission | |
-AppId 9NBLGGH516XP | |
-SubmissionDataPath "$SubmissionRoot\EarTrumpet.json" | |
-PackagePath "$SubmissionRoot\EarTrumpet.zip" | |
-AddPackages | |
-UpdateListings | |
-UpdatePublishModeAndVisibility | |
-UpdatePricingAndAvailability | |
-UpdateAppProperties | |
-UpdateNotesForCertification | |
-TargetPublishMode Manual | |
-Force | |
-Verbose | |
Complete-ApplicationSubmission | |
-AppId 9NBLGGH516XP | |
-SubmissionId $SubmissionId | |
-Verbose | |
# | |
# Deployment: GitHub | |
# | |
deploy-github: | |
name: 🚀 Deploy GitHub Release | |
runs-on: windows-latest | |
needs: loose | |
if: | | |
github.event_name != 'pull_request' && | |
( | |
startsWith(github.ref, 'refs/heads/master') | |
) | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
fetch-tags: true | |
- name: Restore base | |
uses: actions/cache/restore@v4 | |
with: | |
path: .artifacts | |
key: base-${{ hashFiles(env.GHA_HASH_PATHS) }} | |
fail-on-cache-miss: true | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: Loose | |
path: .artifacts/loose | |
- name: Generate changelog | |
id: changelog | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
shell: pwsh | |
run: > | |
$lastTagRef = git describe --match "[0-9]*.[0-9]*.[0-9]*.[0-9]*" --abbrev=0 --tags HEAD 2>$null | |
$lastTagDate = git show -s --format=%aI "$lastTagRef^{commit}" | |
$query = (Get-Content ".github/workflows/queries/commits.graphql" -Raw) | |
-replace '%%OWNER%%', '${{ github.repository_owner }}' | |
-replace '%%REPO%%', '${{ github.event.repository.name }}' | |
$template = Get-Content ".github/workflows/templates/commits.md" -Raw | |
$changelog = gh api graphql | |
--paginate | |
-F query="$query" | |
-F lastTagDate="$lastTagDate" | |
-F ref="HEAD" | |
--template "$template" | |
$changelog | Out-File -FilePath .artifacts/changelog.md | |
- name: Create Release | |
shell: pwsh | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: > | |
$version = Get-Content .artifacts/version_4.txt | |
gh release create "v$version" | |
--draft | |
--title "$version" | |
--notes-file .artifacts/changelog.md | |
(Get-ChildItem ".artifacts/loose/*.zip").FullName |