mirror of
https://github.com/orangecoding/fredy.git
synced 2026-06-16 12:31:07 +00:00
* upgrading dependencies, fixing image placeholder * improving processing times label and hide when screen width is too low * aligning run now button * renaming settings -> general settings * smaller security and memory improvements * improving footer * preparing listing management * improve filtering for listings * preparing new settings page * preparing new settings page * storing settings in db * next release version
49 lines
1.5 KiB
JavaScript
49 lines
1.5 KiB
JavaScript
import restana from 'restana';
|
|
import * as userStorage from '../../services/storage/userStorage.js';
|
|
import * as hasher from '../../services/security/hash.js';
|
|
import { trackDemoAccessed } from '../../services/tracking/Tracker.js';
|
|
import logger from '../../services/logger.js';
|
|
import { getSettings } from '../../services/storage/settingsStorage.js';
|
|
const service = restana();
|
|
const loginRouter = service.newRouter();
|
|
loginRouter.get('/user', async (req, res) => {
|
|
const currentUserId = req.session.currentUser;
|
|
const currentUser = currentUserId == null ? null : userStorage.getUser(currentUserId);
|
|
if (currentUser == null) {
|
|
res.body = {};
|
|
} else {
|
|
res.body = {
|
|
userId: currentUser.id,
|
|
isAdmin: currentUser.isAdmin,
|
|
};
|
|
}
|
|
res.send();
|
|
});
|
|
loginRouter.post('/', async (req, res) => {
|
|
const settings = await getSettings();
|
|
const { username, password } = req.body;
|
|
const user = userStorage.getUsers(true).find((user) => user.username === username);
|
|
if (user == null) {
|
|
res.send(401);
|
|
return;
|
|
}
|
|
if (user.password === hasher.hash(password)) {
|
|
if (settings.demoMode) {
|
|
await trackDemoAccessed();
|
|
}
|
|
|
|
req.session.currentUser = user.id;
|
|
userStorage.setLastLoginToNow({ userId: user.id });
|
|
res.send(200);
|
|
return;
|
|
} else {
|
|
logger.error(`User ${username} tried to login, but password was wrong.`);
|
|
}
|
|
res.send(401);
|
|
});
|
|
loginRouter.post('/logout', async (req, res) => {
|
|
req.session = null;
|
|
res.send(200);
|
|
});
|
|
export { loginRouter };
|