Added road incidents, just need to update backbone object to deal with them

This commit is contained in:
martin 2018-05-22 15:38:49 +01:00
parent a70d76127a
commit d5d129b58a
7 changed files with 2302 additions and 2181 deletions

4348
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -22,6 +22,14 @@ const cache = apicache.middleware;
app.use(express.static(path.join(__dirname, sitePath)));
// app.get('/weather', cache('15 minutes'), (req, res) => {
const asyncMiddleware = fn =>
(req, res, next) => {
Promise.resolve(fn(req, res, next))
.catch(next);
};
app.get('/weather', (req, res) => {
if (req.query.hasOwnProperty('ll'))
@ -196,6 +204,20 @@ app.get('/traffic', cache('5 minutes'), (req, res) => {
res.status(500).send('oLat Missing');
}
});
app.get('/incidents', cache('5 minutes'), (req, res) => {
logger.debug(req.query);
directions.getIncidents()
.then((d) => {
logger.debug(d);
res.send(d);
}).catch((e) => {
logger.error(e);
res.status(500).send('directions.getIncidents: There was an error!');
});
});
app.listen(port, (err) => {
if (err)
return logger.error('Server error:', err);

View File

@ -1,14 +1,20 @@
const request = require('request');
const FeedMe = require('feedme');
const http = require('http');
const logger = require('log4js').getLogger('Directions');
logger.level = 'debug';
const { reduceEstDirections } = require('./reducers/directions');
const { reduceEstDirections, reduceIncidents } = require('./reducers/directions');
module.exports = {
'getTraffic': doGetEstDirections
'getTraffic': doGetEstDirections,
'getIncidents' : doGetTraffic
};
const headers = {};
const lastGood = {};
//
// https://maps.googleapis.com/maps/api/directions/json?origin=Toronto&destination=Montreal&key=AIzaSyBl7O9LHIthCagcqIaDkQ4um_hghYG5reE
@ -17,6 +23,7 @@ function doGetEstDirections(olat, olon, dlat, dlon) {
const url = `https://sgws2.maps.yahoo.com/Directions?time=now&cache=n&flags=J&olat=${olat}&olon=${olon}&dlat=${dlat}&dlon=${dlon}`;
logger.debug(url);
return new Promise(function(resolve, reject) {
request(url, function(err, resp, body) {
if (err)
@ -29,6 +36,7 @@ function doGetEstDirections(olat, olon, dlat, dlon) {
output.timestamp = new Date().getTime();
console.log(output);
return resolve(output);
}, function(error, response, body) {
console.log(response);
@ -41,3 +49,61 @@ function doGetEstDirections(olat, olon, dlat, dlon) {
});
});
}
function doGetTraffic() {
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);
}
});
});
}

View File

@ -1,6 +1,6 @@
const logger = require('log4js').getLogger('Directions 🔧');
const { get, isEmpty, has } = require('lodash');
const { get, isEmpty, has, uniq } = require('lodash');
const humanizeDuration = require('humanize-duration');
logger.level = 'debug';
@ -13,9 +13,11 @@ function reduceEstDirections(body = '') {
const jBody = JSON.parse(body);
const obj = {};
const { ResultSet } = jBody;
const streets = [];
if (has(ResultSet, 'Result')) {
const directions = get(ResultSet, 'Result.yahoo_driving_directions');
const route = get(directions, 'directions.route_leg');
obj.totalTime = parseFloat(get(directions, 'total_time'));
obj.totalTimeWithTraffic = parseFloat(get(directions, 'total_time_with_traffic'));
@ -39,9 +41,37 @@ function reduceEstDirections(body = '') {
obj.traffic = 'no traffic';
obj.className = 'trafficNone';
}
for (const item of route) {
const street = item.street.split(',');
if (street[0] !== '') streets.push(street[0]);
}
obj.streets = uniq(streets);
}
return obj;
}
module.exports = { reduceEstDirections };
function reduceIncidents(body = '') {
if (body === '') return [];
let workObj = Object.assign({}, body);
let incidents = [];
const items = get(workObj, 'items');
for (let item of items) {
let title = item.title.split(' ');
incidents.push({
title : item.title,
description: item.description,
road : title[0]
})
}
return incidents;
}
module.exports = { reduceEstDirections, reduceIncidents };

View File

@ -11,7 +11,7 @@
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
const CACHE_VERSION = { 'version': '0.0.704' };
const CACHE_VERSION = { 'version': '0.0.707' };
const dataCacheName = 'jubileeData-v1';
const cacheName = 'jubilee-final-1';
const filesToCache = [

View File

@ -30,6 +30,8 @@ const TrafficModel = Backbone.Model.extend({
if (day !== 0 && day !== 6)
doRequest = (((hour >= 7) && (hour <= 9)) || ((hour >= 17) && (hour <= 19)));
doRequest = true;
const delay = doRequest ? 600000 : toHour();
if (this.has('latlong') && doRequest) {
@ -51,6 +53,7 @@ const TrafficModel = Backbone.Model.extend({
'getTraffic': function() {
console.log('Get Traffic');
// olat, olon, dlat, dlon
const override = true;
const time = new Date().getTime() ;
const hour = (new Date()).getHours();
const latlong = this.get('latlong');
@ -70,7 +73,7 @@ const TrafficModel = Backbone.Model.extend({
'olat': latlong.lat, 'olon': latlong.lon, 'dlat': 55.872407, 'dlon': -3.549003
};
}
else if ((hour >= 17) && (hour <= 19)) {
else if (((hour >= 17) && (hour <= 19)) || override) {
mode = 1;
this.set('dest', 'Home');
qs = {

View File

@ -21,7 +21,7 @@ const { NearbyListModel, NearbyListView } = require('./NearbyList');
const { NearbyPlacesView } = require('./NearbyPlaces');
var app = app || {};
const live = true;
const live = false;
if (live) {
window.loc = 'https://jubilee.silvrtree.co.uk';