home *** CD-ROM | disk | FTP | other *** search
/ 600 Games / 600games.iso / Puzzle / crazycube.swf / scripts / frame_2 / DoAction.as
Encoding:
Text File  |  2006-06-13  |  9.3 KB  |  230 lines

  1. function hex_md5(s)
  2. {
  3.    return binl2hex(core_md5(str2binl(s),s.length * chrsz));
  4. }
  5. function b64_md5(s)
  6. {
  7.    return binl2b64(core_md5(str2binl(s),s.length * chrsz));
  8. }
  9. function str_md5(s)
  10. {
  11.    return binl2str(core_md5(str2binl(s),s.length * chrsz));
  12. }
  13. function hex_hmac_md5(key, data)
  14. {
  15.    return binl2hex(core_hmac_md5(key,data));
  16. }
  17. function b64_hmac_md5(key, data)
  18. {
  19.    return binl2b64(core_hmac_md5(key,data));
  20. }
  21. function str_hmac_md5(key, data)
  22. {
  23.    return binl2str(core_hmac_md5(key,data));
  24. }
  25. function md5_vm_test()
  26. {
  27.    return hex_md5("abc") == "900150983cd24fb0d6963f7d28e17f72";
  28. }
  29. function core_md5(x, len)
  30. {
  31.    x[len >> 5] |= 128 << len % 32;
  32.    x[(len + 64 >>> 9 << 4) + 14] = len;
  33.    var _loc4_ = 1732584193;
  34.    var _loc3_ = -271733879;
  35.    var _loc2_ = -1732584194;
  36.    var _loc1_ = 271733878;
  37.    var _loc5_ = 0;
  38.    while(_loc5_ < x.length)
  39.    {
  40.       var _loc10_ = _loc4_;
  41.       var _loc9_ = _loc3_;
  42.       var _loc8_ = _loc2_;
  43.       var _loc7_ = _loc1_;
  44.       _loc4_ = md5_ff(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 0],7,-680876936);
  45.       _loc1_ = md5_ff(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 1],12,-389564586);
  46.       _loc2_ = md5_ff(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 2],17,606105819);
  47.       _loc3_ = md5_ff(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 3],22,-1044525330);
  48.       _loc4_ = md5_ff(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 4],7,-176418897);
  49.       _loc1_ = md5_ff(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 5],12,1200080426);
  50.       _loc2_ = md5_ff(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 6],17,-1473231341);
  51.       _loc3_ = md5_ff(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 7],22,-45705983);
  52.       _loc4_ = md5_ff(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 8],7,1770035416);
  53.       _loc1_ = md5_ff(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 9],12,-1958414417);
  54.       _loc2_ = md5_ff(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 10],17,-42063);
  55.       _loc3_ = md5_ff(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 11],22,-1990404162);
  56.       _loc4_ = md5_ff(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 12],7,1804603682);
  57.       _loc1_ = md5_ff(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 13],12,-40341101);
  58.       _loc2_ = md5_ff(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 14],17,-1502002290);
  59.       _loc3_ = md5_ff(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 15],22,1236535329);
  60.       _loc4_ = md5_gg(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 1],5,-165796510);
  61.       _loc1_ = md5_gg(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 6],9,-1069501632);
  62.       _loc2_ = md5_gg(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 11],14,643717713);
  63.       _loc3_ = md5_gg(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 0],20,-373897302);
  64.       _loc4_ = md5_gg(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 5],5,-701558691);
  65.       _loc1_ = md5_gg(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 10],9,38016083);
  66.       _loc2_ = md5_gg(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 15],14,-660478335);
  67.       _loc3_ = md5_gg(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 4],20,-405537848);
  68.       _loc4_ = md5_gg(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 9],5,568446438);
  69.       _loc1_ = md5_gg(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 14],9,-1019803690);
  70.       _loc2_ = md5_gg(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 3],14,-187363961);
  71.       _loc3_ = md5_gg(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 8],20,1163531501);
  72.       _loc4_ = md5_gg(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 13],5,-1444681467);
  73.       _loc1_ = md5_gg(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 2],9,-51403784);
  74.       _loc2_ = md5_gg(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 7],14,1735328473);
  75.       _loc3_ = md5_gg(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 12],20,-1926607734);
  76.       _loc4_ = md5_hh(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 5],4,-378558);
  77.       _loc1_ = md5_hh(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 8],11,-2022574463);
  78.       _loc2_ = md5_hh(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 11],16,1839030562);
  79.       _loc3_ = md5_hh(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 14],23,-35309556);
  80.       _loc4_ = md5_hh(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 1],4,-1530992060);
  81.       _loc1_ = md5_hh(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 4],11,1272893353);
  82.       _loc2_ = md5_hh(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 7],16,-155497632);
  83.       _loc3_ = md5_hh(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 10],23,-1094730640);
  84.       _loc4_ = md5_hh(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 13],4,681279174);
  85.       _loc1_ = md5_hh(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 0],11,-358537222);
  86.       _loc2_ = md5_hh(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 3],16,-722521979);
  87.       _loc3_ = md5_hh(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 6],23,76029189);
  88.       _loc4_ = md5_hh(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 9],4,-640364487);
  89.       _loc1_ = md5_hh(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 12],11,-421815835);
  90.       _loc2_ = md5_hh(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 15],16,530742520);
  91.       _loc3_ = md5_hh(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 2],23,-995338651);
  92.       _loc4_ = md5_ii(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 0],6,-198630844);
  93.       _loc1_ = md5_ii(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 7],10,1126891415);
  94.       _loc2_ = md5_ii(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 14],15,-1416354905);
  95.       _loc3_ = md5_ii(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 5],21,-57434055);
  96.       _loc4_ = md5_ii(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 12],6,1700485571);
  97.       _loc1_ = md5_ii(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 3],10,-1894986606);
  98.       _loc2_ = md5_ii(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 10],15,-1051523);
  99.       _loc3_ = md5_ii(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 1],21,-2054922799);
  100.       _loc4_ = md5_ii(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 8],6,1873313359);
  101.       _loc1_ = md5_ii(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 15],10,-30611744);
  102.       _loc2_ = md5_ii(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 6],15,-1560198380);
  103.       _loc3_ = md5_ii(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 13],21,1309151649);
  104.       _loc4_ = md5_ii(_loc4_,_loc3_,_loc2_,_loc1_,x[_loc5_ + 4],6,-145523070);
  105.       _loc1_ = md5_ii(_loc1_,_loc4_,_loc3_,_loc2_,x[_loc5_ + 11],10,-1120210379);
  106.       _loc2_ = md5_ii(_loc2_,_loc1_,_loc4_,_loc3_,x[_loc5_ + 2],15,718787259);
  107.       _loc3_ = md5_ii(_loc3_,_loc2_,_loc1_,_loc4_,x[_loc5_ + 9],21,-343485551);
  108.       _loc4_ = safe_add(_loc4_,_loc10_);
  109.       _loc3_ = safe_add(_loc3_,_loc9_);
  110.       _loc2_ = safe_add(_loc2_,_loc8_);
  111.       _loc1_ = safe_add(_loc1_,_loc7_);
  112.       _loc5_ += 16;
  113.    }
  114.    return Array(_loc4_,_loc3_,_loc2_,_loc1_);
  115. }
  116. function md5_cmn(q, a, b, x, s, t)
  117. {
  118.    return safe_add(bit_rol(safe_add(safe_add(a,q),safe_add(x,t)),s),b);
  119. }
  120. function md5_ff(a, b, c, d, x, s, t)
  121. {
  122.    return md5_cmn(b & c | (~b) & d,a,b,x,s,t);
  123. }
  124. function md5_gg(a, b, c, d, x, s, t)
  125. {
  126.    return md5_cmn(b & d | c & (~d),a,b,x,s,t);
  127. }
  128. function md5_hh(a, b, c, d, x, s, t)
  129. {
  130.    return md5_cmn(b ^ c ^ d,a,b,x,s,t);
  131. }
  132. function md5_ii(a, b, c, d, x, s, t)
  133. {
  134.    return md5_cmn(c ^ (b | ~d),a,b,x,s,t);
  135. }
  136. function core_hmac_md5(key, data)
  137. {
  138.    var _loc2_ = str2binl(key);
  139.    if(_loc2_.length > 16)
  140.    {
  141.       _loc2_ = core_md5(_loc2_,key.length * chrsz);
  142.    }
  143.    var _loc3_ = Array(16);
  144.    var _loc4_ = Array(16);
  145.    var _loc1_ = 0;
  146.    while(_loc1_ < 16)
  147.    {
  148.       _loc3_[_loc1_] = _loc2_[_loc1_] ^ 0x36363636;
  149.       _loc4_[_loc1_] = _loc2_[_loc1_] ^ 0x5C5C5C5C;
  150.       _loc1_ = _loc1_ + 1;
  151.    }
  152.    var _loc5_ = core_md5(_loc3_.concat(str2binl(data)),512 + data.length * chrsz);
  153.    return core_md5(_loc4_.concat(_loc5_),640);
  154. }
  155. function safe_add(x, y)
  156. {
  157.    var _loc1_ = (x & 0xFFFF) + (y & 0xFFFF);
  158.    var _loc2_ = (x >> 16) + (y >> 16) + (_loc1_ >> 16);
  159.    return _loc2_ << 16 | _loc1_ & 0xFFFF;
  160. }
  161. function bit_rol(num, cnt)
  162. {
  163.    return num << cnt | num >>> 32 - cnt;
  164. }
  165. function str2binl(str)
  166. {
  167.    var _loc3_ = Array();
  168.    var _loc4_ = (1 << chrsz) - 1;
  169.    var _loc1_ = 0;
  170.    while(_loc1_ < str.length * chrsz)
  171.    {
  172.       _loc3_[_loc1_ >> 5] |= (str.charCodeAt(_loc1_ / chrsz) & _loc4_) << _loc1_ % 32;
  173.       _loc1_ += chrsz;
  174.    }
  175.    return _loc3_;
  176. }
  177. function binl2str(bin)
  178. {
  179.    var _loc3_ = "";
  180.    var _loc4_ = (1 << chrsz) - 1;
  181.    var _loc1_ = 0;
  182.    while(_loc1_ < bin.length * 32)
  183.    {
  184.       _loc3_ += String.fromCharCode(bin[_loc1_ >> 5] >>> _loc1_ % 32 & _loc4_);
  185.       _loc1_ += chrsz;
  186.    }
  187.    return _loc3_;
  188. }
  189. function binl2hex(binarray)
  190. {
  191.    var _loc3_ = !hexcase ? "0123456789abcdef" : "0123456789ABCDEF";
  192.    var _loc4_ = "";
  193.    var _loc1_ = 0;
  194.    while(_loc1_ < binarray.length * 4)
  195.    {
  196.       _loc4_ += _loc3_.charAt(binarray[_loc1_ >> 2] >> _loc1_ % 4 * 8 + 4 & 0x0F) + _loc3_.charAt(binarray[_loc1_ >> 2] >> _loc1_ % 4 * 8 & 0x0F);
  197.       _loc1_ = _loc1_ + 1;
  198.    }
  199.    return _loc4_;
  200. }
  201. function binl2b64(binarray)
  202. {
  203.    var _loc6_ = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  204.    var _loc4_ = "";
  205.    var _loc2_ = 0;
  206.    while(_loc2_ < binarray.length * 4)
  207.    {
  208.       var _loc5_ = (binarray[_loc2_ >> 2] >> 8 * (_loc2_ % 4) & 0xFF) << 16 | (binarray[_loc2_ + 1 >> 2] >> 8 * ((_loc2_ + 1) % 4) & 0xFF) << 8 | binarray[_loc2_ + 2 >> 2] >> 8 * ((_loc2_ + 2) % 4) & 0xFF;
  209.       var _loc1_ = 0;
  210.       while(_loc1_ < 4)
  211.       {
  212.          if(_loc2_ * 8 + _loc1_ * 6 > binarray.length * 32)
  213.          {
  214.             _loc4_ += b64pad;
  215.          }
  216.          else
  217.          {
  218.             _loc4_ += _loc6_.charAt(_loc5_ >> 6 * (3 - _loc1_) & 0x3F);
  219.          }
  220.          _loc1_ = _loc1_ + 1;
  221.       }
  222.       _loc2_ += 3;
  223.    }
  224.    return _loc4_;
  225. }
  226. stop();
  227. var hexcase = 0;
  228. var b64pad = "";
  229. var chrsz = 8;
  230.