-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathe2ee-diffiehellman.js
More file actions
36 lines (27 loc) · 1.13 KB
/
e2ee-diffiehellman.js
File metadata and controls
36 lines (27 loc) · 1.13 KB
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
"use strict";
// Dependencies
const sAES256 = require("simple-aes-256")
const crypto = require("crypto")
// Variables
const message = "The First Decree"
// Functions
const sAES256E = (string, key)=>{return sAES256.encrypt(key, string).toString("hex")}
const sAES256D = (string, key)=>{return sAES256.decrypt(key, Buffer.from(string, "hex")).toString("utf8")}
// Main
//* Server
const server = crypto.createDiffieHellman(2048)
const serverPK = server.generateKeys()
//* Client
const client = crypto.createDiffieHellman(server.getPrime(), server.getGenerator()) // Prime and Generator is encoded to something and passed to client from server.
const clientPK = client.generateKeys()
//* Client-End
const serverSecret = client.computeSecret(serverPK)
//* Server-End
const clientSecret = server.computeSecret(clientPK)
//* End
const encrypted = sAES256E(message, serverSecret.toString("hex"))
const decrypted = sAES256D(encrypted, clientSecret.toString("hex"))
console.log("Server Key:", serverSecret.toString("hex"))
console.log("Client Key:", clientSecret.toString("hex"))
console.log("Encrypted:", encrypted)
console.log("Decrypted:", decrypted)