feat: add write API route for checking login credentials
parent
1cf0032d9f
commit
56f929ed4f
@ -0,0 +1,44 @@
|
||||
'use strict';
|
||||
|
||||
const user = require('../../user');
|
||||
const authenticationController = require('../authentication');
|
||||
const slugify = require('../../slugify');
|
||||
const helpers = require('../helpers');
|
||||
|
||||
const Utilities = module.exports;
|
||||
|
||||
Utilities.ping = {};
|
||||
Utilities.ping.get = (req, res) => {
|
||||
helpers.formatApiResponse(200, res, {
|
||||
pong: true,
|
||||
});
|
||||
};
|
||||
|
||||
Utilities.ping.post = (req, res) => {
|
||||
helpers.formatApiResponse(200, res, {
|
||||
uid: req.user.uid,
|
||||
received: req.body,
|
||||
});
|
||||
};
|
||||
|
||||
Utilities.login = (req, res) => {
|
||||
res.locals.continueLogin = async (req, res) => {
|
||||
const { username, password } = req.body;
|
||||
|
||||
const userslug = slugify(username);
|
||||
const uid = await user.getUidByUserslug(userslug);
|
||||
const ok = await user.isPasswordCorrect(uid, password, req.ip);
|
||||
|
||||
if (ok) {
|
||||
const userData = await user.getUsers([uid], uid);
|
||||
helpers.formatApiResponse(200, res, userData);
|
||||
} else {
|
||||
helpers.formatApiResponse(403, res);
|
||||
}
|
||||
};
|
||||
res.locals.noScriptErrors = (req, res, err, statusCode) => {
|
||||
helpers.formatApiResponse(statusCode, res, new Error(err));
|
||||
};
|
||||
|
||||
authenticationController.login(req, res);
|
||||
};
|
@ -0,0 +1,16 @@
|
||||
'use strict';
|
||||
|
||||
const router = require('express').Router();
|
||||
const middleware = require('../../middleware');
|
||||
const controllers = require('../../controllers');
|
||||
const routeHelpers = require('../helpers');
|
||||
|
||||
const setupApiRoute = routeHelpers.setupApiRoute;
|
||||
|
||||
module.exports = function () {
|
||||
// The "ping" routes are mounted at root level, but for organizational purposes, the controllers are in `utilities.js`
|
||||
|
||||
setupApiRoute(router, 'post', '/login', [middleware.checkRequired.bind(null, ['username', 'password'])], controllers.write.utilities.login);
|
||||
|
||||
return router;
|
||||
};
|
Loading…
Reference in New Issue