| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 | ;(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) {	/**	 * Cipher Feedback block mode.	 */	CryptoJS.mode.CFB = (function () {	    var CFB = CryptoJS.lib.BlockCipherMode.extend();	    CFB.Encryptor = CFB.extend({	        processBlock: function (words, offset) {	            // Shortcuts	            var cipher = this._cipher;	            var blockSize = cipher.blockSize;	            generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);	            // Remember this block to use with next block	            this._prevBlock = words.slice(offset, offset + blockSize);	        }	    });	    CFB.Decryptor = CFB.extend({	        processBlock: function (words, offset) {	            // Shortcuts	            var cipher = this._cipher;	            var blockSize = cipher.blockSize;	            // Remember this block to use with next block	            var thisBlock = words.slice(offset, offset + blockSize);	            generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);	            // This block becomes the previous block	            this._prevBlock = thisBlock;	        }	    });	    function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) {	        var keystream;	        // Shortcut	        var iv = this._iv;	        // Generate keystream	        if (iv) {	            keystream = iv.slice(0);	            // Remove IV for subsequent blocks	            this._iv = undefined;	        } else {	            keystream = this._prevBlock;	        }	        cipher.encryptBlock(keystream, 0);	        // Encrypt	        for (var i = 0; i < blockSize; i++) {	            words[offset + i] ^= keystream[i];	        }	    }	    return CFB;	}());	return CryptoJS.mode.CFB;}));
 |