2022-09-15 08:51:48 +00:00
|
|
|
name: Add new issues to triage column
|
|
|
|
|
|
|
|
on:
|
|
|
|
issues:
|
|
|
|
types:
|
|
|
|
- opened
|
|
|
|
|
|
|
|
env:
|
2023-02-11 20:04:53 +00:00
|
|
|
GH_TOKEN: ${{ secrets.PROJECT_BOARD_AUTOMATION }}
|
2022-09-15 08:51:48 +00:00
|
|
|
ORGANIZATION: ethereum
|
2023-02-11 20:04:53 +00:00
|
|
|
PROJECT_NUMBER: 27 # Solidity Bug Triaging Board
|
|
|
|
# See: https://github.com/orgs/ethereum/projects/27/settings/fields/Status
|
|
|
|
COLUMN_FIELD_NAME: "Status"
|
|
|
|
TRIAGE_COLUMN_NAME: "To Triage"
|
2023-04-26 16:17:58 +00:00
|
|
|
DRY_RUN: false
|
2022-09-15 08:51:48 +00:00
|
|
|
|
|
|
|
jobs:
|
|
|
|
triage_issues:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
2023-02-11 20:04:53 +00:00
|
|
|
- name: Retrieve the content of selected field on the project board
|
2022-09-15 08:51:48 +00:00
|
|
|
run: |
|
|
|
|
gh api graphql \
|
2023-02-11 20:04:53 +00:00
|
|
|
--raw-field organization="$ORGANIZATION" \
|
2022-09-15 08:51:48 +00:00
|
|
|
--field project_number="$PROJECT_NUMBER" \
|
|
|
|
--raw-field query='
|
2023-02-11 20:04:53 +00:00
|
|
|
query($organization: String!, $project_number: Int!) {
|
|
|
|
organization(login: $organization) {
|
|
|
|
projectV2(number: $project_number) {
|
|
|
|
id
|
|
|
|
fields(first: 20) {
|
2022-09-15 08:51:48 +00:00
|
|
|
nodes {
|
2023-02-11 20:04:53 +00:00
|
|
|
... on ProjectV2Field {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
}
|
|
|
|
... on ProjectV2SingleSelectField {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
options {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
}
|
|
|
|
}
|
2022-09-15 08:51:48 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-02-11 20:04:53 +00:00
|
|
|
}' > single_select_fields.json
|
|
|
|
echo 'PROJECT_ID='$(
|
|
|
|
jq \
|
|
|
|
'.data.organization.projectV2.id' \
|
|
|
|
single_select_fields.json
|
|
|
|
) >> $GITHUB_ENV
|
|
|
|
echo 'COLUMN_FIELD_ID='$(
|
|
|
|
jq \
|
|
|
|
--arg column_field_name "$COLUMN_FIELD_NAME" \
|
|
|
|
'.data.organization.projectV2.fields.nodes[]
|
|
|
|
| select(.name == $column_field_name)
|
|
|
|
| .id' \
|
|
|
|
single_select_fields.json
|
|
|
|
) >> $GITHUB_ENV
|
|
|
|
echo 'TRIAGE_COLUMN_ID='$(
|
|
|
|
jq --raw-output \
|
|
|
|
--arg column_field_name "$COLUMN_FIELD_NAME" \
|
|
|
|
--arg triage_column_name "$TRIAGE_COLUMN_NAME" \
|
|
|
|
'.data.organization.projectV2.fields.nodes[]
|
|
|
|
| select(.name == $column_field_name)
|
|
|
|
| .options[]
|
|
|
|
| select(.name == $triage_column_name)
|
|
|
|
| .id' \
|
|
|
|
single_select_fields.json
|
|
|
|
) >> $GITHUB_ENV
|
2022-09-15 08:51:48 +00:00
|
|
|
|
2023-02-11 20:04:53 +00:00
|
|
|
- name: Add issue#${{ github.event.issue.number }} to project
|
2022-09-15 08:51:48 +00:00
|
|
|
env:
|
|
|
|
ISSUE_ID: ${{ github.event.issue.node_id }}
|
|
|
|
run: |
|
2023-02-11 20:04:53 +00:00
|
|
|
echo "Adding issue: ${{ github.event.issue.number }} to project ${{ env.PROJECT_NUMBER }}"
|
|
|
|
if [[ $DRY_RUN == 'false' ]]; then
|
|
|
|
echo 'ITEM_ID='$(
|
|
|
|
gh api graphql \
|
|
|
|
--jq '.data.addProjectV2ItemById.item.id' \
|
|
|
|
--raw-field project_id="$PROJECT_ID" \
|
|
|
|
--raw-field issue_id="$ISSUE_ID" \
|
|
|
|
--raw-field query='
|
|
|
|
mutation($project_id: ID!, $issue_id: ID!) {
|
|
|
|
addProjectV2ItemById(input: {projectId: $project_id, contentId: $issue_id}) {
|
|
|
|
item {
|
|
|
|
id
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}'
|
|
|
|
) >> $GITHUB_ENV
|
|
|
|
fi
|
|
|
|
|
|
|
|
- name: Move issue#${{ github.event.issue.number }} to Triage column
|
|
|
|
run: |
|
|
|
|
echo "Moving issue: ${{ github.event.issue.number }} to Triage column in project ${{ env.PROJECT_NUMBER }}"
|
|
|
|
if [[ $DRY_RUN == 'false' ]]; then
|
2022-09-15 08:51:48 +00:00
|
|
|
gh api graphql \
|
|
|
|
--silent \
|
2023-02-11 20:04:53 +00:00
|
|
|
--raw-field project_id="$PROJECT_ID" \
|
|
|
|
--raw-field item_id="$ITEM_ID" \
|
|
|
|
--raw-field column_field_id="$COLUMN_FIELD_ID" \
|
|
|
|
--raw-field column_value_id="$TRIAGE_COLUMN_ID" \
|
2022-09-15 08:51:48 +00:00
|
|
|
--raw-field query='
|
2023-02-11 20:04:53 +00:00
|
|
|
mutation (
|
|
|
|
$project_id: ID!
|
|
|
|
$item_id: ID!
|
|
|
|
$column_field_id: ID!
|
|
|
|
$column_value_id: String!
|
|
|
|
) {
|
|
|
|
updateProjectV2ItemFieldValue(input: {
|
|
|
|
projectId: $project_id
|
|
|
|
itemId: $item_id
|
|
|
|
fieldId: $column_field_id
|
|
|
|
value: {
|
|
|
|
singleSelectOptionId: $column_value_id
|
|
|
|
}
|
2022-09-15 08:51:48 +00:00
|
|
|
}) {
|
2023-02-11 20:04:53 +00:00
|
|
|
projectV2Item {
|
|
|
|
id
|
|
|
|
}
|
2022-09-15 08:51:48 +00:00
|
|
|
}
|
|
|
|
}'
|
|
|
|
fi
|