Updating server modules

This commit is contained in:
Martin Donnelly 2017-08-18 15:08:28 +01:00
parent 36b32b5c1d
commit f20f9bc8fc
7 changed files with 388 additions and 340 deletions

View File

@ -1,24 +1,45 @@
{ {
"plugins": [
"react"
],
"parserOptions": { "parserOptions": {
"ecmaVersion": 6, "ecmaVersion": 6,
"sourceType": "module", "sourceType": "module",
"ecmaFeatures": { "ecmaFeatures": {
"jsx": true "jsx": false
} }
}, },
"env": { "env": {
"es6": true,
"browser": true, "browser": true,
"node": true, "node": true,
"mocha": true "es6": true
}, },
"extends": [
"eslint:recommended",
"plugin:react/recommended"
],
"rules": { "rules": {
"no-new-object": 1,
"no-reserved-keys": 1,
"no-array-constructor": 1,
"quotes": [1, "single"],
"max-len": [1, 120, 2], // 2 spaces per tab, max 80 chars per line
"no-inner-declarations": [1, "both"],
"no-shadow-restricted-names": 1,
"one-var": 0,
"vars-on-top": 1,
"eqeqeq": 1,
"curly": [1, "multi"],
"no-mixed-spaces-and-tabs": 1,
"space-before-blocks": [1, "always"],
"space-infix-ops": 1,
"eol-last": 1,
"comma-style": [1, "last"],
"no-comma-dangle": 1,
"semi": [1, "always"],
"radix": 1,
"camelcase": 1,
"new-cap": 1,
"consistent-this": [1, "_this"],
"func-names": 1,
"no-multi-spaces": 2,
"brace-style": [2,"1tbs",{}],
"indent": [2,2],
"comma-spacing": ["error", { "before": false, "after": true }]
} }
} }

View File

