-
Notifications
You must be signed in to change notification settings - Fork 1
/
oneTimePad.js
110 lines (84 loc) · 4.44 KB
/
oneTimePad.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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
oneTimePadMethodEncryption = (message, oneTimePad, cb) => {
let lowerCaseCharacterList = 'abcdefghijklmnopqrstuvwxyz'.split('');
let upperCaseCharacterList = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.split('');
let length = message.length;
let encryptedMessage = '';
if (length > oneTimePad.length) {
return cb('Length of oneTimePad is smaller than the message length.', null);
}
for (let index = 0; index < message.length; index ++) {
let messageCharacter = message.charAt(index);
let oneTimePadCharacter = oneTimePad.charAt(index);
let messageCharacterIndex, oneTimePadCharacterIndex;
let newCharacter, newCharacterIndex;
if (messageCharacter == messageCharacter.toUpperCase()) {
messageCharacterIndex = upperCaseCharacterList.indexOf(messageCharacter) + 1;
} else {
messageCharacterIndex = lowerCaseCharacterList.indexOf(messageCharacter) + 1;
}
if (oneTimePadCharacter == oneTimePadCharacter.toUpperCase()) {
oneTimePadCharacterIndex = upperCaseCharacterList.indexOf(oneTimePadCharacter) + 1;
} else {
oneTimePadCharacterIndex = lowerCaseCharacterList.indexOf(oneTimePadCharacter) + 1;
}
newCharacterIndex = (messageCharacterIndex + oneTimePadCharacterIndex) % 26;
// newCharacterIndex --;
if (newCharacterIndex <= 0) newCharacterIndex += 25;
newCharacter = (messageCharacter == messageCharacter.toUpperCase()) ? upperCaseCharacterList[newCharacterIndex] : lowerCaseCharacterList[newCharacterIndex];
console.log(messageCharacter + '(' + messageCharacterIndex + ') ' + oneTimePadCharacter + '(' + oneTimePadCharacterIndex + ') ' + newCharacter + '(' + newCharacterIndex + ')');
encryptedMessage += newCharacter;
}
console.log('message : ' + message);
console.log('oneTime Pad: ' + oneTimePad);
return cb(null, encryptedMessage);
};
oneTimePadMethodDecryption = (message, oneTimePad, cb) => {
let lowerCaseCharacterList = 'abcdefghijklmnopqrstuvwxyz'.split('');
let upperCaseCharacterList = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.split('');
let length = message.length;
let encryptedMessage = '';
if (length > oneTimePad.length) {
return cb('Length of oneTimePad is smaller than the message length.', null);
}
for (let index = 0; index < message.length; index ++) {
let messageCharacter = message.charAt(index);
let oneTimePadCharacter = oneTimePad.charAt(index);
let messageCharacterIndex, oneTimePadCharacterIndex;
let newCharacter, newCharacterIndex;
if (messageCharacter == messageCharacter.toUpperCase()) {
messageCharacterIndex = upperCaseCharacterList.indexOf(messageCharacter);
} else {
messageCharacterIndex = lowerCaseCharacterList.indexOf(messageCharacter);
}
// messageCharacterIndex ++;
if (oneTimePadCharacter == oneTimePadCharacter.toUpperCase()) {
oneTimePadCharacterIndex = upperCaseCharacterList.indexOf(oneTimePadCharacter);
} else {
oneTimePadCharacterIndex = lowerCaseCharacterList.indexOf(oneTimePadCharacter);
}
oneTimePadCharacterIndex ++;
newCharacterIndex = (messageCharacterIndex - oneTimePadCharacterIndex);
if (newCharacterIndex < 0) newCharacterIndex = newCharacterIndex + 26;
newCharacter = (messageCharacter == messageCharacter.toUpperCase()) ? upperCaseCharacterList[newCharacterIndex] : lowerCaseCharacterList[newCharacterIndex];
console.log(messageCharacter + '(' + messageCharacterIndex + ') ' + oneTimePadCharacter + '(' + oneTimePadCharacterIndex + ') ' + newCharacter + '(' + newCharacterIndex + ')');
encryptedMessage += newCharacter;
}
console.log('message : ' + message);
console.log('oneTime Pad: ' + oneTimePad);
return cb(null, encryptedMessage);
};
oneTimePadMethodEncryption('ZM', 'ZM', (err, encryptedMessage) => {
if (err) {
console.log(err);
} else {
console.log('Encrypted Message: ' + encryptedMessage);
console.log('----------------------------------------------------------------------------------------');
oneTimePadMethodDecryption(encryptedMessage, 'ZM', (err, decryptedMessage) => {
if (err) {
console.log(err);
} else {
console.log('Decrypted Message: ' + decryptedMessage) ;
}
});
}
});