bayeux.rack
Bayeux (COMET or long-polling) protocol server as a Sinatra application. Light weight and high scalability are achieved by using the asynchronous Rack extensions added to Thin by async_sinatra.
Because it uses async_sinatra, which uses EventMachine, it won’t work in Passenger. Sorry about that, but Apache doesn’t really like long-polling anyhow. Use Thin.
You can see a video presentation of this code here: www.youtube.com/watch?v=Bhj9QOfNd4c
Usage
See github.com/cjheath/jquery.comet for an example of usage and for a COMET client in Javascript.
class MyServer < Bayeux
configure do
# The default :public is inside the Bayeux gem
set :public, File.dirname(__FILE__)
end
def deliver message
case channel_name = message['channel']
when '/my/interesting/channel'
data = message if data == ‘ping’ publish :channel => channel_name, :data => ‘pong’ else super end
else
super
end
end
end
Installing
gem install bayeux-rack
License
The MIT license.
Developing
Fork on github github.com/cjheath/bayeux-rack or just clone to play:
git clone git://github.com/cjheath/bayeux-rack.git
Patches welcome! Fork and send a pull request. Please follow coding conventions already in use. Please use jslint if you can. There are currently no warnings, please keep it that way.
Status
Current release has a happy path (working ok). Significant drawbacks to be fixed are:
-
Server-side timeout of long-polls to avoid possible loss of sent messages
-
Detecting multiple connections (tabs?) from the same browser, to fall back to callback polling.