我正在尝试使用@octokit/rest
在Enterprise GitHub上进行身份验证。如果我使用以下Curl,则会获得API URL的列表:
curl -u "my@email.com" https://api.github.<my domain>.com
当我跑步时,系统会提示我输入密码,以输入个人访问令牌。
但是,如果我在节点应用程序中使用相同的详细信息,则会收到401 Bad Credentials响应。这就是我配置身份验证的方式:
octokit.authenticate({
baseUrl: 'https://api.github.<my domain>.com',
type: 'basic',
username: 'my@email.com',
password: '<my personal access token>'
});
基于文档,我认为这应该可行。有人可以建议为什么不这样做吗?
这是我得到的完整HTTP响应:
{ HttpError: {"message":"Bad credentials","documentation_url":"https://developer.github.com/v3"}
at response.text.then.message (/node_modules/@octokit/rest/lib/request/request.js:72:19)
at <anonymous>
at process._tickCallback (internal/process/next_tick.js:188:7)
name: 'HttpError',
code: 401,
status: undefined,
headers:
{ 'access-control-allow-origin': '*',
'access-control-expose-headers': 'ETag, Link, Retry-After, X-GitHub-OTP, X-RateLimit-Limit, X-RateLimit-Remaining, X-RateLimit-Reset, X-OAuth-Scopes, X-Accepted-OAuth-Scopes, X-Poll-Interval',
connection: 'close',
'content-length': '83',
'content-security-policy': 'default-src \'none\'',
'content-type': 'application/json; charset=utf-8',
date: 'Mon, 10 Sep 2018 13:20:12 GMT',
'referrer-policy': 'origin-when-cross-origin, strict-origin-when-cross-origin',
server: 'GitHub.com',
status: '401 Unauthorized',
'strict-transport-security': 'max-age=31536000; includeSubdomains; preload',
'x-content-type-options': 'nosniff',
'x-frame-options': 'deny',
'x-github-media-type': 'github.v3; format=json',
'x-github-request-id': 'C8BA:76CE:24B2BB3:45F82A2:5B966F8B',
'x-ratelimit-limit': '10',
'x-ratelimit-remaining': '9',
'x-ratelimit-reset': '1536585672',
'x-runtime-rack': '0.039959',
'x-xss-protection': '1; mode=block' } }
其他信息
这似乎是我的问题发生的地方
let response = await method({
q: "repo:" + repoOrg + "/" + repoName + " is:issue",
per_page: 100
});
这类似于npm页面上的示例。可以通过某种方式使身份验证不适用于该身份验证,如果可以,如何确保身份验证确实适用?
答案 0 :(得分:2)
为了使用令牌进行身份验证,您应该将身份验证类型设置为token
和generate a token
username
同时接收电子邮件和用户名
完整的示例:
const octokit = require('@octokit/rest')();
octokit.authenticate({
type: 'token',
username: 'my username',
token: 'my token'
});
octokit.activity.getStarredRepos().then(results => {
console.log(results);
});
答案 1 :(得分:0)
.authenticate
方法不接受baseUrl
参数。您必须将其添加到Octokit构造函数中,请参见https://github.com/octokit/rest.js#client-options
这是我代码中的一个示例:
const octokit = require('@octokit/rest')({
baseUrl: 'https://api.github.<my domain>.com'
})
octokit.authenticate({
type: 'basic',
username: 'my@email.com',
password: '<my personal access token>'
});