mirror of
https://github.com/girlbossceo/conduwuit.git
synced 2025-03-14 18:55:37 +00:00
118 lines
3.7 KiB
YAML
118 lines
3.7 KiB
YAML
name: Upload Release Assets
|
|
|
|
on:
|
|
release:
|
|
types: [published]
|
|
workflow_dispatch:
|
|
inputs:
|
|
tag:
|
|
description: 'Tag to release'
|
|
required: true
|
|
type: string
|
|
action_id:
|
|
description: 'Action ID of the CI run'
|
|
required: true
|
|
type: string
|
|
|
|
permissions: {}
|
|
|
|
jobs:
|
|
publish:
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: write
|
|
env:
|
|
GH_EVENT_NAME: ${{ github.event_name }}
|
|
GH_EVENT_INPUTS_ACTION_ID: ${{ github.event.inputs.action_id }}
|
|
GH_EVENT_INPUTS_TAG: ${{ github.event.inputs.tag }}
|
|
GH_REPOSITORY: ${{ github.repository }}
|
|
GH_SHA: ${{ github.sha }}
|
|
GH_TAG: ${{ github.event.release.tag_name }}
|
|
|
|
steps:
|
|
- name: get latest ci id
|
|
id: get_ci_id
|
|
env:
|
|
GH_TOKEN: ${{ github.token }}
|
|
run: |
|
|
if [ "${GH_EVENT_NAME}" == "workflow_dispatch" ]; then
|
|
id="${GH_EVENT_INPUTS_ACTION_ID}"
|
|
tag="${GH_EVENT_INPUTS_TAG}"
|
|
else
|
|
# get all runs of the ci workflow
|
|
json=$(gh api "repos/${GH_REPOSITORY}/actions/workflows/ci.yml/runs")
|
|
|
|
# find first run that is github sha and status is completed
|
|
id=$(echo "$json" | jq ".workflow_runs[] | select(.head_sha == \"${GH_SHA}\" and .status == \"completed\") | .id" | head -n 1)
|
|
|
|
if [ ! "$id" ]; then
|
|
echo "No completed runs found"
|
|
echo "ci_id=0" >> "$GITHUB_OUTPUT"
|
|
exit 0
|
|
fi
|
|
|
|
tag="${GH_TAG}"
|
|
fi
|
|
|
|
echo "ci_id=$id" >> "$GITHUB_OUTPUT"
|
|
echo "tag=$tag" >> "$GITHUB_OUTPUT"
|
|
|
|
- name: get latest ci artifacts
|
|
if: steps.get_ci_id.outputs.ci_id != 0
|
|
uses: actions/download-artifact@v4
|
|
env:
|
|
GH_TOKEN: ${{ github.token }}
|
|
with:
|
|
merge-multiple: true
|
|
run-id: ${{ steps.get_ci_id.outputs.ci_id }}
|
|
github-token: ${{ github.token }}
|
|
|
|
- run: |
|
|
ls
|
|
|
|
- name: upload release assets
|
|
if: steps.get_ci_id.outputs.ci_id != 0
|
|
env:
|
|
GH_TOKEN: ${{ github.token }}
|
|
TAG: ${{ steps.get_ci_id.outputs.tag }}
|
|
run: |
|
|
for file in $(find . -type f); do
|
|
case "$file" in
|
|
*json*) echo "Skipping $file...";;
|
|
*) echo "Uploading $file..."; gh release upload $TAG "$file" --clobber --repo="${GH_REPOSITORY}" || echo "Something went wrong, skipping.";;
|
|
esac
|
|
done
|
|
|
|
- name: upload release assets to website
|
|
if: steps.get_ci_id.outputs.ci_id != 0
|
|
env:
|
|
TAG: ${{ steps.get_ci_id.outputs.tag }}
|
|
run: |
|
|
mkdir -p -v ~/.ssh
|
|
|
|
echo "${{ secrets.WEB_UPLOAD_SSH_KNOWN_HOSTS }}" >> ~/.ssh/known_hosts
|
|
echo "${{ secrets.WEB_UPLOAD_SSH_PRIVATE_KEY }}" >> ~/.ssh/id_ed25519
|
|
|
|
chmod 600 ~/.ssh/id_ed25519
|
|
|
|
cat >>~/.ssh/config <<END
|
|
Host website
|
|
HostName ${{ secrets.WEB_UPLOAD_SSH_HOSTNAME }}
|
|
User ${{ secrets.WEB_UPLOAD_SSH_USERNAME }}
|
|
IdentityFile ~/.ssh/id_ed25519
|
|
StrictHostKeyChecking yes
|
|
AddKeysToAgent no
|
|
ForwardX11 no
|
|
BatchMode yes
|
|
END
|
|
|
|
echo "Creating tag directory on web server"
|
|
ssh -q website "rm -rf /var/www/girlboss.ceo/~strawberry/conduwuit/releases/$TAG/"
|
|
ssh -q website "mkdir -v /var/www/girlboss.ceo/~strawberry/conduwuit/releases/$TAG/"
|
|
|
|
for file in $(find . -type f); do
|
|
case "$file" in
|
|
*json*) echo "Skipping $file...";;
|
|
*) echo "Uploading $file to website"; scp $file website:/var/www/girlboss.ceo/~strawberry/conduwuit/releases/$TAG/$file;;
|
|
esac
|
|
done
|