A Twitch.tv viewer reward and games system.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

89 lines
2.7 KiB

var express = require('express'),
https = require('https');
//---- Construct ----
function WEB(db, currency, options) {
var __self = this;
__self.db = db;
__self.currency = currency;
__self.port = options.port || 9000;
__self.title = options.title;
__self.slogan = options.slogan;
__self.logo = options.logo;
__self.twitter = options.twitter;
__self.statdir = options.statdir;
}
// ---- Methods ----
WEB.prototype.start = function () {
var __self = this;
__self.srv = express();
__self.srv.set('view engine', 'jade');
__self.srv.set('views', 'web/templates');
__self.srv.use(express.static('./web/public'));
__self.render_opts = {
title: __self.title,
slogan: __self.slogan,
logo: __self.logo,
twitter: __self.twitter,
};
// ---- Routes -----
__self.srv.get('/', function(req, res) {
//lets get the top 5
sql = 'SELECT * FROM viewers ORDER BY points DESC LIMIT 10;';
__self.db.execute(sql, function(rows) {
var opts = __self.render_opts;
opts.rows = rows;
opts.bet_status = __self.currency.bets_status;
opts.bet_board = __self.currency.bets_board;
opts.bet_viewers = __self.currency.bets_viewers;
res.render('index', opts);
});
});
__self.srv.get('/ladder', function(req, res) {
//get the whole viewer list
sql = 'SELECT * FROM viewers ORDER BY points DESC;';
__self.db.execute(sql, function(rows) {
var opts = __self.render_opts;
opts.rows = rows;
res.render('ladder', opts);
});
});
__self.srv.get('/stats', function(req, res) {
var opts = __self.render_opts;
opts.statdir = __self.statdir;
res.render('stats', opts);
});
/* Raw data for android app */
__self.srv.get('/fanart', function(req, res) {
res.render('fanart', __self.render_opts);
});
__self.srv.get('/api/test', function(req, res) {
res.send("Hey, its Potatr. This data was pulled from the web.");
});
__self.srv.all('/api/data', function(req, res) {
sql = 'SELECT * FROM viewers ORDER BY points DESC;';
__self.db.execute(sql, function(rows) {
ladder_data = new Object();
rows.forEach(function(element, index, array){
ladder_data[element.user] = element.points;
});
res.send(ladder_data);
});
});
__self.srv.listen(__self.port);
console.log('Started website at '+__self.port);
};
module.exports = function (db, currency, options) {
return new WEB(db, currency, options);
};