You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

external_connect.js 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /**
  2. * Requests the given webservice that will create the connection and will return
  3. * the necessary details(rid, sid and jid) to attach to this connection and
  4. * start using it. This script can be used for optimizing the connection startup
  5. * time. The function will send AJAX request to a webservice that should
  6. * create the bosh session much faster than the client because the webservice
  7. * can be started on the same machine as the XMPP serever.
  8. *
  9. * NOTE: It's vert important to execute this function as early as you can for
  10. * optimal results.
  11. *
  12. * @param webserviceUrl the url for the web service that is going to create the
  13. * connection.
  14. * @param success_callback callback function called with the result of the AJAX
  15. * request if the request was successfull. The callback will receive one
  16. * parameter which will be JS Object with properties - rid, sid and jid. This
  17. * result should be passed to JitsiConnection.attach method in order to use that
  18. * connection.
  19. * @param error_callback callback function called the AJAX request fail. This
  20. * callback is going to receive one parameter which is going to be JS error
  21. * object with a reason for failure in it.
  22. */
  23. function createConnectionExternally(webserviceUrl, success_callback,
  24. error_callback) {
  25. if (!window.XMLHttpRequest) {
  26. error_callback(new Error("XMLHttpRequest is not supported!"));
  27. return;
  28. }
  29. var xhttp = new XMLHttpRequest();
  30. xhttp.onreadystatechange = function() {
  31. if (xhttp.readyState == 4) {
  32. if (xhttp.status == 200) {
  33. try {
  34. var data = JSON.parse(xhttp.responseText);
  35. success_callback(data);
  36. } catch (e) {
  37. error_callback(e);
  38. }
  39. } else {
  40. error_callback(new Error("XMLHttpRequest error. Status: " +
  41. xhttp.status + ". Error message: " + xhttp.statusText));
  42. }
  43. }
  44. };
  45. xhttp.open("GET", webserviceUrl, true);
  46. xhttp.send();
  47. }