name: Label PR on: pull_request_target: types: - opened - reopened - synchronize permissions: contents: write # to determine modified files (actions/labeler) pull-requests: write # to add labels to PRs (actions/labeler) jobs: triage: runs-on: ubuntu-latest timeout-minutes: 20 name: Label PR steps: - name: Label PR uses: actions/labeler@v3 with: repo-token: "${{ secrets.GITHUB_TOKEN }}" configuration-path: .github/pr_labeler.yml community: runs-on: ubuntu-latest timeout-minutes: 20 name: Label PR - Community steps: - uses: actions/checkout@v3 - uses: actions/setup-python@v4 - name: Install python requests run: pip install requests - name: Check if user is a member of Ansible org uses: jannekem/run-python-script-action@v1 id: check_user with: script: | import requests headers = {'Accept': 'application/vnd.github+json', 'Authorization': 'token ${{ secrets.GITHUB_TOKEN }}'} response = requests.get('${{ fromJson(toJson(github.event.pull_request.user.url)) }}/orgs?per_page=100', headers=headers) is_member = False for org in response.json(): if org['login'] == 'ansible': is_member = True if is_member: print("User is member") else: print("User is community") - name: Add community label if not a member if: contains(steps.check_user.outputs.stdout, 'community') uses: andymckay/labeler@e6c4322d0397f3240f0e7e30a33b5c5df2d39e90 with: add-labels: "community" repo-token: ${{ secrets.GITHUB_TOKEN }}