crabfit/crabfit-backend/routes/login.js
2022-08-20 21:52:09 +10:00

36 lines
994 B
JavaScript

import bcrypt from 'bcrypt'
const login = async (req, res) => {
const { eventId, personName } = req.params
const { person } = req.body
try {
const query = req.datastore.createQuery(req.types.person)
.filter('eventId', eventId)
.filter('name', personName)
const 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({ error: 'Incorrect password' })
}
}
res.send({
name: personName,
availability: personResult.availability,
created: personResult.created,
})
} else {
res.status(404).send({ error: 'Person does not exist' })
}
} catch (e) {
console.error(e)
res.status(400).send({ error: 'An error occurred' })
}
}
export default login