|  |  |  | /* | 
					
						
							|  |  |  |  * vim: ts=4:sw=4:expandtab | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('MessageReceiver', function() { | 
					
						
							|  |  |  |     textsecure.storage.impl = new SignalProtocolStore(); | 
					
						
							|  |  |  |     var WebSocket = window.WebSocket; | 
					
						
							|  |  |  |     var number = '+19999999999'; | 
					
						
							|  |  |  |     var deviceId = 1; | 
					
						
							|  |  |  |     var signalingKey = libsignal.crypto.getRandomBytes(32 + 20); | 
					
						
							|  |  |  |     before(function() { | 
					
						
							|  |  |  |         window.WebSocket = MockSocket; | 
					
						
							|  |  |  |         textsecure.storage.user.setNumberAndDeviceId(number, deviceId, 'name'); | 
					
						
							|  |  |  |         textsecure.storage.put("password", "password"); | 
					
						
							|  |  |  |         textsecure.storage.put("signaling_key", signalingKey); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     after (function() { window.WebSocket = WebSocket;  }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('connecting', function() { | 
					
						
							|  |  |  |         var blob = null; | 
					
						
							|  |  |  |         var attrs = { | 
					
						
							|  |  |  |             type: textsecure.protobuf.Envelope.Type.CIPHERTEXT, | 
					
						
							|  |  |  |             source: number, | 
					
						
							|  |  |  |             sourceDevice: deviceId, | 
					
						
							|  |  |  |             timestamp: Date.now(), | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         var websocketmessage = new textsecure.protobuf.WebSocketMessage({ | 
					
						
							|  |  |  |             type: textsecure.protobuf.WebSocketMessage.Type.REQUEST, | 
					
						
							|  |  |  |             request: { verb: 'PUT', path: '/messages' } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         before(function(done) { | 
					
						
							|  |  |  |             var signal = new textsecure.protobuf.Envelope(attrs).toArrayBuffer(); | 
					
						
							|  |  |  |             var data = new textsecure.protobuf.DataMessage({ body: 'hello' }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             var signaling_key = signalingKey; | 
					
						
							|  |  |  |             var aes_key = signaling_key.slice(0, 32); | 
					
						
							|  |  |  |             var mac_key = signaling_key.slice(32, 32 + 20); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             window.crypto.subtle.importKey('raw', aes_key, {name: 'AES-CBC'}, false, ['encrypt']).then(function(key) { | 
					
						
							|  |  |  |                 var iv = libsignal.crypto.getRandomBytes(16); | 
					
						
							|  |  |  |                 window.crypto.subtle.encrypt({name: 'AES-CBC', iv: new Uint8Array(iv)}, key, signal).then(function(ciphertext) { | 
					
						
							|  |  |  |                     window.crypto.subtle.importKey('raw', mac_key, {name: 'HMAC', hash: {name: 'SHA-256'}}, false, ['sign']).then(function(key) { | 
					
						
							|  |  |  |                         window.crypto.subtle.sign( {name: 'HMAC', hash: 'SHA-256'}, key, signal).then(function(mac) { | 
					
						
							|  |  |  |                             var version = new Uint8Array([1]); | 
					
						
							|  |  |  |                             var message = dcodeIO.ByteBuffer.concat([version, iv, ciphertext, mac ]); | 
					
						
							|  |  |  |                             websocketmessage.request.body = message.toArrayBuffer(); | 
					
						
							|  |  |  |                             console.log(new Uint8Array(message.toArrayBuffer())); | 
					
						
							|  |  |  |                             done(); | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         it('connects', function(done) { | 
					
						
							|  |  |  |             var mockServer = new MockServer('ws://localhost:8080/v1/websocket/?login='+ encodeURIComponent(number) +'.1&password=password'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             mockServer.on('connection', function(server) { | 
					
						
							|  |  |  |                 server.send(new Blob([ websocketmessage.toArrayBuffer() ])); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             window.addEventListener('textsecure:message', function(ev) { | 
					
						
							|  |  |  |                 var signal = ev.proto; | 
					
						
							|  |  |  |                 for (var key in attrs) { | 
					
						
							|  |  |  |                     assert.strictEqual(attrs[key], signal[key]); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 assert.strictEqual(signal.message.body, 'hello'); | 
					
						
							|  |  |  |                 server.close(); | 
					
						
							|  |  |  |                 done(); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |             var messageReceiver = new textsecure.MessageReceiver('ws://localhost:8080', window); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | }); |