@ -1,12 +1,16 @@
let http = require('http'); const http = require('http');
let https = require('https'); const https = require('https');
const LimitedArray = require('limitedarray');
const trend = require('trend');
const logger = require('log4js').getLogger('btc');
let btcCache = {}; let btcCache = {};
let balanceCache = {}; let balanceCache = {};
exports.doBTC = function (req, res) { let history = new LimitedArray(288); // one days worth in 5 minute chunks
console.log('Bitcoin request');
function btcQuery (callback, r) { function getBitcoin () {
var req = r; logger.info('>> getting bitcoin');
var options = { function btcQuery (callback) {
const options = {
host: 'api.coindesk.com', host: 'api.coindesk.com',
// port: 80, // port: 80,
path: '/v1/bpi/currentprice.json', path: '/v1/bpi/currentprice.json',
@ -18,111 +22,120 @@ exports.doBTC = function (req, res) {
} }
}; };
try { try {
http.request(options).on('response', function (response) { http.request(options).on('response', response => {
var data = ''; let data = '';
response.on('data', function (chunk) { response.on('data', chunk => {
data += chunk; data += chunk;
}); });
response.on('end', function () { response.on('end', () => {
console.log('>> data', data);
let cData = {}; let cData = {};
try { try {
cData = JSON.parse(data); cData = JSON.parse(data);
} } catch (e) {
catch (e) { logger.error(e);
console.error(e); } finally{
} callback(cData);
finally{
callback(cData, r);
} }
}); });
response.on('error', function (e) { response.on('error', e => {
console.error(e); logger.error(e);
}); });
}).end(); }).end();
} catch (e) { } catch (e) {
console.error(e); logger.error(e);
} }
} }
let now = new Date(); btcQuery(a => {
if (now - GLOBAL.lastcheck > (59000 )) { // logger.info(a);
btcQuery(function (a) { logger.info('Got btc data. Storing it');
// console.log(a);
console.log('Got btc data.');
btcCache = a; btcCache = a;
GLOBAL.lastcheck = now; history.push(a.bpi.USD.rate_float);
res.setHeader('Content-Type', 'application/json'); btcCache.history = history.get();
res.end(JSON.stringify(btcCache)); btcCache.trend = trend(btcCache.history, {avgPoints: 12});
}, res); GLOBAL.lastcheck = new Date();
} else {
console.log('Using cache');
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(btcCache));
}
};
exports.doBalance = function (req, res) { });
console.log('Bitcoin request'); }
function getBalance() {
logger.info('>> getting Balance');
function balanceQuery (callback, r) { function balanceQuery (callback, r) {
var req = r;
// https://blockexplorer.com/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif
var options = {
host: 'blockexplorer.com',
// port: 80,
path: '/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif',
// method: 'GET',
headers: {
/* 'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(data)*/
}
};
try { try {
https.get('https://blockexplorer.com/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif').on('response', function (response) { https.get('https://blockexplorer.com/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif').on('response', response => {
var data = ''; let data = '';
response.on('data', function (chunk) { response.on('data', chunk => {
data += chunk; data += chunk;
}); });
response.on('end', function () { response.on('end', () => {
console.log('>> data', data);
let cData = {}; let cData = {};
try { try {
cData = JSON.parse(data); cData = JSON.parse(data);
} } catch (e) {
catch (e) { logger.error(e);
console.error(e); } finally{
}
finally{
callback(cData, r); callback(cData, r);
} }
}); });
response.on('error', function (e) { response.on('error', e => {
console.error(e); logger.error(e);
}); });
}).end(); }).end();
} catch (e) { } catch (e) {
console.error(e); logger.error(e);
} }
} }
let now = new Date(); balanceQuery(a => {
if (now - GLOBAL.lastcheck > (59000 )) { logger.info('Got balance data. Storing it');
balanceQuery(function (a) {
// console.log(a);
console.log('Got balance data.');
balanceCache = a; balanceCache = a;
GLOBAL.lastcheck = now;
});
}
exports.doBTC = (req, res) => {
logger.info('Bitcoin request');
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(btcCache));
};
exports.doBalance = (req, res) => {
logger.info('Balance request');
res.setHeader('Content-Type', 'application/json'); res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(balanceCache)); res.end(JSON.stringify(balanceCache));
}, res);
} else {
console.log('Using cache');
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(balanceCache));
}
}; };
function updateBitcoin() {
logger.warn('updateBitcoin');
getBitcoin();
const now = new Date();
const mod = 300000 - (now.getTime() % 300000);
let btcupdateFn = () => {
updateBitcoin();
};
setTimeout(btcupdateFn.bind(this), mod + 10);
}
function updateBalance() {
logger.warn('updateBalance');
getBalance();
const now = new Date();
const mod = 3.6e+6 - (now.getTime() % 3.6e+6);
let balanceUpdateFn = () => {
updateBalance();
};
setTimeout(balanceUpdateFn.bind(this), mod + 10);
}
updateBitcoin();
updateBalance();

View File

