Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hex7c0/basic-authentication
http basic authentication for Nodejs
https://github.com/hex7c0/basic-authentication
basic-authentication htpasswd nodejs
Last synced: 24 days ago
JSON representation
http basic authentication for Nodejs
- Host: GitHub
- URL: https://github.com/hex7c0/basic-authentication
- Owner: hex7c0
- License: apache-2.0
- Created: 2014-06-13T17:10:28.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-04-23T00:00:02.000Z (8 months ago)
- Last Synced: 2024-11-11T19:38:42.039Z (about 1 month ago)
- Topics: basic-authentication, htpasswd, nodejs
- Language: JavaScript
- Homepage: https://github.com/hex7c0/basic-authentication
- Size: 201 KB
- Stars: 3
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# [basic-authentication](https://github.com/hex7c0/basic-authentication)
[![NPM version](https://img.shields.io/npm/v/basic-authentication.svg)](https://www.npmjs.com/package/basic-authentication)
[![Linux Status](https://img.shields.io/travis/hex7c0/basic-authentication.svg?label=linux-osx)](https://travis-ci.org/hex7c0/basic-authentication)
[![Windows Status](https://img.shields.io/appveyor/ci/hex7c0/basic-authentication.svg?label=windows)](https://ci.appveyor.com/project/hex7c0/basic-authentication)
[![Dependency Status](https://img.shields.io/david/hex7c0/basic-authentication.svg)](https://david-dm.org/hex7c0/basic-authentication)
[![Coveralls](https://img.shields.io/coveralls/hex7c0/basic-authentication.svg)](https://coveralls.io/r/hex7c0/basic-authentication)Basic authentication is method for a HTTP user agent to provide a user name and password.
## Installation
Install through NPM
```bash
npm install basic-authentication
```
or
```bash
git clone git://github.com/hex7c0/basic-authentication.git
```## API
inside expressjs project like a middleware
```js
var authentication = require('basic-authentication')();var app = require('express')();
app.use(authentication);
```
inside expressjs project like a callback for certain route
```js
var authentication = require('basic-authentication')();var app = require('express')();
app.get('/', authentication, function(req, res) {res.send('ok');
});
```
inside routing like a function
```js
var authentication = require('basic-authentication')({functions: true});var app = require('express')();
app.get('/', function(req, res) {var user = authentication(req);
if (user == 'foo') {
res.send('ok');
} else {
res.send('ko');
}
});
```### authentication(options)
#### options
- `user` - **String** User for web basic access authentication *(default "admin")*
- `password` - **String** Password for web basic access authentication *(default "password")*
- `file` - **String** Path of htpasswd file *(default "disabled")*
- `hash` - **String** Type of [hash](http://nodejs.org/api/crypto.html#crypto_crypto_createhash_algorithm) inside your htpasswd file *(default "md5")*
- `agent` - **String** Browser User Agent for web authentication *(default "all accepted")*
- `realm` - **String** Realm for web authentication *(default "Authorization required")*
- `ending` - **Boolean** Flag for send `res.end` (response) to client after error or wrong password (not in "functions" mode) *(default "true")*
- `functions` - **Boolean** Flag for using module like a function *(default "false")*
- `legacy` - **Boolean** Flag for using module like a function that return an Object *(default "false")*
- `suppress` - **Boolean** Suppress all routing error *(default "false")*in `functions` mode, it return a Base64 **String**; otherwise, if some errors occurred, return an Empty **String**
in `legacy` mode, it return an **Object** `{user, password}`; otherwise, if some errors occurred, return an Empty **Object**
## Examples
Take a look at my [examples](examples)
### [License Apache2](LICENSE)