143 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| ;(function (root, factory) {
 | |
| 	if (typeof exports === "object") {
 | |
| 		// CommonJS
 | |
| 		module.exports = exports = factory(require("./core"));
 | |
| 	}
 | |
| 	else if (typeof define === "function" && define.amd) {
 | |
| 		// AMD
 | |
| 		define(["./core"], factory);
 | |
| 	}
 | |
| 	else {
 | |
| 		// Global (browser)
 | |
| 		factory(root.CryptoJS);
 | |
| 	}
 | |
| }(this, function (CryptoJS) {
 | |
| 
 | |
| 	(function () {
 | |
| 	    // Shortcuts
 | |
| 	    var C = CryptoJS;
 | |
| 	    var C_lib = C.lib;
 | |
| 	    var Base = C_lib.Base;
 | |
| 	    var C_enc = C.enc;
 | |
| 	    var Utf8 = C_enc.Utf8;
 | |
| 	    var C_algo = C.algo;
 | |
| 
 | |
| 	    /**
 | |
| 	     * HMAC algorithm.
 | |
| 	     */
 | |
| 	    var HMAC = C_algo.HMAC = Base.extend({
 | |
| 	        /**
 | |
| 	         * Initializes a newly created HMAC.
 | |
| 	         *
 | |
| 	         * @param {Hasher} hasher The hash algorithm to use.
 | |
| 	         * @param {WordArray|string} key The secret key.
 | |
| 	         *
 | |
| 	         * @example
 | |
| 	         *
 | |
| 	         *     var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key);
 | |
| 	         */
 | |
| 	        init: function (hasher, key) {
 | |
| 	            // Init hasher
 | |
| 	            hasher = this._hasher = new hasher.init();
 | |
| 
 | |
| 	            // Convert string to WordArray, else assume WordArray already
 | |
| 	            if (typeof key == 'string') {
 | |
| 	                key = Utf8.parse(key);
 | |
| 	            }
 | |
| 
 | |
| 	            // Shortcuts
 | |
| 	            var hasherBlockSize = hasher.blockSize;
 | |
| 	            var hasherBlockSizeBytes = hasherBlockSize * 4;
 | |
| 
 | |
| 	            // Allow arbitrary length keys
 | |
| 	            if (key.sigBytes > hasherBlockSizeBytes) {
 | |
| 	                key = hasher.finalize(key);
 | |
| 	            }
 | |
| 
 | |
| 	            // Clamp excess bits
 | |
| 	            key.clamp();
 | |
| 
 | |
| 	            // Clone key for inner and outer pads
 | |
| 	            var oKey = this._oKey = key.clone();
 | |
| 	            var iKey = this._iKey = key.clone();
 | |
| 
 | |
| 	            // Shortcuts
 | |
| 	            var oKeyWords = oKey.words;
 | |
| 	            var iKeyWords = iKey.words;
 | |
| 
 | |
| 	            // XOR keys with pad constants
 | |
| 	            for (var i = 0; i < hasherBlockSize; i++) {
 | |
| 	                oKeyWords[i] ^= 0x5c5c5c5c;
 | |
| 	                iKeyWords[i] ^= 0x36363636;
 | |
| 	            }
 | |
| 	            oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes;
 | |
| 
 | |
| 	            // Set initial values
 | |
| 	            this.reset();
 | |
| 	        },
 | |
| 
 | |
| 	        /**
 | |
| 	         * Resets this HMAC to its initial state.
 | |
| 	         *
 | |
| 	         * @example
 | |
| 	         *
 | |
| 	         *     hmacHasher.reset();
 | |
| 	         */
 | |
| 	        reset: function () {
 | |
| 	            // Shortcut
 | |
| 	            var hasher = this._hasher;
 | |
| 
 | |
| 	            // Reset
 | |
| 	            hasher.reset();
 | |
| 	            hasher.update(this._iKey);
 | |
| 	        },
 | |
| 
 | |
| 	        /**
 | |
| 	         * Updates this HMAC with a message.
 | |
| 	         *
 | |
| 	         * @param {WordArray|string} messageUpdate The message to append.
 | |
| 	         *
 | |
| 	         * @return {HMAC} This HMAC instance.
 | |
| 	         *
 | |
| 	         * @example
 | |
| 	         *
 | |
| 	         *     hmacHasher.update('message');
 | |
| 	         *     hmacHasher.update(wordArray);
 | |
| 	         */
 | |
| 	        update: function (messageUpdate) {
 | |
| 	            this._hasher.update(messageUpdate);
 | |
| 
 | |
| 	            // Chainable
 | |
| 	            return this;
 | |
| 	        },
 | |
| 
 | |
| 	        /**
 | |
| 	         * Finalizes the HMAC computation.
 | |
| 	         * Note that the finalize operation is effectively a destructive, read-once operation.
 | |
| 	         *
 | |
| 	         * @param {WordArray|string} messageUpdate (Optional) A final message update.
 | |
| 	         *
 | |
| 	         * @return {WordArray} The HMAC.
 | |
| 	         *
 | |
| 	         * @example
 | |
| 	         *
 | |
| 	         *     var hmac = hmacHasher.finalize();
 | |
| 	         *     var hmac = hmacHasher.finalize('message');
 | |
| 	         *     var hmac = hmacHasher.finalize(wordArray);
 | |
| 	         */
 | |
| 	        finalize: function (messageUpdate) {
 | |
| 	            // Shortcut
 | |
| 	            var hasher = this._hasher;
 | |
| 
 | |
| 	            // Compute HMAC
 | |
| 	            var innerHash = hasher.finalize(messageUpdate);
 | |
| 	            hasher.reset();
 | |
| 	            var hmac = hasher.finalize(this._oKey.clone().concat(innerHash));
 | |
| 
 | |
| 	            return hmac;
 | |
| 	        }
 | |
| 	    });
 | |
| 	}());
 | |
| 
 | |
| 
 | |
| })); |