@ -1,52 +1,65 @@
const http = require('http'); const http = require('http');
const LimitedArray = require('limitedarray');
const trend = require('trend');
const logger = require('log4js').getLogger('fx');
let fxCache = {}; let fxCache = {};
exports.doFx = function (req,res) { let history = new LimitedArray(96); // one days worth in 5 minute chunks
console.log('FX request');
function fxQuery(callback, r) { function getFx() {
let req = r; logger.info('FX request');
function fxQuery(callback) {
let options = { let options = {
host: 'openexchangerates.org', host: 'openexchangerates.org',
// port: 80, // port: 80,
path: '/api/latest.json?app_id=0eb932cee3bc40259f824d4b4c96c7d2', path: '/api/latest.json?app_id=0eb932cee3bc40259f824d4b4c96c7d2',
// method: 'GET', // method: 'GET',
headers: { headers: { }
/* 'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(data)*/
}
}; };
http.request(options).on('response', function (response) { http.request(options).on('response', response => {
let data = ''; let data = '';
response.on("data", function (chunk) { response.on('data', chunk => {
data += chunk; data += chunk;
}); });
response.on('end', function () { response.on('end', () => {
console.log('Data done...'); logger.info('Data done...');
callback(JSON.parse(data), r); callback(JSON.parse(data));
}); });
response.on('error', function(e) { response.on('error', e => {
console.error(e); logger.error(e);
}); });
}).end(); }).end();
} }
let now = new Date(); fxQuery(a => {
if (now - GLOBAL.fxLastCheck > (60000 * 14)) { logger.info('Got FX data. Storing it');
fxQuery(function (a, b) {
console.log(a);
fxCache = a; fxCache = a;
GLOBAL.fxLastCheck = now;
history.push(a.rates.GBP);
fxCache.history = history.get();
fxCache.trend = trend(fxCache.history, {avgPoints: 24});
});
}
function updateFX() {
logger.warn('updateBitcoin');
getFx();
const now = new Date();
const mod = (60000 * 15) - (now.getTime() % (60000 * 15));
let fxUpdateFn = () => {
updateFX();
};
setTimeout(fxUpdateFn.bind(this), mod + 10);
}
updateFX();
exports.doFx = (req, res) => {
logger.info('FX request');
res.setHeader('Content-Type', 'application/json'); res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(fxCache)); res.end(JSON.stringify(fxCache));
}, res);
}
else {
console.log("Using cache");
res.setHeader('Content-Type', 'application/json');
console.log('Cache length:', JSON.stringify(fxCache).length);
console.log(JSON.stringify(fxCache).substring(0,50));
res.end(JSON.stringify(fxCache));
}
}; };

File diff suppressed because one or more lines are too long

View File

