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.

strophe.logger.js 1.3KB

1234567891011121314151617181920212223242526272829303132333435
  1. /*
  2. * Copyright @ 2015 Atlassian Pty Ltd
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. /* global Strophe */
  17. module.exports = function () {
  18. Strophe.addConnectionPlugin('logger', {
  19. // logs raw stanzas and makes them available for download as JSON
  20. connection: null,
  21. log: [],
  22. init: function (conn) {
  23. this.connection = conn;
  24. this.connection.rawInput = this.log_incoming.bind(this);
  25. this.connection.rawOutput = this.log_outgoing.bind(this);
  26. },
  27. log_incoming: function (stanza) {
  28. this.log.push([new Date().getTime(), 'incoming', stanza]);
  29. },
  30. log_outgoing: function (stanza) {
  31. this.log.push([new Date().getTime(), 'outgoing', stanza]);
  32. }
  33. });
  34. };