-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
112 lines (95 loc) · 3.14 KB
/
app.js
File metadata and controls
112 lines (95 loc) · 3.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
var express = require('express'),
http = require('http'),
app = express(),
server = http.createServer(app),
io = require('socket.io').listen(server),
stylus = require('stylus'),
nib = require('nib'),
redis = require('redis'),
publisherClient = redis.createClient(),
routes = require('./routes');
// Configuration
function compileCss(str, path) {
return stylus(str)
.set('filename', path)
.use(nib())
}
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon())
app.use(express.logger("dev"))
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(stylus.middleware(
{ src: __dirname + '/public'
, compile: compileCss
}
))
app.use(express.static(__dirname + '/public'));
app.use(function(req, res, next){
throw new Error(req.url + ' not found');
});
app.use(function(err, req, res, next) {
console.log(err);
res.send(err.message);
});
});
app.configure('development', function() {
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function() {
app.use(express.errorHandler());
});
// Heroku won't actually allow us to use WebSockets
// so we have to setup polling instead.
// https://devcenter.heroku.com/articles/using-socket-io-with-node-js-on-heroku
io.configure(function () {
io.set("transports", ["xhr-polling"]);
io.set("polling duration", 10);
});
// Routes
var port = process.env.PORT || 5000; // Use the port that Heroku provides or default to 5000
server.listen(port);
var router = require("./router.js");
router.createRoutes(app, routes)
// events
app.get('/update-stream', function(req, res) {
// let request last as long as possible
req.socket.setTimeout(Infinity);
var messageCount = 0;
var subscriber = redis.createClient();
subscriber.subscribe("updates");
// In case we encounter an error...print it out to the console
subscriber.on("error", function(err) {
console.log("Redis Error: " + err);
});
// When we receive a message from the redis connection
subscriber.on("message", function(channel, message) {
messageCount++; // Increment our message count
res.write('id: ' + messageCount + '\n');
res.write("data: " + message + '\n\n'); // Note the extra newline
});
//send headers for event-stream connection
res.writeHead(200, {
'Content-Type': 'text/event-stream',
'Cache-Control': 'no-cache',
'Connection': 'keep-alive'
});
res.write('\n');
// The 'close' event is fired when a user closes their browser window.
// In that situation we want to make sure our redis channel subscription
// is properly shut down to prevent memory leaks...and incorrect subscriber
// counts to the channel.
req.on("close", function() {
subscriber.unsubscribe();
subscriber.quit();
});
});
app.get('/fire/:event/:token', function(req, res) {
publisherClient.publish( 'updates', ('"' + req.params.event + '" page visited') );
res.writeHead(200, {'Content-Type': 'text/html'});
res.write('All clients have received "' + req.params.event + '"');
res.end();
})