2014-07-05 00:01:23 +04:00
|
|
|
/*!
|
2015-02-11 22:11:08 +03:00
|
|
|
* Webogram v0.4.0 - messaging web application for MTProto
|
2014-07-05 00:01:23 +04:00
|
|
|
* https://github.com/zhukov/webogram
|
|
|
|
* Copyright (C) 2014 Igor Zhukov <igor.beatle@gmail.com>
|
|
|
|
* https://github.com/zhukov/webogram/blob/master/LICENSE
|
|
|
|
*/
|
|
|
|
|
|
|
|
importScripts(
|
2014-10-01 21:36:11 +04:00
|
|
|
'polyfill.js',
|
2014-07-05 00:01:23 +04:00
|
|
|
'bin_utils.js',
|
|
|
|
'../../vendor/jsbn/jsbn_combined.js',
|
|
|
|
'../../vendor/leemon_bigint/bigint.js',
|
|
|
|
'../../vendor/closure/long.js',
|
2014-10-23 13:33:46 +04:00
|
|
|
'../../vendor/cryptoJS/crypto.js',
|
|
|
|
'../../vendor/rusha/rusha.js'
|
2014-07-05 00:01:23 +04:00
|
|
|
);
|
|
|
|
|
|
|
|
onmessage = function (e) {
|
|
|
|
var taskID = e.data.taskID,
|
|
|
|
result;
|
|
|
|
|
|
|
|
switch (e.data.task) {
|
|
|
|
case 'factorize':
|
|
|
|
result = pqPrimeFactorization(e.data.bytes);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'mod-pow':
|
|
|
|
result = bytesModPow(e.data.x, e.data.y, e.data.m);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'sha1-hash':
|
2014-10-24 22:37:43 +04:00
|
|
|
result = sha1HashSync(e.data.bytes);
|
2014-07-05 00:01:23 +04:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'aes-encrypt':
|
2014-10-24 22:37:43 +04:00
|
|
|
result = aesEncryptSync(e.data.bytes, e.data.keyBytes, e.data.ivBytes);
|
2014-07-05 00:01:23 +04:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'aes-decrypt':
|
2014-10-24 22:37:43 +04:00
|
|
|
result = aesDecryptSync(e.data.encryptedBytes, e.data.keyBytes, e.data.ivBytes);
|
2014-07-05 00:01:23 +04:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
throw new Error('Unknown task: ' + e.data.task);
|
|
|
|
}
|
|
|
|
|
|
|
|
postMessage({taskID: taskID, result: result});
|
|
|
|
}
|
2014-10-30 14:20:10 +03:00
|
|
|
|
|
|
|
postMessage('ready');
|