https://github.com/chentsulin/koa-bearer-token
Bearer token parser middleware for koa
https://github.com/chentsulin/koa-bearer-token
Last synced: 2 months ago
JSON representation
Bearer token parser middleware for koa
- Host: GitHub
- URL: https://github.com/chentsulin/koa-bearer-token
- Owner: chentsulin
- License: mit
- Created: 2015-04-24T09:46:31.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2024-10-09T00:16:10.000Z (8 months ago)
- Last Synced: 2025-03-31T04:06:18.019Z (3 months ago)
- Language: TypeScript
- Homepage:
- Size: 924 KB
- Stars: 34
- Watchers: 4
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-koa - koa-bearer-token - Bearer token解析器中间件。   (仓库 / 中间件)
README
# koa-bearer-token
[](https://npmjs.org/package/koa-bearer-token)
[](https://github.com/chentsulin/koa-bearer-token/actions?query=branch%3Amaster)
[](https://coveralls.io/r/chentsulin/koa-bearer-token?branch=master)> Bearer token parser middleware for koa
Inspired by [express-bearer-token](https://www.npmjs.com/package/express-bearer-token)
## Installation
```sh
$ npm install koa-bearer-token
```## What?
Per [RFC6750](https://datatracker.ietf.org/doc/html/rfc6750) this module will attempt to extract a bearer token from a request from these locations:
- The key `access_token` in the request body.
- The key `access_token` in the request query params.
- The value from the header `Authorization: Bearer `.
- (Optional) Get a token from cookies header with key `access_token`.If a token is found, it will be stored on `ctx.request.token`. If one has been provided in more than one location, this will abort the request immediately by sending code 400 (per [RFC6750]).
```js
const Koa = require('koa');
const bodyParser = require('koa-bodyparser');
const { bearerToken } = require('koa-bearer-token');const app = new Koa();
app.use(bodyParser());
app.use(bearerToken());app.use((ctx) => {
// ctx.request.token
});app.listen(3000);
```For APIs which are not compliant with [RFC6750], the key for the token in each location is customizable, as is the key the token is bound to on the request (default configuration shown):
```js
app.use(
bearerToken({
bodyKey: 'access_token',
queryKey: 'access_token',
headerKey: 'Bearer',
reqKey: 'token',
}),
);
```Get token from cookie key (it can be signed or not)
**Warning**: by **NOT** passing `{ signed: true }` you are accepting a non signed cookie and an attacker might spoof the cookies. so keep in mind to use signed cookies
```js
app.use(
bearerToken({
cookie: {
signed: true, // if passed true you must pass secret otherwise will throw error
secret: 'YOUR_APP_SECRET',
key: 'access_token', // default value
},
}),
);
```## TypeScript
As of version 2.0.1 we've added initial support for TypeScript.
If you're using your custom `reqKey`, you must do [module augmentation](https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation) on your own:
```ts
declare module 'koa' {
interface Request {
myToken?: string;
}
}app.use(
bearerToken({
reqKey: 'myToken',
}),
);
```## Compatibility table
| koa version | koa-bearer-token version |
| :---------: | :----------------------: |
| `<2` | `0.x.x` |
| `2` | `>=1.x.x` |## License
MIT © [C. T. Lin](https://github.com/chentsulin)