silvrgit/web-server.js

222 lines
5.9 KiB
JavaScript
Raw Normal View History

2017-03-22 15:48:36 +00:00
const express = require('express');
const path = require('path');
2017-09-11 14:47:01 +00:00
const http = require('http');
2017-03-22 15:48:36 +00:00
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');
2017-08-18 14:08:28 +00:00
// const today = require('./lib/today');
2017-03-22 15:48:36 +00:00
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');
const busEmitter = new Events.EventEmitter();
2016-10-05 14:09:12 +00:00
// busEmitter.on('update', today.broadcast);
2016-10-05 14:09:12 +00:00
2017-09-11 14:47:01 +00:00
const WebSocket = require('ws');
// 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-09-11 14:47:01 +00:00
// const webSocket = new SocketHandler(busEmitter, wss);
2016-10-05 14:09:12 +00:00
btc.setEmitter(busEmitter);
// today.setEmitter(busEmitter);
2016-10-05 14:09:12 +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
const fs = require('fs');
2017-03-22 15:48:36 +00:00
const config = require('./config/config.json');
const Fitbit = require('fitbit-oauth2');
2017-03-22 15:48:36 +00:00
const polys = require('./lib/poly.js');
2016-04-01 09:39:53 +00:00
2017-08-18 14:08:28 +00:00
const logger = require('log4js').getLogger('web-server');
const apicache = require('apicache');
2017-03-22 15:48:36 +00:00
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({
'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 }));
2016-03-08 21:52:21 +00:00
// parse application/json
app.use(bodyparser.json());
// apicache.options({ 'debug': true });
// const cache = apicache.middleware;
// logger.debug(apicache);
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();
});
// 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 }));
2016-03-08 21:52:21 +00:00
app.use('/btc', btc.doBTC);
app.use('/balance', btc.doBalance);
2017-09-11 14:47:01 +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);
2017-03-22 15:48:36 +00:00
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
app.use('/events', events.getEvents);
app.get('/cinema/:id', events.getCinema);
2016-03-08 21:52:21 +00:00
2016-04-01 09:39:53 +00:00
app.route('/poly').get(polys);
2017-03-22 15:48:36 +00:00
app.get('/slack', function(req, res) {
2017-09-11 14:47:01 +00:00
// res.render('pages/slackV2-min');
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
2017-03-22 15:48:36 +00:00
const tfile = 'fb-token.json';
2016-04-11 14:14:19 +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);
// 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());
});
2017-04-18 09:06:39 +00:00
app.get( '/fb-profile', function( req, res, next ) {
2017-08-18 14:08:28 +00:00
fitbit.request({
'uri': 'https://api.fitbit.com/1/user/-/profile.json',
'method': 'GET'
2017-08-18 14:08:28 +00:00
}, 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
2017-08-18 14:08:28 +00:00
if ( token )
persist.write( tfile, token, function( err ) {
if ( err ) return next( err );
res.send( `<pre>${ JSON.stringify( profile, null, 2 ) }</pre>` );
2017-08-18 14:08:28 +00:00
});
else
res.send( `<pre>${ JSON.stringify( profile, null, 2 ) }</pre>` );
2017-08-18 14:08:28 +00:00
});
2017-04-18 09:06:39 +00:00
});
2017-04-18 09:17:56 +00:00
app.get( '/fb-today', function( req, res, next ) {
const today = Date.create('today').format('{yyyy}-{MM}-{dd}');
const url = `https://api.fitbit.com/1/user/-/activities/date/${ today }.json`;
2017-08-18 14:08:28 +00:00
fitbit.request({
'uri': url,
'method': 'GET'
2017-08-18 14:08:28 +00:00
}, 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
2017-08-18 14:08:28 +00:00
if ( token )
persist.write( tfile, token, function( err ) {
if ( err ) return next( err );
res.send( `<pre>${ JSON.stringify( profile, null, 2 ) }</pre>` );
2017-08-18 14:08:28 +00:00
});
else
res.send( `<pre>${ JSON.stringify( profile, null, 2 ) }</pre>` );
2017-08-18 14:08:28 +00:00
});
2017-04-18 09:17:56 +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) {
2017-08-18 14:08:28 +00:00
if (err)
2017-03-22 15:48:36 +00:00
return next(err);
// persist the token
2017-03-22 15:48:36 +00:00
jsonfile.writeFile(tfile, token, function(err) {
2017-08-18 14:08:28 +00:00
if (err)
2017-03-22 15:48:36 +00:00
return next(err);
2017-08-18 14:08:28 +00:00
2017-03-22 15:48:36 +00:00
console.log('!!!! Fitbit token saved');
res.redirect('/fb-profile');
});
2017-03-22 15:48:36 +00:00
});
});
jsonfile.readFile('./fb-token.json', function(err, obj) {
2017-08-18 14:08:28 +00:00
if (err)
2017-03-22 15:48:36 +00:00
logger.error(err);
2017-08-18 14:08:28 +00:00
else
2017-03-22 15:48:36 +00:00
fitbit.setToken(obj);
});
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
*/
2017-09-11 14:47:01 +00:00
const server = http.createServer(app);
let wss;
let webSocket;
wss = new WebSocket.Server({ server });
webSocket = new SocketHandler(busEmitter, wss);
2016-10-05 14:09:12 +00:00
2017-09-11 14:47:01 +00:00
// server.on('request', app);
2017-08-18 14:08:28 +00:00
server.listen(port, () => {
2017-09-11 14:47:01 +00:00
logger.info(`New server listening on ${ server.address().port}`);
2017-08-18 14:08:28 +00:00
});
2016-10-05 14:09:12 +00:00