/templates/eshq.js.st

http://github.com/biilmann/eventsource-broker · Unknown · 70 lines · 57 code · 13 blank · 0 comment · 0 complexity · 12c7715344abf4670bed4efcd18c2ace MD5 · raw file

  1. (function() {
  2. var origin = "$origin$";
  3. if (typeof(window.addEventListener) == "undefined") {
  4. window.addEventListener = function(name, fn) {
  5. window.attachEvent("on" + name, fn);
  6. };
  7. }
  8. var post = function(path, data, callback) {
  9. var xhr = new XMLHttpRequest();
  10. xhr.open('POST', path, true);
  11. xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  12. xhr.onreadystatechange = callback;
  13. xhr.send(data);
  14. };
  15. var Sub = function(channel, options) {
  16. for (var i in options) {
  17. this[i] = options[i];
  18. };
  19. this.channel = channel;
  20. }
  21. var subs = {};
  22. var onMessage = function(event) {
  23. if (event.origin !== origin) { return; }
  24. var data = JSON.parse(event.data);
  25. if (!data.eshqEvent) { return; }
  26. var sub = subs[data.channel];
  27. if (!sub) { return; }
  28. if (sub[data.eshqEvent]) { sub[data.eshqEvent].call(null, data.originalEvent); }
  29. };
  30. window.addEventListener("message", onMessage, false);
  31. var getSocket = function(channel, url) {
  32. post(url, "channel=" + channel, function() {
  33. if (this.readyState == 4 && this.status == 200) {
  34. var resp = JSON.parse(this.responseText);
  35. openChannel(channel, resp.socket);
  36. }
  37. });
  38. };
  39. var openChannel = function(channel, socket) {
  40. var iframe = document.createElement("iframe");
  41. iframe.setAttribute("style", "display: none;");
  42. iframe.setAttribute("src", origin + "/iframe?channel=" + channel + "&socket=" + socket + "&t=" + new Date().getTime());
  43. document.body.appendChild(iframe);
  44. subs[channel].frame = iframe;
  45. };
  46. window.eshq = {
  47. open: function(channel, options) {
  48. subs[channel] = new Sub(channel, options || {});
  49. getSocket(channel, options.auth_url || "/eshq/socket");
  50. },
  51. send: function(channel, data) {
  52. var sub = subs[channel];
  53. if (!sub) throw "You must open a channel before sending to it";
  54. sub.frame.contentWindow.postMessage(data, "*");
  55. }
  56. };
  57. })();