-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathindex.js
46 lines (37 loc) · 1.82 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
const express = require('express');
const app = express();
const http = require('http').Server(app);
const io = require('socket.io')(http);
const rsaWrapper = require('./components/rsa-wrapper');
const aesWrapper = require('./components/aes-wrapper');
rsaWrapper.initLoadServerKeys(__dirname);
rsaWrapper.serverExampleEncrypt();
// middleware for static processing
app.use(express.static(__dirname + '/static'));
// web socket connection event
io.on('connection', function(socket){
// Test sending to client dummy RSA message
let encrypted = rsaWrapper.encrypt(rsaWrapper.clientPub, 'Hello RSA message from client to server');
socket.emit('rsa server encrypted message', encrypted);
// Test accepting dummy RSA message from client
socket.on('rsa client encrypted message', function (data) {
console.log('Server received RSA message from client');
console.log('Encrypted message is', '\n', data);
console.log('Decrypted message', '\n', rsaWrapper.decrypt(rsaWrapper.serverPrivate, data));
});
// Test AES key sending
const aesKey = aesWrapper.generateKey();
let encryptedAesKey = rsaWrapper.encrypt(rsaWrapper.clientPub, (aesKey.toString('base64')));
socket.emit('send key from server to client', encryptedAesKey);
// Test accepting dummy AES key message
socket.on('aes client encrypted message', function (data) {
// console.log('Server received AES message from client', '\n', 'Encrypted message is', '\n', data);
console.log('Decrypted message', '\n', aesWrapper.decrypt(aesKey, data));
// Test send client dummy AES message
let message = aesWrapper.createAesMessage(aesKey, 'Server AES message');
socket.emit('aes server encrypted message', message);
});
});
http.listen(3000, function(){
console.log('listening on *:3000');
});