1
0
Fork 0
mirror of https://github.com/ohmyzsh/ohmyzsh.git synced 2024-11-23 22:30:07 +00:00
ohmyzsh/.github/workflows/project.yml

141 lines
4.5 KiB
YAML
Raw Normal View History

2022-01-02 01:30:00 +00:00
name: Project tracking
on:
issues:
types: [opened, reopened]
2022-01-02 01:30:00 +00:00
pull_request_target:
types: [opened, reopened, synchronize]
2022-01-02 01:30:00 +00:00
2022-02-21 18:27:21 +00:00
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
permissions: {}
2022-01-02 01:30:00 +00:00
jobs:
add-to-project:
name: Add to project
runs-on: ubuntu-latest
2022-01-03 12:10:53 +00:00
if: github.repository == 'ohmyzsh/ohmyzsh'
env:
GITHUB_TOKEN: ${{ secrets.PROJECT_TOKEN }}
2022-01-02 01:30:00 +00:00
steps:
- name: Read project data
env:
ORGANIZATION: ohmyzsh
PROJECT_NUMBER: "1"
run: |
# Get Project data
2022-01-02 02:37:05 +00:00
gh api graphql -f query='
2022-01-02 01:30:00 +00:00
query($org: String!, $number: Int!) {
organization(login: $org){
projectV2(number: $number) {
2022-01-02 01:30:00 +00:00
id
fields(first:20) {
nodes {
... on ProjectV2Field {
id
name
}
2022-01-02 01:30:00 +00:00
}
}
}
}
}' -f org=$ORGANIZATION -F number=$PROJECT_NUMBER > project_data.json
2022-01-02 01:30:00 +00:00
# Parse project data
cat >> $GITHUB_ENV <<EOF
PROJECT_ID=$(jq '.data.organization.projectV2.id' project_data.json)
PLUGIN_FIELD_ID=$(jq '.data.organization.projectV2.fields.nodes[] | select(.name == "Plugin") | .id' project_data.json)
THEME_FIELD_ID=$(jq '.data.organization.projectV2.fields.nodes[] | select(.name == "Theme") | .id' project_data.json)
2022-01-02 01:30:00 +00:00
EOF
2022-01-02 01:30:00 +00:00
- name: Add to project
env:
2022-01-03 12:02:28 +00:00
ISSUE_OR_PR_ID: ${{ github.event.issue.node_id || github.event.pull_request.node_id }}
2022-01-02 01:30:00 +00:00
run: |
item_id="$(gh api graphql -f query='
mutation($project: ID!, $content: ID!) {
addProjectV2ItemById(input: {projectId: $project, contentId: $content}) {
item {
2022-01-02 01:30:00 +00:00
id
}
}
}
' -f project=$PROJECT_ID -f content=$ISSUE_OR_PR_ID --jq '.data.addProjectV2ItemById.item.id')"
2022-01-02 01:30:00 +00:00
echo "ITEM_ID=$item_id" >> $GITHUB_ENV
2022-01-02 01:30:00 +00:00
- name: Classify Pull Request
if: github.event_name == 'pull_request_target'
run: |
touch plugins.list themes.list
gh pr view ${{ github.event.pull_request.number }} \
--repo ${{ github.repository }} \
--json files --jq '.files.[].path' | awk -F/ '
2022-01-02 01:30:00 +00:00
/^plugins\// {
plugins[$2] = 1
}
/^themes\// {
gsub(/\.zsh-theme$/, "", $2)
themes[$2] = 1
}
END {
for (plugin in plugins) {
print plugin >> "plugins.list"
}
for (theme in themes) {
print theme >> "themes.list"
}
}
'
# If only one plugin is modified, add it to the plugin field
if [[ $(wc -l < plugins.list) = 1 ]]; then
echo "PLUGIN=$(cat plugins.list)" >> $GITHUB_ENV
fi
# If only one theme is modified, add it to the theme field
if [[ $(wc -l < themes.list) = 1 ]]; then
echo "THEME=$(cat themes.list)" >> $GITHUB_ENV
fi
2022-01-02 01:30:00 +00:00
- name: Fill Pull Request fields in project
if: github.event_name == 'pull_request_target'
run: |
gh api graphql -f query='
mutation (
$project: ID!
$item: ID!
$plugin_field: ID!
$plugin_value: String!
$theme_field: ID!
$theme_value: String!
) {
set_plugin: updateProjectV2ItemFieldValue(input: {
2022-01-02 01:30:00 +00:00
projectId: $project
itemId: $item
fieldId: $plugin_field
value: {
text: $plugin_value
}
2022-01-02 01:30:00 +00:00
}) {
projectV2Item {
2022-01-02 01:30:00 +00:00
id
}
}
set_theme: updateProjectV2ItemFieldValue(input: {
2022-01-02 01:30:00 +00:00
projectId: $project
itemId: $item
fieldId: $theme_field
value: {
text: $theme_value
}
2022-01-02 01:30:00 +00:00
}) {
projectV2Item {
2022-01-02 01:30:00 +00:00
id
}
}
}
' -f project=$PROJECT_ID -f item=$ITEM_ID \
-f plugin_field=$PLUGIN_FIELD_ID -f plugin_value=$PLUGIN \
-f theme_field=$THEME_FIELD_ID -f theme_value=$THEME \
--silent