-
Notifications
You must be signed in to change notification settings - Fork 0
125 lines (94 loc) · 5.28 KB
/
update-issue-status.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
name: Update Issue Status
on:
pull_request:
types: [closed]
jobs:
update-status:
runs-on: ubuntu-latest
steps:
# Step 1: Check for issue number in PR title or description
- name: Check for issue number in PR title or description
id: check-pr-for-issue
run: |
pr_title="${{ github.event.pull_request.title }}"
pr_body="${{ github.event.pull_request.body }}"
issue_number=$(echo "$pr_title" "$pr_body" | grep -oE '#[0-9]+' | head -n 1 | sed 's/#//')
if [ -z "$issue_number" ]; then
echo "No issue number found in PR title or description."
exit 1
fi
echo "Issue number found: $issue_number"
echo "issue_number=$issue_number" >> $GITHUB_ENV
# Step 2: Get organization name, project ID, status field ID, and done option ID
- name: Retrieve project details
id: get-project-details
run: |
org_name="${{ github.repository_owner }}"
project_number="1314"
echo "Fetching details for organization: $org_name, project number: $project_number"
# GraphQL query to get project fields (including "Status" field and "Done" option)
query="{\"query\": \"{ organization(login: \\\"$org_name\\\") { projectV2(number: $project_number) { id fields(first: 20) { nodes { ... on ProjectV2SingleSelectField { id name options { id name } } } } } } }\"}"
echo "Query being sent to GraphQL API: $query"
response=$(curl -H "Authorization: Bearer ${{ secrets.GH_TOKEN }}" \
-X POST \
-H "Content-Type: application/json" \
-d "$query" \
https://api.github.com/graphql)
echo "GraphQL Response: $response"
# Extracting the status field ID and done option ID from the response
status_field_id=$(echo $response | jq -r '.data.organization.projectV2.fields.nodes[] | select(.name == "Status") | .id')
done_option_id=$(echo $response | jq -r '.data.organization.projectV2.fields.nodes[] | select(.name == "Status") | .options[] | select(.name == "Done") | .id')
echo "Status Field ID: $status_field_id"
echo "Done Option ID: $done_option_id"
# Set environment variables for later steps
echo "status_field_id=$status_field_id" >> $GITHUB_ENV
echo "done_option_id=$done_option_id" >> $GITHUB_ENV
# Step 3: Get Issue ID (itemId) from project
- name: Get Issue ID from project
id: get-issue-id
run: |
issue_number=${{ env.issue_number }}
project_number="1314"
query="{\"query\": \"{ organization(login: \\\"${{ github.repository_owner }}\\\") { projectV2(number: $project_number) { items(first: 100, orderBy: {field: POSITION, direction: DESC}) { nodes { id content { ... on Issue { number id } } } } } } }\"}"
response=$(curl -H "Authorization: Bearer ${{ secrets.GH_TOKEN }}" \
-X POST \
-H "Content-Type: application/json" \
-d "$query" \
https://api.github.com/graphql)
issue_id=$(echo $response | jq -r ".data.organization.projectV2.items.nodes[] | select(.content.number == $issue_number) | .id")
if [ -z "$issue_id" ]; then
echo "Issue ID not found for issue #$issue_number."
exit 1
fi
echo "Issue ID: $issue_id"
echo "issue_id=$issue_id" >> $GITHUB_ENV
# Step 4: Update 'Status' field of the issue to 'Done'
- name: Update Issue Status to 'Done'
run: |
issue_id=${{ env.issue_id }}
project_number="1314"
status_field_id="${{ env.status_field_id }}"
done_option_id="${{ env.done_option_id }}"
echo "Updating issue #$issue_number status to 'Done'"
# Query to get the global project ID
project_query="{\"query\": \"{ organization(login: \\\"department-of-veterans-affairs\\\") { projectV2(number: $project_number) { id } } }\"}"
# Get the project ID
project_response=$(curl -H "Authorization: Bearer ${{ secrets.GH_TOKEN }}" \
-X POST \
-H "Content-Type: application/json" \
-d "$project_query" \
https://api.github.com/graphql)
project_id=$(echo $project_response | jq -r '.data.organization.projectV2.id')
if [ -z "$project_id" ]; then
echo "Project ID not found for project number $project_number."
exit 1
fi
echo "Found global project ID: $project_id"
# GraphQL Mutation to update status
mutation_query="{\"query\": \"mutation { updateProjectV2ItemFieldValue(input: { projectId: \\\"$project_id\\\", itemId: \\\"$issue_id\\\", fieldId: \\\"$status_field_id\\\", value: { singleSelectOptionId: \\\"$done_option_id\\\" } }) { projectV2Item { id content { ... on Issue { id number title } } } } }\"}"
response=$(curl -H "Authorization: Bearer ${{ secrets.GH_TOKEN }}" \
-X POST \
-H "Content-Type: application/json" \
-d "$mutation_query" \
https://api.github.com/graphql)
echo "Response: $response"