如果您通过应用程序页面创建了您正在使用的令牌,那么此令牌将具有以下范围:user
、、、、。您可以通过使用该令牌发出 API 请求并查看响应 HTTP 标头来验证这一点:public_repo
repo
gist
curl -v -H 'Authorization: token xxx' https://api.github.com
查找X-OAuth-Scopes
将具有范围列表的响应标头:
X-OAuth-Scopes: user, public_repo, repo, gist
但是,要删除存储库,令牌需要具有delete_repo
范围。
因此,您需要一个与您所拥有的范围不同的令牌。您可以使用Authorizations API创建这样的令牌:
curl -v -u username -X POST https://api.github.com/authorizations -d '{"scopes":["delete_repo"], "note":"token with delete repo scope"}'
这将返回一个带有新令牌的 JSON 文档,您应该可以使用它来删除存储库:
{
"id": XXXXX,
"url": "https://api.github.com/authorizations/XXXXX",
"app": {
"name": "GitHub API",
"url": "http://developer.github.com/v3/oauth/#oauth-authorizations-api",
"client_id": "00000000000000000000"
},
"token": "XXXXXX",
"note": "token with delete repo scope",
"note_url": null,
"created_at": "2013-10-11T20:34:49Z",
"updated_at": "2013-10-11T20:34:49Z",
"scopes": [
"delete_repo"
]
}
当然,以这种方式创建令牌时,您可以请求多个范围,而不仅仅是delete_repo
范围。
另外,作为旁注,当您没有正确授权时 API 返回 404 错误的原因是为了防止信息泄漏。