crabfit/crabfit-backend/routes/login.js
2021-02-27 00:52:20 +11:00

33 lines
797 B
JavaScript

const bcrypt = require('bcrypt');
module.exports = async (req, res) => {
const { eventId, personName } = req.params;
const { person } = req.body;
try {
const query = req.datastore.createQuery('Person')
.filter('eventId', eventId)
.filter('name', personName);
let personResult = (await req.datastore.runQuery(query))[0][0];
if (personResult) {
if (personResult.password) {
const passwordsMatch = person && person.password && await bcrypt.compare(person.password, personResult.password);
if (!passwordsMatch) {
return res.status(401).send('Incorrect password');
}
}
res.send({
name: personName,
availability: personResult.availability,
});
} else {
res.sendStatus(404);
}
} catch (e) {
console.error(e);
res.sendStatus(404);
}
};