-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for GHE #618
Add support for GHE #618
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for addressing around this feature!
I don't have experience to use GHE, but the logic and suggestion looks good.
I have reviewed about some CI failures and parameters. 🙏
@@ -9,6 +9,10 @@ inputs: | |||
description: 'The GITHUB_TOKEN secret' | |||
required: true | |||
default: ${{ github.token }} | |||
github-api-url: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
github-api-url: | |
github-graphql-url: |
I think this will be better to clarify the difference of REST endpoints
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In this case - octokit graphql actually does "magic" to figure out graphql endpoint from rest endpoint here:
https://github.com/octokit/graphql.js/blob/main/src/graphql.ts#L67
If we pass graphql endpoint as baseUrl
it would produce url such as "https://ghe.example.net/graphql/graphql".
So in this case we need to leave it as github-api-url
. Or if you'd prefer github-rest-api-url
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://github.com/octokit/graphql.js/blob/9c0643d34f36ed558e55193438d7aa8b031ca43d/src/graphql.ts#L23
https://github.com/octokit/graphql.js/blob/9c0643d34f36ed558e55193438d7aa8b031ca43d/src/graphql.ts#L67-L72
const GHES_V3_SUFFIX_REGEX = /\/api\/v3\/?$/;
// workaround for GitHub Enterprise baseUrl set with /api/v3 suffix
// https://github.com/octokit/auth-app.js/issues/111#issuecomment-657610451
const baseUrl = parsedOptions.baseUrl || request.endpoint.DEFAULTS.baseUrl;
if (GHES_V3_SUFFIX_REGEX.test(baseUrl)) {
requestOptions.url = baseUrl.replace(GHES_V3_SUFFIX_REGEX, "/api/graphql");
}
If we pass graphql endpoint as baseUrl it would produce url such as "https://ghe.example.net/graphql/graphql".
The workaround seems to focus only on the /api/v3
suffix. Did it actually append nested graphql suffix for your URL?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So we have https://ghe.example.com/api/v3
for the api_url. When I use it I end with following error (redacted):
const error2 = new import_request_error.RequestError(toErrorMessage(data), status, {
RequestError [HttpError]: Not Found
at main/dist/index.js:18839:26
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async Object.next (main/dist/index.js:21920:32)
at async Function.paginate (main/dist/index.js:21968:26)
at async getCheckRunSummaries (main/dist/index.js:25927:55)
at async fetchOtherRunStatus (main/dist/index.js:26018:27)
at async run (main/dist/index.js:26183:20) {
status: 404,
response: {
url: 'https://ghe.example.com/api/graphql/graphql',
status: 404,
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
github.api_url
may raise the error, but your ${{ github.graphql_url }}
have same suffix? As I understand it, GitHub GraphQL API is v4. (I may not know GHE backgrounds 🙇♂️ )
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In our GHE instance ${{ github.graphql_url }}
resolves to something like: https://ghe.example.net/api/graphql
(which is correct endpoint for it). So the octokit graphql takes: https://ghe.example.net/api/v3
and replaces api/v3
with api/graphql
. Otherwise it appends graphql
(assuming baseURL is api.github.com
). Which is why we need to just give octokit ${{ github.api_url }}
. It figures out graphql endoint on its own.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for sharing! I'm reading how some other actions are handling this ....
https://github.com/google-github-actions/release-please-action/pull/532
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NOTE to me: The patch introduced in octokit/graphql.js#186 is still active in latest https://github.com/octokit/graphql.js/blob/a801c2f72fc5e56d531b16d0f4c4946e687e32e6/src/graphql.ts#L67-L72
02d65dd
to
6690a97
Compare
Not sure if there's anything more I should be fixing here. |
Sorry for my delayed reply 🙇 Your implementation looks good to me 👍 , but I have stacked to determine the input naming A fundamental problem is that I don't have an environment to test GitHub Enterprise Edition... |
Without this support octokit always tries to query api.github.com instead of GitHub Enterprise where it's running
6790c36
to
6214189
Compare
I've rebased the changes on latest main (things are a bit simpler now). I'm still interested in getting this merged but if you don't have access to GHE and don't want to merge this support without it I'd prefer if you just rejected the PR so I can make other arrangements. |
Sorry for the delay in pending the state for a long time. I have not forgotten this PR, but I could not determine any action or direction regarding it. Basically, if I cannot maintain the feature, I would exclude it from my personal project. So I'm planning to merge this PR in this or next month. |
You are an open-source maintainer, providing tools/code for others to reuse for free. You have no obligation to reply to anyone but I appreciate the gesture :-)
That is absolutely a fair point and would be absolutely acceptable reason to reject my PR.
Yeah, I think with your refactoring the changes became much simpler
Great, no rush. For what it's worth I've been using this version on our GH enterprise instance for a while without issues. New version fixed a few issues we had with the matrix jobs etc. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for all of your work of this PR! 👍
I left some review comments. But I may merge this PR with adding some revised commit (or squashed commit) 💪
|
||
```yaml | ||
with: | ||
github-api-url: 'https://ghe-host.acme.net/api/v3' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
github-api-url: 'https://ghe-host.acme.net/api/v3' | |
github-api-url: 'https://ghe-host.example.net/api/v3' |
I don't know the detail for acme and the domain owner, don't we need to use example.*
for this use? https://www.rfc-editor.org/rfc/rfc2606.txt
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I guess resolving conflict drops old review points... #618 (comment)
Sorry for my lately response 🙇♂️
@@ -109,6 +109,7 @@ export type RetryMethod = z.infer<typeof retryMethods>; | |||
// - Do not specify default values with zod. That is an action.yml role | |||
// - Do not include secrets here, for example githubToken. See https://github.com/colinhacks/zod/issues/1783 | |||
export const Options = z.object({ | |||
apiUrl: z.string().url(), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I didn't know zod provides url validations 👍
github-api-url: | ||
description: 'Github API URL' | ||
required: true | ||
default: 'https://api.github.com' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
default: 'https://api.github.com' | |
default: '${{ github.api_url }}' |
Can we use placeholder for getting default value?
@@ -68,6 +68,7 @@ Full list of the options | |||
|
|||
| NAME | DESCRIPTION | TYPE | DEFAULT | OPTIONS | | |||
| ----------------------------------- | -------------------------------------------------------------- | -------- | --------------------- | ---------------------------------------- | | |||
| `github-api-url` | The Github API endpoint. Override for Github Enterprise usage. | `string` | `true` | `https://api.github.com` | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
At least for REST endpoint, this option name is good 👍 ref: actions/create-github-app-token#88
| `github-api-url` | The Github API endpoint. Override for Github Enterprise usage. | `string` | `true` | `https://api.github.com` | | |
| `github-api-url` | The Github API endpoint. Override for Github Enterprise usage. | `string` | `${{ github.api_url }}` | `https://api.github.com` | |
? (sorry for unformatting)
@@ -9,6 +9,10 @@ inputs: | |||
description: 'The GITHUB_TOKEN secret' | |||
required: true | |||
default: ${{ github.token }} | |||
github-api-url: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NOTE to me: The patch introduced in octokit/graphql.js#186 is still active in latest https://github.com/octokit/graphql.js/blob/a801c2f72fc5e56d531b16d0f4c4946e687e32e6/src/graphql.ts#L67-L72
By providing github-api-url we can enable support for Github Enterprise.
In some cases it might be available for octokit automatically but it's
safer to provide an override.