34 lines
1.1 KiB
JavaScript
34 lines
1.1 KiB
JavaScript
// Finds PIS Codes using DB Lookups
|
|
|
|
const db = require('../services/dbAccess.services');
|
|
const log = require('../utils/log.utils');
|
|
const clean = require('../utils/sanitizer.utils');
|
|
|
|
async function findPisByOrigDest(start,end) {
|
|
log.out(`pisServices.findPisByOrigDest: Searching for PIS for Orig: ${start}, Dest: ${end}`, 'dbug');
|
|
const firstCrs = clean.cleanApiEndpointTxt(start.toLowerCase());
|
|
const lastCrs = clean.cleanApiEndpointTxt(end.toLowerCase());
|
|
const query = {
|
|
stops: {
|
|
$all: [
|
|
{ $elemMatch: { $eq: firstCrs } },
|
|
{ $elemMatch: { $eq: lastCrs } }
|
|
]
|
|
},
|
|
$expr: {
|
|
$and: [
|
|
{ $eq: [{ $arrayElemAt: [ '$stops', -1 ] }, lastCrs] },
|
|
{ $eq: [{ $arrayElemAt: [ '$stops', 0 ] }, firstCrs] }
|
|
]
|
|
}
|
|
};
|
|
//const oldQuery = {$and:[{$expr:{$eq:[{$first:"$stops"},firstCrs]}},{$expr:{$eq:[{$last:"$stops"},lastCrs]}}]}
|
|
const search = db.query('pis', query);
|
|
return search;
|
|
}
|
|
|
|
// Hopefully at some point, I will also be able to implement a find PIS code by headcode option.
|
|
|
|
module.exports = {
|
|
findPisByOrigDest
|
|
}; |