116 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
		
			
		
	
	
			116 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
|  | ;(function (root, factory, undef) { | ||
|  | 	if (typeof exports === "object") { | ||
|  | 		// CommonJS
 | ||
|  | 		module.exports = exports = factory(require("./core"), require("./cipher-core")); | ||
|  | 	} | ||
|  | 	else if (typeof define === "function" && define.amd) { | ||
|  | 		// AMD
 | ||
|  | 		define(["./core", "./cipher-core"], factory); | ||
|  | 	} | ||
|  | 	else { | ||
|  | 		// Global (browser)
 | ||
|  | 		factory(root.CryptoJS); | ||
|  | 	} | ||
|  | }(this, function (CryptoJS) { | ||
|  | 
 | ||
|  | 	/** @preserve | ||
|  | 	 * Counter block mode compatible with  Dr Brian Gladman fileenc.c | ||
|  | 	 * derived from CryptoJS.mode.CTR | ||
|  | 	 * Jan Hruby jhruby.web@gmail.com | ||
|  | 	 */ | ||
|  | 	CryptoJS.mode.CTRGladman = (function () { | ||
|  | 	    var CTRGladman = CryptoJS.lib.BlockCipherMode.extend(); | ||
|  | 
 | ||
|  | 		function incWord(word) | ||
|  | 		{ | ||
|  | 			if (((word >> 24) & 0xff) === 0xff) { //overflow
 | ||
|  | 			var b1 = (word >> 16)&0xff; | ||
|  | 			var b2 = (word >> 8)&0xff; | ||
|  | 			var b3 = word & 0xff; | ||
|  | 
 | ||
|  | 			if (b1 === 0xff) // overflow b1
 | ||
|  | 			{ | ||
|  | 			b1 = 0; | ||
|  | 			if (b2 === 0xff) | ||
|  | 			{ | ||
|  | 				b2 = 0; | ||
|  | 				if (b3 === 0xff) | ||
|  | 				{ | ||
|  | 					b3 = 0; | ||
|  | 				} | ||
|  | 				else | ||
|  | 				{ | ||
|  | 					++b3; | ||
|  | 				} | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 				++b2; | ||
|  | 			} | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 			++b1; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			word = 0; | ||
|  | 			word += (b1 << 16); | ||
|  | 			word += (b2 << 8); | ||
|  | 			word += b3; | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 			word += (0x01 << 24); | ||
|  | 			} | ||
|  | 			return word; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		function incCounter(counter) | ||
|  | 		{ | ||
|  | 			if ((counter[0] = incWord(counter[0])) === 0) | ||
|  | 			{ | ||
|  | 				// encr_data in fileenc.c from  Dr Brian Gladman's counts only with DWORD j < 8
 | ||
|  | 				counter[1] = incWord(counter[1]); | ||
|  | 			} | ||
|  | 			return counter; | ||
|  | 		} | ||
|  | 
 | ||
|  | 	    var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({ | ||
|  | 	        processBlock: function (words, offset) { | ||
|  | 	            // Shortcuts
 | ||
|  | 	            var cipher = this._cipher | ||
|  | 	            var blockSize = cipher.blockSize; | ||
|  | 	            var iv = this._iv; | ||
|  | 	            var counter = this._counter; | ||
|  | 
 | ||
|  | 	            // Generate keystream
 | ||
|  | 	            if (iv) { | ||
|  | 	                counter = this._counter = iv.slice(0); | ||
|  | 
 | ||
|  | 	                // Remove IV for subsequent blocks
 | ||
|  | 	                this._iv = undefined; | ||
|  | 	            } | ||
|  | 
 | ||
|  | 				incCounter(counter); | ||
|  | 
 | ||
|  | 				var keystream = counter.slice(0); | ||
|  | 	            cipher.encryptBlock(keystream, 0); | ||
|  | 
 | ||
|  | 	            // Encrypt
 | ||
|  | 	            for (var i = 0; i < blockSize; i++) { | ||
|  | 	                words[offset + i] ^= keystream[i]; | ||
|  | 	            } | ||
|  | 	        } | ||
|  | 	    }); | ||
|  | 
 | ||
|  | 	    CTRGladman.Decryptor = Encryptor; | ||
|  | 
 | ||
|  | 	    return CTRGladman; | ||
|  | 	}()); | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 	return CryptoJS.mode.CTRGladman; | ||
|  | 
 | ||
|  | })); |