@sendsafely/sendsafely 1.1.3 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/FileUtil.js +13 -3
- package/lib/SendSafely.js +3 -0
- package/lib/keyGeneratorWorker.js +21 -22
- package/package.json +1 -1
package/lib/FileUtil.js
CHANGED
|
@@ -29,6 +29,7 @@ function FileUtil(param) {
|
|
|
29
29
|
this.eof = false;
|
|
30
30
|
this.data = [];
|
|
31
31
|
this.tempSize = 0;
|
|
32
|
+
this.part = 1;
|
|
32
33
|
|
|
33
34
|
this.init = function() {
|
|
34
35
|
return new Promise(function(resolve) {
|
|
@@ -40,7 +41,7 @@ function FileUtil(param) {
|
|
|
40
41
|
myself.file.name = path.basename(myself.filePath);
|
|
41
42
|
|
|
42
43
|
if(myself.file.size > (myself.SEGMENT_SIZE/4)) {
|
|
43
|
-
myself.file.totalParts = Math.ceil((myself.file.size-(myself.SEGMENT_SIZE/4))/myself.SEGMENT_SIZE);
|
|
44
|
+
myself.file.totalParts = 1 + Math.ceil((myself.file.size-(myself.SEGMENT_SIZE/4))/myself.SEGMENT_SIZE);
|
|
44
45
|
} else {
|
|
45
46
|
myself.file.totalParts = 1;
|
|
46
47
|
}
|
|
@@ -56,9 +57,14 @@ function FileUtil(param) {
|
|
|
56
57
|
|
|
57
58
|
myself.readableStream.on('end', function() {
|
|
58
59
|
// done reading file
|
|
59
|
-
|
|
60
|
-
|
|
60
|
+
myself.eof = true;
|
|
61
|
+
if(myself.part === myself.file.totalParts) {
|
|
61
62
|
callback(true);
|
|
63
|
+
} else {
|
|
64
|
+
// increment extra part if file size is less than segment/4
|
|
65
|
+
// so that we callback with an empty array
|
|
66
|
+
myself.part++;
|
|
67
|
+
callback(false);
|
|
62
68
|
}
|
|
63
69
|
});
|
|
64
70
|
}
|
|
@@ -71,11 +77,15 @@ function FileUtil(param) {
|
|
|
71
77
|
if(!myself.reading && !myself.eof) {
|
|
72
78
|
myself.reading = true;
|
|
73
79
|
processChunk();
|
|
80
|
+
} else if(myself.part === myself.file.totalParts) {
|
|
81
|
+
//extra part padding with empty array if file size is less than segment/4
|
|
82
|
+
callback(true);
|
|
74
83
|
}
|
|
75
84
|
}
|
|
76
85
|
|
|
77
86
|
function processChunk() {
|
|
78
87
|
if(myself.tempSize === myself.SEGMENT_SIZE) {
|
|
88
|
+
myself.part++;
|
|
79
89
|
// callback when data size reaches SEGMENT_SIZE
|
|
80
90
|
callback(false);
|
|
81
91
|
} else {
|
package/lib/SendSafely.js
CHANGED
|
@@ -2077,6 +2077,9 @@ function DecryptKeycode (eventHandler) {
|
|
|
2077
2077
|
randomness = sjcl.codec.utf8String.fromBits(sjcl.random.randomWords(data.bytes,6));
|
|
2078
2078
|
window.postMessage({'cmd': 'randBuff', 'randomness': randomness},'*');
|
|
2079
2079
|
break;
|
|
2080
|
+
case 'error':
|
|
2081
|
+
myself.eventHandler.raiseError(data.stacktrace, data.message, myself.customErrorEvent);
|
|
2082
|
+
break;
|
|
2080
2083
|
}
|
|
2081
2084
|
}
|
|
2082
2085
|
|
|
@@ -78,30 +78,29 @@ self.addEventListener('message', async function(e) {
|
|
|
78
78
|
}
|
|
79
79
|
break;
|
|
80
80
|
case 'decrypt_keycode':
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
81
|
+
try {
|
|
82
|
+
self.randomCounter = 0;
|
|
83
|
+
self.randomness = data.randomness;
|
|
84
|
+
var privKeys = await openpgp.key.readArmored(data.privateKey);
|
|
85
|
+
privKey = privKeys.keys[0];
|
|
86
|
+
var message = await openpgp.message.readArmored(data.keyCode);
|
|
87
|
+
|
|
88
|
+
options =
|
|
89
|
+
{
|
|
90
|
+
message: message, // parse armored message
|
|
91
|
+
privateKeys: [privKey] // for decryption
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
openpgp.decrypt(options).then(function(plaintext) {
|
|
95
|
+
self.send({'cmd': 'keycode_decrypted', 'decryptedKeycode': plaintext.data});
|
|
96
|
+
}, function(err) {
|
|
97
|
+
debug('ERROR');
|
|
98
|
+
debug(err);
|
|
98
99
|
sendError(err);
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
debug('ERROR');
|
|
102
|
-
debug(err);
|
|
100
|
+
});
|
|
101
|
+
} catch (err) {
|
|
103
102
|
sendError(err);
|
|
104
|
-
}
|
|
103
|
+
}
|
|
105
104
|
break;
|
|
106
105
|
case 'randBuff':
|
|
107
106
|
self.randomness += data.randomness;
|