Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Conversation

@wata727
Copy link
Contributor

@wata727 wata727 commented Mar 10, 2025

Fixes #10573
Follow up of #7612

The missingWorkflowScopeRE is defined to capture the error message when the GH_TOKEN does not have workflow scope in gh repo sync <remote>, but this is only intended for error messages for OAuth Apps and does not work with GitHub Apps.

In GitHub App, you will get the following error:

{
  "message": "refusing to allow a GitHub App to create or update workflow `.github/workflows/teamcity-pr-checks.yml` without `workflows` permission",
  "documentation_url": "https://docs.github.com/rest/branches/branches#sync-a-fork-branch-with-the-upstream-repository",
  "status": "422"
}

As you can see above, the existing regexp does not match the "workflows permission".

This change modifies the regexp to return the user-friendly error message when the workflow permission is missing, even in the case of a GitHub App.

@wata727 wata727 requested a review from a team as a code owner March 10, 2025 13:20
@wata727 wata727 requested a review from jtmcg March 10, 2025 13:20
@wata727 wata727 temporarily deployed to cli-automation March 10, 2025 13:20 — with GitHub Actions Inactive
@cliAutomation cliAutomation added the external pull request originating outside of the CLI core team label Mar 10, 2025
@jtmcg
Copy link
Contributor

jtmcg commented Mar 10, 2025

Thanks for the fast turnaround on this, @wata727! I'm looking into testing this locally before giving it the πŸ‘

Follow up of cli#7612

The `missingWorkflowScopeRE` is defined to capture
the error message when the `GH_TOKEN` does not have
`workflow` scope in `gh repo sync <remote>`,
but this is only intended for error messages for
OAuth Apps and does not work with GitHub Apps.

In GitHub App, you will get the following error:

```
{
  "message": "refusing to allow a GitHub App to create or update workflow `.github/workflows/teamcity-pr-checks.yml` without `workflows` permission",
  "documentation_url": "https://docs.github.com/rest/branches/branches#sync-a-fork-branch-with-the-upstream-repository",
  "status": "422"
}
```

As you can see above, the existing regexp does not
match the "`workflows` permission".

This change modifies the regexp to return
the user-friendly error message when the `workflow`
permission is missing, even in the case of a GitHub App.
@wata727 wata727 force-pushed the make_missing_workflow_scope_regexp_aware_of_github_app branch from 88e0452 to b012886 Compare March 11, 2025 02:39
Copy link
Contributor

@jtmcg jtmcg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Boy, this ended up being a doozy to test, but with the wizardry of @andyfeller we managed to validate this change in a workflow πŸ₯³

@jtmcg jtmcg merged commit 66e51c7 into cli:trunk Mar 12, 2025
9 checks passed
@wata727 wata727 deleted the make_missing_workflow_scope_regexp_aware_of_github_app branch March 13, 2025 06:02
tmeijn pushed a commit to tmeijn/dotfiles that referenced this pull request Mar 26, 2025
This MR contains the following updates:

| Package | Update | Change |
|---|---|---|
| [cli/cli](https://github.com/cli/cli) | minor | `v2.68.1` -> `v2.69.0` |

MR created with the help of [el-capitano/tools/renovate-bot](https://gitlab.com/el-capitano/tools/renovate-bot).

**Proposed changes to behavior should be submitted there as MRs.**

---

### Release Notes

<details>
<summary>cli/cli (cli/cli)</summary>

### [`v2.69.0`](https://github.com/cli/cli/releases/tag/v2.69.0): GitHub CLI 2.69.0

[Compare Source](cli/cli@v2.68.1...v2.69.0)

#### What's Changed

##### Features

-   Commands that accept filepath arguments will do glob expansion for `*` characters, by [@&#8203;iamazeem](https://github.com/iamazeem) in cli/cli#10413

##### Bug Fixes

-   `gh issue/pr comment --edit-last` no longer creates a comment in non-interactive mode if there weren't one. A new flag `--create-if-none` provides this behaviour, by [@&#8203;andyfeller](https://github.com/andyfeller) in cli/cli#10625
-   `gh repo sync` provides a more informative error for missing workflow permissions when the token is provided by a GitHub app, by [@&#8203;wata727](https://github.com/wata727) in cli/cli#10574
-   `gh api` no longer tries to encode URLs incorrectly, by [@&#8203;williammartin](https://github.com/williammartin) in cli/cli#10630

##### Other

-   Add cli-discuss-automation environment to triage.md by [@&#8203;jtmcg](https://github.com/jtmcg) in cli/cli#10552
-   chore: remove redundant word in comment by [@&#8203;kevincatty](https://github.com/kevincatty) in cli/cli#10586
-   Bump golang.org/x/net from 0.34.0 to 0.36.0 by [@&#8203;dependabot](https://github.com/dependabot) in cli/cli#10593

#### New Contributors

-   [@&#8203;kevincatty](https://github.com/kevincatty) made their first contribution in cli/cli#10586
-   [@&#8203;wata727](https://github.com/wata727) made their first contribution in cli/cli#10574

**Full Changelog**: cli/cli@v2.68.1...v2.69.0

</details>

---

### Configuration

πŸ“… **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

β™» **Rebasing**: Whenever MR becomes conflicted, or you tick the rebase/retry checkbox.

πŸ”• **Ignore**: Close this MR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this MR, check this box

---

This MR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOS4yMTMuNSIsInVwZGF0ZWRJblZlciI6IjM5LjIxMy41IiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJSZW5vdmF0ZSBCb3QiXX0=-->
@0367124113

This comment was marked as spam.

@0367124113

This comment was marked as spam.

@0367124113

This comment was marked as spam.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

external pull request originating outside of the CLI core team

Projects

None yet

Development

Successfully merging this pull request may close these issues.

gh repo sync fails with surprising error if workflow scope is missing and token is from GitHub App

4 participants