update to primus
This commit is contained in:
parent
5076d6c33f
commit
8954fbae16
119
app.js
119
app.js
@ -1,19 +1,73 @@
|
|||||||
var express = require('express.io');
|
var express = require('express.io');
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
var favicon = require('serve-favicon');
|
var favicon = require('serve-favicon');
|
||||||
var logger = require('morgan');
|
|
||||||
var bodyParser = require('body-parser');
|
var bodyParser = require('body-parser');
|
||||||
var fs = require('fs');
|
|
||||||
var config;
|
|
||||||
|
|
||||||
if(fs.existsSync('./config/nodes.js')){
|
|
||||||
config = require('./config/nodes');
|
|
||||||
} else {
|
|
||||||
config = require('./config/nodes.default');
|
|
||||||
}
|
|
||||||
|
|
||||||
var Node = require('./models/node');
|
var Node = require('./models/node');
|
||||||
|
|
||||||
|
var Primus = require('primus'),
|
||||||
|
http = require('http'),
|
||||||
|
server,
|
||||||
|
api,
|
||||||
|
client;
|
||||||
|
|
||||||
|
var Collection = require('./models/collection');
|
||||||
|
|
||||||
|
var Nodes = new Collection();
|
||||||
|
|
||||||
|
server = http.createServer();
|
||||||
|
api = new Primus(server, {
|
||||||
|
transformer: 'websockets',
|
||||||
|
pathname: '/api',
|
||||||
|
parser: 'JSON'
|
||||||
|
});
|
||||||
|
|
||||||
|
api.use('emit', require('primus-emit'));
|
||||||
|
|
||||||
|
api.on('connection', function(spark) {
|
||||||
|
console.log(spark.id);
|
||||||
|
console.log(spark.address);
|
||||||
|
console.log(spark.query);
|
||||||
|
|
||||||
|
spark.on('hello', function(data){
|
||||||
|
console.log('got hello data from ' + spark.id);
|
||||||
|
console.log(data);
|
||||||
|
Nodes.add(data);
|
||||||
|
});
|
||||||
|
|
||||||
|
spark.on('update', function(data){
|
||||||
|
console.log('got update from ' + spark.id);
|
||||||
|
console.log(data);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
var client = new Primus(server, {
|
||||||
|
transformer: 'websockets',
|
||||||
|
pathname: '/primus',
|
||||||
|
parser: 'JSON'
|
||||||
|
});
|
||||||
|
|
||||||
|
client.use('emit', require('primus-emit'));
|
||||||
|
|
||||||
|
client.on('connection', function(spark) {
|
||||||
|
console.log(spark);
|
||||||
|
|
||||||
|
console.log(spark.id);
|
||||||
|
console.log(spark.headers);
|
||||||
|
console.log(spark.address);
|
||||||
|
console.log(spark.query);
|
||||||
|
spark.write({give: 'identity'});
|
||||||
|
});
|
||||||
|
|
||||||
|
server.listen(process.env.API_PORT || 3000);
|
||||||
|
|
||||||
|
// if(fs.existsSync('./config/nodes.js')){
|
||||||
|
// config = require('./config/nodes');
|
||||||
|
// } else {
|
||||||
|
// config = require('./config/nodes.default');
|
||||||
|
// }
|
||||||
|
|
||||||
|
// var Node = require('./models/node');
|
||||||
|
|
||||||
var app = express();
|
var app = express();
|
||||||
app.http().io();
|
app.http().io();
|
||||||
|
|
||||||
@ -23,37 +77,36 @@ app.set('view engine', 'jade');
|
|||||||
|
|
||||||
// uncomment after placing favicon in /public
|
// uncomment after placing favicon in /public
|
||||||
//app.use(favicon(__dirname + '/public/favicon.ico'));
|
//app.use(favicon(__dirname + '/public/favicon.ico'));
|
||||||
app.use(logger('dev'));
|
|
||||||
app.use(bodyParser.json());
|
app.use(bodyParser.json());
|
||||||
app.use(bodyParser.urlencoded({ extended: false }));
|
app.use(bodyParser.urlencoded({ extended: false }));
|
||||||
app.use(express.static(path.join(__dirname, 'public')));
|
app.use(express.static(path.join(__dirname, 'public')));
|
||||||
|
|
||||||
var nodes = [],
|
// var nodes = [],
|
||||||
nodeStatus = [],
|
// nodeStatus = [],
|
||||||
nodeInterval;
|
// nodeInterval;
|
||||||
|
|
||||||
for(i in config) {
|
// for(i in config) {
|
||||||
nodes[i] = new Node(config[i], i);
|
// nodes[i] = new Node(config[i], i);
|
||||||
console.log(nodes[i]);
|
// console.log(nodes[i]);
|
||||||
nodeStatus[i] = nodes[i].update();
|
// nodeStatus[i] = nodes[i].update();
|
||||||
}
|
// }
|
||||||
|
|
||||||
nodeInterval = setInterval(function(){
|
// nodeInterval = setInterval(function(){
|
||||||
for(i in nodes){
|
// for(i in nodes){
|
||||||
app.io.broadcast('update', nodes[i].update());
|
// app.io.broadcast('update', nodes[i].update());
|
||||||
}
|
// }
|
||||||
}, 10000);
|
// }, 10000);
|
||||||
|
|
||||||
app.get('/', function(req, res) {
|
// app.get('/', function(req, res) {
|
||||||
res.render('index', { title: 'Ethereum Network Status' });
|
// res.render('index', { title: 'Ethereum Network Status' });
|
||||||
});
|
// });
|
||||||
|
|
||||||
app.io.route('ready', function(req) {
|
// app.io.route('ready', function(req) {
|
||||||
req.io.emit('init', {
|
// req.io.emit('init', {
|
||||||
nodes: nodeStatus
|
// nodes: nodeStatus
|
||||||
});
|
// });
|
||||||
console.log('emited');
|
// console.log('emited');
|
||||||
});
|
// });
|
||||||
|
|
||||||
// catch 404 and forward to error handler
|
// catch 404 and forward to error handler
|
||||||
app.use(function(req, res, next) {
|
app.use(function(req, res, next) {
|
||||||
|
53
models/collection.js
Normal file
53
models/collection.js
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
var _ = require('lodash');
|
||||||
|
var Node = require('./node');
|
||||||
|
|
||||||
|
var Collection = function Collection()
|
||||||
|
{
|
||||||
|
this._list = [];
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.add = function(data)
|
||||||
|
{
|
||||||
|
if(typeof data.id == 'undefined')
|
||||||
|
return false;
|
||||||
|
|
||||||
|
var node = this.getNodeOrNew({ id : data.id });
|
||||||
|
|
||||||
|
node.info = data.info;
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.get = function(id)
|
||||||
|
{
|
||||||
|
return this.getNode(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.getIndex = function(search)
|
||||||
|
{
|
||||||
|
return _.findIndex(this._list, search);
|
||||||
|
|
||||||
|
return (index >= 0 ? index : false);
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.getNode = function(search)
|
||||||
|
{
|
||||||
|
var index = this.getIndex(search);
|
||||||
|
|
||||||
|
if(index)
|
||||||
|
return this._list[index];
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.getIndexOrNew = function(search)
|
||||||
|
{
|
||||||
|
var index = this.getIndex(search) || this._list.push(new Node());
|
||||||
|
}
|
||||||
|
|
||||||
|
Collection.prototype.getNodeOrNew = function(search)
|
||||||
|
{
|
||||||
|
return this.getNode(this.getIndexOrNew(search));
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Collection;
|
@ -1,68 +1,34 @@
|
|||||||
var geoip = require('geoip-lite');
|
var geoip = require('geoip-lite');
|
||||||
|
|
||||||
var Node = function Node(options, id)
|
var Node = function Node()
|
||||||
{
|
{
|
||||||
this.options = options;
|
this.id = null;
|
||||||
this.info = {
|
this.info = {};
|
||||||
name: options.name,
|
this.geo = {}
|
||||||
ip: options.rpcHost,
|
this.stats = {
|
||||||
type: options.type,
|
|
||||||
os: options.os
|
|
||||||
};
|
|
||||||
|
|
||||||
this.info.geo = geoip.lookup(this.info.ip);
|
|
||||||
this.info.id = parseInt(id);
|
|
||||||
this.info.stats = {
|
|
||||||
active: false,
|
active: false,
|
||||||
peers: 0,
|
listening: false,
|
||||||
mining: false,
|
mining: false,
|
||||||
block: {
|
peers: 0,
|
||||||
number: 0,
|
pending: 0,
|
||||||
hash: '?',
|
gasPrice: 0,
|
||||||
timestamp: 0
|
block: {},
|
||||||
},
|
blocktimeAvg: 0,
|
||||||
|
difficulty: [],
|
||||||
uptime: {
|
uptime: {
|
||||||
down: 0,
|
down: 0,
|
||||||
inc: 0,
|
inc: 0,
|
||||||
total: 0
|
total: 0
|
||||||
}
|
},
|
||||||
}
|
lastUpdate: 0
|
||||||
|
};
|
||||||
this.web3 = require('ethereum.js');
|
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
Node.prototype.update = function()
|
Node.prototype.setGeo = function()
|
||||||
{
|
{
|
||||||
var sock = new this.web3.providers.HttpSyncProvider('http://' + this.options.rpcHost + ':' + this.options.rpcPort);
|
this.geo = geoip.lookup(ip);
|
||||||
this.web3.setProvider(sock);
|
}
|
||||||
|
|
||||||
var eth = this.web3.eth;
|
|
||||||
|
|
||||||
try {
|
|
||||||
this.info.stats.peers = eth.peerCount;
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
this.info.stats.peers = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(this.info.stats.peers != null) {
|
|
||||||
this.info.stats.block = eth.block(parseInt(eth.number));
|
|
||||||
if(this.info.stats.block.hash != '?' && typeof this.info.stats.block.difficulty !== 'undefined'){
|
|
||||||
this.info.stats.block.difficulty = this.web3.toDecimal(this.info.stats.block.difficulty);
|
|
||||||
}
|
|
||||||
this.info.stats.mining = eth.mining;
|
|
||||||
this.info.stats.active = true;
|
|
||||||
} else {
|
|
||||||
this.info.stats.active = false;
|
|
||||||
this.info.stats.uptime.down++;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.info.stats.uptime.inc++;
|
|
||||||
this.info.stats.uptime.total = ((this.info.stats.uptime.inc - this.info.stats.uptime.down) / this.info.stats.uptime.inc) * 100;
|
|
||||||
|
|
||||||
return this.info;
|
|
||||||
};
|
|
||||||
|
|
||||||
module.exports = Node;
|
module.exports = Node;
|
||||||
|
@ -16,8 +16,12 @@
|
|||||||
"express.io": "^1.1.13",
|
"express.io": "^1.1.13",
|
||||||
"geoip-lite": "^1.1.4",
|
"geoip-lite": "^1.1.4",
|
||||||
"jade": "~1.6.0",
|
"jade": "~1.6.0",
|
||||||
|
"lodash": "^3.2.0",
|
||||||
"morgan": "~1.3.0",
|
"morgan": "~1.3.0",
|
||||||
|
"primus": "^2.4.12",
|
||||||
|
"primus-emit": "^0.1.2",
|
||||||
"serve-favicon": "~2.1.3",
|
"serve-favicon": "~2.1.3",
|
||||||
"stylus": "0.42.3"
|
"stylus": "0.42.3",
|
||||||
|
"ws": "^0.7.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user