53 lines
1.3 KiB
JavaScript
53 lines
1.3 KiB
JavaScript
const express = require('express');
|
|
const router = express.Router();
|
|
const AvtocodProvider = require('../data_providers/avtocod');
|
|
|
|
const makeError = error => ({ success: false, error });
|
|
|
|
router.post('/check', async (req, res) => {
|
|
const { number } = req.body;
|
|
const { login } = req.user;
|
|
|
|
number = number.replace(/ /g, '').toUpperCase();
|
|
|
|
let collection = req.db.collection('vehicles');
|
|
let vehicles = await collection.find({ number }).toArray();
|
|
if(vehicles.length > 0) {
|
|
res.send({ success: true, data: vehicles[0] });
|
|
} else {
|
|
try {
|
|
let vehicle = await AvtocodProvider.getReport(number);
|
|
vehicle.addedBy = login;
|
|
await collection.insertOne(vehicle);
|
|
res.status(201).send({ success: true, data: vehicle });
|
|
} catch(ex) {
|
|
res.send(makeError(ex.message));
|
|
console.error(ex);
|
|
}
|
|
}
|
|
});
|
|
|
|
router.get('/', async (req, res) => {
|
|
const { limit, query } = req.query;
|
|
|
|
console.log('limit:', limit);
|
|
console.log('query:', query);
|
|
|
|
let findQuery = {};
|
|
|
|
if(query) {
|
|
findQuery.number = RegExp(query);
|
|
}
|
|
|
|
try {
|
|
let collection = req.db.collection('vehicles');
|
|
let vehicles = await collection.find(findQuery).sort({ addedDate: -1 }).limit(parseInt(limit)).toArray();
|
|
res.send({ success: true, data: vehicles });
|
|
} catch(ex) {
|
|
res.send(makeError('Error reading vehicles from DB'));
|
|
console.error(ex);
|
|
}
|
|
});
|
|
|
|
module.exports = router;
|