From 1906ddfb5d3887edeedaf8e07d14ad89abbd214d Mon Sep 17 00:00:00 2001 From: Giulio Cesare Solaroli Date: Sun, 21 Apr 2013 15:54:15 +0000 Subject: Aborted attempt to factor out the Crypto library on its own module --- (limited to 'frontend/gamma/js/ClipperzCryptoLibrary/AES.js') diff --git a/frontend/gamma/js/ClipperzCryptoLibrary/AES.js b/frontend/gamma/js/ClipperzCryptoLibrary/AES.js deleted file mode 100644 index cbbbb13..0000000 --- a/frontend/gamma/js/ClipperzCryptoLibrary/AES.js +++ b/dev/null @@ -1,864 +0,0 @@ -/* - -Copyright 2008-2013 Clipperz Srl - -This file is part of Clipperz, the online password manager. -For further information about its features and functionalities please -refer to http://www.clipperz.com. - -* Clipperz is free software: you can redistribute it and/or modify it - under the terms of the GNU Affero General Public License as published - by the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - -* Clipperz is distributed in the hope that it will be useful, but - WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - See the GNU Affero General Public License for more details. - -* You should have received a copy of the GNU Affero General Public - License along with Clipperz. If not, see http://www.gnu.org/licenses/. - -*/ - -try { if (typeof(Clipperz.ByteArray) == 'undefined') { throw ""; }} catch (e) { - throw "Clipperz.Crypto.AES depends on Clipperz.ByteArray!"; -} - -// Dependency commented to avoid a circular reference -//try { if (typeof(Clipperz.Crypto.PRNG) == 'undefined') { throw ""; }} catch (e) { -// throw "Clipperz.Crypto.AES depends on Clipperz.Crypto.PRNG!"; -//} - -if (typeof(Clipperz.Crypto.AES) == 'undefined') { Clipperz.Crypto.AES = {}; } - -//############################################################################# - -Clipperz.Crypto.AES.DeferredExecutionContext = function(args) { - args = args || {}; - - this._key = args.key; - this._message = args.message; - this._result = args.message.clone(); - this._nonce = args.nonce; - this._messageLength = this._message.length(); - - this._messageArray = this._message.arrayValues(); - this._resultArray = this._result.arrayValues(); - this._nonceArray = this._nonce.arrayValues(); - - this._executionStep = 0; - -// this._elaborationChunkSize = 1024; // 4096; // 16384; // 4096; - this._elaborationChunks = 10; - this._pauseTime = 0.02; // 0.02 // 0.2; - - return this; -} - -Clipperz.Crypto.AES.DeferredExecutionContext.prototype = MochiKit.Base.update(null, { - - 'key': function() { - return this._key; - }, - - 'message': function() { - return this._message; - }, - - 'messageLength': function() { - return this._messageLength; - }, - - 'result': function() { - return new Clipperz.ByteArray(this.resultArray()); - }, - - 'nonce': function() { - return this._nonce; - }, - - 'messageArray': function() { - return this._messageArray; - }, - - 'resultArray': function() { - return this._resultArray; - }, - - 'nonceArray': function() { - return this._nonceArray; - }, - - 'elaborationChunkSize': function() { -// return Clipperz.Crypto.AES.DeferredExecution.chunkSize; -// return this._elaborationChunkSize; - return (this._elaborationChunks * 1024); - }, - - 'executionStep': function() { - return this._executionStep; - }, - - 'setExecutionStep': function(aValue) { - this._executionStep = aValue; - }, - - 'tuneExecutionParameters': function (anElapsedTime) { -//var originalChunks = this._elaborationChunks; - if (anElapsedTime > 0) { - this._elaborationChunks = Math.round(this._elaborationChunks * ((anElapsedTime + 1000)/(anElapsedTime * 2))); - } -//Clipperz.log("tuneExecutionParameters - elapsedTime: " + anElapsedTime + /*originalChunks,*/ " chunks # " + this._elaborationChunks + " [" + this._executionStep + " / " + this._messageLength + "]"); - }, - - 'pause': function(aValue) { -// return MochiKit.Async.wait(Clipperz.Crypto.AES.DeferredExecution.pauseTime, aValue); - return MochiKit.Async.wait(this._pauseTime, aValue); - }, - - 'isDone': function () { -//console.log("isDone", this.executionStep(), this.messageLength()); - return (this._executionStep >= this._messageLength); - }, - - //----------------------------------------------------------------------------- - __syntaxFix__: "syntax fix" - -}); - -//############################################################################# - -Clipperz.Crypto.AES.Key = function(args) { - args = args || {}; - - this._key = args.key; - this._keySize = args.keySize || this.key().length(); - - if (this.keySize() == 128/8) { - this._b = 176; - this._numberOfRounds = 10; - } else if (this.keySize() == 256/8) { - this._b = 240; - this._numberOfRounds = 14; - } else { - MochiKit.Logging.logError("AES unsupported key size: " + (this.keySize() * 8) + " bits"); - throw Clipperz.Crypto.AES.exception.UnsupportedKeySize; - } - - this._stretchedKey = null; - - return this; -} - -Clipperz.Crypto.AES.Key.prototype = MochiKit.Base.update(null, { - - 'asString': function() { - return "Clipperz.Crypto.AES.Key (" + this.key().toHexString() + ")"; - }, - - //----------------------------------------------------------------------------- - - 'key': function() { - return this._key; - }, - - 'keySize': function() { - return this._keySize; - }, - - 'b': function() { - return this._b; - }, - - 'numberOfRounds': function() { - return this._numberOfRounds; - }, - //========================================================================= - - 'keyScheduleCore': function(aWord, aRoundConstantsIndex) { - var result; - var sbox; - - sbox = Clipperz.Crypto.AES.sbox(); - - result = [ sbox[aWord[1]] ^ Clipperz.Crypto.AES.roundConstants()[aRoundConstantsIndex], - sbox[aWord[2]], - sbox[aWord[3]], - sbox[aWord[0]] ]; - - return result; - }, - - //----------------------------------------------------------------------------- - - 'xorWithPreviousStretchValues': function(aKey, aWord, aPreviousWordIndex) { - var result; - var i,c; - - result = []; - c = 4; - for (i=0; i 5 9 13 1 - // 2 6 10 14 10 14 2 6 - // 3 7 11 15 15 3 7 11 - // - '_shiftRowMapping': null, - 'shiftRowMapping': function() { - if (Clipperz.Crypto.AES._shiftRowMapping == null) { - Clipperz.Crypto.AES._shiftRowMapping = [0, 5, 10, 15, 4, 9, 14, 3, 8, 13, 2, 7, 12, 1, 6, 11]; - } - - return Clipperz.Crypto.AES._shiftRowMapping; - }, - - //----------------------------------------------------------------------------- - - '_mixColumnsMatrix': null, - 'mixColumnsMatrix': function() { - if (Clipperz.Crypto.AES._mixColumnsMatrix == null) { - Clipperz.Crypto.AES._mixColumnsMatrix = [ [2, 3, 1 ,1], - [1, 2, 3, 1], - [1, 1, 2, 3], - [3, 1, 1, 2] ]; - } - - return Clipperz.Crypto.AES._mixColumnsMatrix; - }, - - '_roundConstants': null, - 'roundConstants': function() { - if (Clipperz.Crypto.AES._roundConstants == null) { - Clipperz.Crypto.AES._roundConstants = [ , 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, 77, 154]; -// Clipperz.Crypto.AES._roundConstants = [ , 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a]; - } - - return Clipperz.Crypto.AES._roundConstants; - }, - - //============================================================================= - - 'incrementNonce': function(aNonce) { -//Clipperz.Profile.start("Clipperz.Crypto.AES.incrementNonce"); - var i; - var done; - - done = false; - i = aNonce.length - 1; - - while ((i>=0) && (done == false)) { - var currentByteValue; - - currentByteValue = aNonce[i]; - - if (currentByteValue == 0xff) { - aNonce[i] = 0; - if (i>= 0) { - i --; - } else { - done = true; - } - } else { - aNonce[i] = currentByteValue + 1; - done = true; - } - } -//Clipperz.Profile.stop("Clipperz.Crypto.AES.incrementNonce"); - }, - - //----------------------------------------------------------------------------- - - 'encryptBlock': function(aKey, aBlock) { - var result; - var state; - - state = new Clipperz.Crypto.AES.State({block:aBlock, key:aKey}); -//is(state.data(), 'before'); - state.encrypt(); - result = state.data(); - - return result; - }, - - //----------------------------------------------------------------------------- - - 'encryptBlocks': function(aKey, aMessage, aNonce) { - var result; - var nonce; - var self; - var messageIndex; - var messageLength; - var blockSize; - - self = Clipperz.Crypto.AES; - blockSize = 128/8; - messageLength = aMessage.length; - nonce = aNonce; - - result = aMessage; - messageIndex = 0; - while (messageIndex < messageLength) { - var encryptedBlock; - var i,c; - - self.incrementNonce(nonce); - encryptedBlock = self.encryptBlock(aKey, nonce); - - if ((messageLength - messageIndex) > blockSize) { - c = blockSize; - } else { - c = messageLength - messageIndex; - } - - for (i=0; i blockSize) { - c = blockSize; - } else { - c = executionLimit - messageIndex; - } - - for (i=0; i>> deferredEncrypt"); return aValue; }); - deferredResult.addCallback(Clipperz.Crypto.AES.deferredEncryptBlocks); - deferredResult.addCallback(function(anExecutionContext) { - var result; - - result = anExecutionContext.nonce().clone(); - result.appendBytes(anExecutionContext.resultArray()); - - return result; - }); -//deferredResult.addCallback(function (aValue) { console.log("<<< deferredEncrypt"); return aValue; }); - deferredResult.callback(executionContext) - - return deferredResult; - }, - - //----------------------------------------------------------------------------- - - 'deferredDecrypt': function(aKey, someData) { - var deferredResult - var nonce; - var message; - var key; - - key = new Clipperz.Crypto.AES.Key({key:aKey}); - nonce = someData.split(0, (128/8)); - message = someData.split(128/8); - executionContext = new Clipperz.Crypto.AES.DeferredExecutionContext({key:key, message:message, nonce:nonce}); - - deferredResult = new Clipperz.Async.Deferred("AES.deferredDecrypt"); -//deferredResult.addCallback(function (aValue) { console.log(">>> deferredDecrypt"); return aValue; }); - deferredResult.addCallback(Clipperz.Crypto.AES.deferredEncryptBlocks); - deferredResult.addCallback(function(anExecutionContext) { - return anExecutionContext.result(); - }); -//deferredResult.addCallback(function (aValue) { console.log("<<< deferredDecrypt"); return aValue; }); - deferredResult.callback(executionContext); - - return deferredResult; - }, - - //----------------------------------------------------------------------------- - __syntaxFix__: "syntax fix" - -}); - -//############################################################################# - -//Clipperz.Crypto.AES.DeferredExecution = { -// 'chunkSize': 16384, // 4096, // 1024 4096 8192 16384 32768; -// 'pauseTime': 0.02 // 0.2 -//} - -Clipperz.Crypto.AES.exception = { - 'UnsupportedKeySize': new MochiKit.Base.NamedError("Clipperz.Crypto.AES.exception.UnsupportedKeySize") -}; -- cgit v0.9.0.2