41 lines
1.2 KiB
JavaScript
41 lines
1.2 KiB
JavaScript
const Router = require('koa-router');
|
|
const router = new Router();
|
|
|
|
// import tools
|
|
const crypto = require('../../libs/crypto.js');
|
|
const so = require('../../libs/storeObject');
|
|
const mongo = require('../../libs/mongo_model.js');
|
|
|
|
router
|
|
.post('/login', async(c, n) => {
|
|
let arr = c.request.body;
|
|
if (!arr.data) throw 'C_EDATA';
|
|
if (!arr.data.account) throw 'C_EACCOUNT';
|
|
if (!arr.data.password) throw 'C_EPASSWORD';
|
|
try {
|
|
let user = await c.syncQuery('select `uid`,`account`,`password`,`name`,`email` from ??.?? where `account` = ?', ['lora', 'user', arr.data.account])
|
|
|
|
if (user.length == 0) throw 'user not exists';
|
|
|
|
if (!crypto.comparePass(arr.data.password, user[0].password)) throw 'password not match';
|
|
|
|
delete user[0].password;
|
|
|
|
c.body = {
|
|
record: user
|
|
}
|
|
} catch (err) {
|
|
throw 'DB Query Error';
|
|
}
|
|
|
|
let u = c.body.record[0];
|
|
let token = new mongo.token({ object: u, expire: Date.now() + 86400000 });
|
|
token.save();
|
|
c.body.rt = {
|
|
token: {
|
|
id: token._id
|
|
}
|
|
}
|
|
})
|
|
|
|
module.exports = router; |