49 lines
1.2 KiB
JavaScript
49 lines
1.2 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) {
|
|
|
|
/**
|
|
* ANSI X.923 padding strategy.
|
|
*/
|
|
CryptoJS.pad.AnsiX923 = {
|
|
pad: function (data, blockSize) {
|
|
// Shortcuts
|
|
var dataSigBytes = data.sigBytes;
|
|
var blockSizeBytes = blockSize * 4;
|
|
|
|
// Count padding bytes
|
|
var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes;
|
|
|
|
// Compute last byte position
|
|
var lastBytePos = dataSigBytes + nPaddingBytes - 1;
|
|
|
|
// Pad
|
|
data.clamp();
|
|
data.words[lastBytePos >>> 2] |= nPaddingBytes << (24 - (lastBytePos % 4) * 8);
|
|
data.sigBytes += nPaddingBytes;
|
|
},
|
|
|
|
unpad: function (data) {
|
|
// Get number of padding bytes from last byte
|
|
var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;
|
|
|
|
// Remove padding
|
|
data.sigBytes -= nPaddingBytes;
|
|
}
|
|
};
|
|
|
|
|
|
return CryptoJS.pad.Ansix923;
|
|
|
|
})); |