winutil/.github/workflows/pre-release.yaml

101 lines
3.3 KiB
YAML
Raw Normal View History

name: Pre-Release WinUtil
2024-07-17 00:29:37 -05:00
permissions:
contents: write
actions: read
on:
workflow_dispatch: # Manual trigger added
jobs:
build-runspace:
runs-on: windows-latest
2024-08-07 15:37:14 -05:00
env:
CERTIFICATE_BASE64: ${{ secrets.CERTIFICATE_BASE64 }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
2024-08-07 15:24:26 -05:00
- name: Compile project
shell: pwsh
run: |
Set-ExecutionPolicy Bypass -Scope Process -Force; ./Compile.ps1
continue-on-error: false # Directly fail the job on error, removing the need for a separate check
- name: Set Version to Todays Date
id: extract_version
run: |
2024-07-17 00:52:12 -05:00
$version = (Get-Date -Format "yy.MM.dd")
echo "VERSION=$version" >> $env:GITHUB_ENV
2024-07-17 00:43:58 -05:00
shell: pwsh
- name: Create Tag
id: create_tag
run: |
$tagExists = git tag -l $env:VERSION
2024-07-17 01:04:39 -05:00
if ($tagExists -eq "") {
2024-07-17 00:43:58 -05:00
git tag $env:VERSION
if ($LASTEXITCODE -ne 0) {
Write-Error "Failed to create tag $env:VERSION"
exit 1
}
2024-07-17 00:43:58 -05:00
git push origin $env:VERSION
if ($LASTEXITCODE -ne 0) {
Write-Error "Failed to push tag $env:VERSION"
exit 1
}
2024-07-17 00:52:12 -05:00
} else {
Write-Host "Tag $env:VERSION already exists, skipping tag creation"
2024-07-17 00:43:58 -05:00
}
shell: pwsh
2024-08-07 15:24:26 -05:00
- name: Create and import code signing certificate
shell: pwsh
run: |
[System.IO.File]::WriteAllBytes("$env:USERPROFILE\code-signing-cert.pfx", [System.Convert]::FromBase64String("$env:CERTIFICATE_BASE64"))
Import-PfxCertificate -FilePath "$env:USERPROFILE\code-signing-cert.pfx" -CertStoreLocation Cert:\CurrentUser\My
- name: Code sign winutil.ps1
shell: pwsh
run: |
$cert = Get-ChildItem -Path Cert:\CurrentUser\My -CodeSigningCert | Select-Object -First 1
if ($null -eq $cert) { throw "Code signing certificate not found" }
2024-12-30 08:14:08 -06:00
Set-AuthenticodeSignature -FilePath ./winutil.ps1 -Certificate $cert -TimeStampServer "http://timestamp.digicert.com"
2024-08-07 15:24:26 -05:00
- name: Verify code signature
shell: pwsh
run: |
$signature = Get-AuthenticodeSignature -FilePath ./winutil.ps1
if ($signature.Status -ne 'Valid') { throw "Code signing failed" }
2024-08-09 10:15:20 -05:00
2024-08-07 15:24:26 -05:00
- name: Upload winutil.ps1 as artifact
uses: actions/upload-artifact@v4
2024-08-07 15:24:26 -05:00
with:
name: winutil
path: ./winutil.ps1
2024-08-09 10:15:20 -05:00
2024-08-29 00:12:00 -05:00
- name: Generate Release Notes
id: generate_notes
uses: release-drafter/release-drafter@v6
2024-08-29 00:12:00 -05:00
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
2024-09-10 18:02:42 -05:00
config-name: release-drafter.yml
2024-09-10 18:01:18 -05:00
version: ${{ env.VERSION }} # Pass the version variable
2024-08-29 22:47:18 -05:00
- name: Create and Upload Release
id: create_release
uses: softprops/action-gh-release@v2
with:
2024-09-10 18:01:18 -05:00
tag_name: ${{ env.VERSION }}
name: Pre-Release ${{ env.VERSION }}
2024-08-29 00:12:00 -05:00
body: |
2024-08-29 22:47:18 -05:00
${{ steps.generate_notes.outputs.body }}
2024-08-29 00:12:00 -05:00
![GitHub Downloads (specific asset, specific tag)](https://img.shields.io/github/downloads/ChrisTitusTech/winutil/${{ env.VERSION }}/winutil.ps1)
2024-07-16 13:58:31 -05:00
append_body: false
files: ./winutil.ps1
prerelease: true
env:
2024-08-06 15:50:36 -05:00
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}