https://github.com/microauth/microauth-google
Google oauth for micro
https://github.com/microauth/microauth-google
Last synced: 6 months ago
JSON representation
Google oauth for micro
- Host: GitHub
- URL: https://github.com/microauth/microauth-google
- Owner: microauth
- License: mit
- Created: 2017-10-21T14:34:04.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2020-02-05T09:35:22.000Z (almost 6 years ago)
- Last Synced: 2025-04-11T04:35:22.848Z (7 months ago)
- Language: JavaScript
- Size: 655 KB
- Stars: 11
- Watchers: 2
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-micro - microauth-google
README
# microauth-google
> Google oauth for [micro](https://github.com/zeit/micro/)
[](https://travis-ci.org/microauth/microauth-google)
[](https://github.com/sindresorhus/xo)
[](https://greenkeeper.io/)
Add [google](https://google.com) authentication to your [micro](https://github.com/zeit/micro/) in few lines of code.
Inspired by [Dmitry Pavlovsky](http://palosk.in) [microauth-github](https://github.com/microauth/microauth-github)
## Installation
```sh
npm install --save microauth-google
# or
yarn add microauth-google
```
## Usage
app.js
```js
const { send } = require('micro');
const microAuthGoogle = require('microauth-google');
const options = {
clientId: 'CLIENT_ID',
clientSecret: 'CLIENT_SECRET',
callbackUrl: 'http://localhost:3000/auth/google/callback',
path: '/auth/google',
scope: 'https://www.googleapis.com/auth/plus.me'
};
const googleAuth = microAuthGoogle(options);
// third `auth` argument will provide error or result of authentication
// so it will {err: errorObject} or {result: {
// provider: 'google',
// accessToken: 'blahblah',
// info: userInfo,
// client: OAuth2Client instance
// }}
module.exports = googleAuth(async (req, res, auth) => {
if (!auth) {
return send(res, 404, 'Not Found');
}
if (auth.err) {
// Error handler
return send(res, 403, 'Forbidden');
}
return `Hello ${auth.result.info.display_name}`;
});
```
Run:
```sh
micro app.js
```
Now visit `http://localhost:3000/auth/google`
### Scopes
**String|String[]**
Scopes define the access list the app needs. It can either be a string or an array of strings.
Default scopes and **always** present are the mandatory from [OpenID 2.0](https://developers.google.com/identity/protocols/OpenIDConnect?hl=en#discovery):
- `openid`
- `email`
- `profile`
### OAuth2Client
**OAuth2Client**
An instance of **OAuth2Client** is supplied for further use, mainly because this module no longer relies on `googleapis` nor it has as dependecy.
## Author
[Rui Pedro Lima](https://github.com/rapzo)