- ]
-
- class MD5():
- HEX_FORMAT_LOWERCASE = 0
- HEX_FORMAT_UPPERCASE = 1
- BASE64_PAD_CHARACTER_DEFAULT_COMPLIANCE = ''
- BASE64_PAD_CHARACTER_RFC_COMPLIANCE = '='
- PADDING = '=0xFF01DD'
- hexcase = 0
- b64pad = ''
-
- def __init__(self):
- pass
-
- class JSArray(list):
- def __getitem__(self, y):
- try:
- return list.__getitem__(self, y)
- except IndexError:
- return 0
-
- def __setitem__(self, i, y):
- try:
- return list.__setitem__(self, i, y)
- except IndexError:
- self.extend([0] * (i - len(self) + 1))
- self[-1] = y
-
- @classmethod
- def hex_md5(cls, param1):
- return cls.rstr2hex(cls.rstr_md5(cls.str2rstr_utf8(param1)))
-
- @classmethod
- def b64_md5(cls, param1, param2=None):
- return cls.rstr2b64(cls.rstr_md5(cls.str2rstr_utf8(param1, param2)))
-
- @classmethod
- def any_md5(cls, param1, param2):
- return cls.rstr2any(cls.rstr_md5(cls.str2rstr_utf8(param1)), param2)
-
- @classmethod
- def rstr_md5(cls, param1):
- return cls.binl2rstr(cls.binl_md5(cls.rstr2binl(param1), len(param1) * 8))
-
- @classmethod
- def rstr2hex(cls, param1):
- _loc_2 = '0123456789ABCDEF' if cls.hexcase else '0123456789abcdef'
- _loc_3 = ''
- for _loc_5 in range(0, len(param1)):
- _loc_4 = compat_ord(param1[_loc_5])
- _loc_3 += _loc_2[_loc_4 >> 4 & 15] + _loc_2[_loc_4 & 15]
- return _loc_3
-
- @classmethod
- def rstr2b64(cls, param1):
- _loc_2 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_'
- _loc_3 = ''
- _loc_4 = len(param1)
- for _loc_5 in range(0, _loc_4, 3):
- _loc_6_1 = compat_ord(param1[_loc_5]) << 16
- _loc_6_2 = compat_ord(param1[_loc_5 + 1]) << 8 if _loc_5 + 1 < _loc_4 else 0
- _loc_6_3 = compat_ord(param1[_loc_5 + 2]) if _loc_5 + 2 < _loc_4 else 0
- _loc_6 = _loc_6_1 | _loc_6_2 | _loc_6_3
- for _loc_7 in range(0, 4):
- if _loc_5 * 8 + _loc_7 * 6 > len(param1) * 8:
- _loc_3 += cls.b64pad
- else:
- _loc_3 += _loc_2[_loc_6 >> 6 * (3 - _loc_7) & 63]
- return _loc_3
-
- @staticmethod
- def rstr2any(param1, param2):
- _loc_3 = len(param2)
- _loc_4 = []
- _loc_9 = [0] * ((len(param1) >> 2) + 1)
- for _loc_5 in range(0, len(_loc_9)):
- _loc_9[_loc_5] = compat_ord(param1[_loc_5 * 2]) << 8 | compat_ord(param1[_loc_5 * 2 + 1])
-
- while len(_loc_9) > 0:
- _loc_8 = []
- _loc_7 = 0
- for _loc_5 in range(0, len(_loc_9)):
- _loc_7 = (_loc_7 << 16) + _loc_9[_loc_5]
- _loc_6 = math.floor(_loc_7 / _loc_3)
- _loc_7 -= _loc_6 * _loc_3
- if len(_loc_8) > 0 or _loc_6 > 0:
- _loc_8[len(_loc_8)] = _loc_6
-
- _loc_4[len(_loc_4)] = _loc_7
- _loc_9 = _loc_8
-
- _loc_10 = ''
- _loc_5 = len(_loc_4) - 1
- while _loc_5 >= 0:
- _loc_10 += param2[_loc_4[_loc_5]]
- _loc_5 -= 1
-
- return _loc_10
-
- @classmethod
- def str2rstr_utf8(cls, param1, param2=None):
- _loc_3 = ''
- _loc_4 = -1
- if not param2:
- param2 = cls.PADDING
- param1 = param1 + param2[1:9]
- while True:
- _loc_4 += 1
- if _loc_4 >= len(param1):
- break
- _loc_5 = compat_ord(param1[_loc_4])
- _loc_6 = compat_ord(param1[_loc_4 + 1]) if _loc_4 + 1 < len(param1) else 0
- if 55296 <= _loc_5 <= 56319 and 56320 <= _loc_6 <= 57343:
- _loc_5 = 65536 + ((_loc_5 & 1023) << 10) + (_loc_6 & 1023)
- _loc_4 += 1
- if _loc_5 <= 127:
- _loc_3 += compat_chr(_loc_5)
- continue
- if _loc_5 <= 2047:
- _loc_3 += compat_chr(192 | _loc_5 >> 6 & 31) + compat_chr(128 | _loc_5 & 63)
- continue
- if _loc_5 <= 65535:
- _loc_3 += compat_chr(224 | _loc_5 >> 12 & 15) + compat_chr(128 | _loc_5 >> 6 & 63) + compat_chr(
- 128 | _loc_5 & 63)
- continue
- if _loc_5 <= 2097151:
- _loc_3 += compat_chr(240 | _loc_5 >> 18 & 7) + compat_chr(128 | _loc_5 >> 12 & 63) + compat_chr(
- 128 | _loc_5 >> 6 & 63) + compat_chr(128 | _loc_5 & 63)
- return _loc_3
-
- @staticmethod
- def rstr2binl(param1):
- _loc_2 = [0] * ((len(param1) >> 2) + 1)
- for _loc_3 in range(0, len(_loc_2)):
- _loc_2[_loc_3] = 0
- for _loc_3 in range(0, len(param1) * 8, 8):
- _loc_2[_loc_3 >> 5] |= (compat_ord(param1[_loc_3 // 8]) & 255) << _loc_3 % 32
- return _loc_2
-
- @staticmethod
- def binl2rstr(param1):
- _loc_2 = ''
- for _loc_3 in range(0, len(param1) * 32, 8):
- _loc_2 += compat_chr(param1[_loc_3 >> 5] >> _loc_3 % 32 & 255)
- return _loc_2
-
- @classmethod
- def binl_md5(cls, param1, param2):
- param1 = cls.JSArray(param1)
- param1[param2 >> 5] |= 128 << param2 % 32
- param1[(param2 + 64 >> 9 << 4) + 14] = param2
- _loc_3 = 1732584193
- _loc_4 = -271733879
- _loc_5 = -1732584194
- _loc_6 = 271733878
- for _loc_7 in range(0, len(param1), 16):
- _loc_8 = _loc_3
- _loc_9 = _loc_4
- _loc_10 = _loc_5
- _loc_11 = _loc_6
- _loc_3 = cls.md5_ff(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 0], 7, -680876936)
- _loc_6 = cls.md5_ff(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 1], 12, -389564586)
- _loc_5 = cls.md5_ff(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 2], 17, 606105819)
- _loc_4 = cls.md5_ff(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 3], 22, -1044525330)
- _loc_3 = cls.md5_ff(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 4], 7, -176418897)
- _loc_6 = cls.md5_ff(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 5], 12, 1200080426)
- _loc_5 = cls.md5_ff(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 6], 17, -1473231341)
- _loc_4 = cls.md5_ff(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 7], 22, -45705983)
- _loc_3 = cls.md5_ff(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 8], 7, 1770035416)
- _loc_6 = cls.md5_ff(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 9], 12, -1958414417)
- _loc_5 = cls.md5_ff(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 10], 17, -42063)
- _loc_4 = cls.md5_ff(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 11], 22, -1990404162)
- _loc_3 = cls.md5_ff(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 12], 7, 1804603682)
- _loc_6 = cls.md5_ff(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 13], 12, -40341101)
- _loc_5 = cls.md5_ff(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 14], 17, -1502002290)
- _loc_4 = cls.md5_ff(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 15], 22, 1236535329)
- _loc_3 = cls.md5_gg(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 1], 5, -165796510)
- _loc_6 = cls.md5_gg(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 6], 9, -1069501632)
- _loc_5 = cls.md5_gg(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 11], 14, 643717713)
- _loc_4 = cls.md5_gg(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 0], 20, -373897302)
- _loc_3 = cls.md5_gg(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 5], 5, -701558691)
- _loc_6 = cls.md5_gg(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 10], 9, 38016083)
- _loc_5 = cls.md5_gg(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 15], 14, -660478335)
- _loc_4 = cls.md5_gg(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 4], 20, -405537848)
- _loc_3 = cls.md5_gg(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 9], 5, 568446438)
- _loc_6 = cls.md5_gg(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 14], 9, -1019803690)
- _loc_5 = cls.md5_gg(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 3], 14, -187363961)
- _loc_4 = cls.md5_gg(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 8], 20, 1163531501)
- _loc_3 = cls.md5_gg(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 13], 5, -1444681467)
- _loc_6 = cls.md5_gg(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 2], 9, -51403784)
- _loc_5 = cls.md5_gg(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 7], 14, 1735328473)
- _loc_4 = cls.md5_gg(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 12], 20, -1926607734)
- _loc_3 = cls.md5_hh(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 5], 4, -378558)
- _loc_6 = cls.md5_hh(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 8], 11, -2022574463)
- _loc_5 = cls.md5_hh(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 11], 16, 1839030562)
- _loc_4 = cls.md5_hh(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 14], 23, -35309556)
- _loc_3 = cls.md5_hh(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 1], 4, -1530992060)
- _loc_6 = cls.md5_hh(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 4], 11, 1272893353)
- _loc_5 = cls.md5_hh(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 7], 16, -155497632)
- _loc_4 = cls.md5_hh(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 10], 23, -1094730640)
- _loc_3 = cls.md5_hh(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 13], 4, 681279174)
- _loc_6 = cls.md5_hh(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 0], 11, -358537222)
- _loc_5 = cls.md5_hh(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 3], 16, -722521979)
- _loc_4 = cls.md5_hh(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 6], 23, 76029189)
- _loc_3 = cls.md5_hh(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 9], 4, -640364487)
- _loc_6 = cls.md5_hh(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 12], 11, -421815835)
- _loc_5 = cls.md5_hh(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 15], 16, 530742520)
- _loc_4 = cls.md5_hh(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 2], 23, -995338651)
- _loc_3 = cls.md5_ii(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 0], 6, -198630844)
- _loc_6 = cls.md5_ii(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 7], 10, 1126891415)
- _loc_5 = cls.md5_ii(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 14], 15, -1416354905)
- _loc_4 = cls.md5_ii(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 5], 21, -57434055)
- _loc_3 = cls.md5_ii(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 12], 6, 1700485571)
- _loc_6 = cls.md5_ii(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 3], 10, -1894986606)
- _loc_5 = cls.md5_ii(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 10], 15, -1051523)
- _loc_4 = cls.md5_ii(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 1], 21, -2054922799)
- _loc_3 = cls.md5_ii(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 8], 6, 1873313359)
- _loc_6 = cls.md5_ii(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 15], 10, -30611744)
- _loc_5 = cls.md5_ii(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 6], 15, -1560198380)
- _loc_4 = cls.md5_ii(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 13], 21, 1309151649)
- _loc_3 = cls.md5_ii(_loc_3, _loc_4, _loc_5, _loc_6, param1[_loc_7 + 4], 6, -145523070)
- _loc_6 = cls.md5_ii(_loc_6, _loc_3, _loc_4, _loc_5, param1[_loc_7 + 11], 10, -1120210379)
- _loc_5 = cls.md5_ii(_loc_5, _loc_6, _loc_3, _loc_4, param1[_loc_7 + 2], 15, 718787259)
- _loc_4 = cls.md5_ii(_loc_4, _loc_5, _loc_6, _loc_3, param1[_loc_7 + 9], 21, -343485551)
- _loc_3 = cls.safe_add(_loc_3, _loc_8)
- _loc_4 = cls.safe_add(_loc_4, _loc_9)
- _loc_5 = cls.safe_add(_loc_5, _loc_10)
- _loc_6 = cls.safe_add(_loc_6, _loc_11)
- return [_loc_3, _loc_4, _loc_5, _loc_6]
-
- @classmethod
- def md5_cmn(cls, param1, param2, param3, param4, param5, param6):
- return cls.safe_add(
- cls.bit_rol(cls.safe_add(cls.safe_add(param2, param1), cls.safe_add(param4, param6)), param5), param3)
-
- @classmethod
- def md5_ff(cls, param1, param2, param3, param4, param5, param6, param7):
- return cls.md5_cmn(param2 & param3 | ~param2 & param4, param1, param2, param5, param6, param7)
-
- @classmethod
- def md5_gg(cls, param1, param2, param3, param4, param5, param6, param7):
- return cls.md5_cmn(param2 & param4 | param3 & ~param4, param1, param2, param5, param6, param7)
-
- @classmethod
- def md5_hh(cls, param1, param2, param3, param4, param5, param6, param7):
- return cls.md5_cmn(param2 ^ param3 ^ param4, param1, param2, param5, param6, param7)
-
- @classmethod
- def md5_ii(cls, param1, param2, param3, param4, param5, param6, param7):
- return cls.md5_cmn(param3 ^ (param2 | ~param4), param1, param2, param5, param6, param7)
-
- @classmethod
- def safe_add(cls, param1, param2):
- _loc_3 = (param1 & 65535) + (param2 & 65535)
- _loc_4 = (param1 >> 16) + (param2 >> 16) + (_loc_3 >> 16)
- return cls.lshift(_loc_4, 16) | _loc_3 & 65535
-
- @classmethod
- def bit_rol(cls, param1, param2):
- return cls.lshift(param1, param2) | (param1 & 0xFFFFFFFF) >> (32 - param2)
-
- @staticmethod
- def lshift(value, count):
- r = (0xFFFFFFFF & value) << count
- return -(~(r - 1) & 0xFFFFFFFF) if r > 0x7FFFFFFF else r