You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Jul 17, 2023. It is now read-only.
On popular request, it would be nice if user could click name of reviewer on reviewers list to request review from that person. This way requesting reviews would require only some clicks, without any typing.
This is harder than it looks like.
Canonical way of requesting reviews is using GitHub API. This doesn't work, because being logged in on website doesn't make you authenticated to API.
There are two ways of authenticating user in API:
send username and password. This would require prompting for password on each script load, or storing password permanently somehow. Will probably not work for users with 2 factor authentication enabled.
send OAuth2 token. Tokens are specific to users and pose the same challenges as passwords. Storing them permanently would be a little more acceptable (user can revoke token anytime), but we still can't store them in script itself.
GitHub itself (website) doesn't use public API. Instead, they send POST with multiform data to special endpoint $PR_URL/review-requests. This endpoint does recognize user logged in in web browser, which means it doesn't require further authentication to use.
But it does require to identify users (requested reviewers) by their internal user id, which is not exposed anywhere on website. This can be worked around by clicking "Reviewers" header and then hiding list (technically possible, but really ugly), or by storing username / id map in user script.
Either way, this endpoint is not part of any public API, so it is subject to change without notice. We should use it only as very last resort.
Other ideas and solutions are very welcome.
The text was updated successfully, but these errors were encountered:
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
On popular request, it would be nice if user could click name of reviewer on reviewers list to request review from that person. This way requesting reviews would require only some clicks, without any typing.
This is harder than it looks like.
Canonical way of requesting reviews is using GitHub API. This doesn't work, because being logged in on website doesn't make you authenticated to API.
There are two ways of authenticating user in API:
GitHub itself (website) doesn't use public API. Instead, they send POST with multiform data to special endpoint
$PR_URL/review-requests
. This endpoint does recognize user logged in in web browser, which means it doesn't require further authentication to use.But it does require to identify users (requested reviewers) by their internal user id, which is not exposed anywhere on website. This can be worked around by clicking "Reviewers" header and then hiding list (technically possible, but really ugly), or by storing username / id map in user script.
Either way, this endpoint is not part of any public API, so it is subject to change without notice. We should use it only as very last resort.
Other ideas and solutions are very welcome.
The text was updated successfully, but these errors were encountered: