2017-03-22 15:48:36 +00:00
|
|
|
const express = require('express');
|
|
|
|
const path = require('path');
|
|
|
|
const server = require('http').createServer();
|
|
|
|
|
|
|
|
const fx = require('./lib/fx');
|
|
|
|
const btc = require('./lib/btc');
|
|
|
|
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 morgan = require('morgan');
|
|
|
|
const cookieParser = require('cookie-parser');
|
|
|
|
const session = require('express-session');
|
|
|
|
|
|
|
|
const methodoverride = require('method-override');
|
|
|
|
const bodyparser = require('body-parser');
|
|
|
|
const errorhandler = require('errorhandler');
|
|
|
|
|
|
|
|
const jsonfile = require('jsonfile');
|
|
|
|
|
|
|
|
const Events = require('events');
|
|
|
|
let busEmitter = new Events.EventEmitter();
|
2016-10-05 14:09:12 +00:00
|
|
|
|
|
|
|
busEmitter.on('update', today.broadcast);
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const WebSocketServer = require('ws').Server;
|
|
|
|
const wss = new WebSocketServer({server: server});
|
2016-10-05 14:09:12 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const SocketHandler = require('./lib/wshandlerv2');
|
2016-10-05 14:09:12 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
let webSocket = new SocketHandler(busEmitter, wss);
|
2016-10-05 14:09:12 +00:00
|
|
|
|
|
|
|
today.setEmitter(busEmitter);
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
// train = require('lib/train')
|
2016-03-08 21:52:21 +00:00
|
|
|
/* ,submit = require('./routes/mongo/submit') */
|
2017-04-18 09:06:39 +00:00
|
|
|
|
2016-03-10 20:15:35 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
let fs = require('fs');
|
|
|
|
const config = require('./config/config.json');
|
|
|
|
const Fitbit = require('fitbit-oauth2');
|
2016-04-11 13:46:07 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const polys = require('./lib/poly.js');
|
2016-04-01 09:39:53 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const logger = require('log4js').getLogger();
|
|
|
|
const app = express();
|
2016-03-08 21:52:21 +00:00
|
|
|
GLOBAL.lastcheck = 0;
|
2017-04-02 22:42:24 +00:00
|
|
|
GLOBAL.fxLastCheck = 0;
|
2017-03-22 15:48:36 +00:00
|
|
|
let btcCache = {}, fxCache = {}, trainCache = {};
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const port = process.env.PORT || 9000;
|
2016-10-05 14:09:12 +00:00
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
// app.configure(function () {
|
|
|
|
app.set('port', port);
|
|
|
|
app.set('view engine', 'ejs');
|
|
|
|
app.use(morgan('dev'));
|
|
|
|
app.use(cookieParser('your secret here'));
|
2016-03-08 21:52:21 +00:00
|
|
|
app.use(session({
|
2017-03-22 15:48:36 +00:00
|
|
|
secret: 'd2jRT6ZpYFsXsF3kGS21ZszKbPAaEa', resave: false,
|
|
|
|
saveUninitialized: false
|
2016-03-08 21:52:21 +00:00
|
|
|
}));
|
|
|
|
/* 'default', 'short', 'tiny', 'dev' */
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use(methodoverride());
|
2016-03-08 21:52:21 +00:00
|
|
|
|
|
|
|
app.use(bodyparser.urlencoded({extended: false}));
|
|
|
|
|
|
|
|
// parse application/json
|
|
|
|
app.use(bodyparser.json());
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use(function(req, res, next) {
|
|
|
|
res.header('Access-Control-Allow-Origin', '*');
|
|
|
|
res.header('Access-Control-Allow-Headers', 'X-Requested-With');
|
|
|
|
next();
|
|
|
|
});
|
2016-03-08 21:52:21 +00:00
|
|
|
// app.use(app.router);
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use(express.static(path.join(__dirname, 'app')));
|
2016-03-08 21:52:21 +00:00
|
|
|
|
|
|
|
app.use(errorhandler({dumpExceptions: true, showStack: true}));
|
|
|
|
|
|
|
|
app.use('/btc', btc.doBTC);
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use('/fx', fx.doFx);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use('/dbeglq', train.dbe_glq);
|
|
|
|
app.use('/glqdbe', train.glq_dbe);
|
|
|
|
app.use('/gettrains', train.getTrainTimes);
|
|
|
|
app.use('/getnexttraintimes', train.getNextTrainTimes);
|
|
|
|
app.use('/getroute', train.getRoute);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use('/generate', password.generate);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use('/cleanit', clean.cleanit);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.use('/events', events.getEvents);
|
|
|
|
app.get('/cinema/:id', events.getCinema);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.get('/today', today.getToday);
|
|
|
|
app.get('/today/data', today.getData);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
app.route('/clock').get(today.getClock);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2016-04-01 09:39:53 +00:00
|
|
|
app.route('/poly').get(polys);
|
|
|
|
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
/*app.use('/lot', function(req, res) {
|
|
|
|
const pg = require('pg');
|
|
|
|
|
|
|
|
const conString = 'postgres://pguser:1V3D4m526i@localhost/silver';
|
|
|
|
console.log(conString);
|
2016-03-08 21:52:21 +00:00
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const client = new pg.Client(conString);
|
|
|
|
const q = 'select * from lot order by d desc';
|
|
|
|
client.connect(function(err) {
|
|
|
|
if (err) {
|
|
|
|
return console.error('could not connect to postgres', err);
|
|
|
|
}
|
|
|
|
client.query(q, function(err, result) {
|
|
|
|
if (err) {
|
|
|
|
return console.error('error running query', err);
|
|
|
|
}
|
|
|
|
console.log(result.rows[0].theTime);
|
|
|
|
// output: Tue Jan 15 2013 19:12:47 GMT-600 (CST)
|
|
|
|
client.end();
|
2016-03-08 21:52:21 +00:00
|
|
|
});
|
2017-03-22 15:48:36 +00:00
|
|
|
});
|
|
|
|
});*/
|
|
|
|
|
|
|
|
app.get('/slack', function(req, res) {
|
2017-04-05 13:22:31 +00:00
|
|
|
res.render('pages/slackV2-min');
|
2017-04-11 13:30:48 +00:00
|
|
|
//res.render('pages/slackV2');
|
2017-03-22 15:48:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/temp', function(req, res) {
|
|
|
|
res.render('pages/temp');
|
|
|
|
});
|
2016-03-08 21:52:21 +00:00
|
|
|
|
2016-04-11 13:46:07 +00:00
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const tfile = 'fb-token.json';
|
2016-04-11 14:14:19 +00:00
|
|
|
|
2016-04-11 13:46:07 +00:00
|
|
|
|
|
|
|
// Instanciate a fitbit client. See example config below.
|
|
|
|
//
|
2016-04-11 14:37:49 +00:00
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
const fitbit = new Fitbit(config.fitbit);
|
2016-04-11 13:46:07 +00:00
|
|
|
|
|
|
|
// In a browser, http://localhost:4000/fitbit to authorize a user for the first time.
|
|
|
|
//
|
2017-03-22 15:48:36 +00:00
|
|
|
app.get('/fitbit', function(req, res) {
|
|
|
|
res.redirect(fitbit.authorizeURL());
|
2016-04-11 13:46:07 +00:00
|
|
|
});
|
|
|
|
|
2017-04-18 09:06:39 +00:00
|
|
|
app.get( '/fb-profile', function( req, res, next ) {
|
|
|
|
fitbit.request({
|
|
|
|
uri: "https://api.fitbit.com/1/user/-/profile.json",
|
|
|
|
method: 'GET',
|
|
|
|
}, function( err, body, token ) {
|
|
|
|
if ( err ) return next( err );
|
|
|
|
var profile = JSON.parse( body );
|
|
|
|
// if token is not null, a refesh has happened and we need to persist the new token
|
|
|
|
if ( token )
|
|
|
|
persist.write( tfile, token, function( err ) {
|
|
|
|
if ( err ) return next( err );
|
|
|
|
res.send( '<pre>' + JSON.stringify( profile, null, 2 ) + '</pre>' );
|
|
|
|
});
|
|
|
|
else
|
|
|
|
res.send( '<pre>' + JSON.stringify( profile, null, 2 ) + '</pre>' );
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2016-04-11 13:46:07 +00:00
|
|
|
// Callback service parsing the authorization token and asking for the access token. This
|
|
|
|
// endpoint is refered to in config.fitbit.authorization_uri.redirect_uri. See example
|
|
|
|
// config below.
|
|
|
|
//
|
2017-03-22 15:48:36 +00:00
|
|
|
app.get('/fitbit_auth_callback', function(req, res, next) {
|
|
|
|
const code = req.query.code;
|
|
|
|
fitbit.fetchToken(code, function(err, token) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
2016-04-11 13:46:07 +00:00
|
|
|
|
|
|
|
// persist the token
|
2017-03-22 15:48:36 +00:00
|
|
|
jsonfile.writeFile(tfile, token, function(err) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
|
|
|
console.log('!!!! Fitbit token saved');
|
|
|
|
res.redirect('/fb-profile');
|
|
|
|
|
2016-04-11 13:46:07 +00:00
|
|
|
});
|
2017-03-22 15:48:36 +00:00
|
|
|
});
|
2016-04-11 13:46:07 +00:00
|
|
|
});
|
|
|
|
|
2017-04-18 09:06:39 +00:00
|
|
|
|
2016-04-11 13:46:07 +00:00
|
|
|
jsonfile.readFile('./fb-token.json', function(err, obj) {
|
2017-03-22 15:48:36 +00:00
|
|
|
if (err) {
|
|
|
|
logger.error(err);
|
|
|
|
} else {
|
|
|
|
fitbit.setToken(obj);
|
|
|
|
}
|
|
|
|
});
|
2016-04-11 13:46:07 +00:00
|
|
|
|
|
|
|
|
2017-03-22 15:48:36 +00:00
|
|
|
// });
|
2016-03-08 21:52:21 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* create the server
|
|
|
|
*/
|
2016-10-05 14:09:12 +00:00
|
|
|
/*
|
2016-03-08 21:52:21 +00:00
|
|
|
http.createServer(app).listen(app.get('port'), function () {
|
2016-03-23 15:09:25 +00:00
|
|
|
logger.warn("Express server listening on port " + app.get('port'));
|
2016-03-10 20:15:35 +00:00
|
|
|
//console.log("Express server listening on port " + app.get('port'));
|
2016-03-08 21:52:21 +00:00
|
|
|
});
|
2016-10-05 14:09:12 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
server.on('request', app);
|
2017-03-22 15:48:36 +00:00
|
|
|
server.listen(port, () => { logger.info('New server listening on ' + server.address().port); });
|
2016-10-05 14:09:12 +00:00
|
|
|
|