From 2e4fc1561791265c59369b18e5a164ef5a7abe11 Mon Sep 17 00:00:00 2001 From: insertish Date: Thu, 5 Oct 2023 12:51:13 +0000 Subject: [PATCH] ci: created local '.github/workflows/triage_pr.yml' from remote 'workflows/triage_pr.yml' [skip ci] --- .github/workflows/triage_pr.yml | 79 +++++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 .github/workflows/triage_pr.yml diff --git a/.github/workflows/triage_pr.yml b/.github/workflows/triage_pr.yml new file mode 100644 index 00000000..de5a9421 --- /dev/null +++ b/.github/workflows/triage_pr.yml @@ -0,0 +1,79 @@ +name: Add PR to Board + +on: + pull_request_target: + types: [opened, synchronize, ready_for_review, review_requested] + +jobs: + track_pr: + runs-on: ubuntu-latest + steps: + - name: Get project data + env: + GITHUB_TOKEN: ${{ secrets.PAT }} + run: | + gh api graphql -f query=' + query { + organization(login: "revoltchat"){ + projectV2(number: 3) { + id + fields(first:20) { + nodes { + ... on ProjectV2SingleSelectField { + id + name + options { + id + name + } + } + } + } + } + } + }' > project_data.json + + echo 'PROJECT_ID='$(jq '.data.organization.projectV2.id' project_data.json) >> $GITHUB_ENV + echo 'STATUS_FIELD_ID='$(jq '.data.organization.projectV2.fields.nodes[] | select(.name== "Status") | .id' project_data.json) >> $GITHUB_ENV + echo 'INCOMING_OPTION_ID='$(jq '.data.organization.projectV2.fields.nodes[] | select(.name== "Status") | .options[] | select(.name=="Incoming PRs") |.id' project_data.json) >> $GITHUB_ENV + + - name: Add PR to project + env: + GITHUB_TOKEN: ${{ secrets.PAT }} + PR_ID: ${{ github.event.pull_request.node_id }} + run: | + item_id="$( gh api graphql -f query=' + mutation($project:ID!, $pr:ID!) { + addProjectV2ItemById(input: {projectId: $project, contentId: $pr}) { + item { + id + } + } + }' -f project=$PROJECT_ID -f pr=$PR_ID --jq '.data.addProjectV2ItemById.item.id')" + + echo 'ITEM_ID='$item_id >> $GITHUB_ENV + + - name: Set fields + env: + GITHUB_TOKEN: ${{ secrets.PAT }} + run: | + gh api graphql -f query=' + mutation ( + $project: ID! + $item: ID! + $status_field: ID! + $status_value: String! + ) { + set_status: updateProjectV2ItemFieldValue(input: { + projectId: $project + itemId: $item + fieldId: $status_field + value: { + singleSelectOptionId: $status_value + } + }) { + projectV2Item { + id + } + } + }' -f project=$PROJECT_ID -f item=$ITEM_ID -f status_field=$STATUS_FIELD_ID -f status_value=${{ env.INCOMING_OPTION_ID }} --silent