(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i} Empty promise whose resolution indicates that the buffer has been refilled */ function randomCallback() { if (!randomQueue.length) { self.postMessage({ event: 'request-seed', amount: MAX_SIZE_RANDOM_BUFFER }); } return new Promise(function(resolve) { randomQueue.push(resolve); }); } openpgp.crypto.random.randomBuffer.init(MAX_SIZE_RANDOM_BUFFER, randomCallback); /** * Handle messages from the main window. * @param {Object} event Contains event type and data */ self.onmessage = function(event) { var msg = event.data || {}; switch (msg.event) { case 'configure': configure(msg.config); break; case 'seed-random': seedRandom(msg.buf); var queueCopy = randomQueue; randomQueue = []; for (var i = 0; i < queueCopy.length; i++) { queueCopy[i](); } break; default: delegate(msg.id, msg.event, msg.options || {}); } }; /** * Set config from main context to worker context. * @param {Object} config The openpgp configuration */ function configure(config) { Object.keys(config).forEach(function(key) { openpgp.config[key] = config[key]; }); } /** * Seed the library with entropy gathered window.crypto.getRandomValues * as this api is only avalible in the main window. * @param {ArrayBuffer} buffer Some random bytes */ function seedRandom(buffer) { if (!(buffer instanceof Uint8Array)) { buffer = new Uint8Array(buffer); } openpgp.crypto.random.randomBuffer.set(buffer); } /** * Generic proxy function that handles all commands from the public api. * @param {String} method The public api function to be delegated to the worker thread * @param {Object} options The api function's options */ function delegate(id, method, options) { if (typeof openpgp[method] !== 'function') { response({ id:id, event:'method-return', err:'Unknown Worker Event' }); return; } // construct ReadableStreams from MessagePorts openpgp.util.restoreStreams(options); // parse cloned packets options = openpgp.packet.clone.parseClonedPackets(options, method); openpgp[method](options).then(function(data) { // clone packets (for web worker structured cloning algorithm) response({ id:id, event:'method-return', data:openpgp.packet.clone.clonePackets(data) }); }).catch(function(e) { openpgp.util.print_debug_error(e); response({ id:id, event:'method-return', err:e.message, stack:e.stack }); }); } /** * Respond to the main window. * @param {Object} event Contains event type and data */ function response(event) { self.postMessage(event, openpgp.util.getTransferables(event.data, true)); } /** * Let the main window know the worker has loaded. */ postMessage({ event: 'loaded' }); },{}]},{},[1]);