Update after signature script #83
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: Update latest.yml with SHA512 Hash | |
on: | |
push: | |
# workflow_dispatch: | |
jobs: | |
update-latest-yml: | |
permissions: | |
contents: write # to get the draft versions | |
actions: write | |
runs-on: windows-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v3 | |
- name: Find Latest Draft Release | |
id: find_draft | |
env: | |
GITHUB_TOKEN: ${{ secrets.github_token }} | |
run: | | |
# Retrieve releases | |
$releases = Invoke-RestMethod -Uri "https://api.github.com/repos/KhiopsML/kv-electron/releases" -Headers @{ Authorization = "Bearer $env:GITHUB_TOKEN" } | |
# Select the latest draft release | |
$draft_release = $releases | Where-Object { $_.draft -eq $true } | Sort-Object -Property created_at -Descending | Select-Object -First 1 | |
if (-not $draft_release) { | |
throw "No draft release found." | |
} | |
echo "Draft release ID: $($draft_release.id)" | |
echo "Draft release name: $($draft_release.name)" | |
echo "::set-output name=draft_release_id::$($draft_release.id)" | |
# echo "{draft_release_id}={draft_release.id}" >> $GITHUB_STATE | |
echo "::set-output name=draft_tag_name::$($draft_release.name)" | |
# echo "{draft_tag_name}={draft_release}.name" >> $GITHUB_STATE | |
echo "::set-output name=draft_tag::$($draft_release.tag_name)" | |
# echo "{draft_tag}={draft_release.tag_name}" >> $GITHUB_STATE | |
- name: Download Release Assets | |
uses: robinraju/[email protected] | |
with: | |
token: ${{ secrets.github_token }} | |
releaseId: ${{ steps.find_draft.outputs.draft_release_id }} | |
preRelease: true | |
fileName: "latest.yml" | |
- name: Download Release Assets | |
uses: robinraju/[email protected] | |
with: | |
token: ${{ secrets.github_token }} | |
releaseId: ${{ steps.find_draft.outputs.draft_release_id }} | |
preRelease: true | |
fileName: "*.exe" | |
- name: Verify latest.yml | |
shell: pwsh | |
run: | | |
if (Test-Path -Path latest.yml) { | |
Write-Output "latest.yml exists." | |
} else { | |
throw "latest.yml does not exist after download." | |
} | |
- name: Display latest content | |
shell: pwsh | |
run: | | |
$ct = Get-Content -Path latest.yml -Raw | |
Write-Output "Content of latest.yml:" | |
Write-Output "$ct" | |
- name: Compute SHA512 Hash | |
id: compute_hash | |
shell: pwsh | |
run: | | |
# Calculate SHA512 hash of the .exe file | |
$exePath = "khiops-visualization-Setup-${{ steps.find_draft.outputs.draft_tag_name }}.exe" | |
$hash = Get-FileHash -Algorithm SHA512 -Path $exePath | |
$lowercaseHash = $hash.Hash.ToLower() | |
Write-Output "::set-output name=sha512::$lowercaseHash" | |
echo "-----------> lowercaseHash: $lowercaseHash" | |
- name: Update latest.yml | |
shell: pwsh | |
run: | | |
# Update sha512 hash and remove size attribute in latest.yml | |
(Get-Content -Path latest.yml) | | |
ForEach-Object { | |
if ($_ -match '^sha512:\s.*$') { | |
"sha512: ${{ steps.compute_hash.outputs.sha512 }}" | |
} elseif ($_ -match '^\s*sha512:\s.*$') { | |
" sha512: ${{ steps.compute_hash.outputs.sha512 }}" | |
} elseif ($_ -notmatch '^\s*size:\s.*$') { | |
$_ | |
} | |
} | Set-Content -Path latest.yml | |
$ct = Get-Content -Path latest.yml -Raw | |
echo "Updated latest.yml content:" | |
echo "-----------------------------" | |
echo "$ct" | |
echo "-----------------------------" | |
- uses: IsaacShelton/[email protected] | |
with: | |
token: ${{secrets.GITHUB_TOKEN}} | |
release: ${{steps.find_draft.outputs.draft_tag_name}} | |
tag: ${{steps.find_draft.outputs.draft_tag}} | |
draft: true | |
files: > | |
latest.yml | |
# - name: Upload Binaries to Release | |
# uses: svenstaro/upload-release-action@v2 | |
# with: | |
# repo_token: ${{ secrets.GITHUB_TOKEN }} | |
# file: latest.yml | |
# tag: ${{steps.find_draft.outputs.draft_tag}} | |
# release_name: ${{steps.find_draft.outputs.draft_tag_name}} | |
# draft: true | |
# overwrite: true | |
# - name: Upload updated latest.yml to Draft Release | |
# uses: softprops/action-gh-release@v2 | |
# with: | |
# # draft: true | |
# # name: ${{steps.find_draft.outputs.draft_tag_name}} | |
# files: latest.yml | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # GitHub token for authentication | |
# env: | |
# RELEASE_ID: ${{ steps.find_draft.outputs.draft_release_id }} | |
# GITHUB_TOKEN: ${{ secrets.github_token }} | |
# run: | | |
# # Get release info and find latest.yml asset | |
# $release_info = Invoke-RestMethod -Uri "https://api.github.com/repos/KhiopsML/kv-electron/releases/${{ env.RELEASE_ID }}/assets" -Headers @{ Authorization = "Bearer $env:GITHUB_TOKEN" } | |
# $yml_asset = $release_info | Where-Object { $_.name -eq "latest.yml" } | Select-Object -First 1 | |
# if (-not $yml_asset) { throw "The latest.yml asset was not found in the draft release." } | |
# $upload_url = $yml_asset.url | |
# # Upload the updated latest.yml using curl | |
# Invoke-Expression -Command "curl -X POST -H 'Authorization: Bearer $env:GITHUB_TOKEN' -H 'Content-Type: application/octet-stream' --data-binary @latest.yml $upload_url" |