Quicker failure and description when invalid token supplied (#1161)

Fixes #1156

When users export a GitHub API token that has insufficient privleges
or has been revoked, we have been using a catch all error with retry
to handle it. This change adds a new error type for bad credentials
and does not retry.

Test plan:
There are no unit tests that cover this, however, you can test the
change by supplying a revoked token and attempting to load a GitHub
repo.
This commit is contained in:
Tyler Mace 2019-05-30 12:18:30 -07:00 committed by Dandelion Mané
parent ad2470e5c6
commit 1fbf8cd587
2 changed files with 21 additions and 4 deletions

View File

@ -2,6 +2,7 @@
## [Unreleased] ## [Unreleased]
- Fail quicker and with information when using invalid GH token (#1161)
- Allow the user to save or upload weight settings (#1150) - Allow the user to save or upload weight settings (#1150)
- Allow tweaking weights on a per-node basis (#1143) - Allow tweaking weights on a per-node basis (#1143)
- Add the `pagerank` command (#1114) - Add the `pagerank` command (#1114)

View File

@ -83,6 +83,7 @@ type GithubResponseError =
| {|+type: "GRAPHQL_ERROR", retry: false, error: mixed|} | {|+type: "GRAPHQL_ERROR", retry: false, error: mixed|}
| {|+type: "RATE_LIMIT_EXCEEDED", retry: false, error: mixed|} | {|+type: "RATE_LIMIT_EXCEEDED", retry: false, error: mixed|}
| {|+type: "GITHUB_INTERNAL_EXECUTION_ERROR", retry: true, error: mixed|} | {|+type: "GITHUB_INTERNAL_EXECUTION_ERROR", retry: true, error: mixed|}
| {|+type: "BAD_CREDENTIALS", retry: false, error: mixed|}
| {|+type: "NO_DATA", retry: true, error: mixed|}; | {|+type: "NO_DATA", retry: true, error: mixed|};
// Fetch against the GitHub API with the provided options, returning a // Fetch against the GitHub API with the provided options, returning a
@ -126,10 +127,20 @@ function tryGithubFetch(fetch, fetchOptions): Promise<any> {
} }
} }
if (x.data === undefined) { if (x.data === undefined) {
// See https://github.com/sourcecred/sourcecred/issues/350. if (x.message && x.message.includes("Bad credentials")) {
return Promise.reject( return Promise.reject(
({type: "NO_DATA", retry: true, error: x}: GithubResponseError) ({
); type: "BAD_CREDENTIALS",
retry: false,
error: x,
}: GithubResponseError)
);
} else {
// See https://github.com/sourcecred/sourcecred/issues/350
return Promise.reject(
({type: "NO_DATA", retry: true, error: x}: GithubResponseError)
);
}
} }
return Promise.resolve(x.data); return Promise.resolve(x.data);
}), }),
@ -205,6 +216,11 @@ export async function postQuery(
case "FETCH_ERROR": case "FETCH_ERROR":
// Network error; no need for additional commentary. // Network error; no need for additional commentary.
break; break;
case "BAD_CREDENTIALS":
console.error(
"An invalid token was supplied ($SOURCECRED_GITHUB_TOKEN). This is mostly likely caused by supplying a revoked token."
);
break;
default: default:
throw new Error((type: empty)); throw new Error((type: empty));
} }