ファイルの閲覧注意フラグをファイル単位で連合するようにし、また、フラグを変更した場合は再投稿時などでリモートにも反映するようにして欲しい #1549
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: 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/[email protected] | |
- 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 }} |