Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hollowman6/gatekeeper
Enables client-side applications to dance OAuth with GitHub or GitLab.
https://github.com/hollowman6/gatekeeper
github-api gitlab-api oauth2-client
Last synced: 2 months ago
JSON representation
Enables client-side applications to dance OAuth with GitHub or GitLab.
- Host: GitHub
- URL: https://github.com/hollowman6/gatekeeper
- Owner: HollowMan6
- License: mit
- Created: 2021-10-29T11:27:26.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-03-28T07:39:40.000Z (10 months ago)
- Last Synced: 2024-05-01T15:28:34.727Z (9 months ago)
- Topics: github-api, gitlab-api, oauth2-client
- Language: JavaScript
- Homepage: https://lzu.hollowman.ml/
- Size: 255 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
GateKeeper
==========A forked version from [prose/gatekeeper](https://github.com/prose/gatekeeper) with improvements on:
- URL Redirection.
- GitHub Apps Subscription Webhook support.
- [GitLab support](../../tree/GitLab).
- Send Interactions to Telegram.Because of some [security-related limitations](http://blog.vjeux.com/2012/javascript/github-oauth-login-browser-side.html), Github / GitLab prevents you from implementing the OAuth Web Application Flow on a client-side only application.
This is a real bummer. So we built Gatekeeper, which is the missing piece you need in order to make it work.
Gatekeeper works well with [Github.js](http://github.com/michael/github), which helps you access the [Github API](http://developer.github.com/v3/) or GitLab API from the browser. Gatekeeper is free to use under the [MIT license](https://github.com/HollowMan6/GateKeeper/blob/master/LICENSE).
## API
```
GET http://localhost:9999/authenticate/TEMPORARY_CODE
```## OAuth Steps
Also see the [documentation on Github](http://developer.github.com/v3/oauth/).
1. Redirect users to request GitHub access.
```
GET https://github.com/login/oauth/authorize
```2. GitHub redirects back to your site including a temporary code you need for the next step.
You can grab it like so:
```js
var code = window.location.href.match(/\?code=(.*)/)[1];
```3. Request the actual token using your instance of Gatekeeper, which knows your `client_secret`.
```js
$.getJSON('http://localhost:9999/authenticate/'+code, function(data) {
console.log(data.token);
});
```## Setup your Gatekeeper
1. Clone it
```
git clone [email protected]:HollowMan6/GateKeeper.git
```2. Install Dependencies
```
cd gatekeeper && npm install
```3. Adjust config.json
```json
{
"oauth_client_id": "GITHUB_APPLICATION_CLIENT_ID",
"oauth_client_secret": "GITHUB_APPLICATION_CLIENT_SECRET",
"oauth_host": "github.com",
"oauth_port": 443,
"oauth_path": "/login/oauth/access_token",
"oauth_method": "POST",
"port": 9999
}
```You can also set environment variables to override the settings if you don't want Git to track your adjusted config.json file. Just use UPPER_CASE keys.
4. Serve it
```
$ node index.js
```## Run using Docker
You can build and run the docker image:
```bash
docker build -t gatekeeper .
docker run -p 443:443 -p 9999:9999 --name gatekeeper-server gatekeeper
```Or run it with a .env file:
```bash
docker run -p 443:443 -p 9999:9999 --env-file .env --name gatekeeper-server gatekeeper
```Or run using the docker hub image:
```bash
docker run -p 443:443 -p 9999:9999 --name gatekeeper-server ludwigschubi/gatekeeper
```## Deploy on Heroku
### Heroku Button
Use the button below to instantly setup your own Gatekeeper instance on Heroku.
[![Deploy](https://www.herokucdn.com/deploy/button.png)](https://heroku.com/deploy)
### Heroku manually
1. Create a new Heroku app
```
heroku apps:create APP_NAME
```3. Provide OAUTH_CLIENT_ID and OAUTH_CLIENT_SECRET:
```
heroku config:set OAUTH_CLIENT_ID=XXXX OAUTH_CLIENT_SECRET=YYYY
```4. Push changes to heroku
```
git push heroku master
```
OR```
heroku restart
```## Deploy on Azure
### Azure Button
Use the button below to instantly setup your own Gatekeeper instance on Azure.
[![Deploy to Azure](http://azuredeploy.net/deploybutton.png)](https://azuredeploy.net/)
### Azure manually
1. Create a new Azure site
```
azure site create SITE_NAME --git
```2. Provide OAUTH_CLIENT_ID and OAUTH_CLIENT_SECRET:
```
azure site appsetting add OAUTH_CLIENT_ID=XXXX
azure site appsetting add OAUTH_CLIENT_SECRET=YYYY
```3. Push changes to Azure
```
git push azure master
```