summaryrefslogtreecommitdiff
path: root/addons/bus/controllers/main.py
diff options
context:
space:
mode:
Diffstat (limited to 'addons/bus/controllers/main.py')
-rw-r--r--addons/bus/controllers/main.py44
1 files changed, 44 insertions, 0 deletions
diff --git a/addons/bus/controllers/main.py b/addons/bus/controllers/main.py
new file mode 100644
index 00000000..99fcc82e
--- /dev/null
+++ b/addons/bus/controllers/main.py
@@ -0,0 +1,44 @@
+# -*- coding: utf-8 -*-
+
+from odoo import exceptions, _
+from odoo.http import Controller, request, route
+from odoo.addons.bus.models.bus import dispatch
+
+
+class BusController(Controller):
+ """ Examples:
+ openerp.jsonRpc('/longpolling/poll','call',{"channels":["c1"],last:0}).then(function(r){console.log(r)});
+ openerp.jsonRpc('/longpolling/send','call',{"channel":"c1","message":"m1"});
+ openerp.jsonRpc('/longpolling/send','call',{"channel":"c2","message":"m2"});
+ """
+
+ @route('/longpolling/send', type="json", auth="public")
+ def send(self, channel, message):
+ if not isinstance(channel, str):
+ raise Exception("bus.Bus only string channels are allowed.")
+ return request.env['bus.bus'].sendone(channel, message)
+
+ # override to add channels
+ def _poll(self, dbname, channels, last, options):
+ # update the user presence
+ if request.session.uid and 'bus_inactivity' in options:
+ request.env['bus.presence'].update(options.get('bus_inactivity'))
+ request.cr.close()
+ request._cr = None
+ return dispatch.poll(dbname, channels, last, options)
+
+ @route('/longpolling/poll', type="json", auth="public", cors="*")
+ def poll(self, channels, last, options=None):
+ if options is None:
+ options = {}
+ if not dispatch:
+ raise Exception("bus.Bus unavailable")
+ if [c for c in channels if not isinstance(c, str)]:
+ raise Exception("bus.Bus only string channels are allowed.")
+ if request.registry.in_test_mode():
+ raise exceptions.UserError(_("bus.Bus not available in test mode"))
+ return self._poll(request.db, channels, last, options)
+
+ @route('/longpolling/im_status', type="json", auth="user")
+ def im_status(self, partner_ids):
+ return request.env['res.partner'].with_context(active_test=False).search([('id', 'in', partner_ids)]).read(['im_status'])