2018-03-13 13:46:26 +00:00
|
|
|
const request = require('request');
|
2018-05-22 14:38:49 +00:00
|
|
|
const FeedMe = require('feedme');
|
|
|
|
const http = require('http');
|
2018-03-13 13:46:26 +00:00
|
|
|
|
|
|
|
const logger = require('log4js').getLogger('Directions');
|
|
|
|
logger.level = 'debug';
|
|
|
|
|
2018-05-22 16:10:38 +00:00
|
|
|
const { reduceEstDirections, reduceIncidents, combine } = require('./reducers/directions');
|
2018-03-13 13:46:26 +00:00
|
|
|
|
|
|
|
module.exports = {
|
2018-05-22 14:38:49 +00:00
|
|
|
'getTraffic': doGetEstDirections,
|
2018-05-22 15:16:23 +00:00
|
|
|
'getIncidents' : doGetTraffic,
|
|
|
|
doGetEstDirectionsWithIncidents
|
2018-03-13 13:46:26 +00:00
|
|
|
};
|
|
|
|
|
2018-05-22 14:38:49 +00:00
|
|
|
const headers = {};
|
|
|
|
const lastGood = {};
|
|
|
|
|
2018-03-13 13:46:26 +00:00
|
|
|
//
|
|
|
|
// https://maps.googleapis.com/maps/api/directions/json?origin=Toronto&destination=Montreal&key=AIzaSyBl7O9LHIthCagcqIaDkQ4um_hghYG5reE
|
|
|
|
|
2018-05-22 15:16:23 +00:00
|
|
|
async function doGetEstDirectionsWithIncidents(olat, olon, dlat, dlon) {
|
|
|
|
let traff = await doGetEstDirections(olat, olon, dlat, dlon);
|
|
|
|
let incid = await doGetTraffic();
|
|
|
|
|
|
|
|
logger.debug('after...');
|
2018-05-22 16:10:38 +00:00
|
|
|
|
|
|
|
let combined = combine(traff, incid);
|
|
|
|
return combined;
|
2018-05-22 15:16:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
async function doGetEstDirections(olat, olon, dlat, dlon) {
|
2018-03-13 13:46:26 +00:00
|
|
|
logger.debug('doGetEstDirections');
|
2018-10-11 15:50:58 +00:00
|
|
|
const url = `https://sgws2.maps.yahoo.com/Directions?time=now&cache=n&flags=J&olat=${olat}&olon=${olon}&dlat=${dlat}&dlon=${dlon}&mode=11`;
|
2018-03-13 13:46:26 +00:00
|
|
|
|
|
|
|
logger.debug(url);
|
2018-05-22 14:38:49 +00:00
|
|
|
|
2018-03-13 13:46:26 +00:00
|
|
|
return new Promise(function(resolve, reject) {
|
|
|
|
request(url, function(err, resp, body) {
|
|
|
|
if (err)
|
|
|
|
// Logger.error(err);
|
|
|
|
return reject(err);
|
|
|
|
// Throw err;
|
|
|
|
|
|
|
|
const output = reduceEstDirections(body);
|
2018-03-25 20:43:44 +00:00
|
|
|
output.fullBody = JSON.parse(body);
|
2018-03-13 21:56:17 +00:00
|
|
|
output.timestamp = new Date().getTime();
|
2018-03-13 13:46:26 +00:00
|
|
|
|
|
|
|
console.log(output);
|
2018-05-22 14:38:49 +00:00
|
|
|
|
2018-03-13 13:46:26 +00:00
|
|
|
return resolve(output);
|
|
|
|
}, function(error, response, body) {
|
|
|
|
console.log(response);
|
|
|
|
if (response.statusCode !== 200) {
|
|
|
|
logger.error(response.statusCode);
|
|
|
|
logger.error(body);
|
|
|
|
|
|
|
|
return reject(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2018-05-22 14:38:49 +00:00
|
|
|
|
2018-05-22 15:16:23 +00:00
|
|
|
async function doGetTraffic() {
|
2018-05-22 14:38:49 +00:00
|
|
|
logger.debug('doGetTraffic');
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
// https://trafficscotland.org/rss/feeds/currentincidents.aspx
|
|
|
|
const options = {
|
|
|
|
'hostname': 'trafficscotland.org',
|
|
|
|
'path': '/rss/feeds/currentincidents.aspx',
|
|
|
|
'method': 'GET',
|
|
|
|
'headers': headers
|
|
|
|
};
|
|
|
|
|
|
|
|
http.get(options, (res) => {
|
|
|
|
const { statusCode } = res;
|
|
|
|
const contentType = res.headers['content-type'];
|
|
|
|
const reqLastModified = res.headers['date'];
|
|
|
|
|
|
|
|
logger.debug(res.headers);
|
|
|
|
let error;
|
|
|
|
|
|
|
|
logger.debug('contentType', contentType);
|
|
|
|
if (statusCode !== 200 && statusCode !== 304)
|
|
|
|
error = new Error('Request Failed.\n' +
|
|
|
|
`Status Code: ${statusCode}`);
|
|
|
|
|
|
|
|
else if (!/^application\/rss\+xml/.test(contentType) && statusCode === 200)
|
|
|
|
error = new Error('Invalid content-type.\n' +
|
|
|
|
`Expected application/rss+xml but received ${contentType}`);
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
logger.error(error.message);
|
|
|
|
// consume response data to free up memory
|
|
|
|
res.resume();
|
|
|
|
|
|
|
|
return reject(error);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( statusCode === 200) {
|
|
|
|
headers['If-Modified-Since'] = reqLastModified;
|
|
|
|
const parser = new FeedMe(true);
|
|
|
|
res.pipe(parser);
|
|
|
|
parser.on('end', () => {
|
|
|
|
lastGood.page = reduceIncidents(parser.done());
|
|
|
|
logger.info('Traffic Feed cached');
|
|
|
|
// return resolve(parser.done());
|
|
|
|
return resolve(lastGood.page);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else if (statusCode === 304) {
|
|
|
|
logger.info('Traffic Feed changed');
|
|
|
|
|
|
|
|
return resolve(lastGood.page);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|