authkey
Version:
simple app key issue and verification
84 lines (57 loc) • 2.13 kB
Markdown
# authkey
> self-hosted, bare-bones licensing API
Basically a very limited version of what [keygen.sh](https://keygen.sh/) does.
[](https://www.npmjs.com/package/authkey)
[](https://travis-ci.org/adekbadek/authkey)
[](https://coveralls.io/github/adekbadek/authkey?branch=master)[](https://standardjs.com)
## Quick start
1. configure [Amazon SES](https://aws.amazon.com/ses/) or get some gmail creds
1. install
```shell
npm i authkey
```
1. use
```javascript
const authkey = require('authkey')
authkey({
from: 'superthing@things.com'
productName: 'SuperThing',
mailerConfig: {
// see below for other services
type: 'gmail',
credentials: {
user: process.env.GMAIL_USER,
pass: process.env.GMAIL_PASS,
}
},
}).listen()
```
### `mailerConfig` options
| service (`type`) | required `credentials` |
| :------------- | :------------- |
| `amazonSES` | `accessKeyId`, `secretAccessKey`, `region` |
| `gmail` | `user`, `pass` |
## API Reference
| verb | endpoint | what it does |
| :------------- | :------------- | :------------- |
| `POST` | `/request/:address` | creates a new auth key for the given address and sends an email with the auth key |
| `POST` | `/verify/:authkey` | verifies the given auth key |
## Database
a JSON file handled with [lowdb](https://github.com/typicode/lowdb)
## Versioning
[SemVer](http://semver.org/) is used (with help of [semantic-release](https://github.com/semantic-release/semantic-release)).
## Contributing
```shell
git clone https://github.com/adekbadek/authkey.git
cd authkey/
npm i
npm t
```
Will install the dependencies and run tests in watch mode.
### Tests
with [Jest](https://facebook.github.io/jest/)
```shell
npm t
```
### Style guide
using [Standard](https://standardjs.com/)