-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathapp.js
130 lines (113 loc) · 3.26 KB
/
app.js
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/**
* @fileoverview Base for PubHub.
*/
/**
* Module dependencies.
*/
var cluster = require('cluster');
var cp = require('child_process');
var events = require('events');
var express = require('express');
var Factory = require('./factory.js').Factory;
var routes = require('./routes');
var util = require('util');
if (cluster.isMaster) {
// Make sure the options file is present.
try {
require('fs').statSync('./local.json');
}
catch (error) {
util.log(
'You must create a local.json file with database configuration ' +
'options. See example_local.json for an example.'
);
process.exit(1);
}
// Start the factory!
var factory = new Factory();
// Listen with no more processes than we have CPUs.
for (var i = 0; i < require('os').cpus().length; i++) {
var worker = cluster.fork();
// Backwards compatability, this might not be the cleanest way of doing this.
if (process.version < 'v0.7.0') {
worker.on('message', function onMessage(msg) {
if (msg.query) {
factory.subscribe(msg.query);
}
else if (msg.feed) {
factory.publish(msg.feed);
}
});
}
}
cluster.on('fork', function onFork(worker) {
worker.on('message', function onMessage(msg) {
if (msg.query) {
factory.subscribe(msg.query);
}
else if (msg.feed) {
factory.publish(msg.feed);
}
});
});
var onDeath = function(worker) {
util.log('Worker ' + worker.pid + ' died. Restarting.');
var newWorker = cluster.fork();
// Backwards compatability.
if (process.version < 'v0.7.0') {
newWorker.on('message', function onMessage(msg) {
if (msg.query) {
factory.subscribe(msg.query);
}
else if (msg.feed) {
factory.publish(msg.feed);
}
});
}
}
cluster.on('death', onDeath);
cluster.on('exit', onDeath);
}
else {
var app = module.exports = express.createServer();
// Configuration
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
app.configure('development', function(){
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function(){
app.use(express.errorHandler());
});
var hubEvents = new events.EventEmitter();
hubEvents.on('subscribed', function onSubscribed(query) {
process.send({ 'query': query });
});
hubEvents.on('published', function onPublished(feed) {
process.send({ 'feed': feed });
});
// Routes
app.get('/', routes.index);
app.get('/subscribe', function onGet(req, res) {
res.send('Only POST subscriptions are supported.');
});
app.post('/subscribe', function onSubscribe(req, res) {
routes.subscribe(req, res, hubEvents);
});
app.post('/publish', function onPublish(req, res) {
routes.publish(req, res, hubEvents);
});
var optionsFile = require('fs').readFileSync('./local.json', 'utf8');
var options = JSON.parse(optionsFile);
var port = 3000;
if (typeof options.port !== 'undefined') {
port = options.port;
}
app.listen(port);
}