You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					54 lines
				
				1.3 KiB
			
		
		
			
		
	
	
					54 lines
				
				1.3 KiB
			| 
											11 months ago
										 | ;(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) { | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Output Feedback block mode. | ||
|  | 	 */ | ||
|  | 	CryptoJS.mode.OFB = (function () { | ||
|  | 	    var OFB = CryptoJS.lib.BlockCipherMode.extend(); | ||
|  | 
 | ||
|  | 	    var Encryptor = OFB.Encryptor = OFB.extend({ | ||
|  | 	        processBlock: function (words, offset) { | ||
|  | 	            // Shortcuts
 | ||
|  | 	            var cipher = this._cipher | ||
|  | 	            var blockSize = cipher.blockSize; | ||
|  | 	            var iv = this._iv; | ||
|  | 	            var keystream = this._keystream; | ||
|  | 
 | ||
|  | 	            // Generate keystream
 | ||
|  | 	            if (iv) { | ||
|  | 	                keystream = this._keystream = iv.slice(0); | ||
|  | 
 | ||
|  | 	                // Remove IV for subsequent blocks
 | ||
|  | 	                this._iv = undefined; | ||
|  | 	            } | ||
|  | 	            cipher.encryptBlock(keystream, 0); | ||
|  | 
 | ||
|  | 	            // Encrypt
 | ||
|  | 	            for (var i = 0; i < blockSize; i++) { | ||
|  | 	                words[offset + i] ^= keystream[i]; | ||
|  | 	            } | ||
|  | 	        } | ||
|  | 	    }); | ||
|  | 
 | ||
|  | 	    OFB.Decryptor = Encryptor; | ||
|  | 
 | ||
|  | 	    return OFB; | ||
|  | 	}()); | ||
|  | 
 | ||
|  | 
 | ||
|  | 	return CryptoJS.mode.OFB; | ||
|  | 
 | ||
|  | })); |