前言
地址:aHR0cHM6Ly93d3cubGlhbmdodWFpcG8uY29tLyMvbGlzdGVkX3N0b2NrX2xpc3Q=
分析
请求一次列表页发现就一个XHR响应,显然数据就在data中做了加密。
然后就是找函数入口了,理论上这种响应打个XHR断点紧接着走一次看看有没有可疑的地方,大概点了10次左右就进入这个js了,看右侧的数据发现突然多了个数据集合,果然这个 s.result_list 就是数据集了。锁定了函数入口接下来就是整理解密函数了。
因为这是个webpack打包的嘛,图方便 就不扣分发器了全部用上。贴代码。
var use
window = this
!function(e) {
x = {}
function r(r) {
for (var t, o, i = r[0], c = r[1], a = r[2], d = 0, l = []; d < i.length; d++)
o = i[d],
Object.prototype.hasOwnProperty.call(A, o) && A[o] && l.push(A[o][0]),
A[o] = 0;
for (t in c)
Object.prototype.hasOwnProperty.call(c, t) && (e[t] = c[t]);
for (C && C(r); l.length; )
l.shift()();
return I.push.apply(I, a || []),
n()
}
function n() {
for (var e, r = 0; r < I.length; r++) {
for (var n = I[r], t = !0, o = 1; o < n.length; o++) {
var i = n[o];
0 !== A[i] && (t = !1)
}
t && (I.splice(r--, 1),
e = S(S.s = n[0]))
}
return e
}
var t = window.webpackHotUpdate;
window.webpackHotUpdate = function(e, r) {
!function(e, r) {
if (!_[e] || !O[e])
return;
for (var n in O[e] = !1,
r)
Object.prototype.hasOwnProperty.call(r, n) && (y[n] = r[n]);
0 == --g && 0 === b && P()
}(e, r),
t && t(e, r)
}
;
var o, i = !0, c = "60784d18242a7ca75c66", a = 1e4, d = {}, l = [], u = [];
function s(e) {
var r = {
_acceptedDependencies: {},
_declinedDependencies: {},
_selfAccepted: !1,
_selfDeclined: !1,
_disposeHandlers: [],
_main: o !== e,
active: !0,
accept: function(e, n) {
if (void 0 === e)
r._selfAccepted = !0;
else if ("function" == typeof e)
r._selfAccepted = e;
else if ("object" == typeof e)
for (var t = 0; t < e.length; t++)
r._acceptedDependencies[e[t]] = n || function() {}
;
else
r._acceptedDependencies[e] = n || function() {}
},
decline: function(e) {
if (void 0 === e)
r._selfDeclined = !0;
else if ("object" == typeof e)
for (var n = 0; n < e.length; n++)
r._declinedDependencies[e[n]] = !0;
else
r._declinedDependencies[e] = !0
},
dispose: function(e) {
r._disposeHandlers.push(e)
},
addDisposeHandler: function(e) {
r._disposeHandlers.push(e)
},
removeDisposeHandler: function(e) {
var n = r._disposeHandlers.indexOf(e);
n >= 0 && r._disposeHandlers.splice(n, 1)
},
check: j,
apply: H,
status: function(e) {
if (!e)
return f;
p.push(e)
},
addStatusHandler: function(e) {
p.push(e)
},
removeStatusHandler: function(e) {
var r = p.indexOf(e);
r >= 0 && p.splice(r, 1)
},
data: d[e]
};
return o = void 0,
r
}
var p = []
, f = "idle";
function h(e) {
f = e;
for (var r = 0; r < p.length; r++)
p[r].call(null, e)
}
var v, y, m, g = 0, b = 0, w = {}, O = {}, _ = {};
function E(e) {
return +e + "" === e ? +e : e
}
function j(e) {
if ("idle" !== f)
throw new Error("check() is only allowed in idle status");
return i = e,
h("check"),
(r = a,
r = r || 1e4,
new Promise((function(e, n) {
if ("undefined" == typeof XMLHttpRequest)
return n(new Error("No browser support"));
try {
var t = new XMLHttpRequest
, o = S.p + "" + c + ".hot-update.json";
t.open("GET", o, !0),
t.timeout = r,
t.send(null)
} catch (e) {
return n(e)
}
t.onreadystatechange = function() {
if (4 === t.readyState)
if (0 === t.status)
n(new Error("Manifest request to " + o + " timed out."));
else if (404 === t.status)
e();
else if (200 !== t.status && 304 !== t.status)
n(new Error("Manifest request to " + o + " failed."));
else {
try {
var r = JSON.parse(t.responseText)
} catch (e) {
return void n(e)
}
e(r)
}
}
}
))).then((function(e) {
if (!e)
return h("idle"),
null;
O = {},
w = {},
_ = e.c,
m = e.h,
h("prepare");
var r = new Promise((function(e, r) {
v = {
resolve: e,
reject: r
}
}
));
for (var n in y = {},
A)
D(n);
return "prepare" === f && 0 === b && 0 === g && P(),
r
}
));
var r
}
function D(e) {
_[e] ? (O[e] = !0,
g++,
function(e) {
var r = document.createElement("script");
r.charset = "utf-8",
r.src = S.p + "" + e + "." + c + ".hot-update.js",
document.head.appendChild(r)
}(e)) : w[e] = !0
}
function P() {
h("ready");
var e = v;
if (v = null,
e)
if (i)
Promise.resolve().then((function() {
return H(i)
}
)).then((function(r) {
e.resolve(r)
}
), (function(r) {
e.reject(r)
}
));
else {
var r = [];
for (var n in y)
Object.prototype.hasOwnProperty.call(y, n) && r.push(E(n));
e.resolve(r)
}
}
function H(r) {
if ("ready" !== f)
throw new Error("apply() is only allowed in ready status");
var n, t, o, i, a;
function u(e) {
for (var r = [e], n = {}, t = r.map((function(e) {
return {
chain: [e],
id: e
}
}
)); t.length > 0; ) {
var o = t.pop()
, c = o.id
, a = o.chain;
if ((i = x[c]) && !i.hot._selfAccepted) {
if (i.hot._selfDeclined)
return {
type: "self-declined",
chain: a,
moduleId: c
};
if (i.hot._main)
return {
type: "unaccepted",
chain: a,
moduleId: c
};
for (var d = 0; d < i.parents.length; d++) {
var l = i.parents[d]
, u = x[l];
if (u) {
if (u.hot._declinedDependencies[c])
return {
type: "declined",
chain: a.concat([l]),
moduleId: c,
parentId: l
};
-1 === r.indexOf(l) && (u.hot._acceptedDependencies[c] ? (n[l] || (n[l] = []),
s(n[l], [c])) : (delete n[l],
r.push(l),
t.push({
chain: a.concat([l]),
id: l
})))
}
}
}
}
return {
type: "accepted",
moduleId: e,
outdatedModules: r,
outdatedDependencies: n
}
}
function s(e, r) {
for (var n = 0; n < r.length; n++) {
var t = r[n];
-1 === e.indexOf(t) && e.push(t)
}
}
r = r || {};
var p = {}
, v = []
, g = {}
, b = function() {
console.warn("[HMR] unexpected require(" + O.moduleId + ") to disposed module")
};
for (var w in y)
if (Object.prototype.hasOwnProperty.call(y, w)) {
var O;
a = E(w);
var j = !1
, D = !1
, P = !1
, H = "";
switch ((O = y[w] ? u(a) : {
type: "disposed",
moduleId: w
}).chain && (H = "\nUpdate propagation: " + O.chain.join(" -> ")),
O.type) {
case "self-declined":
r.onDeclined && r.onDeclined(O),
r.ignoreDeclined || (j = new Error("Aborted because of self decline: " + O.moduleId + H));
break;
case "declined":
r.onDeclined && r.onDeclined(O),
r.ignoreDeclined || (j = new Error("Aborted because of declined dependency: " + O.moduleId + " in " + O.parentId + H));
break;
case "unaccepted":
r.onUnaccepted && r.onUnaccepted(O),
r.ignoreUnaccepted || (j = new Error("Aborted because " + a + " is not accepted" + H));
break;
case "accepted":
r.onAccepted && r.onAccepted(O),
D = !0;
break;
case "disposed":
r.onDisposed && r.onDisposed(O),
P = !0;
break;
default:
throw new Error("Unexception type " + O.type)
}
if (j)
return h("abort"),
Promise.reject(j);
if (D)
for (a in g[a] = y[a],
s(v, O.outdatedModules),
O.outdatedDependencies)
Object.prototype.hasOwnProperty.call(O.outdatedDependencies, a) && (p[a] || (p[a] = []),
s(p[a], O.outdatedDependencies[a]));
P && (s(v, [O.moduleId]),
g[a] = b)
}
var k, I = [];
for (t = 0; t < v.length; t++)
a = v[t],
x[a] && x[a].hot._selfAccepted && g[a] !== b && I.push({
module: a,
errorHandler: x[a].hot._selfAccepted
});
h("dispose"),
Object.keys(_).forEach((function(e) {
!1 === _[e] && function(e) {
delete A[e]
}(e)
}
));
for (var M, T, q = v.slice(); q.length > 0; )
if (a = q.pop(),
i = x[a]) {
var C = {}
, U = i.hot._disposeHandlers;
for (o = 0; o < U.length; o++)
(n = U[o])(C);
for (d[a] = C,
i.hot.active = !1,
delete x[a],
delete p[a],
o = 0; o < i.children.length; o++) {
var L = x[i.children[o]];
L && ((k = L.parents.indexOf(a)) >= 0 && L.parents.splice(k, 1))
}
}
for (a in p)
if (Object.prototype.hasOwnProperty.call(p, a) && (i = x[a]))
for (T = p[a],
o = 0; o < T.length; o++)
M = T[o],
(k = i.children.indexOf(M)) >= 0 && i.children.splice(k, 1);
for (a in h("apply"),
c = m,
g)
Object.prototype.hasOwnProperty.call(g, a) && (e[a] = g[a]);
var N = null;
for (a in p)
if (Object.prototype.hasOwnProperty.call(p, a) && (i = x[a])) {
T = p[a];
var R = [];
for (t = 0; t < T.length; t++)
if (M = T[t],
n = i.hot._acceptedDependencies[M]) {
if (-1 !== R.indexOf(n))
continue;
R.push(n)
}
for (t = 0; t < R.length; t++) {
n = R[t];
try {
n(T)
} catch (e) {
r.onErrored && r.onErrored({
type: "accept-errored",
moduleId: a,
dependencyId: T[t],
error: e
}),
r.ignoreErrored || N || (N = e)
}
}
}
for (t = 0; t < I.length; t++) {
var B = I[t];
a = B.module,
l = [a];
try {
S(a)
} catch (e) {
if ("function" == typeof B.errorHandler)
try {
B.errorHandler(e)
} catch (n) {
r.onErrored && r.onErrored({
type: "self-accept-error-handler-errored",
moduleId: a,
error: n,
originalError: e
}),
r.ignoreErrored || N || (N = n),
N || (N = e)
}
else
r.onErrored && r.onErrored({
type: "self-accept-errored",
moduleId: a,
error: e
}),
r.ignoreErrored || N || (N = e)
}
}
return N ? (h("fail"),
Promise.reject(N)) : (h("idle"),
new Promise((function(e) {
e(v)
}
)))
}
var x = {}
, k = {
16: 0
}
, A = {
16: 0
}
, I = [];
function S(r) {
if (x[r])
return x[r].exports;
var n = x[r] = {
i: r,
l: !1,
exports: {},
hot: s(r),
parents: (u = l,
l = [],
u),
children: []
};
return e[r].call(n.exports, n, n.exports, function(e) {
var r = x[e];
if (!r)
return S;
var n = function(n) {
return r.hot.active ? (x[n] ? -1 === x[n].parents.indexOf(e) && x[n].parents.push(e) : (l = [e],
o = n),
-1 === r.children.indexOf(n) && r.children.push(n)) : (console.warn("[HMR] unexpected require(" + n + ") from disposed module " + e),
l = []),
S(n)
}
, t = function(e) {
return {
configurable: !0,
enumerable: !0,
get: function() {
return S[e]
},
set: function(r) {
S[e] = r
}
}
};
for (var i in S)
Object.prototype.hasOwnProperty.call(S, i) && "e" !== i && "t" !== i && Object.defineProperty(n, i, t(i));
return n.e = function(e) {
return "ready" === f && h("prepare"),
b++,
S.e(e).then(r, (function(e) {
throw r(),
e
}
));
function r() {
b--,
"prepare" === f && (w[e] || D(e),
0 === b && 0 === g && P())
}
}
,
n.t = function(e, r) {
return 1 & r && (e = n(e)),
S.t(e, -2 & r)
}
,
n
}(r)),
n.l = !0,
n.exports
}
S.e = function(e) {
var r = [];
k[e] ? r.push(k[e]) : 0 !== k[e] && {
2: 1,
3: 1,
4: 1,
5: 1,
6: 1,
7: 1,
8: 1,
9: 1,
10: 1,
11: 1,
12: 1,
13: 1,
14: 1
}[e] && r.push(k[e] = new Promise((function(r, n) {
for (var t = ({}[e] || e) + "." + c + ".css", o = S.p + t, i = document.getElementsByTagName("link"), a = 0; a < i.length; a++) {
var d = (u = i[a]).getAttribute("data-href") || u.getAttribute("href");
if ("stylesheet" === u.rel && (d === t || d === o))
return r()
}
var l = document.getElementsByTagName("style");
for (a = 0; a < l.length; a++) {
var u;
if ((d = (u = l[a]).getAttribute("data-href")) === t || d === o)
return r()
}
var s = document.createElement("link");
s.rel = "stylesheet",
s.type = "text/css",
s.onload = r,
s.onerror = function(r) {
var t = r && r.target && r.target.src || o
, i = new Error("Loading CSS chunk " + e + " failed.\n(" + t + ")");
i.code = "CSS_CHUNK_LOAD_FAILED",
i.request = t,
delete k[e],
s.parentNode.removeChild(s),
n(i)
}
,
s.href = o,
document.getElementsByTagName("head")[0].appendChild(s)
}
)).then((function() {
k[e] = 0
}
)));
var n = A[e];
if (0 !== n)
if (n)
r.push(n[2]);
else {
var t = new Promise((function(r, t) {
n = A[e] = [r, t]
}
));
r.push(n[2] = t);
var o, i = document.createElement("script");
i.charset = "utf-8",
i.timeout = 120,
S.nc && i.setAttribute("nonce", S.nc),
i.src = function(e) {
return S.p + "" + e + "." + c + ".js"
}(e);
var a = new Error;
o = function(r) {
i.onerror = i.onload = null,
clearTimeout(d);
var n = A[e];
if (0 !== n) {
if (n) {
var t = r && ("load" === r.type ? "missing" : r.type)
, o = r && r.target && r.target.src;
a.message = "Loading chunk " + e + " failed.\n(" + t + ": " + o + ")",
a.name = "ChunkLoadError",
a.type = t,
a.request = o,
n[1](a)
}
A[e] = void 0
}
}
;
var d = setTimeout((function() {
o({
type: "timeout",
target: i
})
}
), 12e4);
i.onerror = i.onload = o,
document.head.appendChild(i)
}
return Promise.all(r)
}
,
S.m = e,
S.c = x,
S.d = function(e, r, n) {
S.o(e, r) || Object.defineProperty(e, r, {
enumerable: !0,
get: n
})
}
,
S.r = function(e) {
"undefined" != typeof Symbol && Symbol.toStringTag && Object.defineProperty(e, Symbol.toStringTag, {
value: "Module"
}),
Object.defineProperty(e, "__esModule", {
value: !0
})
}
,
S.t = function(e, r) {
if (1 & r && (e = S(e)),
8 & r)
return e;
if (4 & r && "object" == typeof e && e && e.__esModule)
return e;
var n = Object.create(null);
if (S.r(n),
Object.defineProperty(n, "default", {
enumerable: !0,
value: e
}),
2 & r && "string" != typeof e)
for (var t in e)
S.d(n, t, function(r) {
return e[r]
}
.bind(null, t));
return n
}
,
S.n = function(e) {
var r = e && e.__esModule ? function() {
return e.default
}
: function() {
return e
}
;
return S.d(r, "a", r),
r
}
,
S.o = function(e, r) {
return Object.prototype.hasOwnProperty.call(e, r)
}
,
S.p = "/",
S.oe = function(e) {
throw console.error(e),
e
}
,
S.h = function() {
return c
}
;
var M = window.webpackJsonp = window.webpackJsonp || []
, T = M.push.bind(M);
M.push = r,
M = M.slice();
for (var q = 0; q < M.length; q++)
r(M[q]);
var C = T;
n()
use = S;
}({
'd504': function(_0xc083b2, _0x2cb30c, _0x32d76d) {
console.log("d504")
},
"7ae52036d1906f8c617e": function(e, t) {
function n(e) {
return (n = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(e) {
return typeof e
}
: function(e) {
return e && "function" == typeof Symbol && e.constructor === Symbol && e !== Symbol.prototype ? "symbol" : typeof e
}
)(e)
}
function i(t) {
return "function" == typeof Symbol && "symbol" === n(Symbol.iterator) ? e.exports = i = function(e) {
return n(e)
}
: e.exports = i = function(e) {
return e && "function" == typeof Symbol && e.constructor === Symbol && e !== Symbol.prototype ? "symbol" : n(e)
}
,
i(t)
}
e.exports = i
},
"5be32fcb987f2caeeb7c": function(e, t, n) {
var i, r, o, s, a, u;
e.exports = (u = u || function(e, t) {
var n = Object.create || function() {
function e() {}
return function(t) {
var n;
return e.prototype = t,
n = new e,
e.prototype = null,
n
}
}()
, i = {}
, r = i.lib = {}
, o = r.Base = {
extend: function(e) {
var t = n(this);
return e && t.mixIn(e),
t.hasOwnProperty("init") && this.init !== t.init || (t.init = function() {
t.$super.init.apply(this, arguments)
}
),
t.init.prototype = t,
t.$super = this,
t
},
create: function() {
var e = this.extend();
return e.init.apply(e, arguments),
e
},
init: function() {},
mixIn: function(e) {
for (var t in e)
e.hasOwnProperty(t) && (this[t] = e[t]);
e.hasOwnProperty("toString") && (this.toString = e.toString)
},
clone: function() {
return this.init.prototype.extend(this)
}
}
, s = r.WordArray = o.extend({
init: function(e, t) {
e = this.words = e || [],
this.sigBytes = null != t ? t : 4 * e.length
},
toString: function(e) {
return (e || u).stringify(this)
},
concat: function(e) {
var t = this.words
, n = e.words
, i = this.sigBytes
, r = e.sigBytes;
if (this.clamp(),
i % 4)
for (var o = 0; o < r; o++) {
var s = n[o >>> 2] >>> 24 - o % 4 * 8 & 255;
t[i + o >>> 2] |= s << 24 - (i + o) % 4 * 8
}
else
for (o = 0; o < r; o += 4)
t[i + o >>> 2] = n[o >>> 2];
return this.sigBytes += r,
this
},
clamp: function() {
var t = this.words
, n = this.sigBytes;
t[n >>> 2] &= 4294967295 << 32 - n % 4 * 8,
t.length = e.ceil(n / 4)
},
clone: function() {
var e = o.clone.call(this);
return e.words = this.words.slice(0),
e
},
random: function(t) {
for (var n, i = [], r = function(t) {
t = t;
var n = 987654321
, i = 4294967295;
return function() {
var r = ((n = 36969 * (65535 & n) + (n >> 16) & i) << 16) + (t = 18e3 * (65535 & t) + (t >> 16) & i) & i;
return r /= 4294967296,
(r += .5) * (e.random() > .5 ? 1 : -1)
}
}, o = 0; o < t; o += 4) {
var a = r(4294967296 * (n || e.random()));
n = 987654071 * a(),
i.push(4294967296 * a() | 0)
}
return new s.init(i,t)
}
})
, a = i.enc = {}
, u = a.Hex = {
stringify: function(e) {
for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r++) {
var o = t[r >>> 2] >>> 24 - r % 4 * 8 & 255;
i.push((o >>> 4).toString(16)),
i.push((15 & o).toString(16))
}
return i.join("")
},
parse: function(e) {
for (var t = e.length, n = [], i = 0; i < t; i += 2)
n[i >>> 3] |= parseInt(e.substr(i, 2), 16) << 24 - i % 8 * 4;
return new s.init(n,t / 2)
}
}
, c = a.Latin1 = {
stringify: function(e) {
for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r++) {
var o = t[r >>> 2] >>> 24 - r % 4 * 8 & 255;
i.push(String.fromCharCode(o))
}
return i.join("")
},
parse: function(e) {
for (var t = e.length, n = [], i = 0; i < t; i++)
n[i >>> 2] |= (255 & e.charCodeAt(i)) << 24 - i % 4 * 8;
return new s.init(n,t)
}
}
, l = a.Utf8 = {
stringify: function(e) {
try {
return decodeURIComponent(escape(c.stringify(e)))
} catch (e) {
throw new Error("Malformed UTF-8 data")
}
},
parse: function(e) {
return c.parse(unescape(encodeURIComponent(e)))
}
}
, d = r.BufferedBlockAlgorithm = o.extend({
reset: function() {
this._data = new s.init,
this._nDataBytes = 0
},
_append: function(e) {
"string" == typeof e && (e = l.parse(e)),
this._data.concat(e),
this._nDataBytes += e.sigBytes
},
_process: function(t) {
var n = this._data
, i = n.words
, r = n.sigBytes
, o = this.blockSize
, a = r / (4 * o)
, u = (a = t ? e.ceil(a) : e.max((0 | a) - this._minBufferSize, 0)) * o
, c = e.min(4 * u, r);
if (u) {
for (var l = 0; l < u; l += o)
this._doProcessBlock(i, l);
var d = i.splice(0, u);
n.sigBytes -= c
}
return new s.init(d,c)
},
clone: function() {
var e = o.clone.call(this);
return e._data = this._data.clone(),
e
},
_minBufferSize: 0
})
, f = (r.Hasher = d.extend({
cfg: o.extend(),
init: function(e) {
this.cfg = this.cfg.extend(e),
this.reset()
},
reset: function() {
d.reset.call(this),
this._doReset()
},
update: function(e) {
return this._append(e),
this._process(),
this
},
finalize: function(e) {
return e && this._append(e),
this._doFinalize()
},
blockSize: 16,
_createHelper: function(e) {
return function(t, n) {
return new e.init(n).finalize(t)
}
},
_createHmacHelper: function(e) {
return function(t, n) {
return new f.HMAC.init(e,n).finalize(t)
}
}
}),
i.algo = {});
return i
}(Math),
a = (s = u).lib.WordArray,
s.enc.Base64 = {
stringify: function(e) {
var t = e.words
, n = e.sigBytes
, i = this._map;
e.clamp();
for (var r = [], o = 0; o < n; o += 3)
for (var s = (t[o >>> 2] >>> 24 - o % 4 * 8 & 255) << 16 | (t[o + 1 >>> 2] >>> 24 - (o + 1) % 4 * 8 & 255) << 8 | t[o + 2 >>> 2] >>> 24 - (o + 2) % 4 * 8 & 255, a = 0; a < 4 && o + .75 * a < n; a++)
r.push(i.charAt(s >>> 6 * (3 - a) & 63));
var u = i.charAt(64);
if (u)
for (; r.length % 4; )
r.push(u);
return r.join("")
},
parse: function(e) {
var t = e.length
, n = this._map
, i = this._reverseMap;
if (!i) {
i = this._reverseMap = [];
for (var r = 0; r < n.length; r++)
i[n.charCodeAt(r)] = r
}
var o = n.charAt(64);
if (o) {
var s = e.indexOf(o);
-1 !== s && (t = s)
}
return function(e, t, n) {
for (var i = [], r = 0, o = 0; o < t; o++)
if (o % 4) {
var s = n[e.charCodeAt(o - 1)] << o % 4 * 2
, u = n[e.charCodeAt(o)] >>> 6 - o % 4 * 2;
i[r >>> 2] |= (s | u) << 24 - r % 4 * 8,
r++
}
return a.create(i, r)
}(e, t, i)
},
_map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="
},
function(e) {
var t = u
, n = t.lib
, i = n.WordArray
, r = n.Hasher
, o = t.algo
, s = [];
!function() {
for (var t = 0; t < 64; t++)
s[t] = 4294967296 * e.abs(e.sin(t + 1)) | 0
}();
var a = o.MD5 = r.extend({
_doReset: function() {
this._hash = new i.init([1732584193, 4023233417, 2562383102, 271733878])
},
_doProcessBlock: function(e, t) {
for (var n = 0; n < 16; n++) {
var i = t + n
, r = e[i];
e[i] = 16711935 & (r << 8 | r >>> 24) | 4278255360 & (r << 24 | r >>> 8)
}
var o = this._hash.words
, a = e[t + 0]
, u = e[t + 1]
, h = e[t + 2]
, p = e[t + 3]
, m = e[t + 4]
, _ = e[t + 5]
, y = e[t + 6]
, v = e[t + 7]
, g = e[t + 8]
, b = e[t + 9]
, w = e[t + 10]
, k = e[t + 11]
, M = e[t + 12]
, L = e[t + 13]
, S = e[t + 14]
, T = e[t + 15]
, Y = o[0]
, x = o[1]
, D = o[2]
, O = o[3];
Y = c(Y, x, D, O, a, 7, s[0]),
O = c(O, Y, x, D, u, 12, s[1]),
D = c(D, O, Y, x, h, 17, s[2]),
x = c(x, D, O, Y, p, 22, s[3]),
Y = c(Y, x, D, O, m, 7, s[4]),
O = c(O, Y, x, D, _, 12, s[5]),
D = c(D, O, Y, x, y, 17, s[6]),
x = c(x, D, O, Y, v, 22, s[7]),
Y = c(Y, x, D, O, g, 7, s[8]),
O = c(O, Y, x, D, b, 12, s[9]),
D = c(D, O, Y, x, w, 17, s[10]),
x = c(x, D, O, Y, k, 22, s[11]),
Y = c(Y, x, D, O, M, 7, s[12]),
O = c(O, Y, x, D, L, 12, s[13]),
D = c(D, O, Y, x, S, 17, s[14]),
Y = l(Y, x = c(x, D, O, Y, T, 22, s[15]), D, O, u, 5, s[16]),
O = l(O, Y, x, D, y, 9, s[17]),
D = l(D, O, Y, x, k, 14, s[18]),
x = l(x, D, O, Y, a, 20, s[19]),
Y = l(Y, x, D, O, _, 5, s[20]),
O = l(O, Y, x, D, w, 9, s[21]),
D = l(D, O, Y, x, T, 14, s[22]),
x = l(x, D, O, Y, m, 20, s[23]),
Y = l(Y, x, D, O, b, 5, s[24]),
O = l(O, Y, x, D, S, 9, s[25]),
D = l(D, O, Y, x, p, 14, s[26]),
x = l(x, D, O, Y, g, 20, s[27]),
Y = l(Y, x, D, O, L, 5, s[28]),
O = l(O, Y, x, D, h, 9, s[29]),
D = l(D, O, Y, x, v, 14, s[30]),
Y = d(Y, x = l(x, D, O, Y, M, 20, s[31]), D, O, _, 4, s[32]),
O = d(O, Y, x, D, g, 11, s[33]),
D = d(D, O, Y, x, k, 16, s[34]),
x = d(x, D, O, Y, S, 23, s[35]),
Y = d(Y, x, D, O, u, 4, s[36]),
O = d(O, Y, x, D, m, 11, s[37]),
D = d(D, O, Y, x, v, 16, s[38]),
x = d(x, D, O, Y, w, 23, s[39]),
Y = d(Y, x, D, O, L, 4, s[40]),
O = d(O, Y, x, D, a, 11, s[41]),
D = d(D, O, Y, x, p, 16, s[42]),
x = d(x, D, O, Y, y, 23, s[43]),
Y = d(Y, x, D, O, b, 4, s[44]),
O = d(O, Y, x, D, M, 11, s[45]),
D = d(D, O, Y, x, T, 16, s[46]),
Y = f(Y, x = d(x, D, O, Y, h, 23, s[47]), D, O, a, 6, s[48]),
O = f(O, Y, x, D, v, 10, s[49]),
D = f(D, O, Y, x, S, 15, s[50]),
x = f(x, D, O, Y, _, 21, s[51]),
Y = f(Y, x, D, O, M, 6, s[52]),
O = f(O, Y, x, D, p, 10, s[53]),
D = f(D, O, Y, x, w, 15, s[54]),
x = f(x, D, O, Y, u, 21, s[55]),
Y = f(Y, x, D, O, g, 6, s[56]),
O = f(O, Y, x, D, T, 10, s[57]),
D = f(D, O, Y, x, y, 15, s[58]),
x = f(x, D, O, Y, L, 21, s[59]),
Y = f(Y, x, D, O, m, 6, s[60]),
O = f(O, Y, x, D, k, 10, s[61]),
D = f(D, O, Y, x, h, 15, s[62]),
x = f(x, D, O, Y, b, 21, s[63]),
o[0] = o[0] + Y | 0,
o[1] = o[1] + x | 0,
o[2] = o[2] + D | 0,
o[3] = o[3] + O | 0
},
_doFinalize: function() {
var t = this._data
, n = t.words
, i = 8 * this._nDataBytes
, r = 8 * t.sigBytes;
n[r >>> 5] |= 128 << 24 - r % 32;
var o = e.floor(i / 4294967296)
, s = i;
n[15 + (r + 64 >>> 9 << 4)] = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8),
n[14 + (r + 64 >>> 9 << 4)] = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8),
t.sigBytes = 4 * (n.length + 1),
this._process();
for (var a = this._hash, u = a.words, c = 0; c < 4; c++) {
var l = u[c];
u[c] = 16711935 & (l << 8 | l >>> 24) | 4278255360 & (l << 24 | l >>> 8)
}
return a
},
clone: function() {
var e = r.clone.call(this);
return e._hash = this._hash.clone(),
e
}
});
function c(e, t, n, i, r, o, s) {
var a = e + (t & n | ~t & i) + r + s;
return (a << o | a >>> 32 - o) + t
}
function l(e, t, n, i, r, o, s) {
var a = e + (t & i | n & ~i) + r + s;
return (a << o | a >>> 32 - o) + t
}
function d(e, t, n, i, r, o, s) {
var a = e + (t ^ n ^ i) + r + s;
return (a << o | a >>> 32 - o) + t
}
function f(e, t, n, i, r, o, s) {
var a = e + (n ^ (t | ~i)) + r + s;
return (a << o | a >>> 32 - o) + t
}
t.MD5 = r._createHelper(a),
t.HmacMD5 = r._createHmacHelper(a)
}(Math),
function() {
var e = u
, t = e.lib
, n = t.WordArray
, i = t.Hasher
, r = e.algo
, o = []
, s = r.SHA1 = i.extend({
_doReset: function() {
this._hash = new n.init([1732584193, 4023233417, 2562383102, 271733878, 3285377520])
},
_doProcessBlock: function(e, t) {
for (var n = this._hash.words, i = n[0], r = n[1], s = n[2], a = n[3], u = n[4], c = 0; c < 80; c++) {
if (c < 16)
o[c] = 0 | e[t + c];
else {
var l = o[c - 3] ^ o[c - 8] ^ o[c - 14] ^ o[c - 16];
o[c] = l << 1 | l >>> 31
}
var d = (i << 5 | i >>> 27) + u + o[c];
d += c < 20 ? 1518500249 + (r & s | ~r & a) : c < 40 ? 1859775393 + (r ^ s ^ a) : c < 60 ? (r & s | r & a | s & a) - 1894007588 : (r ^ s ^ a) - 899497514,
u = a,
a = s,
s = r << 30 | r >>> 2,
r = i,
i = d
}
n[0] = n[0] + i | 0,
n[1] = n[1] + r | 0,
n[2] = n[2] + s | 0,
n[3] = n[3] + a | 0,
n[4] = n[4] + u | 0
},
_doFinalize: function() {
var e = this._data
, t = e.words
, n = 8 * this._nDataBytes
, i = 8 * e.sigBytes;
return t[i >>> 5] |= 128 << 24 - i % 32,
t[14 + (i + 64 >>> 9 << 4)] = Math.floor(n / 4294967296),
t[15 + (i + 64 >>> 9 << 4)] = n,
e.sigBytes = 4 * t.length,
this._process(),
this._hash
},
clone: function() {
var e = i.clone.call(this);
return e._hash = this._hash.clone(),
e
}
});
e.SHA1 = i._createHelper(s),
e.HmacSHA1 = i._createHmacHelper(s)
}(),
function(e) {
var t = u
, n = t.lib
, i = n.WordArray
, r = n.Hasher
, o = t.algo
, s = []
, a = [];
!function() {
function t(t) {
for (var n = e.sqrt(t), i = 2; i <= n; i++)
if (!(t % i))
return !1;
return !0
}
function n(e) {
return 4294967296 * (e - (0 | e)) | 0
}
for (var i = 2, r = 0; r < 64; )
t(i) && (r < 8 && (s[r] = n(e.pow(i, .5))),
a[r] = n(e.pow(i, 1 / 3)),
r++),
i++
}();
var c = []
, l = o.SHA256 = r.extend({
_doReset: function() {
this._hash = new i.init(s.slice(0))
},
_doProcessBlock: function(e, t) {
for (var n = this._hash.words, i = n[0], r = n[1], o = n[2], s = n[3], u = n[4], l = n[5], d = n[6], f = n[7], h = 0; h < 64; h++) {
if (h < 16)
c[h] = 0 | e[t + h];
else {
var p = c[h - 15]
, m = (p << 25 | p >>> 7) ^ (p << 14 | p >>> 18) ^ p >>> 3
, _ = c[h - 2]
, y = (_ << 15 | _ >>> 17) ^ (_ << 13 | _ >>> 19) ^ _ >>> 10;
c[h] = m + c[h - 7] + y + c[h - 16]
}
var v = i & r ^ i & o ^ r & o
, g = (i << 30 | i >>> 2) ^ (i << 19 | i >>> 13) ^ (i << 10 | i >>> 22)
, b = f + ((u << 26 | u >>> 6) ^ (u << 21 | u >>> 11) ^ (u << 7 | u >>> 25)) + (u & l ^ ~u & d) + a[h] + c[h];
f = d,
d = l,
l = u,
u = s + b | 0,
s = o,
o = r,
r = i,
i = b + (g + v) | 0
}
n[0] = n[0] + i | 0,
n[1] = n[1] + r | 0,
n[2] = n[2] + o | 0,
n[3] = n[3] + s | 0,
n[4] = n[4] + u | 0,
n[5] = n[5] + l | 0,
n[6] = n[6] + d | 0,
n[7] = n[7] + f | 0
},
_doFinalize: function() {
var t = this._data
, n = t.words
, i = 8 * this._nDataBytes
, r = 8 * t.sigBytes;
return n[r >>> 5] |= 128 << 24 - r % 32,
n[14 + (r + 64 >>> 9 << 4)] = e.floor(i / 4294967296),
n[15 + (r + 64 >>> 9 << 4)] = i,
t.sigBytes = 4 * n.length,
this._process(),
this._hash
},
clone: function() {
var e = r.clone.call(this);
return e._hash = this._hash.clone(),
e
}
});
t.SHA256 = r._createHelper(l),
t.HmacSHA256 = r._createHmacHelper(l)
}(Math),
function() {
var e = u
, t = e.lib.WordArray
, n = e.enc;
function i(e) {
return e << 8 & 4278255360 | e >>> 8 & 16711935
}
n.Utf16 = n.Utf16BE = {
stringify: function(e) {
for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r += 2) {
var o = t[r >>> 2] >>> 16 - r % 4 * 8 & 65535;
i.push(String.fromCharCode(o))
}
return i.join("")
},
parse: function(e) {
for (var n = e.length, i = [], r = 0; r < n; r++)
i[r >>> 1] |= e.charCodeAt(r) << 16 - r % 2 * 16;
return t.create(i, 2 * n)
}
},
n.Utf16LE = {
stringify: function(e) {
for (var t = e.words, n = e.sigBytes, r = [], o = 0; o < n; o += 2) {
var s = i(t[o >>> 2] >>> 16 - o % 4 * 8 & 65535);
r.push(String.fromCharCode(s))
}
return r.join("")
},
parse: function(e) {
for (var n = e.length, r = [], o = 0; o < n; o++)
r[o >>> 1] |= i(e.charCodeAt(o) << 16 - o % 2 * 16);
return t.create(r, 2 * n)
}
}
}(),
function() {
if ("function" == typeof ArrayBuffer) {
var e = u.lib.WordArray
, t = e.init;
(e.init = function(e) {
if (e instanceof ArrayBuffer && (e = new Uint8Array(e)),
(e instanceof Int8Array || "undefined" != typeof Uint8ClampedArray && e instanceof Uint8ClampedArray || e instanceof Int16Array || e instanceof Uint16Array || e instanceof Int32Array || e instanceof Uint32Array || e instanceof Float32Array || e instanceof Float64Array) && (e = new Uint8Array(e.buffer,e.byteOffset,e.byteLength)),
e instanceof Uint8Array) {
for (var n = e.byteLength, i = [], r = 0; r < n; r++)
i[r >>> 2] |= e[r] << 24 - r % 4 * 8;
t.call(this, i, n)
} else
t.apply(this, arguments)
}
).prototype = e
}
}(),
/** @preserve
(c) 2012 by Cédric Mesnil. All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
function(e) {
var t = u
, n = t.lib
, i = n.WordArray
, r = n.Hasher
, o = t.algo
, s = i.create([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13])
, a = i.create([5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11])
, c = i.create([11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6])
, l = i.create([8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11])
, d = i.create([0, 1518500249, 1859775393, 2400959708, 2840853838])
, f = i.create([1352829926, 1548603684, 1836072691, 2053994217, 0])
, h = o.RIPEMD160 = r.extend({
_doReset: function() {
this._hash = i.create([1732584193, 4023233417, 2562383102, 271733878, 3285377520])
},
_doProcessBlock: function(e, t) {
for (var n = 0; n < 16; n++) {
var i = t + n
, r = e[i];
e[i] = 16711935 & (r << 8 | r >>> 24) | 4278255360 & (r << 24 | r >>> 8)
}
var o, u, h, b, w, k, M, L, S, T, Y, x = this._hash.words, D = d.words, O = f.words, E = s.words, A = a.words, C = c.words, j = l.words;
for (k = o = x[0],
M = u = x[1],
L = h = x[2],
S = b = x[3],
T = w = x[4],
n = 0; n < 80; n += 1)
Y = o + e[t + E[n]] | 0,
Y += n < 16 ? p(u, h, b) + D[0] : n < 32 ? m(u, h, b) + D[1] : n < 48 ? _(u, h, b) + D[2] : n < 64 ? y(u, h, b) + D[3] : v(u, h, b) + D[4],
Y = (Y = g(Y |= 0, C[n])) + w | 0,
o = w,
w = b,
b = g(h, 10),
h = u,
u = Y,
Y = k + e[t + A[n]] | 0,
Y += n < 16 ? v(M, L, S) + O[0] : n < 32 ? y(M, L, S) + O[1] : n < 48 ? _(M, L, S) + O[2] : n < 64 ? m(M, L, S) + O[3] : p(M, L, S) + O[4],
Y = (Y = g(Y |= 0, j[n])) + T | 0,
k = T,
T = S,
S = g(L, 10),
L = M,
M = Y;
Y = x[1] + h + S | 0,
x[1] = x[2] + b + T | 0,
x[2] = x[3] + w + k | 0,
x[3] = x[4] + o + M | 0,
x[4] = x[0] + u + L | 0,
x[0] = Y
},
_doFinalize: function() {
var e = this._data
, t = e.words
, n = 8 * this._nDataBytes
, i = 8 * e.sigBytes;
t[i >>> 5] |= 128 << 24 - i % 32,
t[14 + (i + 64 >>> 9 << 4)] = 16711935 & (n << 8 | n >>> 24) | 4278255360 & (n << 24 | n >>> 8),
e.sigBytes = 4 * (t.length + 1),
this._process();
for (var r = this._hash, o = r.words, s = 0; s < 5; s++) {
var a = o[s];
o[s] = 16711935 & (a << 8 | a >>> 24) | 4278255360 & (a << 24 | a >>> 8)
}
return r
},
clone: function() {
var e = r.clone.call(this);
return e._hash = this._hash.clone(),
e
}
});
function p(e, t, n) {
return e ^ t ^ n
}
function m(e, t, n) {
return e & t | ~e & n
}
function _(e, t, n) {
return (e | ~t) ^ n
}
function y(e, t, n) {
return e & n | t & ~n
}
function v(e, t, n) {
return e ^ (t | ~n)
}
function g(e, t) {
return e << t | e >>> 32 - t
}
t.RIPEMD160 = r._createHelper(h),
t.HmacRIPEMD160 = r._createHmacHelper(h)
}(Math),
function() {
var e = u
, t = e.lib.Base
, n = e.enc.Utf8;
e.algo.HMAC = t.extend({
init: function(e, t) {
e = this._hasher = new e.init,
"string" == typeof t && (t = n.parse(t));
var i = e.blockSize
, r = 4 * i;
t.sigBytes > r && (t = e.finalize(t)),
t.clamp();
for (var o = this._oKey = t.clone(), s = this._iKey = t.clone(), a = o.words, u = s.words, c = 0; c < i; c++)
a[c] ^= 1549556828,
u[c] ^= 909522486;
o.sigBytes = s.sigBytes = r,
this.reset()
},
reset: function() {
var e = this._hasher;
e.reset(),
e.update(this._iKey)
},
update: function(e) {
return this._hasher.update(e),
this
},
finalize: function(e) {
var t = this._hasher
, n = t.finalize(e);
return t.reset(),
t.finalize(this._oKey.clone().concat(n))
}
})
}(),
function() {
var e = u
, t = e.lib
, n = t.Base
, i = t.WordArray
, r = e.algo
, o = r.SHA1
, s = r.HMAC
, a = r.PBKDF2 = n.extend({
cfg: n.extend({
keySize: 4,
hasher: o,
iterations: 1
}),
init: function(e) {
this.cfg = this.cfg.extend(e)
},
compute: function(e, t) {
for (var n = this.cfg, r = s.create(n.hasher, e), o = i.create(), a = i.create([1]), u = o.words, c = a.words, l = n.keySize, d = n.iterations; u.length < l; ) {
var f = r.update(t).finalize(a);
r.reset();
for (var h = f.words, p = h.length, m = f, _ = 1; _ < d; _++) {
m = r.finalize(m),
r.reset();
for (var y = m.words, v = 0; v < p; v++)
h[v] ^= y[v]
}
o.concat(f),
c[0]++
}
return o.sigBytes = 4 * l,
o
}
});
e.PBKDF2 = function(e, t, n) {
return a.create(n).compute(e, t)
}
}(),
function() {
var e = u
, t = e.lib
, n = t.Base
, i = t.WordArray
, r = e.algo
, o = r.MD5
, s = r.EvpKDF = n.extend({
cfg: n.extend({
keySize: 4,
hasher: o,
iterations: 1
}),
init: function(e) {
this.cfg = this.cfg.extend(e)
},
compute: function(e, t) {
for (var n = this.cfg, r = n.hasher.create(), o = i.create(), s = o.words, a = n.keySize, u = n.iterations; s.length < a; ) {
c && r.update(c);
var c = r.update(e).finalize(t);
r.reset();
for (var l = 1; l < u; l++)
c = r.finalize(c),
r.reset();
o.concat(c)
}
return o.sigBytes = 4 * a,
o
}
});
e.EvpKDF = function(e, t, n) {
return s.create(n).compute(e, t)
}
}(),
function() {
var e = u
, t = e.lib.WordArray
, n = e.algo
, i = n.SHA256
, r = n.SHA224 = i.extend({
_doReset: function() {
this._hash = new t.init([3238371032, 914150663, 812702999, 4144912697, 4290775857, 1750603025, 1694076839, 3204075428])
},
_doFinalize: function() {
var e = i._doFinalize.call(this);
return e.sigBytes -= 4,
e
}
});
e.SHA224 = i._createHelper(r),
e.HmacSHA224 = i._createHmacHelper(r)
}(),
function(e) {
var t = u
, n = t.lib
, i = n.Base
, r = n.WordArray
, o = t.x64 = {};
o.Word = i.extend({
init: function(e, t) {
this.high = e,
this.low = t
}
}),
o.WordArray = i.extend({
init: function(e, t) {
e = this.words = e || [],
this.sigBytes = null != t ? t : 8 * e.length
},
toX32: function() {
for (var e = this.words, t = e.length, n = [], i = 0; i < t; i++) {
var o = e[i];
n.push(o.high),
n.push(o.low)
}
return r.create(n, this.sigBytes)
},
clone: function() {
for (var e = i.clone.call(this), t = e.words = this.words.slice(0), n = t.length, r = 0; r < n; r++)
t[r] = t[r].clone();
return e
}
})
}(),
function(e) {
var t = u
, n = t.lib
, i = n.WordArray
, r = n.Hasher
, o = t.x64.Word
, s = t.algo
, a = []
, c = []
, l = [];
!function() {
for (var e = 1, t = 0, n = 0; n < 24; n++) {
a[e + 5 * t] = (n + 1) * (n + 2) / 2 % 64;
var i = (2 * e + 3 * t) % 5;
e = t % 5,
t = i
}
for (e = 0; e < 5; e++)
for (t = 0; t < 5; t++)
c[e + 5 * t] = t + (2 * e + 3 * t) % 5 * 5;
for (var r = 1, s = 0; s < 24; s++) {
for (var u = 0, d = 0, f = 0; f < 7; f++) {
if (1 & r) {
var h = (1 << f) - 1;
h < 32 ? d ^= 1 << h : u ^= 1 << h - 32
}
128 & r ? r = r << 1 ^ 113 : r <<= 1
}
l[s] = o.create(u, d)
}
}();
var d = [];
!function() {
for (var e = 0; e < 25; e++)
d[e] = o.create()
}();
var f = s.SHA3 = r.extend({
cfg: r.cfg.extend({
outputLength: 512
}),
_doReset: function() {
for (var e = this._state = [], t = 0; t < 25; t++)
e[t] = new o.init;
this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32
},
_doProcessBlock: function(e, t) {
for (var n = this._state, i = this.blockSize / 2, r = 0; r < i; r++) {
var o = e[t + 2 * r]
, s = e[t + 2 * r + 1];
o = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8),
s = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8),
(x = n[r]).high ^= s,
x.low ^= o
}
for (var u = 0; u < 24; u++) {
for (var f = 0; f < 5; f++) {
for (var h = 0, p = 0, m = 0; m < 5; m++)
h ^= (x = n[f + 5 * m]).high,
p ^= x.low;
var _ = d[f];
_.high = h,
_.low = p
}
for (f = 0; f < 5; f++) {
var y = d[(f + 4) % 5]
, v = d[(f + 1) % 5]
, g = v.high
, b = v.low;
for (h = y.high ^ (g << 1 | b >>> 31),
p = y.low ^ (b << 1 | g >>> 31),
m = 0; m < 5; m++)
(x = n[f + 5 * m]).high ^= h,
x.low ^= p
}
for (var w = 1; w < 25; w++) {
var k = (x = n[w]).high
, M = x.low
, L = a[w];
L < 32 ? (h = k << L | M >>> 32 - L,
p = M << L | k >>> 32 - L) : (h = M << L - 32 | k >>> 64 - L,
p = k << L - 32 | M >>> 64 - L);
var S = d[c[w]];
S.high = h,
S.low = p
}
var T = d[0]
, Y = n[0];
for (T.high = Y.high,
T.low = Y.low,
f = 0; f < 5; f++)
for (m = 0; m < 5; m++) {
var x = n[w = f + 5 * m]
, D = d[w]
, O = d[(f + 1) % 5 + 5 * m]
, E = d[(f + 2) % 5 + 5 * m];
x.high = D.high ^ ~O.high & E.high,
x.low = D.low ^ ~O.low & E.low
}
x = n[0];
var A = l[u];
x.high ^= A.high,
x.low ^= A.low
}
},
_doFinalize: function() {
var t = this._data
, n = t.words
, r = (this._nDataBytes,
8 * t.sigBytes)
, o = 32 * this.blockSize;
n[r >>> 5] |= 1 << 24 - r % 32,
n[(e.ceil((r + 1) / o) * o >>> 5) - 1] |= 128,
t.sigBytes = 4 * n.length,
this._process();
for (var s = this._state, a = this.cfg.outputLength / 8, u = a / 8, c = [], l = 0; l < u; l++) {
var d = s[l]
, f = d.high
, h = d.low;
f = 16711935 & (f << 8 | f >>> 24) | 4278255360 & (f << 24 | f >>> 8),
h = 16711935 & (h << 8 | h >>> 24) | 4278255360 & (h << 24 | h >>> 8),
c.push(h),
c.push(f)
}
return new i.init(c,a)
},
clone: function() {
for (var e = r.clone.call(this), t = e._state = this._state.slice(0), n = 0; n < 25; n++)
t[n] = t[n].clone();
return e
}
});
t.SHA3 = r._createHelper(f),
t.HmacSHA3 = r._createHmacHelper(f)
}(Math),
function() {
var e = u
, t = e.lib.Hasher
, n = e.x64
, i = n.Word
, r = n.WordArray
, o = e.algo;
function s() {
return i.create.apply(i, arguments)
}
var a = [s(1116352408, 3609767458), s(1899447441, 602891725), s(3049323471, 3964484399), s(3921009573, 2173295548), s(961987163, 4081628472), s(1508970993, 3053834265), s(2453635748, 2937671579), s(2870763221, 3664609560), s(3624381080, 2734883394), s(310598401, 1164996542), s(607225278, 1323610764), s(1426881987, 3590304994), s(1925078388, 4068182383), s(2162078206, 991336113), s(2614888103, 633803317), s(3248222580, 3479774868), s(3835390401, 2666613458), s(4022224774, 944711139), s(264347078, 2341262773), s(604807628, 2007800933), s(770255983, 1495990901), s(1249150122, 1856431235), s(1555081692, 3175218132), s(1996064986, 2198950837), s(2554220882, 3999719339), s(2821834349, 766784016), s(2952996808, 2566594879), s(3210313671, 3203337956), s(3336571891, 1034457026), s(3584528711, 2466948901), s(113926993, 3758326383), s(338241895, 168717936), s(666307205, 1188179964), s(773529912, 1546045734), s(1294757372, 1522805485), s(1396182291, 2643833823), s(1695183700, 2343527390), s(1986661051, 1014477480), s(2177026350, 1206759142), s(2456956037, 344077627), s(2730485921, 1290863460), s(2820302411, 3158454273), s(3259730800, 3505952657), s(3345764771, 106217008), s(3516065817, 3606008344), s(3600352804, 1432725776), s(4094571909, 1467031594), s(275423344, 851169720), s(430227734, 3100823752), s(506948616, 1363258195), s(659060556, 3750685593), s(883997877, 3785050280), s(958139571, 3318307427), s(1322822218, 3812723403), s(1537002063, 2003034995), s(1747873779, 3602036899), s(1955562222, 1575990012), s(2024104815, 1125592928), s(2227730452, 2716904306), s(2361852424, 442776044), s(2428436474, 593698344), s(2756734187, 3733110249), s(3204031479, 2999351573), s(3329325298, 3815920427), s(3391569614, 3928383900), s(3515267271, 566280711), s(3940187606, 3454069534), s(4118630271, 4000239992), s(116418474, 1914138554), s(174292421, 2731055270), s(289380356, 3203993006), s(460393269, 320620315), s(685471733, 587496836), s(852142971, 1086792851), s(1017036298, 365543100), s(1126000580, 2618297676), s(1288033470, 3409855158), s(1501505948, 4234509866), s(1607167915, 987167468), s(1816402316, 1246189591)]
, c = [];
!function() {
for (var e = 0; e < 80; e++)
c[e] = s()
}();
var l = o.SHA512 = t.extend({
_doReset: function() {
this._hash = new r.init([new i.init(1779033703,4089235720), new i.init(3144134277,2227873595), new i.init(1013904242,4271175723), new i.init(2773480762,1595750129), new i.init(1359893119,2917565137), new i.init(2600822924,725511199), new i.init(528734635,4215389547), new i.init(1541459225,327033209)])
},
_doProcessBlock: function(e, t) {
for (var n = this._hash.words, i = n[0], r = n[1], o = n[2], s = n[3], u = n[4], l = n[5], d = n[6], f = n[7], h = i.high, p = i.low, m = r.high, _ = r.low, y = o.high, v = o.low, g = s.high, b = s.low, w = u.high, k = u.low, M = l.high, L = l.low, S = d.high, T = d.low, Y = f.high, x = f.low, D = h, O = p, E = m, A = _, C = y, j = v, H = g, P = b, I = w, B = k, N = M, R = L, F = S, z = T, $ = Y, W = x, U = 0; U < 80; U++) {
var V = c[U];
if (U < 16)
var J = V.high = 0 | e[t + 2 * U]
, q = V.low = 0 | e[t + 2 * U + 1];
else {
var G = c[U - 15]
, X = G.high
, K = G.low
, Z = (X >>> 1 | K << 31) ^ (X >>> 8 | K << 24) ^ X >>> 7
, Q = (K >>> 1 | X << 31) ^ (K >>> 8 | X << 24) ^ (K >>> 7 | X << 25)
, ee = c[U - 2]
, te = ee.high
, ne = ee.low
, ie = (te >>> 19 | ne << 13) ^ (te << 3 | ne >>> 29) ^ te >>> 6
, re = (ne >>> 19 | te << 13) ^ (ne << 3 | te >>> 29) ^ (ne >>> 6 | te << 26)
, oe = c[U - 7]
, se = oe.high
, ae = oe.low
, ue = c[U - 16]
, ce = ue.high
, le = ue.low;
J = (J = (J = Z + se + ((q = Q + ae) >>> 0 < Q >>> 0 ? 1 : 0)) + ie + ((q += re) >>> 0 < re >>> 0 ? 1 : 0)) + ce + ((q += le) >>> 0 < le >>> 0 ? 1 : 0),
V.high = J,
V.low = q
}
var de, fe = I & N ^ ~I & F, he = B & R ^ ~B & z, pe = D & E ^ D & C ^ E & C, me = O & A ^ O & j ^ A & j, _e = (D >>> 28 | O << 4) ^ (D << 30 | O >>> 2) ^ (D << 25 | O >>> 7), ye = (O >>> 28 | D << 4) ^ (O << 30 | D >>> 2) ^ (O << 25 | D >>> 7), ve = (I >>> 14 | B << 18) ^ (I >>> 18 | B << 14) ^ (I << 23 | B >>> 9), ge = (B >>> 14 | I << 18) ^ (B >>> 18 | I << 14) ^ (B << 23 | I >>> 9), be = a[U], we = be.high, ke = be.low, Me = $ + ve + ((de = W + ge) >>> 0 < W >>> 0 ? 1 : 0), Le = ye + me;
$ = F,
W = z,
F = N,
z = R,
N = I,
R = B,
I = H + (Me = (Me = (Me = Me + fe + ((de += he) >>> 0 < he >>> 0 ? 1 : 0)) + we + ((de += ke) >>> 0 < ke >>> 0 ? 1 : 0)) + J + ((de += q) >>> 0 < q >>> 0 ? 1 : 0)) + ((B = P + de | 0) >>> 0 < P >>> 0 ? 1 : 0) | 0,
H = C,
P = j,
C = E,
j = A,
E = D,
A = O,
D = Me + (_e + pe + (Le >>> 0 < ye >>> 0 ? 1 : 0)) + ((O = de + Le | 0) >>> 0 < de >>> 0 ? 1 : 0) | 0
}
p = i.low = p + O,
i.high = h + D + (p >>> 0 < O >>> 0 ? 1 : 0),
_ = r.low = _ + A,
r.high = m + E + (_ >>> 0 < A >>> 0 ? 1 : 0),
v = o.low = v + j,
o.high = y + C + (v >>> 0 < j >>> 0 ? 1 : 0),
b = s.low = b + P,
s.high = g + H + (b >>> 0 < P >>> 0 ? 1 : 0),
k = u.low = k + B,
u.high = w + I + (k >>> 0 < B >>> 0 ? 1 : 0),
L = l.low = L + R,
l.high = M + N + (L >>> 0 < R >>> 0 ? 1 : 0),
T = d.low = T + z,
d.high = S + F + (T >>> 0 < z >>> 0 ? 1 : 0),
x = f.low = x + W,
f.high = Y + $ + (x >>> 0 < W >>> 0 ? 1 : 0)
},
_doFinalize: function() {
var e = this._data
, t = e.words
, n = 8 * this._nDataBytes
, i = 8 * e.sigBytes;
return t[i >>> 5] |= 128 << 24 - i % 32,
t[30 + (i + 128 >>> 10 << 5)] = Math.floor(n / 4294967296),
t[31 + (i + 128 >>> 10 << 5)] = n,
e.sigBytes = 4 * t.length,
this._process(),
this._hash.toX32()
},
clone: function() {
var e = t.clone.call(this);
return e._hash = this._hash.clone(),
e
},
blockSize: 32
});
e.SHA512 = t._createHelper(l),
e.HmacSHA512 = t._createHmacHelper(l)
}(),
function() {
var e = u
, t = e.x64
, n = t.Word
, i = t.WordArray
, r = e.algo
, o = r.SHA512
, s = r.SHA384 = o.extend({
_doReset: function() {
this._hash = new i.init([new n.init(3418070365,3238371032), new n.init(1654270250,914150663), new n.init(2438529370,812702999), new n.init(355462360,4144912697), new n.init(1731405415,4290775857), new n.init(2394180231,1750603025), new n.init(3675008525,1694076839), new n.init(1203062813,3204075428)])
},
_doFinalize: function() {
var e = o._doFinalize.call(this);
return e.sigBytes -= 16,
e
}
});
e.SHA384 = o._createHelper(s),
e.HmacSHA384 = o._createHmacHelper(s)
}(),
u.lib.Cipher || function(e) {
var t = u
, n = t.lib
, i = n.Base
, r = n.WordArray
, o = n.BufferedBlockAlgorithm
, s = t.enc
, a = (s.Utf8,
s.Base64)
, c = t.algo.EvpKDF
, l = n.Cipher = o.extend({
cfg: i.extend(),
createEncryptor: function(e, t) {
return this.create(this._ENC_XFORM_MODE, e, t)
},
createDecryptor: function(e, t) {
return this.create(this._DEC_XFORM_MODE, e, t)
},
init: function(e, t, n) {
this.cfg = this.cfg.extend(n),
this._xformMode = e,
this._key = t,
this.reset()
},
reset: function() {
o.reset.call(this),
this._doReset()
},
process: function(e) {
return this._append(e),
this._process()
},
finalize: function(e) {
return e && this._append(e),
this._doFinalize()
},
keySize: 4,
ivSize: 4,
_ENC_XFORM_MODE: 1,
_DEC_XFORM_MODE: 2,
_createHelper: function() {
function e(e) {
return "string" == typeof e ? g : y
}
return function(t) {
return {
encrypt: function(n, i, r) {
return e(i).encrypt(t, n, i, r)
},
decrypt: function(n, i, r) {
return e(i).decrypt(t, n, i, r)
}
}
}
}()
})
, d = (n.StreamCipher = l.extend({
_doFinalize: function() {
return this._process(!0)
},
blockSize: 1
}),
t.mode = {})
, f = n.BlockCipherMode = i.extend({
createEncryptor: function(e, t) {
return this.Encryptor.create(e, t)
},
createDecryptor: function(e, t) {
return this.Decryptor.create(e, t)
},
init: function(e, t) {
this._cipher = e,
this._iv = t
}
})
, h = d.CBC = function() {
var t = f.extend();
function n(t, n, i) {
var r = this._iv;
if (r) {
var o = r;
this._iv = e
} else
o = this._prevBlock;
for (var s = 0; s < i; s++)
t[n + s] ^= o[s]
}
return t.Encryptor = t.extend({
processBlock: function(e, t) {
var i = this._cipher
, r = i.blockSize;
n.call(this, e, t, r),
i.encryptBlock(e, t),
this._prevBlock = e.slice(t, t + r)
}
}),
t.Decryptor = t.extend({
processBlock: function(e, t) {
var i = this._cipher
, r = i.blockSize
, o = e.slice(t, t + r);
i.decryptBlock(e, t),
n.call(this, e, t, r),
this._prevBlock = o
}
}),
t
}()
, p = (t.pad = {}).Pkcs7 = {
pad: function(e, t) {
for (var n = 4 * t, i = n - e.sigBytes % n, o = i << 24 | i << 16 | i << 8 | i, s = [], a = 0; a < i; a += 4)
s.push(o);
var u = r.create(s, i);
e.concat(u)
},
unpad: function(e) {
var t = 255 & e.words[e.sigBytes - 1 >>> 2];
e.sigBytes -= t
}
}
, m = (n.BlockCipher = l.extend({
cfg: l.cfg.extend({
mode: h,
padding: p
}),
reset: function() {
l.reset.call(this);
var e = this.cfg
, t = e.iv
, n = e.mode;
if (this._xformMode == this._ENC_XFORM_MODE)
var i = n.createEncryptor;
else
i = n.createDecryptor,
this._minBufferSize = 1;
this._mode && this._mode.__creator == i ? this._mode.init(this, t && t.words) : (this._mode = i.call(n, this, t && t.words),
this._mode.__creator = i)
},
_doProcessBlock: function(e, t) {
this._mode.processBlock(e, t)
},
_doFinalize: function() {
var e = this.cfg.padding;
if (this._xformMode == this._ENC_XFORM_MODE) {
e.pad(this._data, this.blockSize);
var t = this._process(!0)
} else
t = this._process(!0),
e.unpad(t);
return t
},
blockSize: 4
}),
n.CipherParams = i.extend({
init: function(e) {
this.mixIn(e)
},
toString: function(e) {
return (e || this.formatter).stringify(this)
}
}))
, _ = (t.format = {}).OpenSSL = {
stringify: function(e) {
var t = e.ciphertext
, n = e.salt;
if (n)
var i = r.create([1398893684, 1701076831]).concat(n).concat(t);
else
i = t;
return i.toString(a)
},
parse: function(e) {
var t = a.parse(e)
, n = t.words;
if (1398893684 == n[0] && 1701076831 == n[1]) {
var i = r.create(n.slice(2, 4));
n.splice(0, 4),
t.sigBytes -= 16
}
return m.create({
ciphertext: t,
salt: i
})
}
}
, y = n.SerializableCipher = i.extend({
cfg: i.extend({
format: _
}),
encrypt: function(e, t, n, i) {
i = this.cfg.extend(i);
var r = e.createEncryptor(n, i)
, o = r.finalize(t)
, s = r.cfg;
return m.create({
ciphertext: o,
key: n,
iv: s.iv,
algorithm: e,
mode: s.mode,
padding: s.padding,
blockSize: e.blockSize,
formatter: i.format
})
},
decrypt: function(e, t, n, i) {
return i = this.cfg.extend(i),
t = this._parse(t, i.format),
e.createDecryptor(n, i).finalize(t.ciphertext)
},
_parse: function(e, t) {
return "string" == typeof e ? t.parse(e, this) : e
}
})
, v = (t.kdf = {}).OpenSSL = {
execute: function(e, t, n, i) {
i || (i = r.random(8));
var o = c.create({
keySize: t + n
}).compute(e, i)
, s = r.create(o.words.slice(t), 4 * n);
return o.sigBytes = 4 * t,
m.create({
key: o,
iv: s,
salt: i
})
}
}
, g = n.PasswordBasedCipher = y.extend({
cfg: y.cfg.extend({
kdf: v
}),
encrypt: function(e, t, n, i) {
var r = (i = this.cfg.extend(i)).kdf.execute(n, e.keySize, e.ivSize);
i.iv = r.iv;
var o = y.encrypt.call(this, e, t, r.key, i);
return o.mixIn(r),
o
},
decrypt: function(e, t, n, i) {
i = this.cfg.extend(i),
t = this._parse(t, i.format);
var r = i.kdf.execute(n, e.keySize, e.ivSize, t.salt);
return i.iv = r.iv,
y.decrypt.call(this, e, t, r.key, i)
}
})
}(),
u.mode.CFB = function() {
var e = u.lib.BlockCipherMode.extend();
function t(e, t, n, i) {
var r = this._iv;
if (r) {
var o = r.slice(0);
this._iv = void 0
} else
o = this._prevBlock;
i.encryptBlock(o, 0);
for (var s = 0; s < n; s++)
e[t + s] ^= o[s]
}
return e.Encryptor = e.extend({
processBlock: function(e, n) {
var i = this._cipher
, r = i.blockSize;
t.call(this, e, n, r, i),
this._prevBlock = e.slice(n, n + r)
}
}),
e.Decryptor = e.extend({
processBlock: function(e, n) {
var i = this._cipher
, r = i.blockSize
, o = e.slice(n, n + r);
t.call(this, e, n, r, i),
this._prevBlock = o
}
}),
e
}(),
u.mode.ECB = ((o = u.lib.BlockCipherMode.extend()).Encryptor = o.extend({
processBlock: function(e, t) {
this._cipher.encryptBlock(e, t)
}
}),
o.Decryptor = o.extend({
processBlock: function(e, t) {
this._cipher.decryptBlock(e, t)
}
}),
o),
u.pad.AnsiX923 = {
pad: function(e, t) {
var n = e.sigBytes
, i = 4 * t
, r = i - n % i
, o = n + r - 1;
e.clamp(),
e.words[o >>> 2] |= r << 24 - o % 4 * 8,
e.sigBytes += r
},
unpad: function(e) {
var t = 255 & e.words[e.sigBytes - 1 >>> 2];
e.sigBytes -= t
}
},
u.pad.Iso10126 = {
pad: function(e, t) {
var n = 4 * t
, i = n - e.sigBytes % n;
e.concat(u.lib.WordArray.random(i - 1)).concat(u.lib.WordArray.create([i << 24], 1))
},
unpad: function(e) {
var t = 255 & e.words[e.sigBytes - 1 >>> 2];
e.sigBytes -= t
}
},
u.pad.Iso97971 = {
pad: function(e, t) {
e.concat(u.lib.WordArray.create([2147483648], 1)),
u.pad.ZeroPadding.pad(e, t)
},
unpad: function(e) {
u.pad.ZeroPadding.unpad(e),
e.sigBytes--
}
},
u.mode.OFB = (i = u.lib.BlockCipherMode.extend(),
r = i.Encryptor = i.extend({
processBlock: function(e, t) {
var n = this._cipher
, i = n.blockSize
, r = this._iv
, o = this._keystream;
r && (o = this._keystream = r.slice(0),
this._iv = void 0),
n.encryptBlock(o, 0);
for (var s = 0; s < i; s++)
e[t + s] ^= o[s]
}
}),
i.Decryptor = r,
i),
u.pad.NoPadding = {
pad: function() {},
unpad: function() {}
},
function(e) {
var t = u
, n = t.lib.CipherParams
, i = t.enc.Hex;
t.format.Hex = {
stringify: function(e) {
return e.ciphertext.toString(i)
},
parse: function(e) {
var t = i.parse(e);
return n.create({
ciphertext: t
})
}
}
}(),
function() {
var e = u
, t = e.lib.BlockCipher
, n = e.algo
, i = []
, r = []
, o = []
, s = []
, a = []
, c = []
, l = []
, d = []
, f = []
, h = [];
!function() {
for (var e = [], t = 0; t < 256; t++)
e[t] = t < 128 ? t << 1 : t << 1 ^ 283;
var n = 0
, u = 0;
for (t = 0; t < 256; t++) {
var p = u ^ u << 1 ^ u << 2 ^ u << 3 ^ u << 4;
p = p >>> 8 ^ 255 & p ^ 99,
i[n] = p,
r[p] = n;
var m = e[n]
, _ = e[m]
, y = e[_]
, v = 257 * e[p] ^ 16843008 * p;
o[n] = v << 24 | v >>> 8,
s[n] = v << 16 | v >>> 16,
a[n] = v << 8 | v >>> 24,
c[n] = v,
v = 16843009 * y ^ 65537 * _ ^ 257 * m ^ 16843008 * n,
l[p] = v << 24 | v >>> 8,
d[p] = v << 16 | v >>> 16,
f[p] = v << 8 | v >>> 24,
h[p] = v,
n ? (n = m ^ e[e[e[y ^ m]]],
u ^= e[e[u]]) : n = u = 1
}
}();
var p = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54]
, m = n.AES = t.extend({
_doReset: function() {
if (!this._nRounds || this._keyPriorReset !== this._key) {
for (var e = this._keyPriorReset = this._key, t = e.words, n = e.sigBytes / 4, r = 4 * ((this._nRounds = n + 6) + 1), o = this._keySchedule = [], s = 0; s < r; s++)
if (s < n)
o[s] = t[s];
else {
var a = o[s - 1];
s % n ? n > 6 && s % n == 4 && (a = i[a >>> 24] << 24 | i[a >>> 16 & 255] << 16 | i[a >>> 8 & 255] << 8 | i[255 & a]) : (a = i[(a = a << 8 | a >>> 24) >>> 24] << 24 | i[a >>> 16 & 255] << 16 | i[a >>> 8 & 255] << 8 | i[255 & a],
a ^= p[s / n | 0] << 24),
o[s] = o[s - n] ^ a
}
for (var u = this._invKeySchedule = [], c = 0; c < r; c++)
s = r - c,
a = c % 4 ? o[s] : o[s - 4],
u[c] = c < 4 || s <= 4 ? a : l[i[a >>> 24]] ^ d[i[a >>> 16 & 255]] ^ f[i[a >>> 8 & 255]] ^ h[i[255 & a]]
}
},
encryptBlock: function(e, t) {
this._doCryptBlock(e, t, this._keySchedule, o, s, a, c, i)
},
decryptBlock: function(e, t) {
var n = e[t + 1];
e[t + 1] = e[t + 3],
e[t + 3] = n,
this._doCryptBlock(e, t, this._invKeySchedule, l, d, f, h, r),
n = e[t + 1],
e[t + 1] = e[t + 3],
e[t + 3] = n
},
_doCryptBlock: function(e, t, n, i, r, o, s, a) {
for (var u = this._nRounds, c = e[t] ^ n[0], l = e[t + 1] ^ n[1], d = e[t + 2] ^ n[2], f = e[t + 3] ^ n[3], h = 4, p = 1; p < u; p++) {
var m = i[c >>> 24] ^ r[l >>> 16 & 255] ^ o[d >>> 8 & 255] ^ s[255 & f] ^ n[h++]
, _ = i[l >>> 24] ^ r[d >>> 16 & 255] ^ o[f >>> 8 & 255] ^ s[255 & c] ^ n[h++]
, y = i[d >>> 24] ^ r[f >>> 16 & 255] ^ o[c >>> 8 & 255] ^ s[255 & l] ^ n[h++]
, v = i[f >>> 24] ^ r[c >>> 16 & 255] ^ o[l >>> 8 & 255] ^ s[255 & d] ^ n[h++];
c = m,
l = _,
d = y,
f = v
}
m = (a[c >>> 24] << 24 | a[l >>> 16 & 255] << 16 | a[d >>> 8 & 255] << 8 | a[255 & f]) ^ n[h++],
_ = (a[l >>> 24] << 24 | a[d >>> 16 & 255] << 16 | a[f >>> 8 & 255] << 8 | a[255 & c]) ^ n[h++],
y = (a[d >>> 24] << 24 | a[f >>> 16 & 255] << 16 | a[c >>> 8 & 255] << 8 | a[255 & l]) ^ n[h++],
v = (a[f >>> 24] << 24 | a[c >>> 16 & 255] << 16 | a[l >>> 8 & 255] << 8 | a[255 & d]) ^ n[h++],
e[t] = m,
e[t + 1] = _,
e[t + 2] = y,
e[t + 3] = v
},
keySize: 8
});
e.AES = t._createHelper(m)
}(),
function() {
var e = u
, t = e.lib
, n = t.WordArray
, i = t.BlockCipher
, r = e.algo
, o = [57, 49, 41, 33, 25, 17, 9, 1, 58, 50, 42, 34, 26, 18, 10, 2, 59, 51, 43, 35, 27, 19, 11, 3, 60, 52, 44, 36, 63, 55, 47, 39, 31, 23, 15, 7, 62, 54, 46, 38, 30, 22, 14, 6, 61, 53, 45, 37, 29, 21, 13, 5, 28, 20, 12, 4]
, s = [14, 17, 11, 24, 1, 5, 3, 28, 15, 6, 21, 10, 23, 19, 12, 4, 26, 8, 16, 7, 27, 20, 13, 2, 41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48, 44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32]
, a = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28]
, c = [{
0: 8421888,
268435456: 32768,
536870912: 8421378,
805306368: 2,
1073741824: 512,
1342177280: 8421890,
1610612736: 8389122,
1879048192: 8388608,
2147483648: 514,
2415919104: 8389120,
2684354560: 33280,
2952790016: 8421376,
3221225472: 32770,
3489660928: 8388610,
3758096384: 0,
4026531840: 33282,
134217728: 0,
402653184: 8421890,
671088640: 33282,
939524096: 32768,
1207959552: 8421888,
1476395008: 512,
1744830464: 8421378,
2013265920: 2,
2281701376: 8389120,
2550136832: 33280,
2818572288: 8421376,
3087007744: 8389122,
3355443200: 8388610,
3623878656: 32770,
3892314112: 514,
4160749568: 8388608,
1: 32768,
268435457: 2,
536870913: 8421888,
805306369: 8388608,
1073741825: 8421378,
1342177281: 33280,
1610612737: 512,
1879048193: 8389122,
2147483649: 8421890,
2415919105: 8421376,
2684354561: 8388610,
2952790017: 33282,
3221225473: 514,
3489660929: 8389120,
3758096385: 32770,
4026531841: 0,
134217729: 8421890,
402653185: 8421376,
671088641: 8388608,
939524097: 512,
1207959553: 32768,
1476395009: 8388610,
1744830465: 2,
2013265921: 33282,
2281701377: 32770,
2550136833: 8389122,
2818572289: 514,
3087007745: 8421888,
3355443201: 8389120,
3623878657: 0,
3892314113: 33280,
4160749569: 8421378
}, {
0: 1074282512,
16777216: 16384,
33554432: 524288,
50331648: 1074266128,
67108864: 1073741840,
83886080: 1074282496,
100663296: 1073758208,
117440512: 16,
134217728: 540672,
150994944: 1073758224,
167772160: 1073741824,
184549376: 540688,
201326592: 524304,
218103808: 0,
234881024: 16400,
251658240: 1074266112,
8388608: 1073758208,
25165824: 540688,
41943040: 16,
58720256: 1073758224,
75497472: 1074282512,
92274688: 1073741824,
109051904: 524288,
125829120: 1074266128,
142606336: 524304,
159383552: 0,
176160768: 16384,
192937984: 1074266112,
209715200: 1073741840,
226492416: 540672,
243269632: 1074282496,
260046848: 16400,
268435456: 0,
285212672: 1074266128,
301989888: 1073758224,
318767104: 1074282496,
335544320: 1074266112,
352321536: 16,
369098752: 540688,
385875968: 16384,
402653184: 16400,
419430400: 524288,
436207616: 524304,
452984832: 1073741840,
469762048: 540672,
486539264: 1073758208,
503316480: 1073741824,
520093696: 1074282512,
276824064: 540688,
293601280: 524288,
310378496: 1074266112,
327155712: 16384,
343932928: 1073758208,
360710144: 1074282512,
377487360: 16,
394264576: 1073741824,
411041792: 1074282496,
427819008: 1073741840,
444596224: 1073758224,
461373440: 524304,
478150656: 0,
494927872: 16400,
511705088: 1074266128,
528482304: 540672
}, {
0: 260,
1048576: 0,
2097152: 67109120,
3145728: 65796,
4194304: 65540,
5242880: 67108868,
6291456: 67174660,
7340032: 67174400,
8388608: 67108864,
9437184: 67174656,
10485760: 65792,
11534336: 67174404,
12582912: 67109124,
13631488: 65536,
14680064: 4,
15728640: 256,
524288: 67174656,
1572864: 67174404,
2621440: 0,
3670016: 67109120,
4718592: 67108868,
5767168: 65536,
6815744: 65540,
7864320: 260,
8912896: 4,
9961472: 256,
11010048: 67174400,
12058624: 65796,
13107200: 65792,
14155776: 67109124,
15204352: 67174660,
16252928: 67108864,
16777216: 67174656,
17825792: 65540,
18874368: 65536,
19922944: 67109120,
20971520: 256,
22020096: 67174660,
23068672: 67108868,
24117248: 0,
25165824: 67109124,
26214400: 67108864,
27262976: 4,
28311552: 65792,
29360128: 67174400,
30408704: 260,
31457280: 65796,
32505856: 67174404,
17301504: 67108864,
18350080: 260,
19398656: 67174656,
20447232: 0,
21495808: 65540,
22544384: 67109120,
23592960: 256,
24641536: 67174404,
25690112: 65536,
26738688: 67174660,
27787264: 65796,
28835840: 67108868,
29884416: 67109124,
30932992: 67174400,
31981568: 4,
33030144: 65792
}, {
0: 2151682048,
65536: 2147487808,
131072: 4198464,
196608: 2151677952,
262144: 0,
327680: 4198400,
393216: 2147483712,
458752: 4194368,
524288: 2147483648,
589824: 4194304,
655360: 64,
720896: 2147487744,
786432: 2151678016,
851968: 4160,
917504: 4096,
983040: 2151682112,
32768: 2147487808,
98304: 64,
163840: 2151678016,
229376: 2147487744,
294912: 4198400,
360448: 2151682112,
425984: 0,
491520: 2151677952,
557056: 4096,
622592: 2151682048,
688128: 4194304,
753664: 4160,
819200: 2147483648,
884736: 4194368,
950272: 4198464,
1015808: 2147483712,
1048576: 4194368,
1114112: 4198400,
1179648: 2147483712,
1245184: 0,
1310720: 4160,
1376256: 2151678016,
1441792: 2151682048,
1507328: 2147487808,
1572864: 2151682112,
1638400: 2147483648,
1703936: 2151677952,
1769472: 4198464,
1835008: 2147487744,
1900544: 4194304,
1966080: 64,
2031616: 4096,
1081344: 2151677952,
1146880: 2151682112,
1212416: 0,
1277952: 4198400,
1343488: 4194368,
1409024: 2147483648,
1474560: 2147487808,
1540096: 64,
1605632: 2147483712,
1671168: 4096,
1736704: 2147487744,
1802240: 2151678016,
1867776: 4160,
1933312: 2151682048,
1998848: 4194304,
2064384: 4198464
}, {
0: 128,
4096: 17039360,
8192: 262144,
12288: 536870912,
16384: 537133184,
20480: 16777344,
24576: 553648256,
28672: 262272,
32768: 16777216,
36864: 537133056,
40960: 536871040,
45056: 553910400,
49152: 553910272,
53248: 0,
57344: 17039488,
61440: 553648128,
2048: 17039488,
6144: 553648256,
10240: 128,
14336: 17039360,
18432: 262144,
22528: 537133184,
26624: 553910272,
30720: 536870912,
34816: 537133056,
38912: 0,
43008: 553910400,
47104: 16777344,
51200: 536871040,
55296: 553648128,
59392: 16777216,
63488: 262272,
65536: 262144,
69632: 128,
73728: 536870912,
77824: 553648256,
81920: 16777344,
86016: 553910272,
90112: 537133184,
94208: 16777216,
98304: 553910400,
102400: 553648128,
106496: 17039360,
110592: 537133056,
114688: 262272,
118784: 536871040,
122880: 0,
126976: 17039488,
67584: 553648256,
71680: 16777216,
75776: 17039360,
79872: 537133184,
83968: 536870912,
88064: 17039488,
92160: 128,
96256: 553910272,
100352: 262272,
104448: 553910400,
108544: 0,
112640: 553648128,
116736: 16777344,
120832: 262144,
124928: 537133056,
129024: 536871040
}, {
0: 268435464,
256: 8192,
512: 270532608,
768: 270540808,
1024: 268443648,
1280: 2097152,
1536: 2097160,
1792: 268435456,
2048: 0,
2304: 268443656,
2560: 2105344,
2816: 8,
3072: 270532616,
3328: 2105352,
3584: 8200,
3840: 270540800,
128: 270532608,
384: 270540808,
640: 8,
896: 2097152,
1152: 2105352,
1408: 268435464,
1664: 268443648,
1920: 8200,
2176: 2097160,
2432: 8192,
2688: 268443656,
2944: 270532616,
3200: 0,
3456: 270540800,
3712: 2105344,
3968: 268435456,
4096: 268443648,
4352: 270532616,
4608: 270540808,
4864: 8200,
5120: 2097152,
5376: 268435456,
5632: 268435464,
5888: 2105344,
6144: 2105352,
6400: 0,
6656: 8,
6912: 270532608,
7168: 8192,
7424: 268443656,
7680: 270540800,
7936: 2097160,
4224: 8,
4480: 2105344,
4736: 2097152,
4992: 268435464,
5248: 268443648,
5504: 8200,
5760: 270540808,
6016: 270532608,
6272: 270540800,
6528: 270532616,
6784: 8192,
7040: 2105352,
7296: 2097160,
7552: 0,
7808: 268435456,
8064: 268443656
}, {
0: 1048576,
16: 33555457,
32: 1024,
48: 1049601,
64: 34604033,
80: 0,
96: 1,
112: 34603009,
128: 33555456,
144: 1048577,
160: 33554433,
176: 34604032,
192: 34603008,
208: 1025,
224: 1049600,
240: 33554432,
8: 34603009,
24: 0,
40: 33555457,
56: 34604032,
72: 1048576,
88: 33554433,
104: 33554432,
120: 1025,
136: 1049601,
152: 33555456,
168: 34603008,
184: 1048577,
200: 1024,
216: 34604033,
232: 1,
248: 1049600,
256: 33554432,
272: 1048576,
288: 33555457,
304: 34603009,
320: 1048577,
336: 33555456,
352: 34604032,
368: 1049601,
384: 1025,
400: 34604033,
416: 1049600,
432: 1,
448: 0,
464: 34603008,
480: 33554433,
496: 1024,
264: 1049600,
280: 33555457,
296: 34603009,
312: 1,
328: 33554432,
344: 1048576,
360: 1025,
376: 34604032,
392: 33554433,
408: 34603008,
424: 0,
440: 34604033,
456: 1049601,
472: 1024,
488: 33555456,
504: 1048577
}, {
0: 134219808,
1: 131072,
2: 134217728,
3: 32,
4: 131104,
5: 134350880,
6: 134350848,
7: 2048,
8: 134348800,
9: 134219776,
10: 133120,
11: 134348832,
12: 2080,
13: 0,
14: 134217760,
15: 133152,
2147483648: 2048,
2147483649: 134350880,
2147483650: 134219808,
2147483651: 134217728,
2147483652: 134348800,
2147483653: 133120,
2147483654: 133152,
2147483655: 32,
2147483656: 134217760,
2147483657: 2080,
2147483658: 131104,
2147483659: 134350848,
2147483660: 0,
2147483661: 134348832,
2147483662: 134219776,
2147483663: 131072,
16: 133152,
17: 134350848,
18: 32,
19: 2048,
20: 134219776,
21: 134217760,
22: 134348832,
23: 131072,
24: 0,
25: 131104,
26: 134348800,
27: 134219808,
28: 134350880,
29: 133120,
30: 2080,
31: 134217728,
2147483664: 131072,
2147483665: 2048,
2147483666: 134348832,
2147483667: 133152,
2147483668: 32,
2147483669: 134348800,
2147483670: 134217728,
2147483671: 134219808,
2147483672: 134350880,
2147483673: 134217760,
2147483674: 134219776,
2147483675: 0,
2147483676: 133120,
2147483677: 2080,
2147483678: 131104,
2147483679: 134350848
}]
, l = [4160749569, 528482304, 33030144, 2064384, 129024, 8064, 504, 2147483679]
, d = r.DES = i.extend({
_doReset: function() {
for (var e = this._key.words, t = [], n = 0; n < 56; n++) {
var i = o[n] - 1;
t[n] = e[i >>> 5] >>> 31 - i % 32 & 1
}
for (var r = this._subKeys = [], u = 0; u < 16; u++) {
var c = r[u] = []
, l = a[u];
for (n = 0; n < 24; n++)
c[n / 6 | 0] |= t[(s[n] - 1 + l) % 28] << 31 - n % 6,
c[4 + (n / 6 | 0)] |= t[28 + (s[n + 24] - 1 + l) % 28] << 31 - n % 6;
for (c[0] = c[0] << 1 | c[0] >>> 31,
n = 1; n < 7; n++)
c[n] = c[n] >>> 4 * (n - 1) + 3;
c[7] = c[7] << 5 | c[7] >>> 27
}
var d = this._invSubKeys = [];
for (n = 0; n < 16; n++)
d[n] = r[15 - n]
},
encryptBlock: function(e, t) {
this._doCryptBlock(e, t, this._subKeys)
},
decryptBlock: function(e, t) {
this._doCryptBlock(e, t, this._invSubKeys)
},
_doCryptBlock: function(e, t, n) {
this._lBlock = e[t],
this._rBlock = e[t + 1],
f.call(this, 4, 252645135),
f.call(this, 16, 65535),
h.call(this, 2, 858993459),
h.call(this, 8, 16711935),
f.call(this, 1, 1431655765);
for (var i = 0; i < 16; i++) {
for (var r = n[i], o = this._lBlock, s = this._rBlock, a = 0, u = 0; u < 8; u++)
a |= c[u][((s ^ r[u]) & l[u]) >>> 0];
this._lBlock = s,
this._rBlock = o ^ a
}
var d = this._lBlock;
this._lBlock = this._rBlock,
this._rBlock = d,
f.call(this, 1, 1431655765),
h.call(this, 8, 16711935),
h.call(this, 2, 858993459),
f.call(this, 16, 65535),
f.call(this, 4, 252645135),
e[t] = this._lBlock,
e[t + 1] = this._rBlock
},
keySize: 2,
ivSize: 2,
blockSize: 2
});
function f(e, t) {
var n = (this._lBlock >>> e ^ this._rBlock) & t;
this._rBlock ^= n,
this._lBlock ^= n << e
}
function h(e, t) {
var n = (this._rBlock >>> e ^ this._lBlock) & t;
this._lBlock ^= n,
this._rBlock ^= n << e
}
e.DES = i._createHelper(d);
var p = r.TripleDES = i.extend({
_doReset: function() {
var e = this._key.words;
this._des1 = d.createEncryptor(n.create(e.slice(0, 2))),
this._des2 = d.createEncryptor(n.create(e.slice(2, 4))),
this._des3 = d.createEncryptor(n.create(e.slice(4, 6)))
},
encryptBlock: function(e, t) {
this._des1.encryptBlock(e, t),
this._des2.decryptBlock(e, t),
this._des3.encryptBlock(e, t)
},
decryptBlock: function(e, t) {
this._des3.decryptBlock(e, t),
this._des2.encryptBlock(e, t),
this._des1.decryptBlock(e, t)
},
keySize: 6,
ivSize: 2,
blockSize: 2
});
e.TripleDES = i._createHelper(p)
}(),
function() {
var e = u
, t = e.lib.StreamCipher
, n = e.algo
, i = n.RC4 = t.extend({
_doReset: function() {
for (var e = this._key, t = e.words, n = e.sigBytes, i = this._S = [], r = 0; r < 256; r++)
i[r] = r;
r = 0;
for (var o = 0; r < 256; r++) {
var s = r % n
, a = t[s >>> 2] >>> 24 - s % 4 * 8 & 255;
o = (o + i[r] + a) % 256;
var u = i[r];
i[r] = i[o],
i[o] = u
}
this._i = this._j = 0
},
_doProcessBlock: function(e, t) {
e[t] ^= r.call(this)
},
keySize: 8,
ivSize: 0
});
function r() {
for (var e = this._S, t = this._i, n = this._j, i = 0, r = 0; r < 4; r++) {
n = (n + e[t = (t + 1) % 256]) % 256;
var o = e[t];
e[t] = e[n],
e[n] = o,
i |= e[(e[t] + e[n]) % 256] << 24 - 8 * r
}
return this._i = t,
this._j = n,
i
}
e.RC4 = t._createHelper(i);
var o = n.RC4Drop = i.extend({
cfg: i.cfg.extend({
drop: 192
}),
_doReset: function() {
i._doReset.call(this);
for (var e = this.cfg.drop; e > 0; e--)
r.call(this)
}
});
e.RC4Drop = t._createHelper(o)
}(),
/** @preserve
* Counter block mode compatible with Dr Brian Gladman fileenc.c
* derived from CryptoJS.mode.CTR
* Jan Hruby jhruby.web@gmail.com
*/
u.mode.CTRGladman = function() {
var e = u.lib.BlockCipherMode.extend();
function t(e) {
if (255 == (e >> 24 & 255)) {
var t = e >> 16 & 255
, n = e >> 8 & 255
, i = 255 & e;
255 === t ? (t = 0,
255 === n ? (n = 0,
255 === i ? i = 0 : ++i) : ++n) : ++t,
e = 0,
e += t << 16,
e += n << 8,
e += i
} else
e += 1 << 24;
return e
}
var n = e.Encryptor = e.extend({
processBlock: function(e, n) {
var i = this._cipher
, r = i.blockSize
, o = this._iv
, s = this._counter;
o && (s = this._counter = o.slice(0),
this._iv = void 0),
function(e) {
0 === (e[0] = t(e[0])) && (e[1] = t(e[1]))
}(s);
var a = s.slice(0);
i.encryptBlock(a, 0);
for (var u = 0; u < r; u++)
e[n + u] ^= a[u]
}
});
return e.Decryptor = n,
e
}(),
function() {
var e = u
, t = e.lib.StreamCipher
, n = e.algo
, i = []
, r = []
, o = []
, s = n.Rabbit = t.extend({
_doReset: function() {
for (var e = this._key.words, t = this.cfg.iv, n = 0; n < 4; n++)
e[n] = 16711935 & (e[n] << 8 | e[n] >>> 24) | 4278255360 & (e[n] << 24 | e[n] >>> 8);
var i = this._X = [e[0], e[3] << 16 | e[2] >>> 16, e[1], e[0] << 16 | e[3] >>> 16, e[2], e[1] << 16 | e[0] >>> 16, e[3], e[2] << 16 | e[1] >>> 16]
, r = this._C = [e[2] << 16 | e[2] >>> 16, 4294901760 & e[0] | 65535 & e[1], e[3] << 16 | e[3] >>> 16, 4294901760 & e[1] | 65535 & e[2], e[0] << 16 | e[0] >>> 16, 4294901760 & e[2] | 65535 & e[3], e[1] << 16 | e[1] >>> 16, 4294901760 & e[3] | 65535 & e[0]];
for (this._b = 0,
n = 0; n < 4; n++)
a.call(this);
for (n = 0; n < 8; n++)
r[n] ^= i[n + 4 & 7];
if (t) {
var o = t.words
, s = o[0]
, u = o[1]
, c = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8)
, l = 16711935 & (u << 8 | u >>> 24) | 4278255360 & (u << 24 | u >>> 8)
, d = c >>> 16 | 4294901760 & l
, f = l << 16 | 65535 & c;
for (r[0] ^= c,
r[1] ^= d,
r[2] ^= l,
r[3] ^= f,
r[4] ^= c,
r[5] ^= d,
r[6] ^= l,
r[7] ^= f,
n = 0; n < 4; n++)
a.call(this)
}
},
_doProcessBlock: function(e, t) {
var n = this._X;
a.call(this),
i[0] = n[0] ^ n[5] >>> 16 ^ n[3] << 16,
i[1] = n[2] ^ n[7] >>> 16 ^ n[5] << 16,
i[2] = n[4] ^ n[1] >>> 16 ^ n[7] << 16,
i[3] = n[6] ^ n[3] >>> 16 ^ n[1] << 16;
for (var r = 0; r < 4; r++)
i[r] = 16711935 & (i[r] << 8 | i[r] >>> 24) | 4278255360 & (i[r] << 24 | i[r] >>> 8),
e[t + r] ^= i[r]
},
blockSize: 4,
ivSize: 2
});
function a() {
for (var e = this._X, t = this._C, n = 0; n < 8; n++)
r[n] = t[n];
for (t[0] = t[0] + 1295307597 + this._b | 0,
t[1] = t[1] + 3545052371 + (t[0] >>> 0 < r[0] >>> 0 ? 1 : 0) | 0,
t[2] = t[2] + 886263092 + (t[1] >>> 0 < r[1] >>> 0 ? 1 : 0) | 0,
t[3] = t[3] + 1295307597 + (t[2] >>> 0 < r[2] >>> 0 ? 1 : 0) | 0,
t[4] = t[4] + 3545052371 + (t[3] >>> 0 < r[3] >>> 0 ? 1 : 0) | 0,
t[5] = t[5] + 886263092 + (t[4] >>> 0 < r[4] >>> 0 ? 1 : 0) | 0,
t[6] = t[6] + 1295307597 + (t[5] >>> 0 < r[5] >>> 0 ? 1 : 0) | 0,
t[7] = t[7] + 3545052371 + (t[6] >>> 0 < r[6] >>> 0 ? 1 : 0) | 0,
this._b = t[7] >>> 0 < r[7] >>> 0 ? 1 : 0,
n = 0; n < 8; n++) {
var i = e[n] + t[n]
, s = 65535 & i
, a = i >>> 16
, u = ((s * s >>> 17) + s * a >>> 15) + a * a
, c = ((4294901760 & i) * i | 0) + ((65535 & i) * i | 0);
o[n] = u ^ c
}
e[0] = o[0] + (o[7] << 16 | o[7] >>> 16) + (o[6] << 16 | o[6] >>> 16) | 0,
e[1] = o[1] + (o[0] << 8 | o[0] >>> 24) + o[7] | 0,
e[2] = o[2] + (o[1] << 16 | o[1] >>> 16) + (o[0] << 16 | o[0] >>> 16) | 0,
e[3] = o[3] + (o[2] << 8 | o[2] >>> 24) + o[1] | 0,
e[4] = o[4] + (o[3] << 16 | o[3] >>> 16) + (o[2] << 16 | o[2] >>> 16) | 0,
e[5] = o[5] + (o[4] << 8 | o[4] >>> 24) + o[3] | 0,
e[6] = o[6] + (o[5] << 16 | o[5] >>> 16) + (o[4] << 16 | o[4] >>> 16) | 0,
e[7] = o[7] + (o[6] << 8 | o[6] >>> 24) + o[5] | 0
}
e.Rabbit = t._createHelper(s)
}(),
u.mode.CTR = function() {
var e = u.lib.BlockCipherMode.extend()
, t = e.Encryptor = e.extend({
processBlock: function(e, t) {
var n = this._cipher
, i = n.blockSize
, r = this._iv
, o = this._counter;
r && (o = this._counter = r.slice(0),
this._iv = void 0);
var s = o.slice(0);
n.encryptBlock(s, 0),
o[i - 1] = o[i - 1] + 1 | 0;
for (var a = 0; a < i; a++)
e[t + a] ^= s[a]
}
});
return e.Decryptor = t,
e
}(),
function() {
var e = u
, t = e.lib.StreamCipher
, n = e.algo
, i = []
, r = []
, o = []
, s = n.RabbitLegacy = t.extend({
_doReset: function() {
var e = this._key.words
, t = this.cfg.iv
, n = this._X = [e[0], e[3] << 16 | e[2] >>> 16, e[1], e[0] << 16 | e[3] >>> 16, e[2], e[1] << 16 | e[0] >>> 16, e[3], e[2] << 16 | e[1] >>> 16]
, i = this._C = [e[2] << 16 | e[2] >>> 16, 4294901760 & e[0] | 65535 & e[1], e[3] << 16 | e[3] >>> 16, 4294901760 & e[1] | 65535 & e[2], e[0] << 16 | e[0] >>> 16, 4294901760 & e[2] | 65535 & e[3], e[1] << 16 | e[1] >>> 16, 4294901760 & e[3] | 65535 & e[0]];
this._b = 0;
for (var r = 0; r < 4; r++)
a.call(this);
for (r = 0; r < 8; r++)
i[r] ^= n[r + 4 & 7];
if (t) {
var o = t.words
, s = o[0]
, u = o[1]
, c = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8)
, l = 16711935 & (u << 8 | u >>> 24) | 4278255360 & (u << 24 | u >>> 8)
, d = c >>> 16 | 4294901760 & l
, f = l << 16 | 65535 & c;
for (i[0] ^= c,
i[1] ^= d,
i[2] ^= l,
i[3] ^= f,
i[4] ^= c,
i[5] ^= d,
i[6] ^= l,
i[7] ^= f,
r = 0; r < 4; r++)
a.call(this)
}
},
_doProcessBlock: function(e, t) {
var n = this._X;
a.call(this),
i[0] = n[0] ^ n[5] >>> 16 ^ n[3] << 16,
i[1] = n[2] ^ n[7] >>> 16 ^ n[5] << 16,
i[2] = n[4] ^ n[1] >>> 16 ^ n[7] << 16,
i[3] = n[6] ^ n[3] >>> 16 ^ n[1] << 16;
for (var r = 0; r < 4; r++)
i[r] = 16711935 & (i[r] << 8 | i[r] >>> 24) | 4278255360 & (i[r] << 24 | i[r] >>> 8),
e[t + r] ^= i[r]
},
blockSize: 4,
ivSize: 2
});
function a() {
for (var e = this._X, t = this._C, n = 0; n < 8; n++)
r[n] = t[n];
for (t[0] = t[0] + 1295307597 + this._b | 0,
t[1] = t[1] + 3545052371 + (t[0] >>> 0 < r[0] >>> 0 ? 1 : 0) | 0,
t[2] = t[2] + 886263092 + (t[1] >>> 0 < r[1] >>> 0 ? 1 : 0) | 0,
t[3] = t[3] + 1295307597 + (t[2] >>> 0 < r[2] >>> 0 ? 1 : 0) | 0,
t[4] = t[4] + 3545052371 + (t[3] >>> 0 < r[3] >>> 0 ? 1 : 0) | 0,
t[5] = t[5] + 886263092 + (t[4] >>> 0 < r[4] >>> 0 ? 1 : 0) | 0,
t[6] = t[6] + 1295307597 + (t[5] >>> 0 < r[5] >>> 0 ? 1 : 0) | 0,
t[7] = t[7] + 3545052371 + (t[6] >>> 0 < r[6] >>> 0 ? 1 : 0) | 0,
this._b = t[7] >>> 0 < r[7] >>> 0 ? 1 : 0,
n = 0; n < 8; n++) {
var i = e[n] + t[n]
, s = 65535 & i
, a = i >>> 16
, u = ((s * s >>> 17) + s * a >>> 15) + a * a
, c = ((4294901760 & i) * i | 0) + ((65535 & i) * i | 0);
o[n] = u ^ c
}
e[0] = o[0] + (o[7] << 16 | o[7] >>> 16) + (o[6] << 16 | o[6] >>> 16) | 0,
e[1] = o[1] + (o[0] << 8 | o[0] >>> 24) + o[7] | 0,
e[2] = o[2] + (o[1] << 16 | o[1] >>> 16) + (o[0] << 16 | o[0] >>> 16) | 0,
e[3] = o[3] + (o[2] << 8 | o[2] >>> 24) + o[1] | 0,
e[4] = o[4] + (o[3] << 16 | o[3] >>> 16) + (o[2] << 16 | o[2] >>> 16) | 0,
e[5] = o[5] + (o[4] << 8 | o[4] >>> 24) + o[3] | 0,
e[6] = o[6] + (o[5] << 16 | o[5] >>> 16) + (o[4] << 16 | o[4] >>> 16) | 0,
e[7] = o[7] + (o[6] << 8 | o[6] >>> 24) + o[5] | 0
}
e.RabbitLegacy = t._createHelper(s)
}(),
u.pad.ZeroPadding = {
pad: function(e, t) {
var n = 4 * t;
e.clamp(),
e.sigBytes += n - (e.sigBytes % n || n)
},
unpad: function(e) {
for (var t = e.words, n = e.sigBytes - 1; !(t[n >>> 2] >>> 24 - n % 4 * 8 & 255); )
n--;
e.sigBytes = n + 1
}
},
u)
},
'cf773e592f332dee5d09': function(t, e, s) {
"use strict";
s.d(e, "a", (function() {
return a
}
)),
s.d(e, "b", (function() {
return o
}
)),
s.d(e, "d", (function() {
return l
}
)),
s.d(e, "c", (function() {
return d
}
));
s("7ae52036d1906f8c617e");
var i = s("5be32fcb987f2caeeb7c")
, r = s.n(i)
, c = r.a.enc.Utf8.parse("eFgabcda1bcda12bc2bcdePgefgadefg")
, n = r.a.enc.Utf8.parse();
function a(t) {
var e = c
, s = n
, i = r.a.enc.Base64.parse(t)
, a = r.a.enc.Base64.stringify(i);
window.key = r.a.AES.decrypt(a, e, {
iv: s,
mode: r.a.mode.ECB,
padding: r.a.pad.Pkcs7
}).toString(r.a.enc.Utf8).toString()
}
var o = function(t, e) {
var s, i, r = e || 500;
return function() {
var e = this
, c = arguments
, n = +new Date;
s && n - s < r ? (clearTimeout(i),
i = setTimeout((function() {
s = n,
t.apply(e, c)
}
), r)) : (s = n,
t.apply(this, c))
}
};
function l(t) {
for (var e = 0, s = 0; s < t.length; s++) {
var i = t.charCodeAt(s);
i >= 1 && i <= 126 || 65376 <= i && i <= 65439 ? e++ : e += 2
}
return e
}
function d(t) {
for (var e = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2], s = t + "", i = t[17], r = s.substring(0, 17).split(""), c = r.length, n = 0, a = 0; a < c; a++)
n += r[a] * e[a];
var o = ["1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"][n % 11]
, l = /^[1-9][0-9]{5}([1][9][0-9]{2}|[2][0][0|1][0-9])([0][1-9]|[1][0|1|2])([0][1-9]|[1|2][0-9]|[3][0|1])[0-9]{3}([0-9]|[X])$/.test(t);
return !(i !== o || !l)
}
},
});
//
stwww= "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"
var s = use("cf773e592f332dee5d09").a(stwww);
console.log(window.key)
结果