message_receiver_test.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * vim: ts=4:sw=4:expandtab
  3. */
  4. describe('MessageReceiver', function() {
  5. textsecure.storage.impl = new SignalProtocolStore();
  6. var WebSocket = window.WebSocket;
  7. var number = '+19999999999';
  8. var deviceId = 1;
  9. var signalingKey = libsignal.crypto.getRandomBytes(32 + 20);
  10. before(function() {
  11. window.WebSocket = MockSocket;
  12. textsecure.storage.user.setNumberAndDeviceId(number, deviceId, 'name');
  13. textsecure.storage.put("password", "password");
  14. textsecure.storage.put("signaling_key", signalingKey);
  15. });
  16. after (function() { window.WebSocket = WebSocket; });
  17. describe('connecting', function() {
  18. var blob = null;
  19. var attrs = {
  20. type: textsecure.protobuf.Envelope.Type.CIPHERTEXT,
  21. source: number,
  22. sourceDevice: deviceId,
  23. timestamp: Date.now(),
  24. };
  25. var websocketmessage = new textsecure.protobuf.WebSocketMessage({
  26. type: textsecure.protobuf.WebSocketMessage.Type.REQUEST,
  27. request: { verb: 'PUT', path: '/messages' }
  28. });
  29. before(function(done) {
  30. var signal = new textsecure.protobuf.Envelope(attrs).toArrayBuffer();
  31. var data = new textsecure.protobuf.DataMessage({ body: 'hello' });
  32. var signaling_key = signalingKey;
  33. var aes_key = signaling_key.slice(0, 32);
  34. var mac_key = signaling_key.slice(32, 32 + 20);
  35. window.crypto.subtle.importKey('raw', aes_key, {name: 'AES-CBC'}, false, ['encrypt']).then(function(key) {
  36. var iv = libsignal.crypto.getRandomBytes(16);
  37. window.crypto.subtle.encrypt({name: 'AES-CBC', iv: new Uint8Array(iv)}, key, signal).then(function(ciphertext) {
  38. window.crypto.subtle.importKey('raw', mac_key, {name: 'HMAC', hash: {name: 'SHA-256'}}, false, ['sign']).then(function(key) {
  39. window.crypto.subtle.sign( {name: 'HMAC', hash: 'SHA-256'}, key, signal).then(function(mac) {
  40. var version = new Uint8Array([1]);
  41. var message = dcodeIO.ByteBuffer.concat([version, iv, ciphertext, mac ]);
  42. websocketmessage.request.body = message.toArrayBuffer();
  43. console.log(new Uint8Array(message.toArrayBuffer()));
  44. done();
  45. });
  46. });
  47. });
  48. });
  49. });
  50. it('connects', function(done) {
  51. var mockServer = new MockServer('ws://localhost:8080/v1/websocket/?login='+ encodeURIComponent(number) +'.1&password=password');
  52. mockServer.on('connection', function(server) {
  53. server.send(new Blob([ websocketmessage.toArrayBuffer() ]));
  54. });
  55. window.addEventListener('textsecure:message', function(ev) {
  56. var signal = ev.proto;
  57. for (var key in attrs) {
  58. assert.strictEqual(attrs[key], signal[key]);
  59. }
  60. assert.strictEqual(signal.message.body, 'hello');
  61. server.close();
  62. done();
  63. });
  64. var messageReceiver = new textsecure.MessageReceiver('ws://localhost:8080', window);
  65. });
  66. });
  67. });