Test dashboards squad action #1
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: When an issue changes and it's part of the dashboards project, add the dashboards squad label | ||
on: | ||
issues: | ||
types: [opened, closed, edited, reopened, assigned, unassigned, labeled, unlabeled] | ||
permissions: | ||
contents: read | ||
id-token: write | ||
env: | ||
ORGANIZATION: ${{ github.repository_owner }} | ||
REPO: ${{ github.event.repository.name }} | ||
TARGET_PROJECT: 202 | ||
LABEL_IDs: "LA_kwDOAOaWjc8AAAABT38U-A" | ||
concurrency: | ||
group: issue-label-when-in-project-${{ github.event.number }} | ||
jobs: | ||
main: | ||
Check failure on line 19 in .github/workflows/dashboards-issue-add-label.yml GitHub Actions / When an issue changes and it's part of the dashboards project, add the dashboards squad labelInvalid workflow file
|
||
needs: config | ||
if: github.repository == 'grafana/grafana' | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: "Get vault secrets" | ||
id: vault-secrets | ||
uses: grafana/shared-workflows/actions/get-vault-secrets@main | ||
with: | ||
# Secrets placed in the ci/repo/grafana/grafana/plugins_platform_issue_commands_github_bot path in Vault | ||
repo_secrets: | | ||
GH_APP_ID=plugins_platform_issue_commands_github_bot:app_id | ||
GH_APP_PEM=plugins_platform_issue_commands_github_bot:app_pem | ||
- name: "Generate token" | ||
id: generate_token | ||
uses: tibdex/github-app-token@b62528385c34dbc9f38e5f4225ac829252d1ea92 | ||
with: | ||
app_id: ${{ env.GH_APP_ID }} | ||
private_key: ${{ env.GH_APP_PEM }} | ||
- name: log in | ||
run: gh api user -q .login | ||
- name: Check if issue is in target project | ||
run: | | ||
gh api graphql -f query=' | ||
query($org: String!, $repo: String!) { | ||
repository(name: $repo, owner: $org) { | ||
issue (number: ${{ github.event.issue.number }}) { | ||
id | ||
projectItems(first:20) { | ||
nodes { | ||
project { | ||
number, | ||
}, | ||
} | ||
} | ||
} | ||
} | ||
}' -f org=$ORGANIZATION -f repo=$REPO > projects_data.json | ||
echo 'IN_TARGET_PROJ='$(jq '.data.repository.issue.projectItems.nodes[] | select(.project.number==${{ env.TARGET_PROJECT }}) | .project != null' projects_data.json) >> $GITHUB_ENV | ||
echo 'ITEM_ID='$(jq '.data.repository.issue.id' projects_data.json) >> $GITHUB_ENV | ||
- name: Set up label array | ||
if: env.IN_TARGET_PROJ | ||
run: | | ||
IFS=',' read -ra LABEL_IDs <<< "${{ env.LABEL_IDs }}" | ||
for item in "${LABEL_IDs[@]}"; do | ||
echo "Item: $item" | ||
done | ||
- name: Add label to issue | ||
if: env.IN_TARGET_PROJ | ||
run: | | ||
gh api graphql -f query=' | ||
mutation ($labelableId: ID!, $labelIds: [ID!]!) { | ||
addLabelsToLabelable( | ||
input: {labelableId: $labelableId, labelIds: $labelIds} | ||
) { | ||
clientMutationId | ||
} | ||
}' -f labelableId=$ITEM_ID -f labelIds=${{ env.LABEL_IDs }} |