update to primus

This commit is contained in:
cubedro 2015-02-17 04:04:15 +02:00
parent 5076d6c33f
commit 8954fbae16
4 changed files with 162 additions and 86 deletions

119
app.js
View File

@ -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
View 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;

View File

@ -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;

View File

@ -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"
} }
} }