@ -1,6 +1,6 @@
// train.js // train.js
const http = require('http'); const http = require('http');
const logger = require('log4js').getLogger(); const logger = require('log4js').getLogger('train');
let trainCache = { let trainCache = {
last: {}, last: {},
data: {} data: {}
@ -14,7 +14,7 @@ module.exports = {
const now = new Date(); const now = new Date();
const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60); const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60);
if (trainCache.last.dbeglq === null || nowSeconds !== trainCache.last.dbeglq) { if (trainCache.last.dbeglq === null || nowSeconds !== trainCache.last.dbeglq)
Query(function (a, b) { Query(function (a, b) {
const ts = a.departures[0].service; const ts = a.departures[0].service;
@ -30,7 +30,7 @@ module.exports = {
res.end(JSON.stringify(trainCache.data.dbeglq)); res.end(JSON.stringify(trainCache.data.dbeglq));
}, res, 'huxley.apphb.com', '/next/dbe/to/glq/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8'); }, res, 'huxley.apphb.com', '/next/dbe/to/glq/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
}
}, },
glq_dbe: function (req, res) { glq_dbe: function (req, res) {
@ -39,7 +39,7 @@ module.exports = {
const now = new Date(); const now = new Date();
const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60); const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60);
if (trainCache.last.glqdbe === null || nowSeconds !== trainCache.last.dbeglq) { if (trainCache.last.glqdbe === null || nowSeconds !== trainCache.last.dbeglq)
Query(function (a, b) { Query(function (a, b) {
const ts = a.departures[0].service; const ts = a.departures[0].service;
@ -58,7 +58,7 @@ module.exports = {
res.end(JSON.stringify(trainCache.data.glqdbe)); res.end(JSON.stringify(trainCache.data.glqdbe));
}, res, 'huxley.apphb.com', '/next/glq/to/dbe/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8'); }, res, 'huxley.apphb.com', '/next/glq/to/dbe/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
}
}, },
getTrainTimes: function (req, res) { getTrainTimes: function (req, res) {
// console.log(req); // console.log(req);
@ -71,8 +71,7 @@ module.exports = {
res.setHeader('Content-Type', 'application/json'); res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(a)); res.end(JSON.stringify(a));
}, res, 'huxley.apphb.com', url); }, res, 'huxley.apphb.com', url);
} } else {
else {
res.setHeader('Content-Type', 'application/json'); res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify({})); res.end(JSON.stringify({}));
} }
@ -86,17 +85,16 @@ module.exports = {
trainTo = req.query.to; trainTo = req.query.to;
trainToken = trainFrom + trainTo; trainToken = trainFrom + trainTo;
url = '/next/' + trainFrom + '/to/' + trainTo + '/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8'; url = '/next/' + trainFrom + '/to/' + trainTo + '/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8';
console.log('Requesting latest time for : ' + trainToken); logger.info('Requesting latest time for : ' + trainToken);
const now = new Date(); const now = new Date();
const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60); const nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60);
console.log('Now Seconds: ' + nowSeconds); logger.info('Now Seconds: ' + nowSeconds);
if (trainCache.last[trainToken] === null || nowSeconds !== trainCache.last[trainToken]) { if (trainCache.last[trainToken] === null || nowSeconds !== trainCache.last[trainToken])
Query(function (a, b) { Query(function (a, b) {
const output = {}; const output = {};
logger.log('a', a);
const ts = a.departures[0].service; const ts = a.departures[0].service;
if (ts !== null) { if (ts !== null) {
// console.log(ts); // console.log(ts);
@ -122,7 +120,6 @@ module.exports = {
}, res, 'huxley.apphb.com', url); }, res, 'huxley.apphb.com', url);
} }
}
}, getRoute: function (req, res) { }, getRoute: function (req, res) {
logger.info('getRoute: ' + JSON.stringify(req.query)); logger.info('getRoute: ' + JSON.stringify(req.query));
@ -133,9 +130,9 @@ module.exports = {
routeID = req.query.route; routeID = req.query.route;
Query(function (a, b) { Query(function (a, b) {
if (a !== null && a.message === null) { if (a !== null && a.message === null)
data = a; data = a;
}
res.setHeader('Content-Type', 'application/json'); res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(data)); res.end(JSON.stringify(data));
}, res, 'huxley.apphb.com', '/service/' + routeID + '?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8'); }, res, 'huxley.apphb.com', '/service/' + routeID + '?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
@ -169,7 +166,7 @@ function Query(callback, r, host, path) {
try { try {
http.request(options).on('response', function (response) { http.request(options).on('response', function (response) {
let data = ''; let data = '';
response.on("data", function (chunk) { response.on('data', function (chunk) {
data += chunk; data += chunk;
}); });
response.on('end', function () { response.on('end', function () {

View File

@ -65,6 +65,7 @@
"ftse": "^1.0.6", "ftse": "^1.0.6",
"gulp": "^3.9.1", "gulp": "^3.9.1",
"ical2json": "^0.2.0", "ical2json": "^0.2.0",
"limitedarray": "git+https://gitlab.silvrtree.co.uk/martind2000/limitedArray.git",
"logger": "0.0.1", "logger": "0.0.1",
"method-override": "^2.3.5", "method-override": "^2.3.5",
"morgan": "^1.7.0", "morgan": "^1.7.0",
@ -74,6 +75,7 @@
"scrape": "^0.2.3", "scrape": "^0.2.3",
"string": "^3.3.1", "string": "^3.3.1",
"sugar-date": "^1.5.1", "sugar-date": "^1.5.1",
"trend": "^0.3.0",
"ultrases": "^0.1.3", "ultrases": "^0.1.3",
"unstyler": "^0.2.2", "unstyler": "^0.2.2",
"ws": "^1.1.1" "ws": "^1.1.1"

View File

@ -8,7 +8,7 @@ const train = require('./lib/train');
const password = require('./lib/password'); const password = require('./lib/password');
const clean = require('./lib/clean'); const clean = require('./lib/clean');
const events = require('./lib/events'); const events = require('./lib/events');
const today = require('./lib/today'); // const today = require('./lib/today');
const morgan = require('morgan'); const morgan = require('morgan');
const cookieParser = require('cookie-parser'); const cookieParser = require('cookie-parser');
const session = require('express-session'); const session = require('express-session');
@ -22,7 +22,7 @@ const jsonfile = require('jsonfile');
const Events = require('events'); const Events = require('events');
let busEmitter = new Events.EventEmitter(); let busEmitter = new Events.EventEmitter();
busEmitter.on('update', today.broadcast); //busEmitter.on('update', today.broadcast);
const WebSocketServer = require('ws').Server; const WebSocketServer = require('ws').Server;
const wss = new WebSocketServer({server: server}); const wss = new WebSocketServer({server: server});
@ -31,7 +31,7 @@ const SocketHandler = require('./lib/wshandlerv2');
let webSocket = new SocketHandler(busEmitter, wss); let webSocket = new SocketHandler(busEmitter, wss);
today.setEmitter(busEmitter); //today.setEmitter(busEmitter);
// train = require('lib/train') // train = require('lib/train')
/* ,submit = require('./routes/mongo/submit') */ /* ,submit = require('./routes/mongo/submit') */
@ -43,7 +43,7 @@ const Fitbit = require('fitbit-oauth2');
const polys = require('./lib/poly.js'); const polys = require('./lib/poly.js');
const logger = require('log4js').getLogger(); const logger = require('log4js').getLogger('web-server');
const app = express(); const app = express();
GLOBAL.lastcheck = 0; GLOBAL.lastcheck = 0;
GLOBAL.fxLastCheck = 0; GLOBAL.fxLastCheck = 0;
@ -99,10 +99,10 @@ app.use('/cleanit', clean.cleanit);
app.use('/events', events.getEvents); app.use('/events', events.getEvents);
app.get('/cinema/:id', events.getCinema); app.get('/cinema/:id', events.getCinema);
app.get('/today', today.getToday); // app.get('/today', today.getToday);
app.get('/today/data', today.getData); // app.get('/today/data', today.getData);
app.route('/clock').get(today.getClock); //app.route('/clock').get(today.getClock);
app.route('/poly').get(polys); app.route('/poly').get(polys);
@ -160,7 +160,7 @@ app.get('/fitbit', function(req, res) {
app.get( '/fb-profile', function( req, res, next ) { app.get( '/fb-profile', function( req, res, next ) {
fitbit.request({ fitbit.request({
uri: "https://api.fitbit.com/1/user/-/profile.json", uri: 'https://api.fitbit.com/1/user/-/profile.json',
method: 'GET', method: 'GET',
}, function( err, body, token ) { }, function( err, body, token ) {
if ( err ) return next( err ); if ( err ) return next( err );
@ -204,15 +204,15 @@ app.get( '/fb-today', function( req, res, next ) {
app.get('/fitbit_auth_callback', function(req, res, next) { app.get('/fitbit_auth_callback', function(req, res, next) {
const code = req.query.code; const code = req.query.code;
fitbit.fetchToken(code, function(err, token) { fitbit.fetchToken(code, function(err, token) {
if (err) { if (err)
return next(err); return next(err);
}
// persist the token // persist the token
jsonfile.writeFile(tfile, token, function(err) { jsonfile.writeFile(tfile, token, function(err) {
if (err) { if (err)
return next(err); return next(err);
}
console.log('!!!! Fitbit token saved'); console.log('!!!! Fitbit token saved');
res.redirect('/fb-profile'); res.redirect('/fb-profile');
@ -222,11 +222,11 @@ app.get('/fitbit_auth_callback', function(req, res, next) {
jsonfile.readFile('./fb-token.json', function(err, obj) { jsonfile.readFile('./fb-token.json', function(err, obj) {
if (err) { if (err)
logger.error(err); logger.error(err);
} else { else
fitbit.setToken(obj); fitbit.setToken(obj);
}
}); });
@ -245,5 +245,7 @@ http.createServer(app).listen(app.get('port'), function () {
server.on('request', app); server.on('request', app);
server.listen(port, () => { logger.info('New server listening on ' + server.address().port); }); server.listen(port, () => {
logger.info('New server listening on ' + server.address().port);
});