mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-21 09:52:06 +03:00
be4146e324
no issue - Enables the Personal Tokens feature.
42 lines
1.1 KiB
JavaScript
42 lines
1.1 KiB
JavaScript
function SessionMiddleware({sessionService}) {
|
|
async function createSession(req, res, next) {
|
|
try {
|
|
await sessionService.createSessionForUser(req, res, req.user);
|
|
res.sendStatus(201);
|
|
} catch (err) {
|
|
next(err);
|
|
}
|
|
}
|
|
|
|
async function destroySession(req, res, next) {
|
|
try {
|
|
await sessionService.destroyCurrentSession(req);
|
|
res.sendStatus(204);
|
|
} catch (err) {
|
|
next(err);
|
|
}
|
|
}
|
|
|
|
async function authenticate(req, res, next) {
|
|
try {
|
|
const user = await sessionService.getUserForSession(req, res);
|
|
if (user) {
|
|
// Do not nullify `req.user` as it might have been already set
|
|
// in a previous middleware (authorize middleware).
|
|
req.user = user;
|
|
}
|
|
next();
|
|
} catch (err) {
|
|
next(err);
|
|
}
|
|
}
|
|
|
|
return {
|
|
createSession: createSession,
|
|
destroySession: destroySession,
|
|
authenticate: authenticate
|
|
};
|
|
}
|
|
|
|
module.exports = SessionMiddleware;
|