mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2024-11-10 02:13:09 +02:00
7fdf5ffea2
Bumps [actions/checkout](https://github.com/actions/checkout) from 3.6.0 to 4.1.1. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/v3.6.0...v4.1.1) --- updated-dependencies: - dependency-name: actions/checkout dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
87 lines
3.3 KiB
YAML
87 lines
3.3 KiB
YAML
name: deploy-test-environment
|
|
|
|
on:
|
|
issue_comment:
|
|
types: [created]
|
|
workflow_dispatch:
|
|
inputs:
|
|
repository:
|
|
description: 'Repository to deploy (optional, use the repository where this workflow is stored by default)'
|
|
required: false
|
|
default: ''
|
|
branch_or_hash:
|
|
description: 'Branch or Commit hash to deploy (optional, use the branch where this workflow is stored by default)'
|
|
required: false
|
|
default: ''
|
|
wait_time:
|
|
description: 'Time to wait in seconds (optional, 1800 seconds by default)'
|
|
required: false
|
|
default: ''
|
|
|
|
jobs:
|
|
get-pr-ref:
|
|
runs-on: ubuntu-latest
|
|
if: github.event_name == 'issue_comment' && github.event.issue.pull_request && startsWith(github.event.comment.body, '/preview')
|
|
outputs:
|
|
is-allowed-user: ${{ steps.check-allowed-users.outputs.is-allowed-user }}
|
|
pr-ref: ${{ steps.get-ref.outputs.pr-ref }}
|
|
wait_time: ${{ steps.get-wait-time.outputs.wait_time }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4.1.1
|
|
|
|
- name: Check allowed users
|
|
id: check-allowed-users
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
ORG_ID: ${{ github.repository_owner_id }}
|
|
COMMENT_AUTHOR: ${{ github.event.comment.user.login }}
|
|
run: |
|
|
MEMBERSHIP_STATUS=$(curl -s -H "Authorization: Bearer $GITHUB_TOKEN" \
|
|
-H "Accept: application/vnd.github+json" \
|
|
-H "X-GitHub-Api-Version: 2022-11-28" \
|
|
"https://api.github.com/organizations/$ORG_ID/public_members/$COMMENT_AUTHOR" \
|
|
-o /dev/null -w '%{http_code}\n' -s)
|
|
if [ "$MEMBERSHIP_STATUS" -eq 204 ]; then
|
|
echo "is-allowed-user=true" > $GITHUB_OUTPUT
|
|
else
|
|
echo "is-allowed-user=false" > $GITHUB_OUTPUT
|
|
fi
|
|
|
|
- name: Get PR ref
|
|
id: get-ref
|
|
env:
|
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
run: |
|
|
PR_NUMBER=$(jq --raw-output .issue.number $GITHUB_EVENT_PATH)
|
|
PR_REF=$(gh pr view $PR_NUMBER --json headRefName -q '.headRefName')
|
|
echo "pr-ref=$PR_REF" > $GITHUB_OUTPUT
|
|
|
|
- name: Extract wait time
|
|
id: get-wait-time
|
|
env:
|
|
COMMENT_BODY: ${{ github.event.comment.body }}
|
|
run: |
|
|
WAIT_TIME=$(echo "$COMMENT_BODY" | grep -oP '(?<=/preview\s)\d+' || echo "1800")
|
|
echo "wait_time=$WAIT_TIME" > $GITHUB_OUTPUT
|
|
|
|
deploy-test-environment-pr-comment:
|
|
needs: get-pr-ref
|
|
if: needs.get-pr-ref.outputs.is-allowed-user == 'true'
|
|
uses: joinmisskey/misskey-tga/.github/workflows/deploy-test-environment.yml@main
|
|
with:
|
|
repository: ${{ github.repository }}
|
|
branch_or_hash: ${{ needs.get-pr-ref.outputs.pr-ref }}
|
|
wait_time: ${{ needs.get-pr-ref.outputs.wait_time }}
|
|
secrets:
|
|
DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }}
|
|
|
|
deploy-test-environment-wd:
|
|
if: github.event_name == 'workflow_dispatch'
|
|
uses: joinmisskey/misskey-tga/.github/workflows/deploy-test-environment.yml@main
|
|
with:
|
|
repository: ${{ inputs.repository || github.repository }}
|
|
branch_or_hash: ${{ inputs.branch_or_hash || github.ref_name }}
|
|
wait_time: ${{ inputs.wait_time || '1800' }}
|
|
secrets:
|
|
DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }}
|