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": {
"ecmaVersion": 6,
"sourceType": "module",
"ecmaFeatures": {
"jsx": true
"jsx": false
}
},
"env": {
"es6": true,
"browser": true,
"node": true,
"mocha": true
"es6": true
},
"extends": [
"eslint:recommended",
"plugin:react/recommended"
],
"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');
let https = require('https');
const http = require('http');
const https = require('https');
const LimitedArray = require('limitedarray');
const trend = require('trend');
const logger = require('log4js').getLogger('btc');
let btcCache = {};
let balanceCache = {};
exports.doBTC = function (req, res) {
console.log('Bitcoin request');
function btcQuery (callback, r) {
var req = r;
var options = {
let history = new LimitedArray(288); // one days worth in 5 minute chunks
function getBitcoin () {
logger.info('>> getting bitcoin');
function btcQuery (callback) {
const options = {
host: 'api.coindesk.com',
// port: 80,
path: '/v1/bpi/currentprice.json',
@ -18,111 +22,120 @@ exports.doBTC = function (req, res) {
}
};
try {
http.request(options).on('response', function (response) {
var data = '';
response.on('data', function (chunk) {
http.request(options).on('response', response => {
let data = '';
response.on('data', chunk => {
data += chunk;
});
response.on('end', function () {
console.log('>> data', data);
response.on('end', () => {
let cData = {};
try {
cData = JSON.parse(data);
}
catch (e) {
console.error(e);
}
finally{
callback(cData, r);
} catch (e) {
logger.error(e);
} finally{
callback(cData);
}
});
response.on('error', function (e) {
console.error(e);
response.on('error', e => {
logger.error(e);
});
}).end();
} catch (e) {
console.error(e);
logger.error(e);
}
}
let now = new Date();
if (now - GLOBAL.lastcheck > (59000 )) {
btcQuery(function (a) {
// console.log(a);
console.log('Got btc data.');
btcQuery(a => {
// logger.info(a);
logger.info('Got btc data. Storing it');
btcCache = a;
GLOBAL.lastcheck = now;
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(btcCache));
}, res);
} else {
console.log('Using cache');
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(btcCache));
}
};
history.push(a.bpi.USD.rate_float);
btcCache.history = history.get();
btcCache.trend = trend(btcCache.history, {avgPoints: 12});
GLOBAL.lastcheck = new Date();
exports.doBalance = function (req, res) {
console.log('Bitcoin request');
});
}
function getBalance() {
logger.info('>> getting Balance');
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 {
https.get('https://blockexplorer.com/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif').on('response', function (response) {
var data = '';
response.on('data', function (chunk) {
https.get('https://blockexplorer.com/api/addr/18sLVW5Aswp2KWLr4hMFZsuSPtvAauFiif').on('response', response => {
let data = '';
response.on('data', chunk => {
data += chunk;
});
response.on('end', function () {
console.log('>> data', data);
response.on('end', () => {
let cData = {};
try {
cData = JSON.parse(data);
}
catch (e) {
console.error(e);
}
finally{
} catch (e) {
logger.error(e);
} finally{
callback(cData, r);
}
});
response.on('error', function (e) {
console.error(e);
response.on('error', e => {
logger.error(e);
});
}).end();
} catch (e) {
console.error(e);
logger.error(e);
}
}
let now = new Date();
if (now - GLOBAL.lastcheck > (59000 )) {
balanceQuery(function (a) {
// console.log(a);
console.log('Got balance data.');
balanceQuery(a => {
logger.info('Got balance data. Storing it');
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.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 LimitedArray = require('limitedarray');
const trend = require('trend');
const logger = require('log4js').getLogger('fx');
let fxCache = {};
exports.doFx = function (req,res) {
console.log('FX request');
function fxQuery(callback, r) {
let req = r;
let history = new LimitedArray(96); // one days worth in 5 minute chunks
function getFx() {
logger.info('FX request');
function fxQuery(callback) {
let options = {
host: 'openexchangerates.org',
// port: 80,
path: '/api/latest.json?app_id=0eb932cee3bc40259f824d4b4c96c7d2',
// method: 'GET',
headers: {
/* 'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(data)*/
}
headers: { }
};
http.request(options).on('response', function (response) {
http.request(options).on('response', response => {
let data = '';
response.on("data", function (chunk) {
response.on('data', chunk => {
data += chunk;
});
response.on('end', function () {
console.log('Data done...');
callback(JSON.parse(data), r);
response.on('end', () => {
logger.info('Data done...');
callback(JSON.parse(data));
});
response.on('error', function(e) {
console.error(e);
response.on('error', e => {
logger.error(e);
});
}).end();
}
let now = new Date();
if (now - GLOBAL.fxLastCheck > (60000 * 14)) {
fxQuery(function (a, b) {
console.log(a);
fxQuery(a => {
logger.info('Got FX data. Storing it');
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.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
const http = require('http');
const logger = require('log4js').getLogger();
const logger = require('log4js').getLogger('train');
let trainCache = {
last: {},
data: {}
@ -14,7 +14,7 @@ module.exports = {
const now = new Date();
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) {
const ts = a.departures[0].service;
@ -30,7 +30,7 @@ module.exports = {
res.end(JSON.stringify(trainCache.data.dbeglq));
}, res, 'huxley.apphb.com', '/next/dbe/to/glq/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
}
},
glq_dbe: function (req, res) {
@ -39,7 +39,7 @@ module.exports = {
const now = new Date();
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) {
const ts = a.departures[0].service;
@ -58,7 +58,7 @@ module.exports = {
res.end(JSON.stringify(trainCache.data.glqdbe));
}, res, 'huxley.apphb.com', '/next/glq/to/dbe/1?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
}
},
getTrainTimes: function (req, res) {
// console.log(req);
@ -71,8 +71,7 @@ module.exports = {
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(a));
}, res, 'huxley.apphb.com', url);
}
else {
} else {
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify({}));
}
@ -86,17 +85,16 @@ module.exports = {
trainTo = req.query.to;
trainToken = trainFrom + trainTo;
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 nowSeconds = (now.getHours() * (60 * 60)) + (now.getMinutes() * 60);
console.log('Now Seconds: ' + nowSeconds);
if (trainCache.last[trainToken] === null || nowSeconds !== trainCache.last[trainToken]) {
logger.info('Now Seconds: ' + nowSeconds);
if (trainCache.last[trainToken] === null || nowSeconds !== trainCache.last[trainToken])
Query(function (a, b) {
const output = {};
logger.log('a', a);
const ts = a.departures[0].service;
if (ts !== null) {
// console.log(ts);
@ -122,7 +120,6 @@ module.exports = {
}, res, 'huxley.apphb.com', url);
}
}
}, getRoute: function (req, res) {
logger.info('getRoute: ' + JSON.stringify(req.query));
@ -133,9 +130,9 @@ module.exports = {
routeID = req.query.route;
Query(function (a, b) {
if (a !== null && a.message === null) {
if (a !== null && a.message === null)
data = a;
}
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(data));
}, res, 'huxley.apphb.com', '/service/' + routeID + '?accessToken=215b99fe-b237-4a01-aadc-cf315d6756d8');
@ -169,7 +166,7 @@ function Query(callback, r, host, path) {
try {
http.request(options).on('response', function (response) {
let data = '';
response.on("data", function (chunk) {
response.on('data', function (chunk) {
data += chunk;
});
response.on('end', function () {

View File

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

View File

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