-
Notifications
You must be signed in to change notification settings - Fork 0
/
basicAuth.js
27 lines (25 loc) · 949 Bytes
/
basicAuth.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
var basicAuth = require('basic-auth');
module.exports = function (db) {
return {
BasicAuthentication: function (request, response, next) {
function unauthorized(response) {
response.set('WWW-Authenticate', 'Basic realm=Authorization Required');
return response.status(401).json({message: 'Unauthorized'});
}
var user = basicAuth(request);
if (!user || !user.name || !user.pass) {
return unauthorized(response);
}
var u = {email: user.name, password: user.pass};
db.collection('user').findOne(u).then(function (result) {
if (!result) {
return unauthorized(response);
}
return next();
}, function (error) {
console.log(error);
return unauthorized(response);
});
}
};
};