diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..55b7616 --- /dev/null +++ b/.gitignore @@ -0,0 +1,46 @@ +HELP.md +target/ +!.mvn/wrapper/maven-wrapper.jar +!**/src/main/** +!**/src/test/** +.vuepress +### node js ### +node_modules + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +build/ + +### VS Code ### +.vscode/ + +### python ## + +#Mac +.DS_Store + +.svn + +*.zip + +/adata.egg-info +/venv \ No newline at end of file diff --git a/HISTORY.md b/HISTORY.md new file mode 100644 index 0000000..bb445ac --- /dev/null +++ b/HISTORY.md @@ -0,0 +1,13 @@ +Release History +=============== + +**A Data** + +master +------ +开放、纯净、持续 + +0.0.1b0 (2023-04-05) +------------------ +清明时节雨纷纷 +第一个测试预览版本 \ No newline at end of file diff --git a/MANIFEST.in b/MANIFEST.in new file mode 100644 index 0000000..2292ffb --- /dev/null +++ b/MANIFEST.in @@ -0,0 +1 @@ +recursive-include adata/common/js *.js \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..fe5b819 --- /dev/null +++ b/README.md @@ -0,0 +1,214 @@ +# A Data + +[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/adata?color=d)](https://pypi.org/project/adata/)[![Licence](https://img.shields.io/hexpm/l/apa?color=d)](https://gitee.com/inchaos/adata/blob/master/LICENSE) + + +## 0、介绍 +免费开源A股数据库; + +专注A股,专注量化,向阳而生; + +开放、纯净、持续、为Ai(爱)发电。 + +## 一、快速开始 + +### (1)安装sdk + +#### 1. 简单安装 + +~~~python +# 首次安装 +pip install adata + +# 升级版本 +pip install -U adata +~~~ + +#### 2. 指定镜像源安装 + +~~~ +# 首次安装 +pip install adata -i http://mirrors.aliyun.com/pypi/simple/ + +# 升级版本 +pip install -U adata -i http://mirrors.aliyun.com/pypi/simple/ +~~~ + +**注:国内镜像可能存在同步延迟,可使用官方镜像源** + +#### 3.推荐镜像源列表 + +国内镜像源 + +阿里云【推荐】:http://mirrors.aliyun.com/pypi/simple/ + +清华大学:https://pypi.tuna.tsinghua.edu.cn/simple + +官方镜像源 + +官方:https://pypi.org/simple + +### (2)使用示例 + +#### 1. 获取股票代码信息 + +所有股票代码 + +~~~python +import adata + +res_df = adata.stock.info.all_code() +print(res_df) +~~~ + +示例结果: + +~~~python + stock_code short_name exchange +0 001324 N长青科 SZ +1 301361 众智科技 SZ +2 300514 友讯达 SZ +3 300880 迦南智能 SZ +4 301368 丰立智能 SZ +... ... ... ... +5488 300325 德威退 SZ +5489 300362 天翔退 SZ +5490 300367 网力退 SZ +5491 300372 欣泰退 SZ +5492 300431 暴风退 SZ + +[5493 rows x 3 columns] +~~~ + + + +#### 2. 获取股票的行情 + +获取到股票代码,传入对应的stock_code,查询对应的股票行情 + +```python +import adata + +# k_type: k线类型:1.日;2.周;3.月 默认:1 日k +res_df = adata.stock.market.get_market(stock_code='000001', k_type=1, start_date='2021-01-01') +print(res_df) +``` + +示例结果: + +~~~ + trade_time open close ... pre_close stock_code trade_date +0 2021-01-04 00:00:00 18.69 18.19 ... 18.93 000001 2021-01-04 +1 2021-01-05 00:00:00 17.99 17.76 ... 18.19 000001 2021-01-05 +2 2021-01-06 00:00:00 17.67 19.15 ... 17.76 000001 2021-01-06 +3 2021-01-07 00:00:00 19.11 19.49 ... 19.15 000001 2021-01-07 +4 2021-01-08 00:00:00 19.49 19.44 ... 19.49 000001 2021-01-08 +.. ... ... ... ... ... ... ... +571 2023-05-16 00:00:00 12.80 12.62 ... 12.83 000001 2023-05-16 +572 2023-05-17 00:00:00 12.58 12.49 ... 12.62 000001 2023-05-17 +573 2023-05-18 00:00:00 12.57 12.49 ... 12.49 000001 2023-05-18 +574 2023-05-19 00:00:00 12.43 12.34 ... 12.49 000001 2023-05-19 +575 2023-05-22 00:00:00 12.31 12.38 ... 12.34 000001 2023-05-22 + +[576 rows :x 13 columns] +~~~ + + + +#### 3. 其它数据使用 + +请参考下面数据列表和相关字典文档,找到对应的函数并查看对应的函数注释,进行正确使用。 + +- [字典DIC](./docs/DIC.md) + +## 二、数据列表 + +整理了最新版本的数据列表和相关使用Api,详细内容和相关使用参数,请参考数据字典文档。 + +### (1)股票-Stock + +#### 1. 基本信息 + +| 数据 | API | 说明 | 备注 | +| ------------ | ------------------------------------ | ----------------------------- | ------------------------------------------------- | +| A股代码 | stock.info.all_code() | 所有A股代码信息 | | +| 概念代码 | stock.info.all_concept_code_ths() | 所有A股概念代码信息(同花顺) | 来源:同花顺公开数据 | +| 概念成分列表 | stock.info.concept_constituent_ths() | 获取同花顺概念指数的成分股 | 注意:返回结果只有股票代码和股票简称,可根据概念名称查询 | +| 股票交易日历 | stock.info.trade_calendar() | 获取股票交易日信息 | 来源:深交所 | + +#### 2. 行情信息 + +| 数据 | API | 说明 | 备注 | +| -------- | ------------------------------------------- | ------------------------------------- | ------------------------------------------------------------ | +| 分红信息 | stock.market.get_dividend() | 获取单只股票的分红信息 | | +| 股票行情 | stock.market.get_market() | 获取单只股票的行情信息-日、周、月 k线 | | +| | stock.market.get_market_min() | 获取单个股票的今日分时行情 | 只能获取当天 | +| | stock.market.list_market_current() | 获取多个股票最新行情信息 | 实时行情 | +| 概念行情 | stock.market.get_market_concept_ths() | 获取单个概念的行情信息-日、周、月 k线 | 只有同花顺相关概念行情,
获取概念行情时,
请注意传入参数是指数代码还是概念代码,
指数代码8开头 | +| | stock.market.get_market_concept_min_ths() | 获取同花顺概念行情当日分时 | 只能获取当天 | +| | stock.market.get_market_concept_today_ths() | 获取同花顺当前的概念行情 | 实时行情 | + +### (2)基金-ETF + +| 项目 | 进度 | 说明 | +| ------------------- | ------------ | ------------------------------ | +| 主要指场内可交易ETF | 排期中...... | 若您有相关资源可以一起参与贡献 | + +### (3)债券-Bond + +| 项目 | 进度 | 说明 | +| -------------------- | ------------ | ------------------------------ | +| 主要指场内可转换债券 | 排期中...... | 若您有相关资源可以一起参与贡献 | + +### (4)舆情 + +| 项目 | 进度 | 说明 | +| ------------------------ | ------------ | ------------------------------ | +| 主要指相关新闻和政策消息 | 排期中...... | 若您有相关资源可以一起参与贡献 | + +## 三、数据源 + +感谢各位大厂提供的数据 + +| 数据源 | 板块 | 描述 | +| ---------- | ------------------------------------------------------------ | ---------------- | +| 同花顺 | [数据中心](http://data.10jqka.com.cn/),[行情中心](http://q.10jqka.com.cn/),[问财](http://www.iwencai.com/unifiedwap/home/index) | 让投资变的更简单 | +| 百度股市通 | [股市通](https://gushitong.baidu.com/) | 科技让投资更简单 | +| 东方财富 | [数据中心](https://data.eastmoney.com/center/),[行情中心](http://quote.eastmoney.com/center/) | 财经门户 | + + + +## 四、 其它参考 + +主要记录查阅过的项目和相关平台,并对此项目产生了深远印象,特此鸣谢。 + +| [akshare](https://gitee.com/mirrors/akshare) | [聚宽量化](https://www.joinquant.com/) | [baostock](http://baostock.com/baostock/index.php/Python%E5%BC%80%E5%8F%91%E8%B5%84%E6%BA%90) | [MyData](http://api.mairui.club/hsdata.html) | | +| -------------------------------------------- | -------------------------------------- | ------------------------------------------------------------ | -------------------------------------------- | ---- | + +## 五、发布计划 + +| 版本号 | 内容 | 发布日期 | 备注 | +| ------ | ---- | ------------ | ------------------------------ | +| 0.x.x | 股票 | 2023-04-05 ~ | 预览版本 | +| 1.x.x | 股票 | 2023-10-01 | 中国Ai股 | +| 2.x.x | 基金 | 排期中 | 场内可交易基金:ETF | +| 3.x.x | 债券 | 排期中 | 场内可交易债券:可转债 | +| 4.x.x | 舆情 | 排期中 | 挖掘新闻、网络文章和政策事件等 | + + + +## 参与贡献 + +1. Fork 本仓库 +2. 新建 Feat_xxx 分支 +3. 提交代码(注意代码风格和本项目一致即可) +4. 新建 Pull Request + + +## 特别鸣谢 + +> 对于项目有支持,包括但不仅限:内容贡献,bug提交,思想交流等等,对项目有影响的个人和机构 + +| Simon | | +| ----- | ---- | + diff --git a/__init__.py b/__init__.py new file mode 100644 index 0000000..6b09deb --- /dev/null +++ b/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/4/4 +@log: change log +""" diff --git a/adata/__init__.py b/adata/__init__.py new file mode 100644 index 0000000..f276a37 --- /dev/null +++ b/adata/__init__.py @@ -0,0 +1,27 @@ +# -*- coding: utf-8 -*- +""" +@desc: adata +@author: 1nchaos +@time: 2023/4/4 +""" +# -*- coding: utf-8 -*- + +import logging + +from .__version__ import __version__ +from .stock import stock + +# set up logging +logger = logging.getLogger("adata") + + +def set_logger(): + format_string = "%(asctime)s - %(levelname)s - %(message)s" + formatter = logging.Formatter(format_string, datefmt="%Y-%m-%dT%H:%M:%S") + handler = logging.StreamHandler() + handler.setFormatter(formatter) + + logger.addHandler(handler) + + +set_logger() diff --git a/adata/__version__.py b/adata/__version__.py new file mode 100644 index 0000000..0880ef6 --- /dev/null +++ b/adata/__version__.py @@ -0,0 +1,23 @@ +# -*- coding: utf-8 -*- + +VERSION = (0, 0, 17) +# PRERELEASE = None # alpha, beta or rc +PRERELEASE = 'beta' # alpha, beta or rc +REVISION = None + + +def generate_version(version, prerelease=None, revision=None): + version_parts = [".".join(map(str, version))] + if prerelease is not None: + version_parts.append(f"-{prerelease}") + if revision is not None: + version_parts.append(f".{revision}") + return "".join(version_parts) + +__title__ = "adata" +__description__ = "A Data,A Stock,ETF,Bond,Quant" +__url__ = "https://gitee.com/inchaos/adata" +__version__ = generate_version(VERSION, prerelease=PRERELEASE, revision=REVISION) +__author__ = "1nchaos" +__author_email__ = "9527@1nchaos.com" +__license__ = "Apache License" diff --git a/adata/bond/__init__.py b/adata/bond/__init__.py new file mode 100644 index 0000000..0e9dcb4 --- /dev/null +++ b/adata/bond/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: 场内债券相关数据 +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" diff --git a/adata/bond/bond_market.py b/adata/bond/bond_market.py new file mode 100644 index 0000000..9b91051 --- /dev/null +++ b/adata/bond/bond_market.py @@ -0,0 +1,14 @@ +# -*- coding: utf-8 -*- +""" +@desc: +@author: 1nchaos +@time:2023/4/5 +@log: +""" + + +class BondMarket(object): + """bond 行情""" + + def __init__(self) -> None: + super().__init__() diff --git a/adata/common/__init__.py b/adata/common/__init__.py new file mode 100644 index 0000000..1e4454b --- /dev/null +++ b/adata/common/__init__.py @@ -0,0 +1,9 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +from .utils import * +from .headers import * diff --git a/adata/common/headers/__init__.py b/adata/common/headers/__init__.py new file mode 100644 index 0000000..57c309b --- /dev/null +++ b/adata/common/headers/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" diff --git a/adata/common/headers/baidu_headers.py b/adata/common/headers/baidu_headers.py new file mode 100644 index 0000000..cc1e89d --- /dev/null +++ b/adata/common/headers/baidu_headers.py @@ -0,0 +1,39 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" + +json_headers = { + 'Host': 'finance.pae.baidu.com', + 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/110.0', + 'Accept': 'application/vnd.finance-web.v1+json', + 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', + 'Accept-Encoding': 'gzip, deflate, br', + 'Acs-Token': '1680073602136_1680187152773_uZ76rU6tKjd6HavzqUwLS+LsRmCm+fagieEZzD622QiLe/Sfrq5cqVY6phLw7Vm/MGvLdp6eJI1R/Egp6PEB4E6agGNB91g61mfdylADtKBaq4zV4ZC/SOfrjh9TxMb6i6WwY5S1WFg/wPK2fPCoCZMkVSTJ704skNglDoLsPm+9RjCM4PJK68GKE7ZG1p13P5iAMk9ndAJ7HZ3FJAnBQCQeI82Q+fAOAtxrXtGf7eAoblBlgX7OaTJD97PIm9zy1yE37KVyfCngWZNp5VwP3OWGU6jCLeeq2vKpg2hS6TkgbUgqom57ZGSlIezfwQ7vltRiGG3cnpoPSBxrfiEXwz5iulsLGeubIzjOj1yYIBPWVYNBhSn7aM0P/dBq0Ug4cf3xmTvUI/GVMq9PXHGqBss1Px0Yl+hiSc1+vbgz7vQ=', + 'Origin': 'https://gushitong.baidu.com', + 'Connection': 'keep-alive', + 'Referer': 'https://gushitong.baidu.com/', + 'Cookie': 'BAIDUID=054924A85233268C182D09EC253E676F:SL=0:NR=10:FG=1; BIDUPSID=19DB8A6DEBD5A452CE6A10E90276DE7C; PSTM=1572438578; MCITY=-75%3A; BDUSS=V-UmF5S1pXNVd1Um15S0Y1MXc0S20wZ3FGYzhIVjlUZUFoczVvRlVjUTB1dTVnRVFBQUFBJCQAAAAAAAAAAAEAAADIruQqaV~EwdPjAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADQtx2A0LcdgS3; __yjs_duid=1_0e624b9d24290650971c8590bcfe96361619270097027; ZFY=KxKVSFoJLIz0l23rNHW:AV1udt6Ern2XM0p4sN7:AJdw8:C; H_PS_PSSID=38185_36546_38409_38470_38439_38468_38289_38380_37931_38382_26350_22157_38282_37881; BDRCVFR[feWj1Vr5u3D]=I67x6TjHwwYf0; delPer=0; PSINO=6; BDORZ=B490B5EBF6F3CD402E515D22BCDA1598; ZD_ENTRY=baidu; __bid_n=184332335315a549634207; FPTOKEN=0G8DZh7ruaz1dUnw7eFAGwkkafhUBvTOkCNkScDsJi6ucyCKBDttk2Tv233PFjFcYDQH/nqo0eEZY9g0psSI5FwqsV/lPlXLoPcGR6EQ3I9iV5fhRVGwx/xKTmJ1O7b09GcBwac2qYSO1tDSfR20KFkYKdZihCdiCAHUPhhniaMVTFa/d2JywSFgXh5ksnMGNkQXY0fS8bKzsP/UTJdtSvg8J8WuYoh7g6EDHeXRVlt5t13dTO8A6DMCNOYlxzGLSDomP/3UOsH+T/4iGsNubZL+y3016UY0ehJa8meg2mAq+wS0DdmsJxYao0qTDaAT/5LfNM4j3LoVRAMUYtOzM/9V4ajJfK7atGKQXFSn+VnANgwuvUvfZGCOdF8oMn4N7Jv6jvQ5XocYTAOb7MZJgOocxgPsL5zDGIcXYmUPAxoPn2/9SsgFLR4mxU+D++F9|c5qXUXOqFRs5f/aOsOlP9AY4If8rgdZFdcLJjdaX0Is=|10|3c9b5f41e931d2d8783fbcce14863165; BAIDU_WISE_UID=wapp_1680175629815_954; arialoadData=false; BCLID=8799370053103418941; BCLID_BFESS=8799370053103418941; BDSFRCVID=A1tOJeC62wVF227f5qXouQCuMHnCdsrTH6aoWSjyl4QjjjGKIQ2REG0Pnf8g0KuMn6bMogKKXgOTHw0F_2uxOjjg8UtVJeC6EG0Ptf8g0f5; BDSFRCVID_BFESS=A1tOJeC62wVF227f5qXouQCuMHnCdsrTH6aoWSjyl4QjjjGKIQ2REG0Pnf8g0KuMn6bMogKKXgOTHw0F_2uxOjjg8UtVJeC6EG0Ptf8g0f5; H_BDCLCKID_SF=JnIOoCIMtID3qnFkKJL_-P4DePLD-URZ5mAqot3C3D_KMnLGKq7o5q_d5tc72fJb-5rnaIQqaM36j4T1jhQ8M4I1yPrIJqj43bRTWJLy5KJvfq6kj45YhP-Uyn7MWh37bbRlMKoaMp78jR093JO4y4Ldj4oxJpOJ5JbMonLafJOKHICweMK; H_BDCLCKID_SF_BFESS=JnIOoCIMtID3qnFkKJL_-P4DePLD-URZ5mAqot3C3D_KMnLGKq7o5q_d5tc72fJb-5rnaIQqaM36j4T1jhQ8M4I1yPrIJqj43bRTWJLy5KJvfq6kj45YhP-Uyn7MWh37bbRlMKoaMp78jR093JO4y4Ldj4oxJpOJ5JbMonLafJOKHICweMK', + 'Sec-Fetch-Dest': 'empty', + 'Sec-Fetch-Mode': 'cors', + 'Sec-Fetch-Site': 'same-site', + 'TE': 'trailers', +} + +text_headers = { + 'Host': 'gushitong.baidu.com', + 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/110.0', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8', + 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', + 'Accept-Encoding': 'gzip, deflate, br', + 'Connection': 'keep-alive', + 'Cookie': 'BAIDUID=DC08E09E609EB9778F0574D4518A5507:SL=0:NR=10:FG=1; BIDUPSID=72A958B07427F9F9CB3F63FD8B6C6565; PSTM=1677461180; MCITY=-%3A; BDUSS=toZjl2NTY0NFNwQWVyaUpFREJlSS1NWmVranN5YzdMSXpEcTZkNTRaTjA4amhrSVFBQUFBJCQAAAAAAAAAAAEAAADIruQqaV~EwdPjAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHRlEWR0ZRFkN0; H_PS_PSSID=38185_36554_38470_38353_38359_38396_38468_38289_36807_38263_37929_38382_26350_38421_38283_37881; BDSFRCVID=5OPOJexroG07v97fK16bU1LKNeKK0PQTDYrEeU9ooveGPK0Vc8uvEG0PtDQMefIb1DMtogKKXgOTHw0F_2uxOjjg8UtVJeC6EG0Ptf8g0M5; H_BDCLCKID_SF=tJPf_CK5JIL3H48k-4QEbbQH-UnLq-jyBgOZ04n-ah02MI5Y04jBynDv3HQrBM69agQN_hcm3UTdsq76Wh35K5tTQP6rLtJHHG74KKJxbn7EKDjHLP5DDbLehUJiBhvMBan7LKJIXKohJh7FM4tW3J0ZyxomtfQxtNRJ0DnjtpChbC_mjT_hjT3BeU5eetjK2CntsJOOaCv-ht5Oy4oWK441DattaljhMm3P5fKhBpvF8nR_06Jk3M04X-o9-hvT-54e2p3FBUQjq66bQft20b0eMeFD0xJaKJRtWb7jWhviep72ybt2QlRX5q79atTMfNTJ-qcH0KQpsIJM5-DWbT8IjHCHtT-tJRkJ_Dvt-5rDHJTg5DTjhPrMyxCjWMT-MTryKKt5JRTCe4To3JblDfAUX4nQBqDfWHnRhlRNB-3iV-OxDUvnyxAZ-pKLQMQxtNRJWbIEtl5THR_x5tnobUPUWMJ9LUvftgcdot5yBbc8eIna5hjkbfJBQttjQn3hfIkj2CKLtK-WbK_wj6t3-t0_qx5Ka43tHD7yWCvdMU7cOR5Jj65ED5-sbx5hBM3kKaID2pvkbUnDSbIC3MA--t4YKGJeQUJ82TAHhDoD5qcHsq0x0h3We-bQypouQb_H0COMahv95h7xO-0xQlPK5JkgMx6MqpQJQeQ-5KQN3KJmfbL9bT3tjjTXjH8JJ60ttR3MB4bH56rjDnCrjfnmXUI82h5y058fbJKf0qkhJJolhqRoX4ovyT8r0JORXRj45GI8Wb7K5l3mOIJK-T7h5xL1Db3J0pou5CcA3DjgB4boepvoW-Jc3MkWD-jdJJQOBKQB0KnGbUQkeq8CQft20b0EeMtjW6LEK5r2SC_XtKDh3j; Hm_lvt_c8bd3584daa59ca83c2ec1247d343576=1679365029; Hm_lpvt_c8bd3584daa59ca83c2ec1247d343576=1680096200; BDORZ=FFFB88E999055A3F8A630C64834BD6D0; ab_sr=1.0.1_OTVlZTQ5MzFhYTMyY2FjZTY5M2NiYTJjMzUwMTVkNTE0OGM1MzUwMWQzZjk4NTNjMmE5NjJiODM3OGI2MzFlNWFlMDZjOTYzNWIxOTE0MmY2MzI4YjM0OGMwNGFmN2NmNzg1MjA1M2E2ODUwYzFlNmI4NThiZmRlNWJiMmU0NDMwOGI0MDY1ZGRiODNjZWM3ZjY0ZDhlM2VmNjIzYTdlOQ==; BA_HECTOR=24akak252l042g848500208u1i28dic1n; delPer=0; PSINO=7; ZFY=a4MO01qoxt3fSy8GE2fVF3isnJZvFcG4BOxTOLYMkmo:C; BDRCVFR[gltLrB7qNCt]=mk3SLVN4HKm', + 'Upgrade-Insecure-Requests': '1', + 'Sec-Fetch-Dest': 'document', + 'Sec-Fetch-Mode': 'navigate', + 'Sec-Fetch-Site': 'none', + 'Sec-Fetch-User': '?1', +} diff --git a/adata/common/headers/sina_headers.py b/adata/common/headers/sina_headers.py new file mode 100644 index 0000000..a4658ae --- /dev/null +++ b/adata/common/headers/sina_headers.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +c_headers = { + 'Host': 'hq.sinajs.cn', + 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/110.0', + 'Accept': '*/*', + 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', + 'Accept-Encoding': 'gzip, deflate, br', + 'Referer': 'http://vip.stock.finance.sina.com.cn/', + 'Connection': 'keep-alive', + 'Sec-Fetch-Dest': 'script', + 'Sec-Fetch-Mode': 'no-cors', + 'Sec-Fetch-Site': 'cross-site', +} diff --git a/adata/common/headers/ths_headers.py b/adata/common/headers/ths_headers.py new file mode 100644 index 0000000..6c38f30 --- /dev/null +++ b/adata/common/headers/ths_headers.py @@ -0,0 +1,40 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +c_headers = { + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9', + 'Cache-Control': 'max-age=0', + 'Connection': 'keep-alive', + 'Cookie': 'SL_G_WPT_TO=eo; SL_GWPT_Show_Hide_tmp=1; SL_wptGlobTipTmp=1', + 'Host': 'search.10jqka.com.cn', + 'Upgrade-Insecure-Requests': '1', + 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/109.0.0.0 Safari/537.36', +} + +json_headers = { + 'Host': 'q.10jqka.com.cn', + 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:105.0) Gecko/20100101 Firefox/105.0', + 'Accept': '*/*', + 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', + 'Accept-Encoding': 'gzip, deflate', + 'Connection': 'keep-alive', + 'Cookie': 'v=AzCSZkisIBam9fwSniGPJndtB_-HeRW6Nl9qaSqB_nJczN4r0onkU4ZtOEN5; __bid_n=18484da3254140db6d4207; Hm_lvt_78c58f01938e4d85eaf619eae71b4ed1=1680163246; FPTOKEN=E5SR2waOvFusCzMCQVA/i0npfLNEl6RajFMppa8aoQmLTnIl68wGldxUBmPM57Q9yOCUCB1aiKbuSjFdBzV5SnHNhe0uSYQIfJ9t5YdBrYTHtRO06p0Kjf3ck0dxo587GXZ/Lln6kY2EoiWCZBlXHLfwWq6d/uLzQfq+BnkeN8y5zWt6kJAzY84fZaTCNQPf4Vae5qHOYpskzus+szaS5Qm2VNc/Q/t/0U7QQADRzNRLfYf6A/407ZMdD6+1sGvCQhh959iGl+DRavRasWH2ISY3G/osl/olB61tXSIxNI+IL+rAu7u5TvknHHwVtcigMY4jsgE8qBkN2HU4wDvH5QMv+0E89L5jACYIF+BoMaBNN6VkPt9Pksg8+K6O4K9rwElcjiWRuyzNy25YO13lYQ==|sPeLn4kqSDrmYnpF7Wn94V4caIa/qNc5YWTtvQFK+ac=|10|2bc6aba78093d71b50d1b70dd20ef09d; Hm_lpvt_78c58f01938e4d85eaf619eae71b4ed1=1680163469', + 'Upgrade-Insecure-Requests': '1', +} + +text_headers = { + 'Host': 'q.10jqka.com.cn', + 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:105.0) Gecko/20100101 Firefox/105.0', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8', + 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', + 'Accept-Encoding': 'gzip, deflate', + 'Connection': 'keep-alive', + 'Cookie': 'v=AzCSZkisIBam9fwSniGPJndtB_-HeRW6Nl9qaSqB_nJczN4r0onkU4ZtOEN5; __bid_n=18484da3254140db6d4207; Hm_lvt_78c58f01938e4d85eaf619eae71b4ed1=1680163246; FPTOKEN=E5SR2waOvFusCzMCQVA/i0npfLNEl6RajFMppa8aoQmLTnIl68wGldxUBmPM57Q9yOCUCB1aiKbuSjFdBzV5SnHNhe0uSYQIfJ9t5YdBrYTHtRO06p0Kjf3ck0dxo587GXZ/Lln6kY2EoiWCZBlXHLfwWq6d/uLzQfq+BnkeN8y5zWt6kJAzY84fZaTCNQPf4Vae5qHOYpskzus+szaS5Qm2VNc/Q/t/0U7QQADRzNRLfYf6A/407ZMdD6+1sGvCQhh959iGl+DRavRasWH2ISY3G/osl/olB61tXSIxNI+IL+rAu7u5TvknHHwVtcigMY4jsgE8qBkN2HU4wDvH5QMv+0E89L5jACYIF+BoMaBNN6VkPt9Pksg8+K6O4K9rwElcjiWRuyzNy25YO13lYQ==|sPeLn4kqSDrmYnpF7Wn94V4caIa/qNc5YWTtvQFK+ac=|10|2bc6aba78093d71b50d1b70dd20ef09d; Hm_lpvt_78c58f01938e4d85eaf619eae71b4ed1=1680163469', + 'Upgrade-Insecure-Requests': '1', +} diff --git a/adata/common/js/__init__.py b/adata/common/js/__init__.py new file mode 100644 index 0000000..86f9ff9 --- /dev/null +++ b/adata/common/js/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: js +@author: 1nchaos +@time: 2023/5/5 +@log: change log +""" diff --git a/adata/common/js/covid.js b/adata/common/js/covid.js new file mode 100644 index 0000000..ae22a23 --- /dev/null +++ b/adata/common/js/covid.js @@ -0,0 +1,6031 @@ +;(function (root, factory) { + if (typeof exports === "object") { + // CommonJS + module.exports = exports = factory(); + } + else if (typeof define === "function" && define.amd) { + // AMD + define([], factory); + } + else { + // Global (browser) + root.CryptoJS = factory(); + } +}(this, function () { + + /** + * CryptoJS core components. + */ + var CryptoJS = CryptoJS || (function (Math, undefined) { + /* + * Local polyfil of Object.create + */ + var create = Object.create || (function () { + function F() {}; + + return function (obj) { + var subtype; + + F.prototype = obj; + + subtype = new F(); + + F.prototype = null; + + return subtype; + }; + }()) + + /** + * CryptoJS namespace. + */ + var C = {}; + + /** + * Library namespace. + */ + var C_lib = C.lib = {}; + + /** + * Base object for prototypal inheritance. + */ + var Base = C_lib.Base = (function () { + + + return { + /** + * Creates a new object that inherits from this object. + * + * @param {Object} overrides Properties to copy into the new object. + * + * @return {Object} The new object. + * + * @static + * + * @example + * + * var MyType = CryptoJS.lib.Base.extend({ + * field: 'value', + * + * method: function () { + * } + * }); + */ + extend: function (overrides) { + // Spawn + var subtype = create(this); + + // Augment + if (overrides) { + subtype.mixIn(overrides); + } + + // Create default initializer + if (!subtype.hasOwnProperty('init') || this.init === subtype.init) { + subtype.init = function () { + subtype.$super.init.apply(this, arguments); + }; + } + + // Initializer's prototype is the subtype object + subtype.init.prototype = subtype; + + // Reference supertype + subtype.$super = this; + + return subtype; + }, + + /** + * Extends this object and runs the init method. + * Arguments to create() will be passed to init(). + * + * @return {Object} The new object. + * + * @static + * + * @example + * + * var instance = MyType.create(); + */ + create: function () { + var instance = this.extend(); + instance.init.apply(instance, arguments); + + return instance; + }, + + /** + * Initializes a newly created object. + * Override this method to add some logic when your objects are created. + * + * @example + * + * var MyType = CryptoJS.lib.Base.extend({ + * init: function () { + * // ... + * } + * }); + */ + init: function () { + }, + + /** + * Copies properties into this object. + * + * @param {Object} properties The properties to mix in. + * + * @example + * + * MyType.mixIn({ + * field: 'value' + * }); + */ + mixIn: function (properties) { + for (var propertyName in properties) { + if (properties.hasOwnProperty(propertyName)) { + this[propertyName] = properties[propertyName]; + } + } + + // IE won't copy toString using the loop above + if (properties.hasOwnProperty('toString')) { + this.toString = properties.toString; + } + }, + + /** + * Creates a copy of this object. + * + * @return {Object} The clone. + * + * @example + * + * var clone = instance.clone(); + */ + clone: function () { + return this.init.prototype.extend(this); + } + }; + }()); + + /** + * An array of 32-bit words. + * + * @property {Array} words The array of 32-bit words. + * @property {number} sigBytes The number of significant bytes in this word array. + */ + var WordArray = C_lib.WordArray = Base.extend({ + /** + * Initializes a newly created word array. + * + * @param {Array} words (Optional) An array of 32-bit words. + * @param {number} sigBytes (Optional) The number of significant bytes in the words. + * + * @example + * + * var wordArray = CryptoJS.lib.WordArray.create(); + * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]); + * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6); + */ + init: function (words, sigBytes) { + words = this.words = words || []; + + if (sigBytes != undefined) { + this.sigBytes = sigBytes; + } else { + this.sigBytes = words.length * 4; + } + }, + + /** + * Converts this word array to a string. + * + * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex + * + * @return {string} The stringified word array. + * + * @example + * + * var string = wordArray + ''; + * var string = wordArray.toString(); + * var string = wordArray.toString(CryptoJS.enc.Utf8); + */ + toString: function (encoder) { + return (encoder || Hex).stringify(this); + }, + + /** + * Concatenates a word array to this word array. + * + * @param {WordArray} wordArray The word array to append. + * + * @return {WordArray} This word array. + * + * @example + * + * wordArray1.concat(wordArray2); + */ + concat: function (wordArray) { + // Shortcuts + var thisWords = this.words; + var thatWords = wordArray.words; + var thisSigBytes = this.sigBytes; + var thatSigBytes = wordArray.sigBytes; + + // Clamp excess bits + this.clamp(); + + // Concat + if (thisSigBytes % 4) { + // Copy one byte at a time + for (var i = 0; i < thatSigBytes; i++) { + var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; + thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8); + } + } else { + // Copy one word at a time + for (var i = 0; i < thatSigBytes; i += 4) { + thisWords[(thisSigBytes + i) >>> 2] = thatWords[i >>> 2]; + } + } + this.sigBytes += thatSigBytes; + + // Chainable + return this; + }, + + /** + * Removes insignificant bits. + * + * @example + * + * wordArray.clamp(); + */ + clamp: function () { + // Shortcuts + var words = this.words; + var sigBytes = this.sigBytes; + + // Clamp + words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8); + words.length = Math.ceil(sigBytes / 4); + }, + + /** + * Creates a copy of this word array. + * + * @return {WordArray} The clone. + * + * @example + * + * var clone = wordArray.clone(); + */ + clone: function () { + var clone = Base.clone.call(this); + clone.words = this.words.slice(0); + + return clone; + }, + + /** + * Creates a word array filled with random bytes. + * + * @param {number} nBytes The number of random bytes to generate. + * + * @return {WordArray} The random word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.lib.WordArray.random(16); + */ + random: function (nBytes) { + var words = []; + + var r = (function (m_w) { + var m_w = m_w; + var m_z = 0x3ade68b1; + var mask = 0xffffffff; + + return function () { + m_z = (0x9069 * (m_z & 0xFFFF) + (m_z >> 0x10)) & mask; + m_w = (0x4650 * (m_w & 0xFFFF) + (m_w >> 0x10)) & mask; + var result = ((m_z << 0x10) + m_w) & mask; + result /= 0x100000000; + result += 0.5; + return result * (Math.random() > .5 ? 1 : -1); + } + }); + + for (var i = 0, rcache; i < nBytes; i += 4) { + var _r = r((rcache || Math.random()) * 0x100000000); + + rcache = _r() * 0x3ade67b7; + words.push((_r() * 0x100000000) | 0); + } + + return new WordArray.init(words, nBytes); + } + }); + + /** + * Encoder namespace. + */ + var C_enc = C.enc = {}; + + /** + * Hex encoding strategy. + */ + var Hex = C_enc.Hex = { + /** + * Converts a word array to a hex string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The hex string. + * + * @static + * + * @example + * + * var hexString = CryptoJS.enc.Hex.stringify(wordArray); + */ + stringify: function (wordArray) { + // Shortcuts + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + + // Convert + var hexChars = []; + for (var i = 0; i < sigBytes; i++) { + var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; + hexChars.push((bite >>> 4).toString(16)); + hexChars.push((bite & 0x0f).toString(16)); + } + + return hexChars.join(''); + }, + + /** + * Converts a hex string to a word array. + * + * @param {string} hexStr The hex string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Hex.parse(hexString); + */ + parse: function (hexStr) { + // Shortcut + var hexStrLength = hexStr.length; + + // Convert + var words = []; + for (var i = 0; i < hexStrLength; i += 2) { + words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4); + } + + return new WordArray.init(words, hexStrLength / 2); + } + }; + + /** + * Latin1 encoding strategy. + */ + var Latin1 = C_enc.Latin1 = { + /** + * Converts a word array to a Latin1 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The Latin1 string. + * + * @static + * + * @example + * + * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray); + */ + stringify: function (wordArray) { + // Shortcuts + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + + // Convert + var latin1Chars = []; + for (var i = 0; i < sigBytes; i++) { + var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; + latin1Chars.push(String.fromCharCode(bite)); + } + + return latin1Chars.join(''); + }, + + /** + * Converts a Latin1 string to a word array. + * + * @param {string} latin1Str The Latin1 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Latin1.parse(latin1String); + */ + parse: function (latin1Str) { + // Shortcut + var latin1StrLength = latin1Str.length; + + // Convert + var words = []; + for (var i = 0; i < latin1StrLength; i++) { + words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8); + } + + return new WordArray.init(words, latin1StrLength); + } + }; + + /** + * UTF-8 encoding strategy. + */ + var Utf8 = C_enc.Utf8 = { + /** + * Converts a word array to a UTF-8 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-8 string. + * + * @static + * + * @example + * + * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray); + */ + stringify: function (wordArray) { + try { + return decodeURIComponent(escape(Latin1.stringify(wordArray))); + } catch (e) { + throw new Error('Malformed UTF-8 data'); + } + }, + + /** + * Converts a UTF-8 string to a word array. + * + * @param {string} utf8Str The UTF-8 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf8.parse(utf8String); + */ + parse: function (utf8Str) { + return Latin1.parse(unescape(encodeURIComponent(utf8Str))); + } + }; + + /** + * Abstract buffered block algorithm template. + * + * The property blockSize must be implemented in a concrete subtype. + * + * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0 + */ + var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({ + /** + * Resets this block algorithm's data buffer to its initial state. + * + * @example + * + * bufferedBlockAlgorithm.reset(); + */ + reset: function () { + // Initial values + this._data = new WordArray.init(); + this._nDataBytes = 0; + }, + + /** + * Adds new data to this block algorithm's buffer. + * + * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8. + * + * @example + * + * bufferedBlockAlgorithm._append('data'); + * bufferedBlockAlgorithm._append(wordArray); + */ + _append: function (data) { + // Convert string to WordArray, else assume WordArray already + if (typeof data == 'string') { + data = Utf8.parse(data); + } + + // Append + this._data.concat(data); + this._nDataBytes += data.sigBytes; + }, + + /** + * Processes available data blocks. + * + * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype. + * + * @param {boolean} doFlush Whether all blocks and partial blocks should be processed. + * + * @return {WordArray} The processed data. + * + * @example + * + * var processedData = bufferedBlockAlgorithm._process(); + * var processedData = bufferedBlockAlgorithm._process(!!'flush'); + */ + _process: function (doFlush) { + // Shortcuts + var data = this._data; + var dataWords = data.words; + var dataSigBytes = data.sigBytes; + var blockSize = this.blockSize; + var blockSizeBytes = blockSize * 4; + + // Count blocks ready + var nBlocksReady = dataSigBytes / blockSizeBytes; + if (doFlush) { + // Round up to include partial blocks + nBlocksReady = Math.ceil(nBlocksReady); + } else { + // Round down to include only full blocks, + // less the number of blocks that must remain in the buffer + nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0); + } + + // Count words ready + var nWordsReady = nBlocksReady * blockSize; + + // Count bytes ready + var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes); + + // Process blocks + if (nWordsReady) { + for (var offset = 0; offset < nWordsReady; offset += blockSize) { + // Perform concrete-algorithm logic + this._doProcessBlock(dataWords, offset); + } + + // Remove processed words + var processedWords = dataWords.splice(0, nWordsReady); + data.sigBytes -= nBytesReady; + } + + // Return processed words + return new WordArray.init(processedWords, nBytesReady); + }, + + /** + * Creates a copy of this object. + * + * @return {Object} The clone. + * + * @example + * + * var clone = bufferedBlockAlgorithm.clone(); + */ + clone: function () { + var clone = Base.clone.call(this); + clone._data = this._data.clone(); + + return clone; + }, + + _minBufferSize: 0 + }); + + /** + * Abstract hasher template. + * + * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits) + */ + var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({ + /** + * Configuration options. + */ + cfg: Base.extend(), + + /** + * Initializes a newly created hasher. + * + * @param {Object} cfg (Optional) The configuration options to use for this hash computation. + * + * @example + * + * var hasher = CryptoJS.algo.SHA256.create(); + */ + init: function (cfg) { + // Apply config defaults + this.cfg = this.cfg.extend(cfg); + + // Set initial values + this.reset(); + }, + + /** + * Resets this hasher to its initial state. + * + * @example + * + * hasher.reset(); + */ + reset: function () { + // Reset data buffer + BufferedBlockAlgorithm.reset.call(this); + + // Perform concrete-hasher logic + this._doReset(); + }, + + /** + * Updates this hasher with a message. + * + * @param {WordArray|string} messageUpdate The message to append. + * + * @return {Hasher} This hasher. + * + * @example + * + * hasher.update('message'); + * hasher.update(wordArray); + */ + update: function (messageUpdate) { + // Append + this._append(messageUpdate); + + // Update the hash + this._process(); + + // Chainable + return this; + }, + + /** + * Finalizes the hash computation. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} messageUpdate (Optional) A final message update. + * + * @return {WordArray} The hash. + * + * @example + * + * var hash = hasher.finalize(); + * var hash = hasher.finalize('message'); + * var hash = hasher.finalize(wordArray); + */ + finalize: function (messageUpdate) { + // Final message update + if (messageUpdate) { + this._append(messageUpdate); + } + + // Perform concrete-hasher logic + var hash = this._doFinalize(); + + return hash; + }, + + blockSize: 512/32, + + /** + * Creates a shortcut function to a hasher's object interface. + * + * @param {Hasher} hasher The hasher to create a helper for. + * + * @return {Function} The shortcut function. + * + * @static + * + * @example + * + * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256); + */ + _createHelper: function (hasher) { + return function (message, cfg) { + return new hasher.init(cfg).finalize(message); + }; + }, + + /** + * Creates a shortcut function to the HMAC's object interface. + * + * @param {Hasher} hasher The hasher to use in this HMAC helper. + * + * @return {Function} The shortcut function. + * + * @static + * + * @example + * + * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256); + */ + _createHmacHelper: function (hasher) { + return function (message, key) { + return new C_algo.HMAC.init(hasher, key).finalize(message); + }; + } + }); + + /** + * Algorithm namespace. + */ + var C_algo = C.algo = {}; + + return C; + }(Math)); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var C_enc = C.enc; + + /** + * Base64 encoding strategy. + */ + var Base64 = C_enc.Base64 = { + /** + * Converts a word array to a Base64 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The Base64 string. + * + * @static + * + * @example + * + * var base64String = CryptoJS.enc.Base64.stringify(wordArray); + */ + stringify: function (wordArray) { + // Shortcuts + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var map = this._map; + + // Clamp excess bits + wordArray.clamp(); + + // Convert + var base64Chars = []; + for (var i = 0; i < sigBytes; i += 3) { + var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; + var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff; + var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff; + + var triplet = (byte1 << 16) | (byte2 << 8) | byte3; + + for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) { + base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f)); + } + } + + // Add padding + var paddingChar = map.charAt(64); + if (paddingChar) { + while (base64Chars.length % 4) { + base64Chars.push(paddingChar); + } + } + + return base64Chars.join(''); + }, + + /** + * Converts a Base64 string to a word array. + * + * @param {string} base64Str The Base64 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Base64.parse(base64String); + */ + parse: function (base64Str) { + // Shortcuts + var base64StrLength = base64Str.length; + var map = this._map; + var reverseMap = this._reverseMap; + + if (!reverseMap) { + reverseMap = this._reverseMap = []; + for (var j = 0; j < map.length; j++) { + reverseMap[map.charCodeAt(j)] = j; + } + } + + // Ignore padding + var paddingChar = map.charAt(64); + if (paddingChar) { + var paddingIndex = base64Str.indexOf(paddingChar); + if (paddingIndex !== -1) { + base64StrLength = paddingIndex; + } + } + + // Convert + return parseLoop(base64Str, base64StrLength, reverseMap); + + }, + + _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' + }; + + function parseLoop(base64Str, base64StrLength, reverseMap) { + var words = []; + var nBytes = 0; + for (var i = 0; i < base64StrLength; i++) { + if (i % 4) { + var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2); + var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2); + words[nBytes >>> 2] |= (bits1 | bits2) << (24 - (nBytes % 4) * 8); + nBytes++; + } + } + return WordArray.create(words, nBytes); + } + }()); + + + (function (Math) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C.algo; + + // Constants table + var T = []; + + // Compute constants + (function () { + for (var i = 0; i < 64; i++) { + T[i] = (Math.abs(Math.sin(i + 1)) * 0x100000000) | 0; + } + }()); + + /** + * MD5 hash algorithm. + */ + var MD5 = C_algo.MD5 = Hasher.extend({ + _doReset: function () { + this._hash = new WordArray.init([ + 0x67452301, 0xefcdab89, + 0x98badcfe, 0x10325476 + ]); + }, + + _doProcessBlock: function (M, offset) { + // Swap endian + for (var i = 0; i < 16; i++) { + // Shortcuts + var offset_i = offset + i; + var M_offset_i = M[offset_i]; + + M[offset_i] = ( + (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) | + (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00) + ); + } + + // Shortcuts + var H = this._hash.words; + + var M_offset_0 = M[offset + 0]; + var M_offset_1 = M[offset + 1]; + var M_offset_2 = M[offset + 2]; + var M_offset_3 = M[offset + 3]; + var M_offset_4 = M[offset + 4]; + var M_offset_5 = M[offset + 5]; + var M_offset_6 = M[offset + 6]; + var M_offset_7 = M[offset + 7]; + var M_offset_8 = M[offset + 8]; + var M_offset_9 = M[offset + 9]; + var M_offset_10 = M[offset + 10]; + var M_offset_11 = M[offset + 11]; + var M_offset_12 = M[offset + 12]; + var M_offset_13 = M[offset + 13]; + var M_offset_14 = M[offset + 14]; + var M_offset_15 = M[offset + 15]; + + // Working varialbes + var a = H[0]; + var b = H[1]; + var c = H[2]; + var d = H[3]; + + // Computation + a = FF(a, b, c, d, M_offset_0, 7, T[0]); + d = FF(d, a, b, c, M_offset_1, 12, T[1]); + c = FF(c, d, a, b, M_offset_2, 17, T[2]); + b = FF(b, c, d, a, M_offset_3, 22, T[3]); + a = FF(a, b, c, d, M_offset_4, 7, T[4]); + d = FF(d, a, b, c, M_offset_5, 12, T[5]); + c = FF(c, d, a, b, M_offset_6, 17, T[6]); + b = FF(b, c, d, a, M_offset_7, 22, T[7]); + a = FF(a, b, c, d, M_offset_8, 7, T[8]); + d = FF(d, a, b, c, M_offset_9, 12, T[9]); + c = FF(c, d, a, b, M_offset_10, 17, T[10]); + b = FF(b, c, d, a, M_offset_11, 22, T[11]); + a = FF(a, b, c, d, M_offset_12, 7, T[12]); + d = FF(d, a, b, c, M_offset_13, 12, T[13]); + c = FF(c, d, a, b, M_offset_14, 17, T[14]); + b = FF(b, c, d, a, M_offset_15, 22, T[15]); + + a = GG(a, b, c, d, M_offset_1, 5, T[16]); + d = GG(d, a, b, c, M_offset_6, 9, T[17]); + c = GG(c, d, a, b, M_offset_11, 14, T[18]); + b = GG(b, c, d, a, M_offset_0, 20, T[19]); + a = GG(a, b, c, d, M_offset_5, 5, T[20]); + d = GG(d, a, b, c, M_offset_10, 9, T[21]); + c = GG(c, d, a, b, M_offset_15, 14, T[22]); + b = GG(b, c, d, a, M_offset_4, 20, T[23]); + a = GG(a, b, c, d, M_offset_9, 5, T[24]); + d = GG(d, a, b, c, M_offset_14, 9, T[25]); + c = GG(c, d, a, b, M_offset_3, 14, T[26]); + b = GG(b, c, d, a, M_offset_8, 20, T[27]); + a = GG(a, b, c, d, M_offset_13, 5, T[28]); + d = GG(d, a, b, c, M_offset_2, 9, T[29]); + c = GG(c, d, a, b, M_offset_7, 14, T[30]); + b = GG(b, c, d, a, M_offset_12, 20, T[31]); + + a = HH(a, b, c, d, M_offset_5, 4, T[32]); + d = HH(d, a, b, c, M_offset_8, 11, T[33]); + c = HH(c, d, a, b, M_offset_11, 16, T[34]); + b = HH(b, c, d, a, M_offset_14, 23, T[35]); + a = HH(a, b, c, d, M_offset_1, 4, T[36]); + d = HH(d, a, b, c, M_offset_4, 11, T[37]); + c = HH(c, d, a, b, M_offset_7, 16, T[38]); + b = HH(b, c, d, a, M_offset_10, 23, T[39]); + a = HH(a, b, c, d, M_offset_13, 4, T[40]); + d = HH(d, a, b, c, M_offset_0, 11, T[41]); + c = HH(c, d, a, b, M_offset_3, 16, T[42]); + b = HH(b, c, d, a, M_offset_6, 23, T[43]); + a = HH(a, b, c, d, M_offset_9, 4, T[44]); + d = HH(d, a, b, c, M_offset_12, 11, T[45]); + c = HH(c, d, a, b, M_offset_15, 16, T[46]); + b = HH(b, c, d, a, M_offset_2, 23, T[47]); + + a = II(a, b, c, d, M_offset_0, 6, T[48]); + d = II(d, a, b, c, M_offset_7, 10, T[49]); + c = II(c, d, a, b, M_offset_14, 15, T[50]); + b = II(b, c, d, a, M_offset_5, 21, T[51]); + a = II(a, b, c, d, M_offset_12, 6, T[52]); + d = II(d, a, b, c, M_offset_3, 10, T[53]); + c = II(c, d, a, b, M_offset_10, 15, T[54]); + b = II(b, c, d, a, M_offset_1, 21, T[55]); + a = II(a, b, c, d, M_offset_8, 6, T[56]); + d = II(d, a, b, c, M_offset_15, 10, T[57]); + c = II(c, d, a, b, M_offset_6, 15, T[58]); + b = II(b, c, d, a, M_offset_13, 21, T[59]); + a = II(a, b, c, d, M_offset_4, 6, T[60]); + d = II(d, a, b, c, M_offset_11, 10, T[61]); + c = II(c, d, a, b, M_offset_2, 15, T[62]); + b = II(b, c, d, a, M_offset_9, 21, T[63]); + + // Intermediate hash value + H[0] = (H[0] + a) | 0; + H[1] = (H[1] + b) | 0; + H[2] = (H[2] + c) | 0; + H[3] = (H[3] + d) | 0; + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); + + var nBitsTotalH = Math.floor(nBitsTotal / 0x100000000); + var nBitsTotalL = nBitsTotal; + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = ( + (((nBitsTotalH << 8) | (nBitsTotalH >>> 24)) & 0x00ff00ff) | + (((nBitsTotalH << 24) | (nBitsTotalH >>> 8)) & 0xff00ff00) + ); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = ( + (((nBitsTotalL << 8) | (nBitsTotalL >>> 24)) & 0x00ff00ff) | + (((nBitsTotalL << 24) | (nBitsTotalL >>> 8)) & 0xff00ff00) + ); + + data.sigBytes = (dataWords.length + 1) * 4; + + // Hash final blocks + this._process(); + + // Shortcuts + var hash = this._hash; + var H = hash.words; + + // Swap endian + for (var i = 0; i < 4; i++) { + // Shortcut + var H_i = H[i]; + + H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) | + (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00); + } + + // Return final computed hash + return hash; + }, + + clone: function () { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + + return clone; + } + }); + + function FF(a, b, c, d, x, s, t) { + var n = a + ((b & c) | (~b & d)) + x + t; + return ((n << s) | (n >>> (32 - s))) + b; + } + + function GG(a, b, c, d, x, s, t) { + var n = a + ((b & d) | (c & ~d)) + x + t; + return ((n << s) | (n >>> (32 - s))) + b; + } + + function HH(a, b, c, d, x, s, t) { + var n = a + (b ^ c ^ d) + x + t; + return ((n << s) | (n >>> (32 - s))) + b; + } + + function II(a, b, c, d, x, s, t) { + var n = a + (c ^ (b | ~d)) + x + t; + return ((n << s) | (n >>> (32 - s))) + b; + } + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.MD5('message'); + * var hash = CryptoJS.MD5(wordArray); + */ + C.MD5 = Hasher._createHelper(MD5); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacMD5(message, key); + */ + C.HmacMD5 = Hasher._createHmacHelper(MD5); + }(Math)); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C.algo; + + // Reusable object + var W = []; + + /** + * SHA-1 hash algorithm. + */ + var SHA1 = C_algo.SHA1 = Hasher.extend({ + _doReset: function () { + this._hash = new WordArray.init([ + 0x67452301, 0xefcdab89, + 0x98badcfe, 0x10325476, + 0xc3d2e1f0 + ]); + }, + + _doProcessBlock: function (M, offset) { + // Shortcut + var H = this._hash.words; + + // Working variables + var a = H[0]; + var b = H[1]; + var c = H[2]; + var d = H[3]; + var e = H[4]; + + // Computation + for (var i = 0; i < 80; i++) { + if (i < 16) { + W[i] = M[offset + i] | 0; + } else { + var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16]; + W[i] = (n << 1) | (n >>> 31); + } + + var t = ((a << 5) | (a >>> 27)) + e + W[i]; + if (i < 20) { + t += ((b & c) | (~b & d)) + 0x5a827999; + } else if (i < 40) { + t += (b ^ c ^ d) + 0x6ed9eba1; + } else if (i < 60) { + t += ((b & c) | (b & d) | (c & d)) - 0x70e44324; + } else /* if (i < 80) */ { + t += (b ^ c ^ d) - 0x359d3e2a; + } + + e = d; + d = c; + c = (b << 30) | (b >>> 2); + b = a; + a = t; + } + + // Intermediate hash value + H[0] = (H[0] + a) | 0; + H[1] = (H[1] + b) | 0; + H[2] = (H[2] + c) | 0; + H[3] = (H[3] + d) | 0; + H[4] = (H[4] + e) | 0; + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + + // Hash final blocks + this._process(); + + // Return final computed hash + return this._hash; + }, + + clone: function () { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + + return clone; + } + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA1('message'); + * var hash = CryptoJS.SHA1(wordArray); + */ + C.SHA1 = Hasher._createHelper(SHA1); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA1(message, key); + */ + C.HmacSHA1 = Hasher._createHmacHelper(SHA1); + }()); + + + (function (Math) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C.algo; + + // Initialization and round constants tables + var H = []; + var K = []; + + // Compute constants + (function () { + function isPrime(n) { + var sqrtN = Math.sqrt(n); + for (var factor = 2; factor <= sqrtN; factor++) { + if (!(n % factor)) { + return false; + } + } + + return true; + } + + function getFractionalBits(n) { + return ((n - (n | 0)) * 0x100000000) | 0; + } + + var n = 2; + var nPrime = 0; + while (nPrime < 64) { + if (isPrime(n)) { + if (nPrime < 8) { + H[nPrime] = getFractionalBits(Math.pow(n, 1 / 2)); + } + K[nPrime] = getFractionalBits(Math.pow(n, 1 / 3)); + + nPrime++; + } + + n++; + } + }()); + + // Reusable object + var W = []; + + /** + * SHA-256 hash algorithm. + */ + var SHA256 = C_algo.SHA256 = Hasher.extend({ + _doReset: function () { + this._hash = new WordArray.init(H.slice(0)); + }, + + _doProcessBlock: function (M, offset) { + // Shortcut + var H = this._hash.words; + + // Working variables + var a = H[0]; + var b = H[1]; + var c = H[2]; + var d = H[3]; + var e = H[4]; + var f = H[5]; + var g = H[6]; + var h = H[7]; + + // Computation + for (var i = 0; i < 64; i++) { + if (i < 16) { + W[i] = M[offset + i] | 0; + } else { + var gamma0x = W[i - 15]; + var gamma0 = ((gamma0x << 25) | (gamma0x >>> 7)) ^ + ((gamma0x << 14) | (gamma0x >>> 18)) ^ + (gamma0x >>> 3); + + var gamma1x = W[i - 2]; + var gamma1 = ((gamma1x << 15) | (gamma1x >>> 17)) ^ + ((gamma1x << 13) | (gamma1x >>> 19)) ^ + (gamma1x >>> 10); + + W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]; + } + + var ch = (e & f) ^ (~e & g); + var maj = (a & b) ^ (a & c) ^ (b & c); + + var sigma0 = ((a << 30) | (a >>> 2)) ^ ((a << 19) | (a >>> 13)) ^ ((a << 10) | (a >>> 22)); + var sigma1 = ((e << 26) | (e >>> 6)) ^ ((e << 21) | (e >>> 11)) ^ ((e << 7) | (e >>> 25)); + + var t1 = h + sigma1 + ch + K[i] + W[i]; + var t2 = sigma0 + maj; + + h = g; + g = f; + f = e; + e = (d + t1) | 0; + d = c; + c = b; + b = a; + a = (t1 + t2) | 0; + } + + // Intermediate hash value + H[0] = (H[0] + a) | 0; + H[1] = (H[1] + b) | 0; + H[2] = (H[2] + c) | 0; + H[3] = (H[3] + d) | 0; + H[4] = (H[4] + e) | 0; + H[5] = (H[5] + f) | 0; + H[6] = (H[6] + g) | 0; + H[7] = (H[7] + h) | 0; + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + + // Hash final blocks + this._process(); + + // Return final computed hash + return this._hash; + }, + + clone: function () { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + + return clone; + } + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA256('message'); + * var hash = CryptoJS.SHA256(wordArray); + */ + C.SHA256 = Hasher._createHelper(SHA256); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA256(message, key); + */ + C.HmacSHA256 = Hasher._createHmacHelper(SHA256); + }(Math)); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var C_enc = C.enc; + + /** + * UTF-16 BE encoding strategy. + */ + var Utf16BE = C_enc.Utf16 = C_enc.Utf16BE = { + /** + * Converts a word array to a UTF-16 BE string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-16 BE string. + * + * @static + * + * @example + * + * var utf16String = CryptoJS.enc.Utf16.stringify(wordArray); + */ + stringify: function (wordArray) { + // Shortcuts + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + + // Convert + var utf16Chars = []; + for (var i = 0; i < sigBytes; i += 2) { + var codePoint = (words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff; + utf16Chars.push(String.fromCharCode(codePoint)); + } + + return utf16Chars.join(''); + }, + + /** + * Converts a UTF-16 BE string to a word array. + * + * @param {string} utf16Str The UTF-16 BE string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf16.parse(utf16String); + */ + parse: function (utf16Str) { + // Shortcut + var utf16StrLength = utf16Str.length; + + // Convert + var words = []; + for (var i = 0; i < utf16StrLength; i++) { + words[i >>> 1] |= utf16Str.charCodeAt(i) << (16 - (i % 2) * 16); + } + + return WordArray.create(words, utf16StrLength * 2); + } + }; + + /** + * UTF-16 LE encoding strategy. + */ + C_enc.Utf16LE = { + /** + * Converts a word array to a UTF-16 LE string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-16 LE string. + * + * @static + * + * @example + * + * var utf16Str = CryptoJS.enc.Utf16LE.stringify(wordArray); + */ + stringify: function (wordArray) { + // Shortcuts + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + + // Convert + var utf16Chars = []; + for (var i = 0; i < sigBytes; i += 2) { + var codePoint = swapEndian((words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff); + utf16Chars.push(String.fromCharCode(codePoint)); + } + + return utf16Chars.join(''); + }, + + /** + * Converts a UTF-16 LE string to a word array. + * + * @param {string} utf16Str The UTF-16 LE string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf16LE.parse(utf16Str); + */ + parse: function (utf16Str) { + // Shortcut + var utf16StrLength = utf16Str.length; + + // Convert + var words = []; + for (var i = 0; i < utf16StrLength; i++) { + words[i >>> 1] |= swapEndian(utf16Str.charCodeAt(i) << (16 - (i % 2) * 16)); + } + + return WordArray.create(words, utf16StrLength * 2); + } + }; + + function swapEndian(word) { + return ((word << 8) & 0xff00ff00) | ((word >>> 8) & 0x00ff00ff); + } + }()); + + + (function () { + // Check if typed arrays are supported + if (typeof ArrayBuffer != 'function') { + return; + } + + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + + // Reference original init + var superInit = WordArray.init; + + // Augment WordArray.init to handle typed arrays + var subInit = WordArray.init = function (typedArray) { + // Convert buffers to uint8 + if (typedArray instanceof ArrayBuffer) { + typedArray = new Uint8Array(typedArray); + } + + // Convert other array views to uint8 + if ( + typedArray instanceof Int8Array || + (typeof Uint8ClampedArray !== "undefined" && typedArray instanceof Uint8ClampedArray) || + typedArray instanceof Int16Array || + typedArray instanceof Uint16Array || + typedArray instanceof Int32Array || + typedArray instanceof Uint32Array || + typedArray instanceof Float32Array || + typedArray instanceof Float64Array + ) { + typedArray = new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength); + } + + // Handle Uint8Array + if (typedArray instanceof Uint8Array) { + // Shortcut + var typedArrayByteLength = typedArray.byteLength; + + // Extract bytes + var words = []; + for (var i = 0; i < typedArrayByteLength; i++) { + words[i >>> 2] |= typedArray[i] << (24 - (i % 4) * 8); + } + + // Initialize this word array + superInit.call(this, words, typedArrayByteLength); + } else { + // Else call normal init + superInit.apply(this, arguments); + } + }; + + subInit.prototype = WordArray; + }()); + + + /** @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 (Math) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C.algo; + + // Constants table + var _zl = WordArray.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]); + var _zr = WordArray.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]); + var _sl = WordArray.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 ]); + var _sr = WordArray.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 ]); + + var _hl = WordArray.create([ 0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E]); + var _hr = WordArray.create([ 0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000]); + + /** + * RIPEMD160 hash algorithm. + */ + var RIPEMD160 = C_algo.RIPEMD160 = Hasher.extend({ + _doReset: function () { + this._hash = WordArray.create([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0]); + }, + + _doProcessBlock: function (M, offset) { + + // Swap endian + for (var i = 0; i < 16; i++) { + // Shortcuts + var offset_i = offset + i; + var M_offset_i = M[offset_i]; + + // Swap + M[offset_i] = ( + (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) | + (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00) + ); + } + // Shortcut + var H = this._hash.words; + var hl = _hl.words; + var hr = _hr.words; + var zl = _zl.words; + var zr = _zr.words; + var sl = _sl.words; + var sr = _sr.words; + + // Working variables + var al, bl, cl, dl, el; + var ar, br, cr, dr, er; + + ar = al = H[0]; + br = bl = H[1]; + cr = cl = H[2]; + dr = dl = H[3]; + er = el = H[4]; + // Computation + var t; + for (var i = 0; i < 80; i += 1) { + t = (al + M[offset+zl[i]])|0; + if (i<16){ + t += f1(bl,cl,dl) + hl[0]; + } else if (i<32) { + t += f2(bl,cl,dl) + hl[1]; + } else if (i<48) { + t += f3(bl,cl,dl) + hl[2]; + } else if (i<64) { + t += f4(bl,cl,dl) + hl[3]; + } else {// if (i<80) { + t += f5(bl,cl,dl) + hl[4]; + } + t = t|0; + t = rotl(t,sl[i]); + t = (t+el)|0; + al = el; + el = dl; + dl = rotl(cl, 10); + cl = bl; + bl = t; + + t = (ar + M[offset+zr[i]])|0; + if (i<16){ + t += f5(br,cr,dr) + hr[0]; + } else if (i<32) { + t += f4(br,cr,dr) + hr[1]; + } else if (i<48) { + t += f3(br,cr,dr) + hr[2]; + } else if (i<64) { + t += f2(br,cr,dr) + hr[3]; + } else {// if (i<80) { + t += f1(br,cr,dr) + hr[4]; + } + t = t|0; + t = rotl(t,sr[i]) ; + t = (t+er)|0; + ar = er; + er = dr; + dr = rotl(cr, 10); + cr = br; + br = t; + } + // Intermediate hash value + t = (H[1] + cl + dr)|0; + H[1] = (H[2] + dl + er)|0; + H[2] = (H[3] + el + ar)|0; + H[3] = (H[4] + al + br)|0; + H[4] = (H[0] + bl + cr)|0; + H[0] = t; + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); + dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = ( + (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) | + (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00) + ); + data.sigBytes = (dataWords.length + 1) * 4; + + // Hash final blocks + this._process(); + + // Shortcuts + var hash = this._hash; + var H = hash.words; + + // Swap endian + for (var i = 0; i < 5; i++) { + // Shortcut + var H_i = H[i]; + + // Swap + H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) | + (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00); + } + + // Return final computed hash + return hash; + }, + + clone: function () { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + + return clone; + } + }); + + + function f1(x, y, z) { + return ((x) ^ (y) ^ (z)); + + } + + function f2(x, y, z) { + return (((x)&(y)) | ((~x)&(z))); + } + + function f3(x, y, z) { + return (((x) | (~(y))) ^ (z)); + } + + function f4(x, y, z) { + return (((x) & (z)) | ((y)&(~(z)))); + } + + function f5(x, y, z) { + return ((x) ^ ((y) |(~(z)))); + + } + + function rotl(x,n) { + return (x<>>(32-n)); + } + + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.RIPEMD160('message'); + * var hash = CryptoJS.RIPEMD160(wordArray); + */ + C.RIPEMD160 = Hasher._createHelper(RIPEMD160); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacRIPEMD160(message, key); + */ + C.HmacRIPEMD160 = Hasher._createHmacHelper(RIPEMD160); + }(Math)); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Base = C_lib.Base; + var C_enc = C.enc; + var Utf8 = C_enc.Utf8; + var C_algo = C.algo; + + /** + * HMAC algorithm. + */ + var HMAC = C_algo.HMAC = Base.extend({ + /** + * Initializes a newly created HMAC. + * + * @param {Hasher} hasher The hash algorithm to use. + * @param {WordArray|string} key The secret key. + * + * @example + * + * var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key); + */ + init: function (hasher, key) { + // Init hasher + hasher = this._hasher = new hasher.init(); + + // Convert string to WordArray, else assume WordArray already + if (typeof key == 'string') { + key = Utf8.parse(key); + } + + // Shortcuts + var hasherBlockSize = hasher.blockSize; + var hasherBlockSizeBytes = hasherBlockSize * 4; + + // Allow arbitrary length keys + if (key.sigBytes > hasherBlockSizeBytes) { + key = hasher.finalize(key); + } + + // Clamp excess bits + key.clamp(); + + // Clone key for inner and outer pads + var oKey = this._oKey = key.clone(); + var iKey = this._iKey = key.clone(); + + // Shortcuts + var oKeyWords = oKey.words; + var iKeyWords = iKey.words; + + // XOR keys with pad constants + for (var i = 0; i < hasherBlockSize; i++) { + oKeyWords[i] ^= 0x5c5c5c5c; + iKeyWords[i] ^= 0x36363636; + } + oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes; + + // Set initial values + this.reset(); + }, + + /** + * Resets this HMAC to its initial state. + * + * @example + * + * hmacHasher.reset(); + */ + reset: function () { + // Shortcut + var hasher = this._hasher; + + // Reset + hasher.reset(); + hasher.update(this._iKey); + }, + + /** + * Updates this HMAC with a message. + * + * @param {WordArray|string} messageUpdate The message to append. + * + * @return {HMAC} This HMAC instance. + * + * @example + * + * hmacHasher.update('message'); + * hmacHasher.update(wordArray); + */ + update: function (messageUpdate) { + this._hasher.update(messageUpdate); + + // Chainable + return this; + }, + + /** + * Finalizes the HMAC computation. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} messageUpdate (Optional) A final message update. + * + * @return {WordArray} The HMAC. + * + * @example + * + * var hmac = hmacHasher.finalize(); + * var hmac = hmacHasher.finalize('message'); + * var hmac = hmacHasher.finalize(wordArray); + */ + finalize: function (messageUpdate) { + // Shortcut + var hasher = this._hasher; + + // Compute HMAC + var innerHash = hasher.finalize(messageUpdate); + hasher.reset(); + var hmac = hasher.finalize(this._oKey.clone().concat(innerHash)); + + return hmac; + } + }); + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var C_algo = C.algo; + var SHA1 = C_algo.SHA1; + var HMAC = C_algo.HMAC; + + /** + * Password-Based Key Derivation Function 2 algorithm. + */ + var PBKDF2 = C_algo.PBKDF2 = Base.extend({ + /** + * Configuration options. + * + * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) + * @property {Hasher} hasher The hasher to use. Default: SHA1 + * @property {number} iterations The number of iterations to perform. Default: 1 + */ + cfg: Base.extend({ + keySize: 128/32, + hasher: SHA1, + iterations: 1 + }), + + /** + * Initializes a newly created key derivation function. + * + * @param {Object} cfg (Optional) The configuration options to use for the derivation. + * + * @example + * + * var kdf = CryptoJS.algo.PBKDF2.create(); + * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8 }); + * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8, iterations: 1000 }); + */ + init: function (cfg) { + this.cfg = this.cfg.extend(cfg); + }, + + /** + * Computes the Password-Based Key Derivation Function 2. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * + * @return {WordArray} The derived key. + * + * @example + * + * var key = kdf.compute(password, salt); + */ + compute: function (password, salt) { + // Shortcut + var cfg = this.cfg; + + // Init HMAC + var hmac = HMAC.create(cfg.hasher, password); + + // Initial values + var derivedKey = WordArray.create(); + var blockIndex = WordArray.create([0x00000001]); + + // Shortcuts + var derivedKeyWords = derivedKey.words; + var blockIndexWords = blockIndex.words; + var keySize = cfg.keySize; + var iterations = cfg.iterations; + + // Generate key + while (derivedKeyWords.length < keySize) { + var block = hmac.update(salt).finalize(blockIndex); + hmac.reset(); + + // Shortcuts + var blockWords = block.words; + var blockWordsLength = blockWords.length; + + // Iterations + var intermediate = block; + for (var i = 1; i < iterations; i++) { + intermediate = hmac.finalize(intermediate); + hmac.reset(); + + // Shortcut + var intermediateWords = intermediate.words; + + // XOR intermediate with block + for (var j = 0; j < blockWordsLength; j++) { + blockWords[j] ^= intermediateWords[j]; + } + } + + derivedKey.concat(block); + blockIndexWords[0]++; + } + derivedKey.sigBytes = keySize * 4; + + return derivedKey; + } + }); + + /** + * Computes the Password-Based Key Derivation Function 2. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * @param {Object} cfg (Optional) The configuration options to use for this computation. + * + * @return {WordArray} The derived key. + * + * @static + * + * @example + * + * var key = CryptoJS.PBKDF2(password, salt); + * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8 }); + * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8, iterations: 1000 }); + */ + C.PBKDF2 = function (password, salt, cfg) { + return PBKDF2.create(cfg).compute(password, salt); + }; + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var C_algo = C.algo; + var MD5 = C_algo.MD5; + + /** + * This key derivation function is meant to conform with EVP_BytesToKey. + * www.openssl.org/docs/crypto/EVP_BytesToKey.html + */ + var EvpKDF = C_algo.EvpKDF = Base.extend({ + /** + * Configuration options. + * + * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) + * @property {Hasher} hasher The hash algorithm to use. Default: MD5 + * @property {number} iterations The number of iterations to perform. Default: 1 + */ + cfg: Base.extend({ + keySize: 128/32, + hasher: MD5, + iterations: 1 + }), + + /** + * Initializes a newly created key derivation function. + * + * @param {Object} cfg (Optional) The configuration options to use for the derivation. + * + * @example + * + * var kdf = CryptoJS.algo.EvpKDF.create(); + * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8 }); + * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8, iterations: 1000 }); + */ + init: function (cfg) { + this.cfg = this.cfg.extend(cfg); + }, + + /** + * Derives a key from a password. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * + * @return {WordArray} The derived key. + * + * @example + * + * var key = kdf.compute(password, salt); + */ + compute: function (password, salt) { + // Shortcut + var cfg = this.cfg; + + // Init hasher + var hasher = cfg.hasher.create(); + + // Initial values + var derivedKey = WordArray.create(); + + // Shortcuts + var derivedKeyWords = derivedKey.words; + var keySize = cfg.keySize; + var iterations = cfg.iterations; + + // Generate key + while (derivedKeyWords.length < keySize) { + if (block) { + hasher.update(block); + } + var block = hasher.update(password).finalize(salt); + hasher.reset(); + + // Iterations + for (var i = 1; i < iterations; i++) { + block = hasher.finalize(block); + hasher.reset(); + } + + derivedKey.concat(block); + } + derivedKey.sigBytes = keySize * 4; + + return derivedKey; + } + }); + + /** + * Derives a key from a password. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * @param {Object} cfg (Optional) The configuration options to use for this computation. + * + * @return {WordArray} The derived key. + * + * @static + * + * @example + * + * var key = CryptoJS.EvpKDF(password, salt); + * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8 }); + * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8, iterations: 1000 }); + */ + C.EvpKDF = function (password, salt, cfg) { + return EvpKDF.create(cfg).compute(password, salt); + }; + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var C_algo = C.algo; + var SHA256 = C_algo.SHA256; + + /** + * SHA-224 hash algorithm. + */ + var SHA224 = C_algo.SHA224 = SHA256.extend({ + _doReset: function () { + this._hash = new WordArray.init([ + 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939, + 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 + ]); + }, + + _doFinalize: function () { + var hash = SHA256._doFinalize.call(this); + + hash.sigBytes -= 4; + + return hash; + } + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA224('message'); + * var hash = CryptoJS.SHA224(wordArray); + */ + C.SHA224 = SHA256._createHelper(SHA224); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA224(message, key); + */ + C.HmacSHA224 = SHA256._createHmacHelper(SHA224); + }()); + + + (function (undefined) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Base = C_lib.Base; + var X32WordArray = C_lib.WordArray; + + /** + * x64 namespace. + */ + var C_x64 = C.x64 = {}; + + /** + * A 64-bit word. + */ + var X64Word = C_x64.Word = Base.extend({ + /** + * Initializes a newly created 64-bit word. + * + * @param {number} high The high 32 bits. + * @param {number} low The low 32 bits. + * + * @example + * + * var x64Word = CryptoJS.x64.Word.create(0x00010203, 0x04050607); + */ + init: function (high, low) { + this.high = high; + this.low = low; + } + + /** + * Bitwise NOTs this word. + * + * @return {X64Word} A new x64-Word object after negating. + * + * @example + * + * var negated = x64Word.not(); + */ + // not: function () { + // var high = ~this.high; + // var low = ~this.low; + + // return X64Word.create(high, low); + // }, + + /** + * Bitwise ANDs this word with the passed word. + * + * @param {X64Word} word The x64-Word to AND with this word. + * + * @return {X64Word} A new x64-Word object after ANDing. + * + * @example + * + * var anded = x64Word.and(anotherX64Word); + */ + // and: function (word) { + // var high = this.high & word.high; + // var low = this.low & word.low; + + // return X64Word.create(high, low); + // }, + + /** + * Bitwise ORs this word with the passed word. + * + * @param {X64Word} word The x64-Word to OR with this word. + * + * @return {X64Word} A new x64-Word object after ORing. + * + * @example + * + * var ored = x64Word.or(anotherX64Word); + */ + // or: function (word) { + // var high = this.high | word.high; + // var low = this.low | word.low; + + // return X64Word.create(high, low); + // }, + + /** + * Bitwise XORs this word with the passed word. + * + * @param {X64Word} word The x64-Word to XOR with this word. + * + * @return {X64Word} A new x64-Word object after XORing. + * + * @example + * + * var xored = x64Word.xor(anotherX64Word); + */ + // xor: function (word) { + // var high = this.high ^ word.high; + // var low = this.low ^ word.low; + + // return X64Word.create(high, low); + // }, + + /** + * Shifts this word n bits to the left. + * + * @param {number} n The number of bits to shift. + * + * @return {X64Word} A new x64-Word object after shifting. + * + * @example + * + * var shifted = x64Word.shiftL(25); + */ + // shiftL: function (n) { + // if (n < 32) { + // var high = (this.high << n) | (this.low >>> (32 - n)); + // var low = this.low << n; + // } else { + // var high = this.low << (n - 32); + // var low = 0; + // } + + // return X64Word.create(high, low); + // }, + + /** + * Shifts this word n bits to the right. + * + * @param {number} n The number of bits to shift. + * + * @return {X64Word} A new x64-Word object after shifting. + * + * @example + * + * var shifted = x64Word.shiftR(7); + */ + // shiftR: function (n) { + // if (n < 32) { + // var low = (this.low >>> n) | (this.high << (32 - n)); + // var high = this.high >>> n; + // } else { + // var low = this.high >>> (n - 32); + // var high = 0; + // } + + // return X64Word.create(high, low); + // }, + + /** + * Rotates this word n bits to the left. + * + * @param {number} n The number of bits to rotate. + * + * @return {X64Word} A new x64-Word object after rotating. + * + * @example + * + * var rotated = x64Word.rotL(25); + */ + // rotL: function (n) { + // return this.shiftL(n).or(this.shiftR(64 - n)); + // }, + + /** + * Rotates this word n bits to the right. + * + * @param {number} n The number of bits to rotate. + * + * @return {X64Word} A new x64-Word object after rotating. + * + * @example + * + * var rotated = x64Word.rotR(7); + */ + // rotR: function (n) { + // return this.shiftR(n).or(this.shiftL(64 - n)); + // }, + + /** + * Adds this word with the passed word. + * + * @param {X64Word} word The x64-Word to add with this word. + * + * @return {X64Word} A new x64-Word object after adding. + * + * @example + * + * var added = x64Word.add(anotherX64Word); + */ + // add: function (word) { + // var low = (this.low + word.low) | 0; + // var carry = (low >>> 0) < (this.low >>> 0) ? 1 : 0; + // var high = (this.high + word.high + carry) | 0; + + // return X64Word.create(high, low); + // } + }); + + /** + * An array of 64-bit words. + * + * @property {Array} words The array of CryptoJS.x64.Word objects. + * @property {number} sigBytes The number of significant bytes in this word array. + */ + var X64WordArray = C_x64.WordArray = Base.extend({ + /** + * Initializes a newly created word array. + * + * @param {Array} words (Optional) An array of CryptoJS.x64.Word objects. + * @param {number} sigBytes (Optional) The number of significant bytes in the words. + * + * @example + * + * var wordArray = CryptoJS.x64.WordArray.create(); + * + * var wordArray = CryptoJS.x64.WordArray.create([ + * CryptoJS.x64.Word.create(0x00010203, 0x04050607), + * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) + * ]); + * + * var wordArray = CryptoJS.x64.WordArray.create([ + * CryptoJS.x64.Word.create(0x00010203, 0x04050607), + * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) + * ], 10); + */ + init: function (words, sigBytes) { + words = this.words = words || []; + + if (sigBytes != undefined) { + this.sigBytes = sigBytes; + } else { + this.sigBytes = words.length * 8; + } + }, + + /** + * Converts this 64-bit word array to a 32-bit word array. + * + * @return {CryptoJS.lib.WordArray} This word array's data as a 32-bit word array. + * + * @example + * + * var x32WordArray = x64WordArray.toX32(); + */ + toX32: function () { + // Shortcuts + var x64Words = this.words; + var x64WordsLength = x64Words.length; + + // Convert + var x32Words = []; + for (var i = 0; i < x64WordsLength; i++) { + var x64Word = x64Words[i]; + x32Words.push(x64Word.high); + x32Words.push(x64Word.low); + } + + return X32WordArray.create(x32Words, this.sigBytes); + }, + + /** + * Creates a copy of this word array. + * + * @return {X64WordArray} The clone. + * + * @example + * + * var clone = x64WordArray.clone(); + */ + clone: function () { + var clone = Base.clone.call(this); + + // Clone "words" array + var words = clone.words = this.words.slice(0); + + // Clone each X64Word object + var wordsLength = words.length; + for (var i = 0; i < wordsLength; i++) { + words[i] = words[i].clone(); + } + + return clone; + } + }); + }()); + + + (function (Math) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_x64 = C.x64; + var X64Word = C_x64.Word; + var C_algo = C.algo; + + // Constants tables + var RHO_OFFSETS = []; + var PI_INDEXES = []; + var ROUND_CONSTANTS = []; + + // Compute Constants + (function () { + // Compute rho offset constants + var x = 1, y = 0; + for (var t = 0; t < 24; t++) { + RHO_OFFSETS[x + 5 * y] = ((t + 1) * (t + 2) / 2) % 64; + + var newX = y % 5; + var newY = (2 * x + 3 * y) % 5; + x = newX; + y = newY; + } + + // Compute pi index constants + for (var x = 0; x < 5; x++) { + for (var y = 0; y < 5; y++) { + PI_INDEXES[x + 5 * y] = y + ((2 * x + 3 * y) % 5) * 5; + } + } + + // Compute round constants + var LFSR = 0x01; + for (var i = 0; i < 24; i++) { + var roundConstantMsw = 0; + var roundConstantLsw = 0; + + for (var j = 0; j < 7; j++) { + if (LFSR & 0x01) { + var bitPosition = (1 << j) - 1; + if (bitPosition < 32) { + roundConstantLsw ^= 1 << bitPosition; + } else /* if (bitPosition >= 32) */ { + roundConstantMsw ^= 1 << (bitPosition - 32); + } + } + + // Compute next LFSR + if (LFSR & 0x80) { + // Primitive polynomial over GF(2): x^8 + x^6 + x^5 + x^4 + 1 + LFSR = (LFSR << 1) ^ 0x71; + } else { + LFSR <<= 1; + } + } + + ROUND_CONSTANTS[i] = X64Word.create(roundConstantMsw, roundConstantLsw); + } + }()); + + // Reusable objects for temporary values + var T = []; + (function () { + for (var i = 0; i < 25; i++) { + T[i] = X64Word.create(); + } + }()); + + /** + * SHA-3 hash algorithm. + */ + var SHA3 = C_algo.SHA3 = Hasher.extend({ + /** + * Configuration options. + * + * @property {number} outputLength + * The desired number of bits in the output hash. + * Only values permitted are: 224, 256, 384, 512. + * Default: 512 + */ + cfg: Hasher.cfg.extend({ + outputLength: 512 + }), + + _doReset: function () { + var state = this._state = [] + for (var i = 0; i < 25; i++) { + state[i] = new X64Word.init(); + } + + this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32; + }, + + _doProcessBlock: function (M, offset) { + // Shortcuts + var state = this._state; + var nBlockSizeLanes = this.blockSize / 2; + + // Absorb + for (var i = 0; i < nBlockSizeLanes; i++) { + // Shortcuts + var M2i = M[offset + 2 * i]; + var M2i1 = M[offset + 2 * i + 1]; + + // Swap endian + M2i = ( + (((M2i << 8) | (M2i >>> 24)) & 0x00ff00ff) | + (((M2i << 24) | (M2i >>> 8)) & 0xff00ff00) + ); + M2i1 = ( + (((M2i1 << 8) | (M2i1 >>> 24)) & 0x00ff00ff) | + (((M2i1 << 24) | (M2i1 >>> 8)) & 0xff00ff00) + ); + + // Absorb message into state + var lane = state[i]; + lane.high ^= M2i1; + lane.low ^= M2i; + } + + // Rounds + for (var round = 0; round < 24; round++) { + // Theta + for (var x = 0; x < 5; x++) { + // Mix column lanes + var tMsw = 0, tLsw = 0; + for (var y = 0; y < 5; y++) { + var lane = state[x + 5 * y]; + tMsw ^= lane.high; + tLsw ^= lane.low; + } + + // Temporary values + var Tx = T[x]; + Tx.high = tMsw; + Tx.low = tLsw; + } + for (var x = 0; x < 5; x++) { + // Shortcuts + var Tx4 = T[(x + 4) % 5]; + var Tx1 = T[(x + 1) % 5]; + var Tx1Msw = Tx1.high; + var Tx1Lsw = Tx1.low; + + // Mix surrounding columns + var tMsw = Tx4.high ^ ((Tx1Msw << 1) | (Tx1Lsw >>> 31)); + var tLsw = Tx4.low ^ ((Tx1Lsw << 1) | (Tx1Msw >>> 31)); + for (var y = 0; y < 5; y++) { + var lane = state[x + 5 * y]; + lane.high ^= tMsw; + lane.low ^= tLsw; + } + } + + // Rho Pi + for (var laneIndex = 1; laneIndex < 25; laneIndex++) { + // Shortcuts + var lane = state[laneIndex]; + var laneMsw = lane.high; + var laneLsw = lane.low; + var rhoOffset = RHO_OFFSETS[laneIndex]; + + // Rotate lanes + if (rhoOffset < 32) { + var tMsw = (laneMsw << rhoOffset) | (laneLsw >>> (32 - rhoOffset)); + var tLsw = (laneLsw << rhoOffset) | (laneMsw >>> (32 - rhoOffset)); + } else /* if (rhoOffset >= 32) */ { + var tMsw = (laneLsw << (rhoOffset - 32)) | (laneMsw >>> (64 - rhoOffset)); + var tLsw = (laneMsw << (rhoOffset - 32)) | (laneLsw >>> (64 - rhoOffset)); + } + + // Transpose lanes + var TPiLane = T[PI_INDEXES[laneIndex]]; + TPiLane.high = tMsw; + TPiLane.low = tLsw; + } + + // Rho pi at x = y = 0 + var T0 = T[0]; + var state0 = state[0]; + T0.high = state0.high; + T0.low = state0.low; + + // Chi + for (var x = 0; x < 5; x++) { + for (var y = 0; y < 5; y++) { + // Shortcuts + var laneIndex = x + 5 * y; + var lane = state[laneIndex]; + var TLane = T[laneIndex]; + var Tx1Lane = T[((x + 1) % 5) + 5 * y]; + var Tx2Lane = T[((x + 2) % 5) + 5 * y]; + + // Mix rows + lane.high = TLane.high ^ (~Tx1Lane.high & Tx2Lane.high); + lane.low = TLane.low ^ (~Tx1Lane.low & Tx2Lane.low); + } + } + + // Iota + var lane = state[0]; + var roundConstant = ROUND_CONSTANTS[round]; + lane.high ^= roundConstant.high; + lane.low ^= roundConstant.low;; + } + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + var blockSizeBits = this.blockSize * 32; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x1 << (24 - nBitsLeft % 32); + dataWords[((Math.ceil((nBitsLeft + 1) / blockSizeBits) * blockSizeBits) >>> 5) - 1] |= 0x80; + data.sigBytes = dataWords.length * 4; + + // Hash final blocks + this._process(); + + // Shortcuts + var state = this._state; + var outputLengthBytes = this.cfg.outputLength / 8; + var outputLengthLanes = outputLengthBytes / 8; + + // Squeeze + var hashWords = []; + for (var i = 0; i < outputLengthLanes; i++) { + // Shortcuts + var lane = state[i]; + var laneMsw = lane.high; + var laneLsw = lane.low; + + // Swap endian + laneMsw = ( + (((laneMsw << 8) | (laneMsw >>> 24)) & 0x00ff00ff) | + (((laneMsw << 24) | (laneMsw >>> 8)) & 0xff00ff00) + ); + laneLsw = ( + (((laneLsw << 8) | (laneLsw >>> 24)) & 0x00ff00ff) | + (((laneLsw << 24) | (laneLsw >>> 8)) & 0xff00ff00) + ); + + // Squeeze state to retrieve hash + hashWords.push(laneLsw); + hashWords.push(laneMsw); + } + + // Return final computed hash + return new WordArray.init(hashWords, outputLengthBytes); + }, + + clone: function () { + var clone = Hasher.clone.call(this); + + var state = clone._state = this._state.slice(0); + for (var i = 0; i < 25; i++) { + state[i] = state[i].clone(); + } + + return clone; + } + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA3('message'); + * var hash = CryptoJS.SHA3(wordArray); + */ + C.SHA3 = Hasher._createHelper(SHA3); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA3(message, key); + */ + C.HmacSHA3 = Hasher._createHmacHelper(SHA3); + }(Math)); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Hasher = C_lib.Hasher; + var C_x64 = C.x64; + var X64Word = C_x64.Word; + var X64WordArray = C_x64.WordArray; + var C_algo = C.algo; + + function X64Word_create() { + return X64Word.create.apply(X64Word, arguments); + } + + // Constants + var K = [ + X64Word_create(0x428a2f98, 0xd728ae22), X64Word_create(0x71374491, 0x23ef65cd), + X64Word_create(0xb5c0fbcf, 0xec4d3b2f), X64Word_create(0xe9b5dba5, 0x8189dbbc), + X64Word_create(0x3956c25b, 0xf348b538), X64Word_create(0x59f111f1, 0xb605d019), + X64Word_create(0x923f82a4, 0xaf194f9b), X64Word_create(0xab1c5ed5, 0xda6d8118), + X64Word_create(0xd807aa98, 0xa3030242), X64Word_create(0x12835b01, 0x45706fbe), + X64Word_create(0x243185be, 0x4ee4b28c), X64Word_create(0x550c7dc3, 0xd5ffb4e2), + X64Word_create(0x72be5d74, 0xf27b896f), X64Word_create(0x80deb1fe, 0x3b1696b1), + X64Word_create(0x9bdc06a7, 0x25c71235), X64Word_create(0xc19bf174, 0xcf692694), + X64Word_create(0xe49b69c1, 0x9ef14ad2), X64Word_create(0xefbe4786, 0x384f25e3), + X64Word_create(0x0fc19dc6, 0x8b8cd5b5), X64Word_create(0x240ca1cc, 0x77ac9c65), + X64Word_create(0x2de92c6f, 0x592b0275), X64Word_create(0x4a7484aa, 0x6ea6e483), + X64Word_create(0x5cb0a9dc, 0xbd41fbd4), X64Word_create(0x76f988da, 0x831153b5), + X64Word_create(0x983e5152, 0xee66dfab), X64Word_create(0xa831c66d, 0x2db43210), + X64Word_create(0xb00327c8, 0x98fb213f), X64Word_create(0xbf597fc7, 0xbeef0ee4), + X64Word_create(0xc6e00bf3, 0x3da88fc2), X64Word_create(0xd5a79147, 0x930aa725), + X64Word_create(0x06ca6351, 0xe003826f), X64Word_create(0x14292967, 0x0a0e6e70), + X64Word_create(0x27b70a85, 0x46d22ffc), X64Word_create(0x2e1b2138, 0x5c26c926), + X64Word_create(0x4d2c6dfc, 0x5ac42aed), X64Word_create(0x53380d13, 0x9d95b3df), + X64Word_create(0x650a7354, 0x8baf63de), X64Word_create(0x766a0abb, 0x3c77b2a8), + X64Word_create(0x81c2c92e, 0x47edaee6), X64Word_create(0x92722c85, 0x1482353b), + X64Word_create(0xa2bfe8a1, 0x4cf10364), X64Word_create(0xa81a664b, 0xbc423001), + X64Word_create(0xc24b8b70, 0xd0f89791), X64Word_create(0xc76c51a3, 0x0654be30), + X64Word_create(0xd192e819, 0xd6ef5218), X64Word_create(0xd6990624, 0x5565a910), + X64Word_create(0xf40e3585, 0x5771202a), X64Word_create(0x106aa070, 0x32bbd1b8), + X64Word_create(0x19a4c116, 0xb8d2d0c8), X64Word_create(0x1e376c08, 0x5141ab53), + X64Word_create(0x2748774c, 0xdf8eeb99), X64Word_create(0x34b0bcb5, 0xe19b48a8), + X64Word_create(0x391c0cb3, 0xc5c95a63), X64Word_create(0x4ed8aa4a, 0xe3418acb), + X64Word_create(0x5b9cca4f, 0x7763e373), X64Word_create(0x682e6ff3, 0xd6b2b8a3), + X64Word_create(0x748f82ee, 0x5defb2fc), X64Word_create(0x78a5636f, 0x43172f60), + X64Word_create(0x84c87814, 0xa1f0ab72), X64Word_create(0x8cc70208, 0x1a6439ec), + X64Word_create(0x90befffa, 0x23631e28), X64Word_create(0xa4506ceb, 0xde82bde9), + X64Word_create(0xbef9a3f7, 0xb2c67915), X64Word_create(0xc67178f2, 0xe372532b), + X64Word_create(0xca273ece, 0xea26619c), X64Word_create(0xd186b8c7, 0x21c0c207), + X64Word_create(0xeada7dd6, 0xcde0eb1e), X64Word_create(0xf57d4f7f, 0xee6ed178), + X64Word_create(0x06f067aa, 0x72176fba), X64Word_create(0x0a637dc5, 0xa2c898a6), + X64Word_create(0x113f9804, 0xbef90dae), X64Word_create(0x1b710b35, 0x131c471b), + X64Word_create(0x28db77f5, 0x23047d84), X64Word_create(0x32caab7b, 0x40c72493), + X64Word_create(0x3c9ebe0a, 0x15c9bebc), X64Word_create(0x431d67c4, 0x9c100d4c), + X64Word_create(0x4cc5d4be, 0xcb3e42b6), X64Word_create(0x597f299c, 0xfc657e2a), + X64Word_create(0x5fcb6fab, 0x3ad6faec), X64Word_create(0x6c44198c, 0x4a475817) + ]; + + // Reusable objects + var W = []; + (function () { + for (var i = 0; i < 80; i++) { + W[i] = X64Word_create(); + } + }()); + + /** + * SHA-512 hash algorithm. + */ + var SHA512 = C_algo.SHA512 = Hasher.extend({ + _doReset: function () { + this._hash = new X64WordArray.init([ + new X64Word.init(0x6a09e667, 0xf3bcc908), new X64Word.init(0xbb67ae85, 0x84caa73b), + new X64Word.init(0x3c6ef372, 0xfe94f82b), new X64Word.init(0xa54ff53a, 0x5f1d36f1), + new X64Word.init(0x510e527f, 0xade682d1), new X64Word.init(0x9b05688c, 0x2b3e6c1f), + new X64Word.init(0x1f83d9ab, 0xfb41bd6b), new X64Word.init(0x5be0cd19, 0x137e2179) + ]); + }, + + _doProcessBlock: function (M, offset) { + // Shortcuts + var H = this._hash.words; + + var H0 = H[0]; + var H1 = H[1]; + var H2 = H[2]; + var H3 = H[3]; + var H4 = H[4]; + var H5 = H[5]; + var H6 = H[6]; + var H7 = H[7]; + + var H0h = H0.high; + var H0l = H0.low; + var H1h = H1.high; + var H1l = H1.low; + var H2h = H2.high; + var H2l = H2.low; + var H3h = H3.high; + var H3l = H3.low; + var H4h = H4.high; + var H4l = H4.low; + var H5h = H5.high; + var H5l = H5.low; + var H6h = H6.high; + var H6l = H6.low; + var H7h = H7.high; + var H7l = H7.low; + + // Working variables + var ah = H0h; + var al = H0l; + var bh = H1h; + var bl = H1l; + var ch = H2h; + var cl = H2l; + var dh = H3h; + var dl = H3l; + var eh = H4h; + var el = H4l; + var fh = H5h; + var fl = H5l; + var gh = H6h; + var gl = H6l; + var hh = H7h; + var hl = H7l; + + // Rounds + for (var i = 0; i < 80; i++) { + // Shortcut + var Wi = W[i]; + + // Extend message + if (i < 16) { + var Wih = Wi.high = M[offset + i * 2] | 0; + var Wil = Wi.low = M[offset + i * 2 + 1] | 0; + } else { + // Gamma0 + var gamma0x = W[i - 15]; + var gamma0xh = gamma0x.high; + var gamma0xl = gamma0x.low; + var gamma0h = ((gamma0xh >>> 1) | (gamma0xl << 31)) ^ ((gamma0xh >>> 8) | (gamma0xl << 24)) ^ (gamma0xh >>> 7); + var gamma0l = ((gamma0xl >>> 1) | (gamma0xh << 31)) ^ ((gamma0xl >>> 8) | (gamma0xh << 24)) ^ ((gamma0xl >>> 7) | (gamma0xh << 25)); + + // Gamma1 + var gamma1x = W[i - 2]; + var gamma1xh = gamma1x.high; + var gamma1xl = gamma1x.low; + var gamma1h = ((gamma1xh >>> 19) | (gamma1xl << 13)) ^ ((gamma1xh << 3) | (gamma1xl >>> 29)) ^ (gamma1xh >>> 6); + var gamma1l = ((gamma1xl >>> 19) | (gamma1xh << 13)) ^ ((gamma1xl << 3) | (gamma1xh >>> 29)) ^ ((gamma1xl >>> 6) | (gamma1xh << 26)); + + // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16] + var Wi7 = W[i - 7]; + var Wi7h = Wi7.high; + var Wi7l = Wi7.low; + + var Wi16 = W[i - 16]; + var Wi16h = Wi16.high; + var Wi16l = Wi16.low; + + var Wil = gamma0l + Wi7l; + var Wih = gamma0h + Wi7h + ((Wil >>> 0) < (gamma0l >>> 0) ? 1 : 0); + var Wil = Wil + gamma1l; + var Wih = Wih + gamma1h + ((Wil >>> 0) < (gamma1l >>> 0) ? 1 : 0); + var Wil = Wil + Wi16l; + var Wih = Wih + Wi16h + ((Wil >>> 0) < (Wi16l >>> 0) ? 1 : 0); + + Wi.high = Wih; + Wi.low = Wil; + } + + var chh = (eh & fh) ^ (~eh & gh); + var chl = (el & fl) ^ (~el & gl); + var majh = (ah & bh) ^ (ah & ch) ^ (bh & ch); + var majl = (al & bl) ^ (al & cl) ^ (bl & cl); + + var sigma0h = ((ah >>> 28) | (al << 4)) ^ ((ah << 30) | (al >>> 2)) ^ ((ah << 25) | (al >>> 7)); + var sigma0l = ((al >>> 28) | (ah << 4)) ^ ((al << 30) | (ah >>> 2)) ^ ((al << 25) | (ah >>> 7)); + var sigma1h = ((eh >>> 14) | (el << 18)) ^ ((eh >>> 18) | (el << 14)) ^ ((eh << 23) | (el >>> 9)); + var sigma1l = ((el >>> 14) | (eh << 18)) ^ ((el >>> 18) | (eh << 14)) ^ ((el << 23) | (eh >>> 9)); + + // t1 = h + sigma1 + ch + K[i] + W[i] + var Ki = K[i]; + var Kih = Ki.high; + var Kil = Ki.low; + + var t1l = hl + sigma1l; + var t1h = hh + sigma1h + ((t1l >>> 0) < (hl >>> 0) ? 1 : 0); + var t1l = t1l + chl; + var t1h = t1h + chh + ((t1l >>> 0) < (chl >>> 0) ? 1 : 0); + var t1l = t1l + Kil; + var t1h = t1h + Kih + ((t1l >>> 0) < (Kil >>> 0) ? 1 : 0); + var t1l = t1l + Wil; + var t1h = t1h + Wih + ((t1l >>> 0) < (Wil >>> 0) ? 1 : 0); + + // t2 = sigma0 + maj + var t2l = sigma0l + majl; + var t2h = sigma0h + majh + ((t2l >>> 0) < (sigma0l >>> 0) ? 1 : 0); + + // Update working variables + hh = gh; + hl = gl; + gh = fh; + gl = fl; + fh = eh; + fl = el; + el = (dl + t1l) | 0; + eh = (dh + t1h + ((el >>> 0) < (dl >>> 0) ? 1 : 0)) | 0; + dh = ch; + dl = cl; + ch = bh; + cl = bl; + bh = ah; + bl = al; + al = (t1l + t2l) | 0; + ah = (t1h + t2h + ((al >>> 0) < (t1l >>> 0) ? 1 : 0)) | 0; + } + + // Intermediate hash value + H0l = H0.low = (H0l + al); + H0.high = (H0h + ah + ((H0l >>> 0) < (al >>> 0) ? 1 : 0)); + H1l = H1.low = (H1l + bl); + H1.high = (H1h + bh + ((H1l >>> 0) < (bl >>> 0) ? 1 : 0)); + H2l = H2.low = (H2l + cl); + H2.high = (H2h + ch + ((H2l >>> 0) < (cl >>> 0) ? 1 : 0)); + H3l = H3.low = (H3l + dl); + H3.high = (H3h + dh + ((H3l >>> 0) < (dl >>> 0) ? 1 : 0)); + H4l = H4.low = (H4l + el); + H4.high = (H4h + eh + ((H4l >>> 0) < (el >>> 0) ? 1 : 0)); + H5l = H5.low = (H5l + fl); + H5.high = (H5h + fh + ((H5l >>> 0) < (fl >>> 0) ? 1 : 0)); + H6l = H6.low = (H6l + gl); + H6.high = (H6h + gh + ((H6l >>> 0) < (gl >>> 0) ? 1 : 0)); + H7l = H7.low = (H7l + hl); + H7.high = (H7h + hh + ((H7l >>> 0) < (hl >>> 0) ? 1 : 0)); + }, + + _doFinalize: function () { + // Shortcuts + var data = this._data; + var dataWords = data.words; + + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + + // Add padding + dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); + dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 30] = Math.floor(nBitsTotal / 0x100000000); + dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 31] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + + // Hash final blocks + this._process(); + + // Convert hash to 32-bit word array before returning + var hash = this._hash.toX32(); + + // Return final computed hash + return hash; + }, + + clone: function () { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + + return clone; + }, + + blockSize: 1024/32 + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA512('message'); + * var hash = CryptoJS.SHA512(wordArray); + */ + C.SHA512 = Hasher._createHelper(SHA512); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA512(message, key); + */ + C.HmacSHA512 = Hasher._createHmacHelper(SHA512); + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_x64 = C.x64; + var X64Word = C_x64.Word; + var X64WordArray = C_x64.WordArray; + var C_algo = C.algo; + var SHA512 = C_algo.SHA512; + + /** + * SHA-384 hash algorithm. + */ + var SHA384 = C_algo.SHA384 = SHA512.extend({ + _doReset: function () { + this._hash = new X64WordArray.init([ + new X64Word.init(0xcbbb9d5d, 0xc1059ed8), new X64Word.init(0x629a292a, 0x367cd507), + new X64Word.init(0x9159015a, 0x3070dd17), new X64Word.init(0x152fecd8, 0xf70e5939), + new X64Word.init(0x67332667, 0xffc00b31), new X64Word.init(0x8eb44a87, 0x68581511), + new X64Word.init(0xdb0c2e0d, 0x64f98fa7), new X64Word.init(0x47b5481d, 0xbefa4fa4) + ]); + }, + + _doFinalize: function () { + var hash = SHA512._doFinalize.call(this); + + hash.sigBytes -= 16; + + return hash; + } + }); + + /** + * Shortcut function to the hasher's object interface. + * + * @param {WordArray|string} message The message to hash. + * + * @return {WordArray} The hash. + * + * @static + * + * @example + * + * var hash = CryptoJS.SHA384('message'); + * var hash = CryptoJS.SHA384(wordArray); + */ + C.SHA384 = SHA512._createHelper(SHA384); + + /** + * Shortcut function to the HMAC's object interface. + * + * @param {WordArray|string} message The message to hash. + * @param {WordArray|string} key The secret key. + * + * @return {WordArray} The HMAC. + * + * @static + * + * @example + * + * var hmac = CryptoJS.HmacSHA384(message, key); + */ + C.HmacSHA384 = SHA512._createHmacHelper(SHA384); + }()); + + + /** + * Cipher core components. + */ + CryptoJS.lib.Cipher || (function (undefined) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm; + var C_enc = C.enc; + var Utf8 = C_enc.Utf8; + var Base64 = C_enc.Base64; + var C_algo = C.algo; + var EvpKDF = C_algo.EvpKDF; + + /** + * Abstract base cipher template. + * + * @property {number} keySize This cipher's key size. Default: 4 (128 bits) + * @property {number} ivSize This cipher's IV size. Default: 4 (128 bits) + * @property {number} _ENC_XFORM_MODE A constant representing encryption mode. + * @property {number} _DEC_XFORM_MODE A constant representing decryption mode. + */ + var Cipher = C_lib.Cipher = BufferedBlockAlgorithm.extend({ + /** + * Configuration options. + * + * @property {WordArray} iv The IV to use for this operation. + */ + cfg: Base.extend(), + + /** + * Creates this cipher in encryption mode. + * + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {Cipher} A cipher instance. + * + * @static + * + * @example + * + * var cipher = CryptoJS.algo.AES.createEncryptor(keyWordArray, { iv: ivWordArray }); + */ + createEncryptor: function (key, cfg) { + return this.create(this._ENC_XFORM_MODE, key, cfg); + }, + + /** + * Creates this cipher in decryption mode. + * + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {Cipher} A cipher instance. + * + * @static + * + * @example + * + * var cipher = CryptoJS.algo.AES.createDecryptor(keyWordArray, { iv: ivWordArray }); + */ + createDecryptor: function (key, cfg) { + return this.create(this._DEC_XFORM_MODE, key, cfg); + }, + + /** + * Initializes a newly created cipher. + * + * @param {number} xformMode Either the encryption or decryption transormation mode constant. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @example + * + * var cipher = CryptoJS.algo.AES.create(CryptoJS.algo.AES._ENC_XFORM_MODE, keyWordArray, { iv: ivWordArray }); + */ + init: function (xformMode, key, cfg) { + // Apply config defaults + this.cfg = this.cfg.extend(cfg); + + // Store transform mode and key + this._xformMode = xformMode; + this._key = key; + + // Set initial values + this.reset(); + }, + + /** + * Resets this cipher to its initial state. + * + * @example + * + * cipher.reset(); + */ + reset: function () { + // Reset data buffer + BufferedBlockAlgorithm.reset.call(this); + + // Perform concrete-cipher logic + this._doReset(); + }, + + /** + * Adds data to be encrypted or decrypted. + * + * @param {WordArray|string} dataUpdate The data to encrypt or decrypt. + * + * @return {WordArray} The data after processing. + * + * @example + * + * var encrypted = cipher.process('data'); + * var encrypted = cipher.process(wordArray); + */ + process: function (dataUpdate) { + // Append + this._append(dataUpdate); + + // Process available blocks + return this._process(); + }, + + /** + * Finalizes the encryption or decryption process. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} dataUpdate The final data to encrypt or decrypt. + * + * @return {WordArray} The data after final processing. + * + * @example + * + * var encrypted = cipher.finalize(); + * var encrypted = cipher.finalize('data'); + * var encrypted = cipher.finalize(wordArray); + */ + finalize: function (dataUpdate) { + // Final data update + if (dataUpdate) { + this._append(dataUpdate); + } + + // Perform concrete-cipher logic + var finalProcessedData = this._doFinalize(); + + return finalProcessedData; + }, + + keySize: 128/32, + + ivSize: 128/32, + + _ENC_XFORM_MODE: 1, + + _DEC_XFORM_MODE: 2, + + /** + * Creates shortcut functions to a cipher's object interface. + * + * @param {Cipher} cipher The cipher to create a helper for. + * + * @return {Object} An object with encrypt and decrypt shortcut functions. + * + * @static + * + * @example + * + * var AES = CryptoJS.lib.Cipher._createHelper(CryptoJS.algo.AES); + */ + _createHelper: (function () { + function selectCipherStrategy(key) { + if (typeof key == 'string') { + return PasswordBasedCipher; + } else { + return SerializableCipher; + } + } + + return function (cipher) { + return { + encrypt: function (message, key, cfg) { + return selectCipherStrategy(key).encrypt(cipher, message, key, cfg); + }, + + decrypt: function (ciphertext, key, cfg) { + return selectCipherStrategy(key).decrypt(cipher, ciphertext, key, cfg); + } + }; + }; + }()) + }); + + /** + * Abstract base stream cipher template. + * + * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 1 (32 bits) + */ + var StreamCipher = C_lib.StreamCipher = Cipher.extend({ + _doFinalize: function () { + // Process partial blocks + var finalProcessedBlocks = this._process(!!'flush'); + + return finalProcessedBlocks; + }, + + blockSize: 1 + }); + + /** + * Mode namespace. + */ + var C_mode = C.mode = {}; + + /** + * Abstract base block cipher mode template. + */ + var BlockCipherMode = C_lib.BlockCipherMode = Base.extend({ + /** + * Creates this mode for encryption. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @static + * + * @example + * + * var mode = CryptoJS.mode.CBC.createEncryptor(cipher, iv.words); + */ + createEncryptor: function (cipher, iv) { + return this.Encryptor.create(cipher, iv); + }, + + /** + * Creates this mode for decryption. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @static + * + * @example + * + * var mode = CryptoJS.mode.CBC.createDecryptor(cipher, iv.words); + */ + createDecryptor: function (cipher, iv) { + return this.Decryptor.create(cipher, iv); + }, + + /** + * Initializes a newly created mode. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @example + * + * var mode = CryptoJS.mode.CBC.Encryptor.create(cipher, iv.words); + */ + init: function (cipher, iv) { + this._cipher = cipher; + this._iv = iv; + } + }); + + /** + * Cipher Block Chaining mode. + */ + var CBC = C_mode.CBC = (function () { + /** + * Abstract base CBC mode. + */ + var CBC = BlockCipherMode.extend(); + + /** + * CBC encryptor. + */ + CBC.Encryptor = CBC.extend({ + /** + * Processes the data block at offset. + * + * @param {Array} words The data words to operate on. + * @param {number} offset The offset where the block starts. + * + * @example + * + * mode.processBlock(data.words, offset); + */ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher; + var blockSize = cipher.blockSize; + + // XOR and encrypt + xorBlock.call(this, words, offset, blockSize); + cipher.encryptBlock(words, offset); + + // Remember this block to use with next block + this._prevBlock = words.slice(offset, offset + blockSize); + } + }); + + /** + * CBC decryptor. + */ + CBC.Decryptor = CBC.extend({ + /** + * Processes the data block at offset. + * + * @param {Array} words The data words to operate on. + * @param {number} offset The offset where the block starts. + * + * @example + * + * mode.processBlock(data.words, offset); + */ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher; + var blockSize = cipher.blockSize; + + // Remember this block to use with next block + var thisBlock = words.slice(offset, offset + blockSize); + + // Decrypt and XOR + cipher.decryptBlock(words, offset); + xorBlock.call(this, words, offset, blockSize); + + // This block becomes the previous block + this._prevBlock = thisBlock; + } + }); + + function xorBlock(words, offset, blockSize) { + // Shortcut + var iv = this._iv; + + // Choose mixing block + if (iv) { + var block = iv; + + // Remove IV for subsequent blocks + this._iv = undefined; + } else { + var block = this._prevBlock; + } + + // XOR blocks + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= block[i]; + } + } + + return CBC; + }()); + + /** + * Padding namespace. + */ + var C_pad = C.pad = {}; + + /** + * PKCS #5/7 padding strategy. + */ + var Pkcs7 = C_pad.Pkcs7 = { + /** + * Pads data using the algorithm defined in PKCS #5/7. + * + * @param {WordArray} data The data to pad. + * @param {number} blockSize The multiple that the data should be padded to. + * + * @static + * + * @example + * + * CryptoJS.pad.Pkcs7.pad(wordArray, 4); + */ + pad: function (data, blockSize) { + // Shortcut + var blockSizeBytes = blockSize * 4; + + // Count padding bytes + var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; + + // Create padding word + var paddingWord = (nPaddingBytes << 24) | (nPaddingBytes << 16) | (nPaddingBytes << 8) | nPaddingBytes; + + // Create padding + var paddingWords = []; + for (var i = 0; i < nPaddingBytes; i += 4) { + paddingWords.push(paddingWord); + } + var padding = WordArray.create(paddingWords, nPaddingBytes); + + // Add padding + data.concat(padding); + }, + + /** + * Unpads data that had been padded using the algorithm defined in PKCS #5/7. + * + * @param {WordArray} data The data to unpad. + * + * @static + * + * @example + * + * CryptoJS.pad.Pkcs7.unpad(wordArray); + */ + unpad: function (data) { + // Get number of padding bytes from last byte + var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; + + // Remove padding + data.sigBytes -= nPaddingBytes; + } + }; + + /** + * Abstract base block cipher template. + * + * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 4 (128 bits) + */ + var BlockCipher = C_lib.BlockCipher = Cipher.extend({ + /** + * Configuration options. + * + * @property {Mode} mode The block mode to use. Default: CBC + * @property {Padding} padding The padding strategy to use. Default: Pkcs7 + */ + cfg: Cipher.cfg.extend({ + mode: CBC, + padding: Pkcs7 + }), + + reset: function () { + // Reset cipher + Cipher.reset.call(this); + + // Shortcuts + var cfg = this.cfg; + var iv = cfg.iv; + var mode = cfg.mode; + + // Reset block mode + if (this._xformMode == this._ENC_XFORM_MODE) { + var modeCreator = mode.createEncryptor; + } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ { + var modeCreator = mode.createDecryptor; + // Keep at least one block in the buffer for unpadding + this._minBufferSize = 1; + } + + if (this._mode && this._mode.__creator == modeCreator) { + this._mode.init(this, iv && iv.words); + } else { + this._mode = modeCreator.call(mode, this, iv && iv.words); + this._mode.__creator = modeCreator; + } + }, + + _doProcessBlock: function (words, offset) { + this._mode.processBlock(words, offset); + }, + + _doFinalize: function () { + // Shortcut + var padding = this.cfg.padding; + + // Finalize + if (this._xformMode == this._ENC_XFORM_MODE) { + // Pad data + padding.pad(this._data, this.blockSize); + + // Process final blocks + var finalProcessedBlocks = this._process(!!'flush'); + } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ { + // Process final blocks + var finalProcessedBlocks = this._process(!!'flush'); + + // Unpad data + padding.unpad(finalProcessedBlocks); + } + + return finalProcessedBlocks; + }, + + blockSize: 128/32 + }); + + /** + * A collection of cipher parameters. + * + * @property {WordArray} ciphertext The raw ciphertext. + * @property {WordArray} key The key to this ciphertext. + * @property {WordArray} iv The IV used in the ciphering operation. + * @property {WordArray} salt The salt used with a key derivation function. + * @property {Cipher} algorithm The cipher algorithm. + * @property {Mode} mode The block mode used in the ciphering operation. + * @property {Padding} padding The padding scheme used in the ciphering operation. + * @property {number} blockSize The block size of the cipher. + * @property {Format} formatter The default formatting strategy to convert this cipher params object to a string. + */ + var CipherParams = C_lib.CipherParams = Base.extend({ + /** + * Initializes a newly created cipher params object. + * + * @param {Object} cipherParams An object with any of the possible cipher parameters. + * + * @example + * + * var cipherParams = CryptoJS.lib.CipherParams.create({ + * ciphertext: ciphertextWordArray, + * key: keyWordArray, + * iv: ivWordArray, + * salt: saltWordArray, + * algorithm: CryptoJS.algo.AES, + * mode: CryptoJS.mode.CBC, + * padding: CryptoJS.pad.PKCS7, + * blockSize: 4, + * formatter: CryptoJS.format.OpenSSL + * }); + */ + init: function (cipherParams) { + this.mixIn(cipherParams); + }, + + /** + * Converts this cipher params object to a string. + * + * @param {Format} formatter (Optional) The formatting strategy to use. + * + * @return {string} The stringified cipher params. + * + * @throws Error If neither the formatter nor the default formatter is set. + * + * @example + * + * var string = cipherParams + ''; + * var string = cipherParams.toString(); + * var string = cipherParams.toString(CryptoJS.format.OpenSSL); + */ + toString: function (formatter) { + return (formatter || this.formatter).stringify(this); + } + }); + + /** + * Format namespace. + */ + var C_format = C.format = {}; + + /** + * OpenSSL formatting strategy. + */ + var OpenSSLFormatter = C_format.OpenSSL = { + /** + * Converts a cipher params object to an OpenSSL-compatible string. + * + * @param {CipherParams} cipherParams The cipher params object. + * + * @return {string} The OpenSSL-compatible string. + * + * @static + * + * @example + * + * var openSSLString = CryptoJS.format.OpenSSL.stringify(cipherParams); + */ + stringify: function (cipherParams) { + // Shortcuts + var ciphertext = cipherParams.ciphertext; + var salt = cipherParams.salt; + + // Format + if (salt) { + var wordArray = WordArray.create([0x53616c74, 0x65645f5f]).concat(salt).concat(ciphertext); + } else { + var wordArray = ciphertext; + } + + return wordArray.toString(Base64); + }, + + /** + * Converts an OpenSSL-compatible string to a cipher params object. + * + * @param {string} openSSLStr The OpenSSL-compatible string. + * + * @return {CipherParams} The cipher params object. + * + * @static + * + * @example + * + * var cipherParams = CryptoJS.format.OpenSSL.parse(openSSLString); + */ + parse: function (openSSLStr) { + // Parse base64 + var ciphertext = Base64.parse(openSSLStr); + + // Shortcut + var ciphertextWords = ciphertext.words; + + // Test for salt + if (ciphertextWords[0] == 0x53616c74 && ciphertextWords[1] == 0x65645f5f) { + // Extract salt + var salt = WordArray.create(ciphertextWords.slice(2, 4)); + + // Remove salt from ciphertext + ciphertextWords.splice(0, 4); + ciphertext.sigBytes -= 16; + } + + return CipherParams.create({ ciphertext: ciphertext, salt: salt }); + } + }; + + /** + * A cipher wrapper that returns ciphertext as a serializable cipher params object. + */ + var SerializableCipher = C_lib.SerializableCipher = Base.extend({ + /** + * Configuration options. + * + * @property {Formatter} format The formatting strategy to convert cipher param objects to and from a string. Default: OpenSSL + */ + cfg: Base.extend({ + format: OpenSSLFormatter + }), + + /** + * Encrypts a message. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {WordArray|string} message The message to encrypt. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {CipherParams} A cipher params object. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key); + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv }); + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + */ + encrypt: function (cipher, message, key, cfg) { + // Apply config defaults + cfg = this.cfg.extend(cfg); + + // Encrypt + var encryptor = cipher.createEncryptor(key, cfg); + var ciphertext = encryptor.finalize(message); + + // Shortcut + var cipherCfg = encryptor.cfg; + + // Create and return serializable cipher params + return CipherParams.create({ + ciphertext: ciphertext, + key: key, + iv: cipherCfg.iv, + algorithm: cipher, + mode: cipherCfg.mode, + padding: cipherCfg.padding, + blockSize: cipher.blockSize, + formatter: cfg.format + }); + }, + + /** + * Decrypts serialized ciphertext. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {CipherParams|string} ciphertext The ciphertext to decrypt. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {WordArray} The plaintext. + * + * @static + * + * @example + * + * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + */ + decrypt: function (cipher, ciphertext, key, cfg) { + // Apply config defaults + cfg = this.cfg.extend(cfg); + + // Convert string to CipherParams + ciphertext = this._parse(ciphertext, cfg.format); + + // Decrypt + var plaintext = cipher.createDecryptor(key, cfg).finalize(ciphertext.ciphertext); + + return plaintext; + }, + + /** + * Converts serialized ciphertext to CipherParams, + * else assumed CipherParams already and returns ciphertext unchanged. + * + * @param {CipherParams|string} ciphertext The ciphertext. + * @param {Formatter} format The formatting strategy to use to parse serialized ciphertext. + * + * @return {CipherParams} The unserialized ciphertext. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.SerializableCipher._parse(ciphertextStringOrParams, format); + */ + _parse: function (ciphertext, format) { + if (typeof ciphertext == 'string') { + return format.parse(ciphertext, this); + } else { + return ciphertext; + } + } + }); + + /** + * Key derivation function namespace. + */ + var C_kdf = C.kdf = {}; + + /** + * OpenSSL key derivation function. + */ + var OpenSSLKdf = C_kdf.OpenSSL = { + /** + * Derives a key and IV from a password. + * + * @param {string} password The password to derive from. + * @param {number} keySize The size in words of the key to generate. + * @param {number} ivSize The size in words of the IV to generate. + * @param {WordArray|string} salt (Optional) A 64-bit salt to use. If omitted, a salt will be generated randomly. + * + * @return {CipherParams} A cipher params object with the key, IV, and salt. + * + * @static + * + * @example + * + * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32); + * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32, 'saltsalt'); + */ + execute: function (password, keySize, ivSize, salt) { + // Generate random salt + if (!salt) { + salt = WordArray.random(64/8); + } + + // Derive key and IV + var key = EvpKDF.create({ keySize: keySize + ivSize }).compute(password, salt); + + // Separate key and IV + var iv = WordArray.create(key.words.slice(keySize), ivSize * 4); + key.sigBytes = keySize * 4; + + // Return params + return CipherParams.create({ key: key, iv: iv, salt: salt }); + } + }; + + /** + * A serializable cipher wrapper that derives the key from a password, + * and returns ciphertext as a serializable cipher params object. + */ + var PasswordBasedCipher = C_lib.PasswordBasedCipher = SerializableCipher.extend({ + /** + * Configuration options. + * + * @property {KDF} kdf The key derivation function to use to generate a key and IV from a password. Default: OpenSSL + */ + cfg: SerializableCipher.cfg.extend({ + kdf: OpenSSLKdf + }), + + /** + * Encrypts a message using a password. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {WordArray|string} message The message to encrypt. + * @param {string} password The password. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {CipherParams} A cipher params object. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password'); + * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password', { format: CryptoJS.format.OpenSSL }); + */ + encrypt: function (cipher, message, password, cfg) { + // Apply config defaults + cfg = this.cfg.extend(cfg); + + // Derive key and other params + var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize); + + // Add IV to config + cfg.iv = derivedParams.iv; + + // Encrypt + var ciphertext = SerializableCipher.encrypt.call(this, cipher, message, derivedParams.key, cfg); + + // Mix in derived params + ciphertext.mixIn(derivedParams); + + return ciphertext; + }, + + /** + * Decrypts serialized ciphertext using a password. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {CipherParams|string} ciphertext The ciphertext to decrypt. + * @param {string} password The password. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {WordArray} The plaintext. + * + * @static + * + * @example + * + * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, 'password', { format: CryptoJS.format.OpenSSL }); + * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, 'password', { format: CryptoJS.format.OpenSSL }); + */ + decrypt: function (cipher, ciphertext, password, cfg) { + // Apply config defaults + cfg = this.cfg.extend(cfg); + + // Convert string to CipherParams + ciphertext = this._parse(ciphertext, cfg.format); + + // Derive key and other params + var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, ciphertext.salt); + + // Add IV to config + cfg.iv = derivedParams.iv; + + // Decrypt + var plaintext = SerializableCipher.decrypt.call(this, cipher, ciphertext, derivedParams.key, cfg); + + return plaintext; + } + }); + }()); + + + /** + * Cipher Feedback block mode. + */ + CryptoJS.mode.CFB = (function () { + var CFB = CryptoJS.lib.BlockCipherMode.extend(); + + CFB.Encryptor = CFB.extend({ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher; + var blockSize = cipher.blockSize; + + generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); + + // Remember this block to use with next block + this._prevBlock = words.slice(offset, offset + blockSize); + } + }); + + CFB.Decryptor = CFB.extend({ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher; + var blockSize = cipher.blockSize; + + // Remember this block to use with next block + var thisBlock = words.slice(offset, offset + blockSize); + + generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); + + // This block becomes the previous block + this._prevBlock = thisBlock; + } + }); + + function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) { + // Shortcut + var iv = this._iv; + + // Generate keystream + if (iv) { + var keystream = iv.slice(0); + + // Remove IV for subsequent blocks + this._iv = undefined; + } else { + var keystream = this._prevBlock; + } + cipher.encryptBlock(keystream, 0); + + // Encrypt + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + + return CFB; + }()); + + + /** + * Electronic Codebook block mode. + */ + CryptoJS.mode.ECB = (function () { + var ECB = CryptoJS.lib.BlockCipherMode.extend(); + + ECB.Encryptor = ECB.extend({ + processBlock: function (words, offset) { + this._cipher.encryptBlock(words, offset); + } + }); + + ECB.Decryptor = ECB.extend({ + processBlock: function (words, offset) { + this._cipher.decryptBlock(words, offset); + } + }); + + return ECB; + }()); + + + /** + * ANSI X.923 padding strategy. + */ + CryptoJS.pad.AnsiX923 = { + pad: function (data, blockSize) { + // Shortcuts + var dataSigBytes = data.sigBytes; + var blockSizeBytes = blockSize * 4; + + // Count padding bytes + var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes; + + // Compute last byte position + var lastBytePos = dataSigBytes + nPaddingBytes - 1; + + // Pad + data.clamp(); + data.words[lastBytePos >>> 2] |= nPaddingBytes << (24 - (lastBytePos % 4) * 8); + data.sigBytes += nPaddingBytes; + }, + + unpad: function (data) { + // Get number of padding bytes from last byte + var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; + + // Remove padding + data.sigBytes -= nPaddingBytes; + } + }; + + + /** + * ISO 10126 padding strategy. + */ + CryptoJS.pad.Iso10126 = { + pad: function (data, blockSize) { + // Shortcut + var blockSizeBytes = blockSize * 4; + + // Count padding bytes + var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; + + // Pad + data.concat(CryptoJS.lib.WordArray.random(nPaddingBytes - 1)). + concat(CryptoJS.lib.WordArray.create([nPaddingBytes << 24], 1)); + }, + + unpad: function (data) { + // Get number of padding bytes from last byte + var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; + + // Remove padding + data.sigBytes -= nPaddingBytes; + } + }; + + + /** + * ISO/IEC 9797-1 Padding Method 2. + */ + CryptoJS.pad.Iso97971 = { + pad: function (data, blockSize) { + // Add 0x80 byte + data.concat(CryptoJS.lib.WordArray.create([0x80000000], 1)); + + // Zero pad the rest + CryptoJS.pad.ZeroPadding.pad(data, blockSize); + }, + + unpad: function (data) { + // Remove zero padding + CryptoJS.pad.ZeroPadding.unpad(data); + + // Remove one more byte -- the 0x80 byte + data.sigBytes--; + } + }; + + + /** + * Output Feedback block mode. + */ + CryptoJS.mode.OFB = (function () { + var OFB = CryptoJS.lib.BlockCipherMode.extend(); + + var Encryptor = OFB.Encryptor = OFB.extend({ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher + var blockSize = cipher.blockSize; + var iv = this._iv; + var keystream = this._keystream; + + // Generate keystream + if (iv) { + keystream = this._keystream = iv.slice(0); + + // Remove IV for subsequent blocks + this._iv = undefined; + } + cipher.encryptBlock(keystream, 0); + + // Encrypt + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + + OFB.Decryptor = Encryptor; + + return OFB; + }()); + + + /** + * A noop padding strategy. + */ + CryptoJS.pad.NoPadding = { + pad: function () { + }, + + unpad: function () { + } + }; + + + (function (undefined) { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var CipherParams = C_lib.CipherParams; + var C_enc = C.enc; + var Hex = C_enc.Hex; + var C_format = C.format; + + var HexFormatter = C_format.Hex = { + /** + * Converts the ciphertext of a cipher params object to a hexadecimally encoded string. + * + * @param {CipherParams} cipherParams The cipher params object. + * + * @return {string} The hexadecimally encoded string. + * + * @static + * + * @example + * + * var hexString = CryptoJS.format.Hex.stringify(cipherParams); + */ + stringify: function (cipherParams) { + return cipherParams.ciphertext.toString(Hex); + }, + + /** + * Converts a hexadecimally encoded ciphertext string to a cipher params object. + * + * @param {string} input The hexadecimally encoded string. + * + * @return {CipherParams} The cipher params object. + * + * @static + * + * @example + * + * var cipherParams = CryptoJS.format.Hex.parse(hexString); + */ + parse: function (input) { + var ciphertext = Hex.parse(input); + return CipherParams.create({ ciphertext: ciphertext }); + } + }; + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var BlockCipher = C_lib.BlockCipher; + var C_algo = C.algo; + + // Lookup tables + var SBOX = []; + var INV_SBOX = []; + var SUB_MIX_0 = []; + var SUB_MIX_1 = []; + var SUB_MIX_2 = []; + var SUB_MIX_3 = []; + var INV_SUB_MIX_0 = []; + var INV_SUB_MIX_1 = []; + var INV_SUB_MIX_2 = []; + var INV_SUB_MIX_3 = []; + + // Compute lookup tables + (function () { + // Compute double table + var d = []; + for (var i = 0; i < 256; i++) { + if (i < 128) { + d[i] = i << 1; + } else { + d[i] = (i << 1) ^ 0x11b; + } + } + + // Walk GF(2^8) + var x = 0; + var xi = 0; + for (var i = 0; i < 256; i++) { + // Compute sbox + var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4); + sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63; + SBOX[x] = sx; + INV_SBOX[sx] = x; + + // Compute multiplication + var x2 = d[x]; + var x4 = d[x2]; + var x8 = d[x4]; + + // Compute sub bytes, mix columns tables + var t = (d[sx] * 0x101) ^ (sx * 0x1010100); + SUB_MIX_0[x] = (t << 24) | (t >>> 8); + SUB_MIX_1[x] = (t << 16) | (t >>> 16); + SUB_MIX_2[x] = (t << 8) | (t >>> 24); + SUB_MIX_3[x] = t; + + // Compute inv sub bytes, inv mix columns tables + var t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100); + INV_SUB_MIX_0[sx] = (t << 24) | (t >>> 8); + INV_SUB_MIX_1[sx] = (t << 16) | (t >>> 16); + INV_SUB_MIX_2[sx] = (t << 8) | (t >>> 24); + INV_SUB_MIX_3[sx] = t; + + // Compute next counter + if (!x) { + x = xi = 1; + } else { + x = x2 ^ d[d[d[x8 ^ x2]]]; + xi ^= d[d[xi]]; + } + } + }()); + + // Precomputed Rcon lookup + var RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]; + + /** + * AES block cipher algorithm. + */ + var AES = C_algo.AES = BlockCipher.extend({ + _doReset: function () { + // Skip reset of nRounds has been set before and key did not change + if (this._nRounds && this._keyPriorReset === this._key) { + return; + } + + // Shortcuts + var key = this._keyPriorReset = this._key; + var keyWords = key.words; + var keySize = key.sigBytes / 4; + + // Compute number of rounds + var nRounds = this._nRounds = keySize + 6; + + // Compute number of key schedule rows + var ksRows = (nRounds + 1) * 4; + + // Compute key schedule + var keySchedule = this._keySchedule = []; + for (var ksRow = 0; ksRow < ksRows; ksRow++) { + if (ksRow < keySize) { + keySchedule[ksRow] = keyWords[ksRow]; + } else { + var t = keySchedule[ksRow - 1]; + + if (!(ksRow % keySize)) { + // Rot word + t = (t << 8) | (t >>> 24); + + // Sub word + t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff]; + + // Mix Rcon + t ^= RCON[(ksRow / keySize) | 0] << 24; + } else if (keySize > 6 && ksRow % keySize == 4) { + // Sub word + t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff]; + } + + keySchedule[ksRow] = keySchedule[ksRow - keySize] ^ t; + } + } + + // Compute inv key schedule + var invKeySchedule = this._invKeySchedule = []; + for (var invKsRow = 0; invKsRow < ksRows; invKsRow++) { + var ksRow = ksRows - invKsRow; + + if (invKsRow % 4) { + var t = keySchedule[ksRow]; + } else { + var t = keySchedule[ksRow - 4]; + } + + if (invKsRow < 4 || ksRow <= 4) { + invKeySchedule[invKsRow] = t; + } else { + invKeySchedule[invKsRow] = INV_SUB_MIX_0[SBOX[t >>> 24]] ^ INV_SUB_MIX_1[SBOX[(t >>> 16) & 0xff]] ^ + INV_SUB_MIX_2[SBOX[(t >>> 8) & 0xff]] ^ INV_SUB_MIX_3[SBOX[t & 0xff]]; + } + } + }, + + encryptBlock: function (M, offset) { + this._doCryptBlock(M, offset, this._keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX); + }, + + decryptBlock: function (M, offset) { + // Swap 2nd and 4th rows + var t = M[offset + 1]; + M[offset + 1] = M[offset + 3]; + M[offset + 3] = t; + + this._doCryptBlock(M, offset, this._invKeySchedule, INV_SUB_MIX_0, INV_SUB_MIX_1, INV_SUB_MIX_2, INV_SUB_MIX_3, INV_SBOX); + + // Inv swap 2nd and 4th rows + var t = M[offset + 1]; + M[offset + 1] = M[offset + 3]; + M[offset + 3] = t; + }, + + _doCryptBlock: function (M, offset, keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX) { + // Shortcut + var nRounds = this._nRounds; + + // Get input, add round key + var s0 = M[offset] ^ keySchedule[0]; + var s1 = M[offset + 1] ^ keySchedule[1]; + var s2 = M[offset + 2] ^ keySchedule[2]; + var s3 = M[offset + 3] ^ keySchedule[3]; + + // Key schedule row counter + var ksRow = 4; + + // Rounds + for (var round = 1; round < nRounds; round++) { + // Shift rows, sub bytes, mix columns, add round key + var t0 = SUB_MIX_0[s0 >>> 24] ^ SUB_MIX_1[(s1 >>> 16) & 0xff] ^ SUB_MIX_2[(s2 >>> 8) & 0xff] ^ SUB_MIX_3[s3 & 0xff] ^ keySchedule[ksRow++]; + var t1 = SUB_MIX_0[s1 >>> 24] ^ SUB_MIX_1[(s2 >>> 16) & 0xff] ^ SUB_MIX_2[(s3 >>> 8) & 0xff] ^ SUB_MIX_3[s0 & 0xff] ^ keySchedule[ksRow++]; + var t2 = SUB_MIX_0[s2 >>> 24] ^ SUB_MIX_1[(s3 >>> 16) & 0xff] ^ SUB_MIX_2[(s0 >>> 8) & 0xff] ^ SUB_MIX_3[s1 & 0xff] ^ keySchedule[ksRow++]; + var t3 = SUB_MIX_0[s3 >>> 24] ^ SUB_MIX_1[(s0 >>> 16) & 0xff] ^ SUB_MIX_2[(s1 >>> 8) & 0xff] ^ SUB_MIX_3[s2 & 0xff] ^ keySchedule[ksRow++]; + + // Update state + s0 = t0; + s1 = t1; + s2 = t2; + s3 = t3; + } + + // Shift rows, sub bytes, add round key + var t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]; + var t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]; + var t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]; + var t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]; + + // Set output + M[offset] = t0; + M[offset + 1] = t1; + M[offset + 2] = t2; + M[offset + 3] = t3; + }, + + keySize: 256/32 + }); + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.AES.encrypt(message, key, cfg); + * var plaintext = CryptoJS.AES.decrypt(ciphertext, key, cfg); + */ + C.AES = BlockCipher._createHelper(AES); + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var WordArray = C_lib.WordArray; + var BlockCipher = C_lib.BlockCipher; + var C_algo = C.algo; + + // Permuted Choice 1 constants + var PC1 = [ + 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 + ]; + + // Permuted Choice 2 constants + var PC2 = [ + 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 + ]; + + // Cumulative bit shift constants + var BIT_SHIFTS = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28]; + + // SBOXes and round permutation constants + var SBOX_P = [ + { + 0x0: 0x808200, + 0x10000000: 0x8000, + 0x20000000: 0x808002, + 0x30000000: 0x2, + 0x40000000: 0x200, + 0x50000000: 0x808202, + 0x60000000: 0x800202, + 0x70000000: 0x800000, + 0x80000000: 0x202, + 0x90000000: 0x800200, + 0xa0000000: 0x8200, + 0xb0000000: 0x808000, + 0xc0000000: 0x8002, + 0xd0000000: 0x800002, + 0xe0000000: 0x0, + 0xf0000000: 0x8202, + 0x8000000: 0x0, + 0x18000000: 0x808202, + 0x28000000: 0x8202, + 0x38000000: 0x8000, + 0x48000000: 0x808200, + 0x58000000: 0x200, + 0x68000000: 0x808002, + 0x78000000: 0x2, + 0x88000000: 0x800200, + 0x98000000: 0x8200, + 0xa8000000: 0x808000, + 0xb8000000: 0x800202, + 0xc8000000: 0x800002, + 0xd8000000: 0x8002, + 0xe8000000: 0x202, + 0xf8000000: 0x800000, + 0x1: 0x8000, + 0x10000001: 0x2, + 0x20000001: 0x808200, + 0x30000001: 0x800000, + 0x40000001: 0x808002, + 0x50000001: 0x8200, + 0x60000001: 0x200, + 0x70000001: 0x800202, + 0x80000001: 0x808202, + 0x90000001: 0x808000, + 0xa0000001: 0x800002, + 0xb0000001: 0x8202, + 0xc0000001: 0x202, + 0xd0000001: 0x800200, + 0xe0000001: 0x8002, + 0xf0000001: 0x0, + 0x8000001: 0x808202, + 0x18000001: 0x808000, + 0x28000001: 0x800000, + 0x38000001: 0x200, + 0x48000001: 0x8000, + 0x58000001: 0x800002, + 0x68000001: 0x2, + 0x78000001: 0x8202, + 0x88000001: 0x8002, + 0x98000001: 0x800202, + 0xa8000001: 0x202, + 0xb8000001: 0x808200, + 0xc8000001: 0x800200, + 0xd8000001: 0x0, + 0xe8000001: 0x8200, + 0xf8000001: 0x808002 + }, + { + 0x0: 0x40084010, + 0x1000000: 0x4000, + 0x2000000: 0x80000, + 0x3000000: 0x40080010, + 0x4000000: 0x40000010, + 0x5000000: 0x40084000, + 0x6000000: 0x40004000, + 0x7000000: 0x10, + 0x8000000: 0x84000, + 0x9000000: 0x40004010, + 0xa000000: 0x40000000, + 0xb000000: 0x84010, + 0xc000000: 0x80010, + 0xd000000: 0x0, + 0xe000000: 0x4010, + 0xf000000: 0x40080000, + 0x800000: 0x40004000, + 0x1800000: 0x84010, + 0x2800000: 0x10, + 0x3800000: 0x40004010, + 0x4800000: 0x40084010, + 0x5800000: 0x40000000, + 0x6800000: 0x80000, + 0x7800000: 0x40080010, + 0x8800000: 0x80010, + 0x9800000: 0x0, + 0xa800000: 0x4000, + 0xb800000: 0x40080000, + 0xc800000: 0x40000010, + 0xd800000: 0x84000, + 0xe800000: 0x40084000, + 0xf800000: 0x4010, + 0x10000000: 0x0, + 0x11000000: 0x40080010, + 0x12000000: 0x40004010, + 0x13000000: 0x40084000, + 0x14000000: 0x40080000, + 0x15000000: 0x10, + 0x16000000: 0x84010, + 0x17000000: 0x4000, + 0x18000000: 0x4010, + 0x19000000: 0x80000, + 0x1a000000: 0x80010, + 0x1b000000: 0x40000010, + 0x1c000000: 0x84000, + 0x1d000000: 0x40004000, + 0x1e000000: 0x40000000, + 0x1f000000: 0x40084010, + 0x10800000: 0x84010, + 0x11800000: 0x80000, + 0x12800000: 0x40080000, + 0x13800000: 0x4000, + 0x14800000: 0x40004000, + 0x15800000: 0x40084010, + 0x16800000: 0x10, + 0x17800000: 0x40000000, + 0x18800000: 0x40084000, + 0x19800000: 0x40000010, + 0x1a800000: 0x40004010, + 0x1b800000: 0x80010, + 0x1c800000: 0x0, + 0x1d800000: 0x4010, + 0x1e800000: 0x40080010, + 0x1f800000: 0x84000 + }, + { + 0x0: 0x104, + 0x100000: 0x0, + 0x200000: 0x4000100, + 0x300000: 0x10104, + 0x400000: 0x10004, + 0x500000: 0x4000004, + 0x600000: 0x4010104, + 0x700000: 0x4010000, + 0x800000: 0x4000000, + 0x900000: 0x4010100, + 0xa00000: 0x10100, + 0xb00000: 0x4010004, + 0xc00000: 0x4000104, + 0xd00000: 0x10000, + 0xe00000: 0x4, + 0xf00000: 0x100, + 0x80000: 0x4010100, + 0x180000: 0x4010004, + 0x280000: 0x0, + 0x380000: 0x4000100, + 0x480000: 0x4000004, + 0x580000: 0x10000, + 0x680000: 0x10004, + 0x780000: 0x104, + 0x880000: 0x4, + 0x980000: 0x100, + 0xa80000: 0x4010000, + 0xb80000: 0x10104, + 0xc80000: 0x10100, + 0xd80000: 0x4000104, + 0xe80000: 0x4010104, + 0xf80000: 0x4000000, + 0x1000000: 0x4010100, + 0x1100000: 0x10004, + 0x1200000: 0x10000, + 0x1300000: 0x4000100, + 0x1400000: 0x100, + 0x1500000: 0x4010104, + 0x1600000: 0x4000004, + 0x1700000: 0x0, + 0x1800000: 0x4000104, + 0x1900000: 0x4000000, + 0x1a00000: 0x4, + 0x1b00000: 0x10100, + 0x1c00000: 0x4010000, + 0x1d00000: 0x104, + 0x1e00000: 0x10104, + 0x1f00000: 0x4010004, + 0x1080000: 0x4000000, + 0x1180000: 0x104, + 0x1280000: 0x4010100, + 0x1380000: 0x0, + 0x1480000: 0x10004, + 0x1580000: 0x4000100, + 0x1680000: 0x100, + 0x1780000: 0x4010004, + 0x1880000: 0x10000, + 0x1980000: 0x4010104, + 0x1a80000: 0x10104, + 0x1b80000: 0x4000004, + 0x1c80000: 0x4000104, + 0x1d80000: 0x4010000, + 0x1e80000: 0x4, + 0x1f80000: 0x10100 + }, + { + 0x0: 0x80401000, + 0x10000: 0x80001040, + 0x20000: 0x401040, + 0x30000: 0x80400000, + 0x40000: 0x0, + 0x50000: 0x401000, + 0x60000: 0x80000040, + 0x70000: 0x400040, + 0x80000: 0x80000000, + 0x90000: 0x400000, + 0xa0000: 0x40, + 0xb0000: 0x80001000, + 0xc0000: 0x80400040, + 0xd0000: 0x1040, + 0xe0000: 0x1000, + 0xf0000: 0x80401040, + 0x8000: 0x80001040, + 0x18000: 0x40, + 0x28000: 0x80400040, + 0x38000: 0x80001000, + 0x48000: 0x401000, + 0x58000: 0x80401040, + 0x68000: 0x0, + 0x78000: 0x80400000, + 0x88000: 0x1000, + 0x98000: 0x80401000, + 0xa8000: 0x400000, + 0xb8000: 0x1040, + 0xc8000: 0x80000000, + 0xd8000: 0x400040, + 0xe8000: 0x401040, + 0xf8000: 0x80000040, + 0x100000: 0x400040, + 0x110000: 0x401000, + 0x120000: 0x80000040, + 0x130000: 0x0, + 0x140000: 0x1040, + 0x150000: 0x80400040, + 0x160000: 0x80401000, + 0x170000: 0x80001040, + 0x180000: 0x80401040, + 0x190000: 0x80000000, + 0x1a0000: 0x80400000, + 0x1b0000: 0x401040, + 0x1c0000: 0x80001000, + 0x1d0000: 0x400000, + 0x1e0000: 0x40, + 0x1f0000: 0x1000, + 0x108000: 0x80400000, + 0x118000: 0x80401040, + 0x128000: 0x0, + 0x138000: 0x401000, + 0x148000: 0x400040, + 0x158000: 0x80000000, + 0x168000: 0x80001040, + 0x178000: 0x40, + 0x188000: 0x80000040, + 0x198000: 0x1000, + 0x1a8000: 0x80001000, + 0x1b8000: 0x80400040, + 0x1c8000: 0x1040, + 0x1d8000: 0x80401000, + 0x1e8000: 0x400000, + 0x1f8000: 0x401040 + }, + { + 0x0: 0x80, + 0x1000: 0x1040000, + 0x2000: 0x40000, + 0x3000: 0x20000000, + 0x4000: 0x20040080, + 0x5000: 0x1000080, + 0x6000: 0x21000080, + 0x7000: 0x40080, + 0x8000: 0x1000000, + 0x9000: 0x20040000, + 0xa000: 0x20000080, + 0xb000: 0x21040080, + 0xc000: 0x21040000, + 0xd000: 0x0, + 0xe000: 0x1040080, + 0xf000: 0x21000000, + 0x800: 0x1040080, + 0x1800: 0x21000080, + 0x2800: 0x80, + 0x3800: 0x1040000, + 0x4800: 0x40000, + 0x5800: 0x20040080, + 0x6800: 0x21040000, + 0x7800: 0x20000000, + 0x8800: 0x20040000, + 0x9800: 0x0, + 0xa800: 0x21040080, + 0xb800: 0x1000080, + 0xc800: 0x20000080, + 0xd800: 0x21000000, + 0xe800: 0x1000000, + 0xf800: 0x40080, + 0x10000: 0x40000, + 0x11000: 0x80, + 0x12000: 0x20000000, + 0x13000: 0x21000080, + 0x14000: 0x1000080, + 0x15000: 0x21040000, + 0x16000: 0x20040080, + 0x17000: 0x1000000, + 0x18000: 0x21040080, + 0x19000: 0x21000000, + 0x1a000: 0x1040000, + 0x1b000: 0x20040000, + 0x1c000: 0x40080, + 0x1d000: 0x20000080, + 0x1e000: 0x0, + 0x1f000: 0x1040080, + 0x10800: 0x21000080, + 0x11800: 0x1000000, + 0x12800: 0x1040000, + 0x13800: 0x20040080, + 0x14800: 0x20000000, + 0x15800: 0x1040080, + 0x16800: 0x80, + 0x17800: 0x21040000, + 0x18800: 0x40080, + 0x19800: 0x21040080, + 0x1a800: 0x0, + 0x1b800: 0x21000000, + 0x1c800: 0x1000080, + 0x1d800: 0x40000, + 0x1e800: 0x20040000, + 0x1f800: 0x20000080 + }, + { + 0x0: 0x10000008, + 0x100: 0x2000, + 0x200: 0x10200000, + 0x300: 0x10202008, + 0x400: 0x10002000, + 0x500: 0x200000, + 0x600: 0x200008, + 0x700: 0x10000000, + 0x800: 0x0, + 0x900: 0x10002008, + 0xa00: 0x202000, + 0xb00: 0x8, + 0xc00: 0x10200008, + 0xd00: 0x202008, + 0xe00: 0x2008, + 0xf00: 0x10202000, + 0x80: 0x10200000, + 0x180: 0x10202008, + 0x280: 0x8, + 0x380: 0x200000, + 0x480: 0x202008, + 0x580: 0x10000008, + 0x680: 0x10002000, + 0x780: 0x2008, + 0x880: 0x200008, + 0x980: 0x2000, + 0xa80: 0x10002008, + 0xb80: 0x10200008, + 0xc80: 0x0, + 0xd80: 0x10202000, + 0xe80: 0x202000, + 0xf80: 0x10000000, + 0x1000: 0x10002000, + 0x1100: 0x10200008, + 0x1200: 0x10202008, + 0x1300: 0x2008, + 0x1400: 0x200000, + 0x1500: 0x10000000, + 0x1600: 0x10000008, + 0x1700: 0x202000, + 0x1800: 0x202008, + 0x1900: 0x0, + 0x1a00: 0x8, + 0x1b00: 0x10200000, + 0x1c00: 0x2000, + 0x1d00: 0x10002008, + 0x1e00: 0x10202000, + 0x1f00: 0x200008, + 0x1080: 0x8, + 0x1180: 0x202000, + 0x1280: 0x200000, + 0x1380: 0x10000008, + 0x1480: 0x10002000, + 0x1580: 0x2008, + 0x1680: 0x10202008, + 0x1780: 0x10200000, + 0x1880: 0x10202000, + 0x1980: 0x10200008, + 0x1a80: 0x2000, + 0x1b80: 0x202008, + 0x1c80: 0x200008, + 0x1d80: 0x0, + 0x1e80: 0x10000000, + 0x1f80: 0x10002008 + }, + { + 0x0: 0x100000, + 0x10: 0x2000401, + 0x20: 0x400, + 0x30: 0x100401, + 0x40: 0x2100401, + 0x50: 0x0, + 0x60: 0x1, + 0x70: 0x2100001, + 0x80: 0x2000400, + 0x90: 0x100001, + 0xa0: 0x2000001, + 0xb0: 0x2100400, + 0xc0: 0x2100000, + 0xd0: 0x401, + 0xe0: 0x100400, + 0xf0: 0x2000000, + 0x8: 0x2100001, + 0x18: 0x0, + 0x28: 0x2000401, + 0x38: 0x2100400, + 0x48: 0x100000, + 0x58: 0x2000001, + 0x68: 0x2000000, + 0x78: 0x401, + 0x88: 0x100401, + 0x98: 0x2000400, + 0xa8: 0x2100000, + 0xb8: 0x100001, + 0xc8: 0x400, + 0xd8: 0x2100401, + 0xe8: 0x1, + 0xf8: 0x100400, + 0x100: 0x2000000, + 0x110: 0x100000, + 0x120: 0x2000401, + 0x130: 0x2100001, + 0x140: 0x100001, + 0x150: 0x2000400, + 0x160: 0x2100400, + 0x170: 0x100401, + 0x180: 0x401, + 0x190: 0x2100401, + 0x1a0: 0x100400, + 0x1b0: 0x1, + 0x1c0: 0x0, + 0x1d0: 0x2100000, + 0x1e0: 0x2000001, + 0x1f0: 0x400, + 0x108: 0x100400, + 0x118: 0x2000401, + 0x128: 0x2100001, + 0x138: 0x1, + 0x148: 0x2000000, + 0x158: 0x100000, + 0x168: 0x401, + 0x178: 0x2100400, + 0x188: 0x2000001, + 0x198: 0x2100000, + 0x1a8: 0x0, + 0x1b8: 0x2100401, + 0x1c8: 0x100401, + 0x1d8: 0x400, + 0x1e8: 0x2000400, + 0x1f8: 0x100001 + }, + { + 0x0: 0x8000820, + 0x1: 0x20000, + 0x2: 0x8000000, + 0x3: 0x20, + 0x4: 0x20020, + 0x5: 0x8020820, + 0x6: 0x8020800, + 0x7: 0x800, + 0x8: 0x8020000, + 0x9: 0x8000800, + 0xa: 0x20800, + 0xb: 0x8020020, + 0xc: 0x820, + 0xd: 0x0, + 0xe: 0x8000020, + 0xf: 0x20820, + 0x80000000: 0x800, + 0x80000001: 0x8020820, + 0x80000002: 0x8000820, + 0x80000003: 0x8000000, + 0x80000004: 0x8020000, + 0x80000005: 0x20800, + 0x80000006: 0x20820, + 0x80000007: 0x20, + 0x80000008: 0x8000020, + 0x80000009: 0x820, + 0x8000000a: 0x20020, + 0x8000000b: 0x8020800, + 0x8000000c: 0x0, + 0x8000000d: 0x8020020, + 0x8000000e: 0x8000800, + 0x8000000f: 0x20000, + 0x10: 0x20820, + 0x11: 0x8020800, + 0x12: 0x20, + 0x13: 0x800, + 0x14: 0x8000800, + 0x15: 0x8000020, + 0x16: 0x8020020, + 0x17: 0x20000, + 0x18: 0x0, + 0x19: 0x20020, + 0x1a: 0x8020000, + 0x1b: 0x8000820, + 0x1c: 0x8020820, + 0x1d: 0x20800, + 0x1e: 0x820, + 0x1f: 0x8000000, + 0x80000010: 0x20000, + 0x80000011: 0x800, + 0x80000012: 0x8020020, + 0x80000013: 0x20820, + 0x80000014: 0x20, + 0x80000015: 0x8020000, + 0x80000016: 0x8000000, + 0x80000017: 0x8000820, + 0x80000018: 0x8020820, + 0x80000019: 0x8000020, + 0x8000001a: 0x8000800, + 0x8000001b: 0x0, + 0x8000001c: 0x20800, + 0x8000001d: 0x820, + 0x8000001e: 0x20020, + 0x8000001f: 0x8020800 + } + ]; + + // Masks that select the SBOX input + var SBOX_MASK = [ + 0xf8000001, 0x1f800000, 0x01f80000, 0x001f8000, + 0x0001f800, 0x00001f80, 0x000001f8, 0x8000001f + ]; + + /** + * DES block cipher algorithm. + */ + var DES = C_algo.DES = BlockCipher.extend({ + _doReset: function () { + // Shortcuts + var key = this._key; + var keyWords = key.words; + + // Select 56 bits according to PC1 + var keyBits = []; + for (var i = 0; i < 56; i++) { + var keyBitPos = PC1[i] - 1; + keyBits[i] = (keyWords[keyBitPos >>> 5] >>> (31 - keyBitPos % 32)) & 1; + } + + // Assemble 16 subkeys + var subKeys = this._subKeys = []; + for (var nSubKey = 0; nSubKey < 16; nSubKey++) { + // Create subkey + var subKey = subKeys[nSubKey] = []; + + // Shortcut + var bitShift = BIT_SHIFTS[nSubKey]; + + // Select 48 bits according to PC2 + for (var i = 0; i < 24; i++) { + // Select from the left 28 key bits + subKey[(i / 6) | 0] |= keyBits[((PC2[i] - 1) + bitShift) % 28] << (31 - i % 6); + + // Select from the right 28 key bits + subKey[4 + ((i / 6) | 0)] |= keyBits[28 + (((PC2[i + 24] - 1) + bitShift) % 28)] << (31 - i % 6); + } + + // Since each subkey is applied to an expanded 32-bit input, + // the subkey can be broken into 8 values scaled to 32-bits, + // which allows the key to be used without expansion + subKey[0] = (subKey[0] << 1) | (subKey[0] >>> 31); + for (var i = 1; i < 7; i++) { + subKey[i] = subKey[i] >>> ((i - 1) * 4 + 3); + } + subKey[7] = (subKey[7] << 5) | (subKey[7] >>> 27); + } + + // Compute inverse subkeys + var invSubKeys = this._invSubKeys = []; + for (var i = 0; i < 16; i++) { + invSubKeys[i] = subKeys[15 - i]; + } + }, + + encryptBlock: function (M, offset) { + this._doCryptBlock(M, offset, this._subKeys); + }, + + decryptBlock: function (M, offset) { + this._doCryptBlock(M, offset, this._invSubKeys); + }, + + _doCryptBlock: function (M, offset, subKeys) { + // Get input + this._lBlock = M[offset]; + this._rBlock = M[offset + 1]; + + // Initial permutation + exchangeLR.call(this, 4, 0x0f0f0f0f); + exchangeLR.call(this, 16, 0x0000ffff); + exchangeRL.call(this, 2, 0x33333333); + exchangeRL.call(this, 8, 0x00ff00ff); + exchangeLR.call(this, 1, 0x55555555); + + // Rounds + for (var round = 0; round < 16; round++) { + // Shortcuts + var subKey = subKeys[round]; + var lBlock = this._lBlock; + var rBlock = this._rBlock; + + // Feistel function + var f = 0; + for (var i = 0; i < 8; i++) { + f |= SBOX_P[i][((rBlock ^ subKey[i]) & SBOX_MASK[i]) >>> 0]; + } + this._lBlock = rBlock; + this._rBlock = lBlock ^ f; + } + + // Undo swap from last round + var t = this._lBlock; + this._lBlock = this._rBlock; + this._rBlock = t; + + // Final permutation + exchangeLR.call(this, 1, 0x55555555); + exchangeRL.call(this, 8, 0x00ff00ff); + exchangeRL.call(this, 2, 0x33333333); + exchangeLR.call(this, 16, 0x0000ffff); + exchangeLR.call(this, 4, 0x0f0f0f0f); + + // Set output + M[offset] = this._lBlock; + M[offset + 1] = this._rBlock; + }, + + keySize: 64/32, + + ivSize: 64/32, + + blockSize: 64/32 + }); + + // Swap bits across the left and right words + function exchangeLR(offset, mask) { + var t = ((this._lBlock >>> offset) ^ this._rBlock) & mask; + this._rBlock ^= t; + this._lBlock ^= t << offset; + } + + function exchangeRL(offset, mask) { + var t = ((this._rBlock >>> offset) ^ this._lBlock) & mask; + this._lBlock ^= t; + this._rBlock ^= t << offset; + } + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.DES.encrypt(message, key, cfg); + * var plaintext = CryptoJS.DES.decrypt(ciphertext, key, cfg); + */ + C.DES = BlockCipher._createHelper(DES); + + /** + * Triple-DES block cipher algorithm. + */ + var TripleDES = C_algo.TripleDES = BlockCipher.extend({ + _doReset: function () { + // Shortcuts + var key = this._key; + var keyWords = key.words; + + // Create DES instances + this._des1 = DES.createEncryptor(WordArray.create(keyWords.slice(0, 2))); + this._des2 = DES.createEncryptor(WordArray.create(keyWords.slice(2, 4))); + this._des3 = DES.createEncryptor(WordArray.create(keyWords.slice(4, 6))); + }, + + encryptBlock: function (M, offset) { + this._des1.encryptBlock(M, offset); + this._des2.decryptBlock(M, offset); + this._des3.encryptBlock(M, offset); + }, + + decryptBlock: function (M, offset) { + this._des3.decryptBlock(M, offset); + this._des2.encryptBlock(M, offset); + this._des1.decryptBlock(M, offset); + }, + + keySize: 192/32, + + ivSize: 64/32, + + blockSize: 64/32 + }); + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.TripleDES.encrypt(message, key, cfg); + * var plaintext = CryptoJS.TripleDES.decrypt(ciphertext, key, cfg); + */ + C.TripleDES = BlockCipher._createHelper(TripleDES); + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C.algo; + + /** + * RC4 stream cipher algorithm. + */ + var RC4 = C_algo.RC4 = StreamCipher.extend({ + _doReset: function () { + // Shortcuts + var key = this._key; + var keyWords = key.words; + var keySigBytes = key.sigBytes; + + // Init sbox + var S = this._S = []; + for (var i = 0; i < 256; i++) { + S[i] = i; + } + + // Key setup + for (var i = 0, j = 0; i < 256; i++) { + var keyByteIndex = i % keySigBytes; + var keyByte = (keyWords[keyByteIndex >>> 2] >>> (24 - (keyByteIndex % 4) * 8)) & 0xff; + + j = (j + S[i] + keyByte) % 256; + + // Swap + var t = S[i]; + S[i] = S[j]; + S[j] = t; + } + + // Counters + this._i = this._j = 0; + }, + + _doProcessBlock: function (M, offset) { + M[offset] ^= generateKeystreamWord.call(this); + }, + + keySize: 256/32, + + ivSize: 0 + }); + + function generateKeystreamWord() { + // Shortcuts + var S = this._S; + var i = this._i; + var j = this._j; + + // Generate keystream word + var keystreamWord = 0; + for (var n = 0; n < 4; n++) { + i = (i + 1) % 256; + j = (j + S[i]) % 256; + + // Swap + var t = S[i]; + S[i] = S[j]; + S[j] = t; + + keystreamWord |= S[(S[i] + S[j]) % 256] << (24 - n * 8); + } + + // Update counters + this._i = i; + this._j = j; + + return keystreamWord; + } + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.RC4.encrypt(message, key, cfg); + * var plaintext = CryptoJS.RC4.decrypt(ciphertext, key, cfg); + */ + C.RC4 = StreamCipher._createHelper(RC4); + + /** + * Modified RC4 stream cipher algorithm. + */ + var RC4Drop = C_algo.RC4Drop = RC4.extend({ + /** + * Configuration options. + * + * @property {number} drop The number of keystream words to drop. Default 192 + */ + cfg: RC4.cfg.extend({ + drop: 192 + }), + + _doReset: function () { + RC4._doReset.call(this); + + // Drop + for (var i = this.cfg.drop; i > 0; i--) { + generateKeystreamWord.call(this); + } + } + }); + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.RC4Drop.encrypt(message, key, cfg); + * var plaintext = CryptoJS.RC4Drop.decrypt(ciphertext, key, cfg); + */ + C.RC4Drop = StreamCipher._createHelper(RC4Drop); + }()); + + + /** @preserve + * Counter block mode compatible with Dr Brian Gladman fileenc.c + * derived from CryptoJS.mode.CTR + * Jan Hruby jhruby.web@gmail.com + */ + CryptoJS.mode.CTRGladman = (function () { + var CTRGladman = CryptoJS.lib.BlockCipherMode.extend(); + + function incWord(word) + { + if (((word >> 24) & 0xff) === 0xff) { //overflow + var b1 = (word >> 16)&0xff; + var b2 = (word >> 8)&0xff; + var b3 = word & 0xff; + + if (b1 === 0xff) // overflow b1 + { + b1 = 0; + if (b2 === 0xff) + { + b2 = 0; + if (b3 === 0xff) + { + b3 = 0; + } + else + { + ++b3; + } + } + else + { + ++b2; + } + } + else + { + ++b1; + } + + word = 0; + word += (b1 << 16); + word += (b2 << 8); + word += b3; + } + else + { + word += (0x01 << 24); + } + return word; + } + + function incCounter(counter) + { + if ((counter[0] = incWord(counter[0])) === 0) + { + // encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8 + counter[1] = incWord(counter[1]); + } + return counter; + } + + var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher + var blockSize = cipher.blockSize; + var iv = this._iv; + var counter = this._counter; + + // Generate keystream + if (iv) { + counter = this._counter = iv.slice(0); + + // Remove IV for subsequent blocks + this._iv = undefined; + } + + incCounter(counter); + + var keystream = counter.slice(0); + cipher.encryptBlock(keystream, 0); + + // Encrypt + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + + CTRGladman.Decryptor = Encryptor; + + return CTRGladman; + }()); + + + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C.algo; + + // Reusable objects + var S = []; + var C_ = []; + var G = []; + + /** + * Rabbit stream cipher algorithm + */ + var Rabbit = C_algo.Rabbit = StreamCipher.extend({ + _doReset: function () { + // Shortcuts + var K = this._key.words; + var iv = this.cfg.iv; + + // Swap endian + for (var i = 0; i < 4; i++) { + K[i] = (((K[i] << 8) | (K[i] >>> 24)) & 0x00ff00ff) | + (((K[i] << 24) | (K[i] >>> 8)) & 0xff00ff00); + } + + // Generate initial state values + var X = this._X = [ + K[0], (K[3] << 16) | (K[2] >>> 16), + K[1], (K[0] << 16) | (K[3] >>> 16), + K[2], (K[1] << 16) | (K[0] >>> 16), + K[3], (K[2] << 16) | (K[1] >>> 16) + ]; + + // Generate initial counter values + var C = this._C = [ + (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff), + (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff), + (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff), + (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff) + ]; + + // Carry bit + this._b = 0; + + // Iterate the system four times + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + + // Modify the counters + for (var i = 0; i < 8; i++) { + C[i] ^= X[(i + 4) & 7]; + } + + // IV setup + if (iv) { + // Shortcuts + var IV = iv.words; + var IV_0 = IV[0]; + var IV_1 = IV[1]; + + // Generate four subvectors + var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00); + var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00); + var i1 = (i0 >>> 16) | (i2 & 0xffff0000); + var i3 = (i2 << 16) | (i0 & 0x0000ffff); + + // Modify counter values + C[0] ^= i0; + C[1] ^= i1; + C[2] ^= i2; + C[3] ^= i3; + C[4] ^= i0; + C[5] ^= i1; + C[6] ^= i2; + C[7] ^= i3; + + // Iterate the system four times + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + } + }, + + _doProcessBlock: function (M, offset) { + // Shortcut + var X = this._X; + + // Iterate the system + nextState.call(this); + + // Generate four keystream words + S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16); + S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16); + S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16); + S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16); + + for (var i = 0; i < 4; i++) { + // Swap endian + S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) | + (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00); + + // Encrypt + M[offset + i] ^= S[i]; + } + }, + + blockSize: 128/32, + + ivSize: 64/32 + }); + + function nextState() { + // Shortcuts + var X = this._X; + var C = this._C; + + // Save old counter values + for (var i = 0; i < 8; i++) { + C_[i] = C[i]; + } + + // Calculate new counter values + C[0] = (C[0] + 0x4d34d34d + this._b) | 0; + C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0; + C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0; + C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0; + C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0; + C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0; + C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0; + C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0; + this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0; + + // Calculate the g-values + for (var i = 0; i < 8; i++) { + var gx = X[i] + C[i]; + + // Construct high and low argument for squaring + var ga = gx & 0xffff; + var gb = gx >>> 16; + + // Calculate high and low result of squaring + var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb; + var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0); + + // High XOR low + G[i] = gh ^ gl; + } + + // Calculate new state values + X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0; + X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0; + X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0; + X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0; + X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0; + X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0; + X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0; + X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0; + } + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.Rabbit.encrypt(message, key, cfg); + * var plaintext = CryptoJS.Rabbit.decrypt(ciphertext, key, cfg); + */ + C.Rabbit = StreamCipher._createHelper(Rabbit); + }()); + + + /** + * Counter block mode. + */ + CryptoJS.mode.CTR = (function () { + var CTR = CryptoJS.lib.BlockCipherMode.extend(); + + var Encryptor = CTR.Encryptor = CTR.extend({ + processBlock: function (words, offset) { + // Shortcuts + var cipher = this._cipher + var blockSize = cipher.blockSize; + var iv = this._iv; + var counter = this._counter; + + // Generate keystream + if (iv) { + counter = this._counter = iv.slice(0); + + // Remove IV for subsequent blocks + this._iv = undefined; + } + var keystream = counter.slice(0); + cipher.encryptBlock(keystream, 0); + + // Increment counter + counter[blockSize - 1] = (counter[blockSize - 1] + 1) | 0 + + // Encrypt + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + + CTR.Decryptor = Encryptor; + + return CTR; + }()); + + + (function () { + // Shortcuts + var C = CryptoJS; + var C_lib = C.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C.algo; + + // Reusable objects + var S = []; + var C_ = []; + var G = []; + + /** + * Rabbit stream cipher algorithm. + * + * This is a legacy version that neglected to convert the key to little-endian. + * This error doesn't affect the cipher's security, + * but it does affect its compatibility with other implementations. + */ + var RabbitLegacy = C_algo.RabbitLegacy = StreamCipher.extend({ + _doReset: function () { + // Shortcuts + var K = this._key.words; + var iv = this.cfg.iv; + + // Generate initial state values + var X = this._X = [ + K[0], (K[3] << 16) | (K[2] >>> 16), + K[1], (K[0] << 16) | (K[3] >>> 16), + K[2], (K[1] << 16) | (K[0] >>> 16), + K[3], (K[2] << 16) | (K[1] >>> 16) + ]; + + // Generate initial counter values + var C = this._C = [ + (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff), + (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff), + (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff), + (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff) + ]; + + // Carry bit + this._b = 0; + + // Iterate the system four times + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + + // Modify the counters + for (var i = 0; i < 8; i++) { + C[i] ^= X[(i + 4) & 7]; + } + + // IV setup + if (iv) { + // Shortcuts + var IV = iv.words; + var IV_0 = IV[0]; + var IV_1 = IV[1]; + + // Generate four subvectors + var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00); + var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00); + var i1 = (i0 >>> 16) | (i2 & 0xffff0000); + var i3 = (i2 << 16) | (i0 & 0x0000ffff); + + // Modify counter values + C[0] ^= i0; + C[1] ^= i1; + C[2] ^= i2; + C[3] ^= i3; + C[4] ^= i0; + C[5] ^= i1; + C[6] ^= i2; + C[7] ^= i3; + + // Iterate the system four times + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + } + }, + + _doProcessBlock: function (M, offset) { + // Shortcut + var X = this._X; + + // Iterate the system + nextState.call(this); + + // Generate four keystream words + S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16); + S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16); + S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16); + S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16); + + for (var i = 0; i < 4; i++) { + // Swap endian + S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) | + (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00); + + // Encrypt + M[offset + i] ^= S[i]; + } + }, + + blockSize: 128/32, + + ivSize: 64/32 + }); + + function nextState() { + // Shortcuts + var X = this._X; + var C = this._C; + + // Save old counter values + for (var i = 0; i < 8; i++) { + C_[i] = C[i]; + } + + // Calculate new counter values + C[0] = (C[0] + 0x4d34d34d + this._b) | 0; + C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0; + C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0; + C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0; + C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0; + C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0; + C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0; + C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0; + this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0; + + // Calculate the g-values + for (var i = 0; i < 8; i++) { + var gx = X[i] + C[i]; + + // Construct high and low argument for squaring + var ga = gx & 0xffff; + var gb = gx >>> 16; + + // Calculate high and low result of squaring + var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb; + var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0); + + // High XOR low + G[i] = gh ^ gl; + } + + // Calculate new state values + X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0; + X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0; + X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0; + X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0; + X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0; + X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0; + X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0; + X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0; + } + + /** + * Shortcut functions to the cipher's object interface. + * + * @example + * + * var ciphertext = CryptoJS.RabbitLegacy.encrypt(message, key, cfg); + * var plaintext = CryptoJS.RabbitLegacy.decrypt(ciphertext, key, cfg); + */ + C.RabbitLegacy = StreamCipher._createHelper(RabbitLegacy); + }()); + + + /** + * Zero padding strategy. + */ + CryptoJS.pad.ZeroPadding = { + pad: function (data, blockSize) { + // Shortcut + var blockSizeBytes = blockSize * 4; + + // Pad + data.clamp(); + data.sigBytes += blockSizeBytes - ((data.sigBytes % blockSizeBytes) || blockSizeBytes); + }, + + unpad: function (data) { + // Shortcut + var dataWords = data.words; + + // Unpad + var i = data.sigBytes - 1; + while (!((dataWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff)) { + i--; + } + data.sigBytes = i + 1; + } + }; + + + return CryptoJS; + +})); + +function generateAjaxParmas(params) { + var timestamp = (new Date().getTime() / 1000).toFixed(); + var token = '23y0ufFl5YxIyGrI8hWRUZmKkvtSjLQA'; + var nonce = '123456789abcdefg'; + var passid = 'zdww'; + + return JSON.stringify( + Object.assign( + { + appId: 'NcApplication', + paasHeader: passid, + timestampHeader: timestamp, + nonceHeader: nonce, + signatureHeader: CryptoJS.SHA256(timestamp + token + nonce + timestamp) + .toString(CryptoJS.enc.Hex) + .toUpperCase() + }, + params + ) + ); +} +function generateHeaderParmas(params) { + var timestamp = (new Date().getTime() / 1000).toFixed(); + var token = 'fTN2pfuisxTavbTuYVSsNJHetwq5bJvC'; + var nonce = 'QkjjtiLM2dCratiA'; + var passid = 'zdww'; + + return JSON.stringify( + Object.assign( + { + appId: 'NcApplication', + paasHeader: passid, + timestampHeader: timestamp, + nonceHeader: nonce, + signatureHeader: CryptoJS.SHA256(timestamp + token + nonce + timestamp) + .toString(CryptoJS.enc.Hex) + .toUpperCase() + }, + params + ) + ); +} \ No newline at end of file diff --git a/adata/common/js/crypto.js b/adata/common/js/crypto.js new file mode 100644 index 0000000..dca6c46 --- /dev/null +++ b/adata/common/js/crypto.js @@ -0,0 +1,139 @@ +function Base64() { + _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", this.encode = function(a) { + var c, d, e, f, g, h, i, b = "", + j = 0; + for (a = _utf8_encode(a); j < a.length;) c = a.charCodeAt(j++), d = a.charCodeAt(j++), e = a.charCodeAt(j++), f = c >> 2, g = (3 & c) << 4 | d >> 4, h = (15 & d) << 2 | e >> 6, i = 63 & e, isNaN(d) ? h = i = 64 : isNaN(e) && (i = 64), b = b + _keyStr.charAt(f) + _keyStr.charAt(g) + _keyStr.charAt(h) + _keyStr.charAt(i); + return b + }, this.decode = function(a) { + var c, d, e, f, g, h, i, b = "", + j = 0; + for (a = a.replace(/[^A-Za-z0-9\+\/\=]/g, ""); j < a.length;) f = _keyStr.indexOf(a.charAt(j++)), g = _keyStr.indexOf(a.charAt(j++)), h = _keyStr.indexOf(a.charAt(j++)), i = _keyStr.indexOf(a.charAt(j++)), c = f << 2 | g >> 4, d = (15 & g) << 4 | h >> 2, e = (3 & h) << 6 | i, b += String.fromCharCode(c), 64 != h && (b += String.fromCharCode(d)), 64 != i && (b += String.fromCharCode(e)); + return b = _utf8_decode(b) + }, _utf8_encode = function(a) { + var b, c, d; + for (a = a.replace(/\r\n/g, "\n"), b = "", c = 0; c < a.length; c++) d = a.charCodeAt(c), 128 > d ? b += String.fromCharCode(d) : d > 127 && 2048 > d ? (b += String.fromCharCode(192 | d >> 6), b += String.fromCharCode(128 | 63 & d)) : (b += String.fromCharCode(224 | d >> 12), b += String.fromCharCode(128 | 63 & d >> 6), b += String.fromCharCode(128 | 63 & d)); + return b + }, _utf8_decode = function(a) { + for (var b = "", c = 0, d = c1 = c2 = 0; c < a.length;) d = a.charCodeAt(c), 128 > d ? (b += String.fromCharCode(d), c++) : d > 191 && 224 > d ? (c2 = a.charCodeAt(c + 1), b += String.fromCharCode((31 & d) << 6 | 63 & c2), c += 2) : (c2 = a.charCodeAt(c + 1), c3 = a.charCodeAt(c + 2), b += String.fromCharCode((15 & d) << 12 | (63 & c2) << 6 | 63 & c3), c += 3); + return b + } +} + +function hex_md5(a) { + return binl2hex(core_md5(str2binl(a), a.length * chrsz)) +} + +function b64_md5(a) { + return binl2b64(core_md5(str2binl(a), a.length * chrsz)) +} + +function str_md5(a) { + return binl2str(core_md5(str2binl(a), a.length * chrsz)) +} + +function hex_hmac_md5(a, b) { + return binl2hex(core_hmac_md5(a, b)) +} + +function b64_hmac_md5(a, b) { + return binl2b64(core_hmac_md5(a, b)) +} + +function str_hmac_md5(a, b) { + return binl2str(core_hmac_md5(a, b)) +} + +function md5_vm_test() { + return "900150983cd24fb0d6963f7d28e17f72" == hex_md5("abc") +} + +function core_md5(a, b) { + var c, d, e, f, g, h, i, j, k; + for (a[b >> 5] |= 128 << b % 32, a[(b + 64 >>> 9 << 4) + 14] = b, c = 1732584193, d = -271733879, e = -1732584194, f = 271733878, g = 0; g < a.length; g += 16) h = c, i = d, j = e, k = f, c = md5_ff(c, d, e, f, a[g + 0], 7, -680876936), f = md5_ff(f, c, d, e, a[g + 1], 12, -389564586), e = md5_ff(e, f, c, d, a[g + 2], 17, 606105819), d = md5_ff(d, e, f, c, a[g + 3], 22, -1044525330), c = md5_ff(c, d, e, f, a[g + 4], 7, -176418897), f = md5_ff(f, c, d, e, a[g + 5], 12, 1200080426), e = md5_ff(e, f, c, d, a[g + 6], 17, -1473231341), d = md5_ff(d, e, f, c, a[g + 7], 22, -45705983), c = md5_ff(c, d, e, f, a[g + 8], 7, 1770035416), f = md5_ff(f, c, d, e, a[g + 9], 12, -1958414417), e = md5_ff(e, f, c, d, a[g + 10], 17, -42063), d = md5_ff(d, e, f, c, a[g + 11], 22, -1990404162), c = md5_ff(c, d, e, f, a[g + 12], 7, 1804603682), f = md5_ff(f, c, d, e, a[g + 13], 12, -40341101), e = md5_ff(e, f, c, d, a[g + 14], 17, -1502002290), d = md5_ff(d, e, f, c, a[g + 15], 22, 1236535329), c = md5_gg(c, d, e, f, a[g + 1], 5, -165796510), f = md5_gg(f, c, d, e, a[g + 6], 9, -1069501632), e = md5_gg(e, f, c, d, a[g + 11], 14, 643717713), d = md5_gg(d, e, f, c, a[g + 0], 20, -373897302), c = md5_gg(c, d, e, f, a[g + 5], 5, -701558691), f = md5_gg(f, c, d, e, a[g + 10], 9, 38016083), e = md5_gg(e, f, c, d, a[g + 15], 14, -660478335), d = md5_gg(d, e, f, c, a[g + 4], 20, -405537848), c = md5_gg(c, d, e, f, a[g + 9], 5, 568446438), f = md5_gg(f, c, d, e, a[g + 14], 9, -1019803690), e = md5_gg(e, f, c, d, a[g + 3], 14, -187363961), d = md5_gg(d, e, f, c, a[g + 8], 20, 1163531501), c = md5_gg(c, d, e, f, a[g + 13], 5, -1444681467), f = md5_gg(f, c, d, e, a[g + 2], 9, -51403784), e = md5_gg(e, f, c, d, a[g + 7], 14, 1735328473), d = md5_gg(d, e, f, c, a[g + 12], 20, -1926607734), c = md5_hh(c, d, e, f, a[g + 5], 4, -378558), f = md5_hh(f, c, d, e, a[g + 8], 11, -2022574463), e = md5_hh(e, f, c, d, a[g + 11], 16, 1839030562), d = md5_hh(d, e, f, c, a[g + 14], 23, -35309556), c = md5_hh(c, d, e, f, a[g + 1], 4, -1530992060), f = md5_hh(f, c, d, e, a[g + 4], 11, 1272893353), e = md5_hh(e, f, c, d, a[g + 7], 16, -155497632), d = md5_hh(d, e, f, c, a[g + 10], 23, -1094730640), c = md5_hh(c, d, e, f, a[g + 13], 4, 681279174), f = md5_hh(f, c, d, e, a[g + 0], 11, -358537222), e = md5_hh(e, f, c, d, a[g + 3], 16, -722521979), d = md5_hh(d, e, f, c, a[g + 6], 23, 76029189), c = md5_hh(c, d, e, f, a[g + 9], 4, -640364487), f = md5_hh(f, c, d, e, a[g + 12], 11, -421815835), e = md5_hh(e, f, c, d, a[g + 15], 16, 530742520), d = md5_hh(d, e, f, c, a[g + 2], 23, -995338651), c = md5_ii(c, d, e, f, a[g + 0], 6, -198630844), f = md5_ii(f, c, d, e, a[g + 7], 10, 1126891415), e = md5_ii(e, f, c, d, a[g + 14], 15, -1416354905), d = md5_ii(d, e, f, c, a[g + 5], 21, -57434055), c = md5_ii(c, d, e, f, a[g + 12], 6, 1700485571), f = md5_ii(f, c, d, e, a[g + 3], 10, -1894986606), e = md5_ii(e, f, c, d, a[g + 10], 15, -1051523), d = md5_ii(d, e, f, c, a[g + 1], 21, -2054922799), c = md5_ii(c, d, e, f, a[g + 8], 6, 1873313359), f = md5_ii(f, c, d, e, a[g + 15], 10, -30611744), e = md5_ii(e, f, c, d, a[g + 6], 15, -1560198380), d = md5_ii(d, e, f, c, a[g + 13], 21, 1309151649), c = md5_ii(c, d, e, f, a[g + 4], 6, -145523070), f = md5_ii(f, c, d, e, a[g + 11], 10, -1120210379), e = md5_ii(e, f, c, d, a[g + 2], 15, 718787259), d = md5_ii(d, e, f, c, a[g + 9], 21, -343485551), c = safe_add(c, h), d = safe_add(d, i), e = safe_add(e, j), f = safe_add(f, k); + return Array(c, d, e, f) +} + +function md5_cmn(a, b, c, d, e, f) { + return safe_add(bit_rol(safe_add(safe_add(b, a), safe_add(d, f)), e), c) +} + +function md5_ff(a, b, c, d, e, f, g) { + return md5_cmn(b & c | ~b & d, a, b, e, f, g) +} + +function md5_gg(a, b, c, d, e, f, g) { + return md5_cmn(b & d | c & ~d, a, b, e, f, g) +} + +function md5_hh(a, b, c, d, e, f, g) { + return md5_cmn(b ^ c ^ d, a, b, e, f, g) +} + +function md5_ii(a, b, c, d, e, f, g) { + return md5_cmn(c ^ (b | ~d), a, b, e, f, g) +} + +function core_hmac_md5(a, b) { + var d, e, f, g, c = str2binl(a); + for (c.length > 16 && (c = core_md5(c, a.length * chrsz)), d = Array(16), e = Array(16), f = 0; 16 > f; f++) d[f] = 909522486 ^ c[f], e[f] = 1549556828 ^ c[f]; + return g = core_md5(d.concat(str2binl(b)), 512 + b.length * chrsz), core_md5(e.concat(g), 640) +} + +function safe_add(a, b) { + var c = (65535 & a) + (65535 & b), + d = (a >> 16) + (b >> 16) + (c >> 16); + return d << 16 | 65535 & c +} + +function bit_rol(a, b) { + return a << b | a >>> 32 - b +} + +function str2binl(a) { + var d, b = Array(), + c = (1 << chrsz) - 1; + for (d = 0; d < a.length * chrsz; d += chrsz) b[d >> 5] |= (a.charCodeAt(d / chrsz) & c) << d % 32; + return b +} + +function binl2str(a) { + var d, b = "", + c = (1 << chrsz) - 1; + for (d = 0; d < 32 * a.length; d += chrsz) b += String.fromCharCode(a[d >> 5] >>> d % 32 & c); + return b +} + +function binl2hex(a) { + var d, b = hexcase ? "0123456789ABCDEF" : "0123456789abcdef", + c = ""; + for (d = 0; d < 4 * a.length; d++) c += b.charAt(15 & a[d >> 2] >> 8 * (d % 4) + 4) + b.charAt(15 & a[d >> 2] >> 8 * (d % 4)); + return c +} + +function binl2b64(a) { + var d, e, f, b = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", + c = ""; + for (d = 0; d < 4 * a.length; d += 3) + for (e = (255 & a[d >> 2] >> 8 * (d % 4)) << 16 | (255 & a[d + 1 >> 2] >> 8 * ((d + 1) % 4)) << 8 | 255 & a[d + 2 >> 2] >> 8 * ((d + 2) % 4), f = 0; 4 > f; f++) c += 8 * d + 6 * f > 32 * a.length ? b64pad : b.charAt(63 & e >> 6 * (3 - f)); + return c +} + +function encode_param(a) { + var b = new Base64; + return b.encode(a) +} + +function encode_secret() { + var b, a = appId; + for (b = 0; b < arguments.length; b++) a += arguments[b]; + return a = a.replace(/\s/g, ""), hex_md5(a) +} + +function decode_result(a) { + var b = new Base64; + return b.decode(b.decode(b.decode(a))) +} +var hexcase = 0, + b64pad = "", + chrsz = 8, + appId = "a01901d3caba1f362d69474674ce477f"; \ No newline at end of file diff --git a/adata/common/js/outcrypto.js b/adata/common/js/outcrypto.js new file mode 100644 index 0000000..2861c36 --- /dev/null +++ b/adata/common/js/outcrypto.js @@ -0,0 +1,4900 @@ +function Base64() { + _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", this.encode = function(a) { + var c, d, e, f, g, h, i, b = "", + j = 0; + for (a = _utf8_encode(a); j < a.length;) c = a.charCodeAt(j++), d = a.charCodeAt(j++), e = a.charCodeAt(j++), f = c >> 2, g = (3 & c) << 4 | d >> 4, h = (15 & d) << 2 | e >> 6, i = 63 & e, isNaN(d) ? h = i = 64 : isNaN(e) && (i = 64), b = b + _keyStr.charAt(f) + _keyStr.charAt(g) + _keyStr.charAt(h) + _keyStr.charAt(i); + return b + }, this.decode = function(a) { + var c, d, e, f, g, h, i, b = "", + j = 0; + for (a = a.replace(/[^A-Za-z0-9\+\/\=]/g, ""); j < a.length;) f = _keyStr.indexOf(a.charAt(j++)), g = _keyStr.indexOf(a.charAt(j++)), h = _keyStr.indexOf(a.charAt(j++)), i = _keyStr.indexOf(a.charAt(j++)), c = f << 2 | g >> 4, d = (15 & g) << 4 | h >> 2, e = (3 & h) << 6 | i, b += String.fromCharCode(c), 64 != h && (b += String.fromCharCode(d)), 64 != i && (b += String.fromCharCode(e)); + return b = _utf8_decode(b) + }, _utf8_encode = function(a) { + var b, c, d; + for (a = a.replace(/\r\n/g, "\n"), b = "", c = 0; c < a.length; c++) d = a.charCodeAt(c), 128 > d ? b += String.fromCharCode(d) : d > 127 && 2048 > d ? (b += String.fromCharCode(192 | d >> 6), b += String.fromCharCode(128 | 63 & d)) : (b += String.fromCharCode(224 | d >> 12), b += String.fromCharCode(128 | 63 & d >> 6), b += String.fromCharCode(128 | 63 & d)); + return b + }, _utf8_decode = function(a) { + for (var b = "", c = 0, d = c1 = c2 = 0; c < a.length;) d = a.charCodeAt(c), 128 > d ? (b += String.fromCharCode(d), c++) : d > 191 && 224 > d ? (c2 = a.charCodeAt(c + 1), b += String.fromCharCode((31 & d) << 6 | 63 & c2), c += 2) : (c2 = a.charCodeAt(c + 1), c3 = a.charCodeAt(c + 2), b += String.fromCharCode((15 & d) << 12 | (63 & c2) << 6 | 63 & c3), c += 3); + return b + } +} + +function hex_md5(a) { + return binl2hex(core_md5(str2binl(a), a.length * chrsz)); +} + +function b64_md5(a) { + return binl2b64(core_md5(str2binl(a), a.length * chrsz)); +} + +function str_md5(a) { + return binl2str(core_md5(str2binl(a), a.length * chrsz)); +} + +function hex_hmac_md5(a, b) { + return binl2hex(core_hmac_md5(a, b)); +} + +function b64_hmac_md5(a, b) { + return binl2b64(core_hmac_md5(a, b)); +} + +function str_hmac_md5(a, b) { + return binl2str(core_hmac_md5(a, b)); +} + +function md5_vm_test() { + return "900150983cd24fb0d6963f7d28e17f72" == hex_md5("abc"); +} + +function core_md5(a, b) { + var c, d, e, f, g, h, i, j, k; + for ( + a[b >> 5] |= 128 << b % 32, + a[(((b + 64) >>> 9) << 4) + 14] = b, + c = 1732584193, + d = -271733879, + e = -1732584194, + f = 271733878, + g = 0; + g < a.length; + g += 16 + ) + (h = c), + (i = d), + (j = e), + (k = f), + (c = md5_ff(c, d, e, f, a[g + 0], 7, -680876936)), + (f = md5_ff(f, c, d, e, a[g + 1], 12, -389564586)), + (e = md5_ff(e, f, c, d, a[g + 2], 17, 606105819)), + (d = md5_ff(d, e, f, c, a[g + 3], 22, -1044525330)), + (c = md5_ff(c, d, e, f, a[g + 4], 7, -176418897)), + (f = md5_ff(f, c, d, e, a[g + 5], 12, 1200080426)), + (e = md5_ff(e, f, c, d, a[g + 6], 17, -1473231341)), + (d = md5_ff(d, e, f, c, a[g + 7], 22, -45705983)), + (c = md5_ff(c, d, e, f, a[g + 8], 7, 1770035416)), + (f = md5_ff(f, c, d, e, a[g + 9], 12, -1958414417)), + (e = md5_ff(e, f, c, d, a[g + 10], 17, -42063)), + (d = md5_ff(d, e, f, c, a[g + 11], 22, -1990404162)), + (c = md5_ff(c, d, e, f, a[g + 12], 7, 1804603682)), + (f = md5_ff(f, c, d, e, a[g + 13], 12, -40341101)), + (e = md5_ff(e, f, c, d, a[g + 14], 17, -1502002290)), + (d = md5_ff(d, e, f, c, a[g + 15], 22, 1236535329)), + (c = md5_gg(c, d, e, f, a[g + 1], 5, -165796510)), + (f = md5_gg(f, c, d, e, a[g + 6], 9, -1069501632)), + (e = md5_gg(e, f, c, d, a[g + 11], 14, 643717713)), + (d = md5_gg(d, e, f, c, a[g + 0], 20, -373897302)), + (c = md5_gg(c, d, e, f, a[g + 5], 5, -701558691)), + (f = md5_gg(f, c, d, e, a[g + 10], 9, 38016083)), + (e = md5_gg(e, f, c, d, a[g + 15], 14, -660478335)), + (d = md5_gg(d, e, f, c, a[g + 4], 20, -405537848)), + (c = md5_gg(c, d, e, f, a[g + 9], 5, 568446438)), + (f = md5_gg(f, c, d, e, a[g + 14], 9, -1019803690)), + (e = md5_gg(e, f, c, d, a[g + 3], 14, -187363961)), + (d = md5_gg(d, e, f, c, a[g + 8], 20, 1163531501)), + (c = md5_gg(c, d, e, f, a[g + 13], 5, -1444681467)), + (f = md5_gg(f, c, d, e, a[g + 2], 9, -51403784)), + (e = md5_gg(e, f, c, d, a[g + 7], 14, 1735328473)), + (d = md5_gg(d, e, f, c, a[g + 12], 20, -1926607734)), + (c = md5_hh(c, d, e, f, a[g + 5], 4, -378558)), + (f = md5_hh(f, c, d, e, a[g + 8], 11, -2022574463)), + (e = md5_hh(e, f, c, d, a[g + 11], 16, 1839030562)), + (d = md5_hh(d, e, f, c, a[g + 14], 23, -35309556)), + (c = md5_hh(c, d, e, f, a[g + 1], 4, -1530992060)), + (f = md5_hh(f, c, d, e, a[g + 4], 11, 1272893353)), + (e = md5_hh(e, f, c, d, a[g + 7], 16, -155497632)), + (d = md5_hh(d, e, f, c, a[g + 10], 23, -1094730640)), + (c = md5_hh(c, d, e, f, a[g + 13], 4, 681279174)), + (f = md5_hh(f, c, d, e, a[g + 0], 11, -358537222)), + (e = md5_hh(e, f, c, d, a[g + 3], 16, -722521979)), + (d = md5_hh(d, e, f, c, a[g + 6], 23, 76029189)), + (c = md5_hh(c, d, e, f, a[g + 9], 4, -640364487)), + (f = md5_hh(f, c, d, e, a[g + 12], 11, -421815835)), + (e = md5_hh(e, f, c, d, a[g + 15], 16, 530742520)), + (d = md5_hh(d, e, f, c, a[g + 2], 23, -995338651)), + (c = md5_ii(c, d, e, f, a[g + 0], 6, -198630844)), + (f = md5_ii(f, c, d, e, a[g + 7], 10, 1126891415)), + (e = md5_ii(e, f, c, d, a[g + 14], 15, -1416354905)), + (d = md5_ii(d, e, f, c, a[g + 5], 21, -57434055)), + (c = md5_ii(c, d, e, f, a[g + 12], 6, 1700485571)), + (f = md5_ii(f, c, d, e, a[g + 3], 10, -1894986606)), + (e = md5_ii(e, f, c, d, a[g + 10], 15, -1051523)), + (d = md5_ii(d, e, f, c, a[g + 1], 21, -2054922799)), + (c = md5_ii(c, d, e, f, a[g + 8], 6, 1873313359)), + (f = md5_ii(f, c, d, e, a[g + 15], 10, -30611744)), + (e = md5_ii(e, f, c, d, a[g + 6], 15, -1560198380)), + (d = md5_ii(d, e, f, c, a[g + 13], 21, 1309151649)), + (c = md5_ii(c, d, e, f, a[g + 4], 6, -145523070)), + (f = md5_ii(f, c, d, e, a[g + 11], 10, -1120210379)), + (e = md5_ii(e, f, c, d, a[g + 2], 15, 718787259)), + (d = md5_ii(d, e, f, c, a[g + 9], 21, -343485551)), + (c = safe_add(c, h)), + (d = safe_add(d, i)), + (e = safe_add(e, j)), + (f = safe_add(f, k)); + return Array(c, d, e, f); +} + +function md5_cmn(a, b, c, d, e, f) { + return safe_add(bit_rol(safe_add(safe_add(b, a), safe_add(d, f)), e), c); +} + +function md5_ff(a, b, c, d, e, f, g) { + return md5_cmn((b & c) | (~b & d), a, b, e, f, g); +} + +function md5_gg(a, b, c, d, e, f, g) { + return md5_cmn((b & d) | (c & ~d), a, b, e, f, g); +} + +function md5_hh(a, b, c, d, e, f, g) { + return md5_cmn(b ^ c ^ d, a, b, e, f, g); +} + +function md5_ii(a, b, c, d, e, f, g) { + return md5_cmn(c ^ (b | ~d), a, b, e, f, g); +} + +function core_hmac_md5(a, b) { + var d, + e, + f, + g, + c = str2binl(a); + for ( + c.length > 16 && (c = core_md5(c, a.length * chrsz)), + d = Array(16), + e = Array(16), + f = 0; + 16 > f; + f++ + ) + (d[f] = 909522486 ^ c[f]), (e[f] = 1549556828 ^ c[f]); + return ( + (g = core_md5(d.concat(str2binl(b)), 512 + b.length * chrsz)), + core_md5(e.concat(g), 640) + ); +} + +function safe_add(a, b) { + var c = (65535 & a) + (65535 & b), + d = (a >> 16) + (b >> 16) + (c >> 16); + return (d << 16) | (65535 & c); +} + +function bit_rol(a, b) { + return (a << b) | (a >>> (32 - b)); +} + +function str2binl(a) { + var d, + b = Array(), + c = (1 << chrsz) - 1; + for (d = 0; d < a.length * chrsz; d += chrsz) + b[d >> 5] |= (a.charCodeAt(d / chrsz) & c) << d % 32; + return b; +} + +function binl2str(a) { + var d, + b = "", + c = (1 << chrsz) - 1; + for (d = 0; d < 32 * a.length; d += chrsz) + b += String.fromCharCode((a[d >> 5] >>> d % 32) & c); + return b; +} + +function binl2hex(a) { + var d, + b = hexcase ? "0123456789ABCDEF" : "0123456789abcdef", + c = ""; + for (d = 0; d < 4 * a.length; d++) + c += + b.charAt(15 & (a[d >> 2] >> (8 * (d % 4) + 4))) + + b.charAt(15 & (a[d >> 2] >> (8 * (d % 4)))); + return c; +} + +function binl2b64(a) { + var d, + e, + f, + b = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", + c = ""; + for (d = 0; d < 4 * a.length; d += 3) + for ( + e = + ((255 & (a[d >> 2] >> (8 * (d % 4)))) << 16) | + ((255 & (a[(d + 1) >> 2] >> (8 * ((d + 1) % 4)))) << 8) | + (255 & (a[(d + 2) >> 2] >> (8 * ((d + 2) % 4)))), + f = 0; + 4 > f; + f++ + ) + c += + 8 * d + 6 * f > 32 * a.length + ? b64pad + : b.charAt(63 & (e >> (6 * (3 - f)))); + return c; +} + +function encode_param(a) { + var b = new Base64(); + var des = DES() + return des.encrypt(b.encode(a)); +} + +function encode_secret() { + var b, + a = appId; + for (b = 0; b < arguments.length; b++) a += arguments[b]; + return (a = a.replace(/\s/g, "")), hex_md5(a); +} + +function decode_result(a) { + var b = new Base64(); + return b.decode(b.decode(b.decode(a))); +} + +var hexcase = 0, + b64pad = "", + chrsz = 8, + appId = "a01901d3caba1f362d69474674ce477f"; + +var CryptoJS = + CryptoJS || + (function(h, r) { + var k = {}, + l = (k.lib = {}), + n = function() {}, + f = (l.Base = { + extend: function(a) { + n.prototype = this; + var b = new n(); + a && b.mixIn(a); + b.hasOwnProperty("init") || + (b.init = function() { + b.s.init.apply(this, arguments); + }); + b.init.prototype = b; + b.s = this; + return b; + }, + create: function() { + var a = this.extend(); + a.init.apply(a, arguments); + return a; + }, + init: function() {}, + mixIn: function(a) { + for (var b in a) a.hasOwnProperty(b) && (this[b] = a[b]); + a.hasOwnProperty("toString") && (this.toString = a.toString); + }, + clone: function() { + return this.init.prototype.extend(this); + } + }), + j = (l.WordArray = f.extend({ + init: function(a, b) { + a = this.words = a || []; + this.sigBytes = b != r ? b : 4 * a.length; + }, + toString: function(a) { + return (a || s).stringify(this); + }, + concat: function(a) { + var b = this.words, + d = a.words, + c = this.sigBytes; + a = a.sigBytes; + this.clamp(); + if (c % 4) + for (var e = 0; e < a; e++) + b[(c + e) >>> 2] |= + ((d[e >>> 2] >>> (24 - 8 * (e % 4))) & 255) << + (24 - 8 * ((c + e) % 4)); + else if (65535 < d.length) + for (e = 0; e < a; e += 4) b[(c + e) >>> 2] = d[e >>> 2]; + else b.push.apply(b, d); + this.sigBytes += a; + return this; + }, + clamp: function() { + var a = this.words, + b = this.sigBytes; + a[b >>> 2] &= 4294967295 << (32 - 8 * (b % 4)); + a.length = h.ceil(b / 4); + }, + clone: function() { + var a = f.clone.call(this); + a.words = this.words.slice(0); + return a; + }, + random: function(a) { + for (var b = [], d = 0; d < a; d += 4) + b.push((4294967296 * h.random()) | 0); + return new j.init(b, a); + } + })), + m = (k.enc = {}), + s = (m.Hex = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) { + var e = (b[c >>> 2] >>> (24 - 8 * (c % 4))) & 255; + d.push((e >>> 4).toString(16)); + d.push((e & 15).toString(16)); + } + return d.join(""); + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c += 2) + d[c >>> 3] |= parseInt(a.substr(c, 2), 16) << (24 - 4 * (c % 8)); + return new j.init(d, b / 2); + } + }), + p = (m.Latin1 = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) + d.push( + String.fromCharCode((b[c >>> 2] >>> (24 - 8 * (c % 4))) & 255) + ); + return d.join(""); + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c++) + d[c >>> 2] |= (a.charCodeAt(c) & 255) << (24 - 8 * (c % 4)); + return new j.init(d, b); + } + }), + t = (m.Utf8 = { + stringify: function(a) { + try { + return decodeURIComponent(escape(p.stringify(a))); + } catch (b) { + throw Error("Malformed UTF-8 data"); + } + }, + parse: function(a) { + return p.parse(unescape(encodeURIComponent(a))); + } + }), + q = (l.BufferedBlockAlgorithm = f.extend({ + reset: function() { + this._2 = new j.init(); + this._22 = 0; + }, + _8: function(a) { + "string" == typeof a && (a = t.parse(a)); + this._2.concat(a); + this._22 += a.sigBytes; + }, + _3: function(a) { + var b = this._2, + d = b.words, + c = b.sigBytes, + e = this.blockSize, + f = c / (4 * e), + f = a ? h.ceil(f) : h.max((f | 0) - this._18, 0); + a = f * e; + c = h.min(4 * a, c); + if (a) { + for (var g = 0; g < a; g += e) this._20(d, g); + g = d.splice(0, a); + b.sigBytes -= c; + } + return new j.init(g, c); + }, + clone: function() { + var a = f.clone.call(this); + a._2 = this._2.clone(); + return a; + }, + _18: 0 + })); + l.Hasher = q.extend({ + cfg: f.extend(), + init: function(a) { + this.cfg = this.cfg.extend(a); + this.reset(); + }, + reset: function() { + q.reset.call(this); + this._5(); + }, + update: function(a) { + this._8(a); + this._3(); + return this; + }, + finalize: function(a) { + a && this._8(a); + return this._9(); + }, + blockSize: 16, + _6: function(a) { + return function(b, d) { + return new a.init(d).finalize(b); + }; + }, + _30: function(a) { + return function(b, d) { + return new u.HMAC.init(a, d).finalize(b); + }; + } + }); + var u = (k.algo = {}); + return k; + })(Math); +(function() { + var h = CryptoJS, + j = h.lib.WordArray; + h.enc.Base64 = { + stringify: function(b) { + var e = b.words, + f = b.sigBytes, + c = this._13; + b.clamp(); + b = []; + for (var a = 0; a < f; a += 3) + for ( + var d = + (((e[a >>> 2] >>> (24 - 8 * (a % 4))) & 255) << 16) | + (((e[(a + 1) >>> 2] >>> (24 - 8 * ((a + 1) % 4))) & 255) << 8) | + ((e[(a + 2) >>> 2] >>> (24 - 8 * ((a + 2) % 4))) & 255), + g = 0; + 4 > g && a + 0.75 * g < f; + g++ + ) + b.push(c.charAt((d >>> (6 * (3 - g))) & 63)); + if ((e = c.charAt(64))) for (; b.length % 4; ) b.push(e); + return b.join(""); + }, + parse: function(b) { + var e = b.length, + f = this._13, + c = f.charAt(64); + c && ((c = b.indexOf(c)), -1 != c && (e = c)); + for (var c = [], a = 0, d = 0; d < e; d++) + if (d % 4) { + var g = f.indexOf(b.charAt(d - 1)) << (2 * (d % 4)), + h = f.indexOf(b.charAt(d)) >>> (6 - 2 * (d % 4)); + c[a >>> 2] |= (g | h) << (24 - 8 * (a % 4)); + a++; + } + return j.create(c, a); + }, + _13: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" + }; +})(); +CryptoJS.lib.Cipher || + (function(u) { + var g = CryptoJS, + f = g.lib, + k = f.Base, + l = f.WordArray, + q = f.BufferedBlockAlgorithm, + r = g.enc.Base64, + v = g.algo.EvpKDF, + n = (f.Cipher = q.extend({ + cfg: k.extend(), + createEncryptor: function(a, b) { + return this.create(this._11, a, b); + }, + createDecryptor: function(a, b) { + return this.create(this._25, a, b); + }, + init: function(a, b, c) { + this.cfg = this.cfg.extend(c); + this._15 = a; + this._12 = b; + this.reset(); + }, + reset: function() { + q.reset.call(this); + this._5(); + }, + process: function(a) { + this._8(a); + return this._3(); + }, + finalize: function(a) { + a && this._8(a); + return this._9(); + }, + keySize: 4, + ivSize: 4, + _11: 1, + _25: 2, + _6: function(a) { + return { + encrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).encrypt(a, b, c, d); + }, + decrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).decrypt(a, b, c, d); + } + }; + } + })); + f.StreamCipher = n.extend({ + _9: function() { + return this._3(!0); + }, + blockSize: 1 + }); + var m = (g.mode = {}), + t = function(a, b, c) { + var d = this._16; + d ? (this._16 = u) : (d = this._19); + for (var e = 0; e < c; e++) a[b + e] ^= d[e]; + }, + h = (f.BlockCipherMode = k.extend({ + createEncryptor: function(a, b) { + return this.Encryptor.create(a, b); + }, + createDecryptor: function(a, b) { + return this.Decryptor.create(a, b); + }, + init: function(a, b) { + this._10 = a; + this._16 = b; + } + })).extend(); + h.Encryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize; + t.call(this, a, b, d); + c.encryptBlock(a, b); + this._19 = a.slice(b, b + d); + } + }); + h.Decryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize, + e = a.slice(b, b + d); + c.decryptBlock(a, b); + t.call(this, a, b, d); + this._19 = e; + } + }); + m = m.CBC = h; + h = (g.pad = {}).Pkcs7 = { + pad: function(a, b) { + for ( + var c = 4 * b, + c = c - (a.sigBytes % c), + d = (c << 24) | (c << 16) | (c << 8) | c, + e = [], + f = 0; + f < c; + f += 4 + ) + e.push(d); + c = l.create(e, c); + a.concat(c); + }, + unpad: function(a) { + a.sigBytes -= a.words[(a.sigBytes - 1) >>> 2] & 255; + } + }; + f.BlockCipher = n.extend({ + cfg: n.cfg.extend({ + mode: m, + padding: h + }), + reset: function() { + n.reset.call(this); + var a = this.cfg, + b = a.iv, + a = a.mode; + if (this._15 == this._11) var c = a.createEncryptor; + else (c = a.createDecryptor), (this._18 = 1); + this._31 = c.call(a, this, b && b.words); + }, + _20: function(a, b) { + this._31.processBlock(a, b); + }, + _9: function() { + var a = this.cfg.padding; + if (this._15 == this._11) { + a.pad(this._2, this.blockSize); + var b = this._3(!0); + } else (b = this._3(!0)), a.unpad(b); + return b; + }, + blockSize: 4 + }); + var p = (f.CipherParams = k.extend({ + init: function(a) { + this.mixIn(a); + }, + toString: function(a) { + return (a || this.formatter).stringify(this); + } + })), + m = ((g.format = {}).OpenSSL = { + stringify: function(a) { + var b = a.ciphertext; + a = a.salt; + return (a + ? l + .create([1398893684, 1701076831]) + .concat(a) + .concat(b) + : b + ).toString(r); + }, + parse: function(a) { + a = r.parse(a); + var b = a.words; + if (1398893684 == b[0] && 1701076831 == b[1]) { + var c = l.create(b.slice(2, 4)); + b.splice(0, 4); + a.sigBytes -= 16; + } + return p.create({ + ciphertext: a, + salt: c + }); + } + }), + j = (f.SerializableCipher = k.extend({ + cfg: k.extend({ + format: m + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + var e = a.createEncryptor(c, d); + b = e.finalize(b); + e = e.cfg; + return p.create({ + ciphertext: b, + key: c, + iv: e.iv, + algorithm: a, + mode: e.mode, + padding: e.padding, + blockSize: a.blockSize, + formatter: d.format + }); + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + return a.createDecryptor(c, d).finalize(b.ciphertext); + }, + _14: function(a, b) { + return "string" == typeof a ? b.parse(a, this) : a; + } + })), + g = ((g.kdf = {}).OpenSSL = { + execute: function(a, b, c, d) { + d || (d = l.random(8)); + a = v + .create({ + keySize: b + c + }) + .compute(a, d); + c = l.create(a.words.slice(b), 4 * c); + a.sigBytes = 4 * b; + return p.create({ + key: a, + iv: c, + salt: d + }); + } + }), + s = (f.PasswordBasedCipher = j.extend({ + cfg: j.cfg.extend({ + kdf: g + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + c = d.kdf.execute(c, a.keySize, a.ivSize); + d.iv = c.iv; + a = j.encrypt.call(this, a, b, c.key, d); + a.mixIn(c); + return a; + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + c = d.kdf.execute(c, a.keySize, a.ivSize, b.salt); + d.iv = c.iv; + return j.decrypt.call(this, a, b, c.key, d); + } + })); + })(); +CryptoJS.mode.ECB = (function() { + var a = CryptoJS.lib.BlockCipherMode.extend(); + a.Encryptor = a.extend({ + processBlock: function(a, b) { + this._10.encryptBlock(a, b); + } + }); + a.Decryptor = a.extend({ + processBlock: function(a, b) { + this._10.decryptBlock(a, b); + } + }); + return a; +})(); +(function(E) { + function h(a, f, g, j, p, h, k) { + a = a + ((f & g) | (~f & j)) + p + k; + return ((a << h) | (a >>> (32 - h))) + f; + } + function k(a, f, g, j, p, h, k) { + a = a + ((f & j) | (g & ~j)) + p + k; + return ((a << h) | (a >>> (32 - h))) + f; + } + function l(a, f, g, j, h, k, l) { + a = a + (f ^ g ^ j) + h + l; + return ((a << k) | (a >>> (32 - k))) + f; + } + function n(a, f, g, j, h, k, l) { + a = a + (g ^ (f | ~j)) + h + l; + return ((a << k) | (a >>> (32 - k))) + f; + } + for ( + var r = CryptoJS, + q = r.lib, + F = q.WordArray, + s = q.Hasher, + q = r.algo, + a = [], + t = 0; + 64 > t; + t++ + ) + a[t] = (4294967296 * E.abs(E.sin(t + 1))) | 0; + q = q.MD5 = s.extend({ + _5: function() { + this._7 = new F.init([1732584193, 4023233417, 2562383102, 271733878]); + }, + _20: function(m, f) { + for (var g = 0; 16 > g; g++) { + var j = f + g, + p = m[j]; + m[j] = + (((p << 8) | (p >>> 24)) & 16711935) | + (((p << 24) | (p >>> 8)) & 4278255360); + } + var g = this._7.words, + j = m[f + 0], + p = m[f + 1], + q = m[f + 2], + r = m[f + 3], + s = m[f + 4], + t = m[f + 5], + u = m[f + 6], + v = m[f + 7], + w = m[f + 8], + x = m[f + 9], + y = m[f + 10], + z = m[f + 11], + A = m[f + 12], + B = m[f + 13], + C = m[f + 14], + D = m[f + 15], + b = g[0], + c = g[1], + d = g[2], + e = g[3], + b = h(b, c, d, e, j, 7, a[0]), + e = h(e, b, c, d, p, 12, a[1]), + d = h(d, e, b, c, q, 17, a[2]), + c = h(c, d, e, b, r, 22, a[3]), + b = h(b, c, d, e, s, 7, a[4]), + e = h(e, b, c, d, t, 12, a[5]), + d = h(d, e, b, c, u, 17, a[6]), + c = h(c, d, e, b, v, 22, a[7]), + b = h(b, c, d, e, w, 7, a[8]), + e = h(e, b, c, d, x, 12, a[9]), + d = h(d, e, b, c, y, 17, a[10]), + c = h(c, d, e, b, z, 22, a[11]), + b = h(b, c, d, e, A, 7, a[12]), + e = h(e, b, c, d, B, 12, a[13]), + d = h(d, e, b, c, C, 17, a[14]), + c = h(c, d, e, b, D, 22, a[15]), + b = k(b, c, d, e, p, 5, a[16]), + e = k(e, b, c, d, u, 9, a[17]), + d = k(d, e, b, c, z, 14, a[18]), + c = k(c, d, e, b, j, 20, a[19]), + b = k(b, c, d, e, t, 5, a[20]), + e = k(e, b, c, d, y, 9, a[21]), + d = k(d, e, b, c, D, 14, a[22]), + c = k(c, d, e, b, s, 20, a[23]), + b = k(b, c, d, e, x, 5, a[24]), + e = k(e, b, c, d, C, 9, a[25]), + d = k(d, e, b, c, r, 14, a[26]), + c = k(c, d, e, b, w, 20, a[27]), + b = k(b, c, d, e, B, 5, a[28]), + e = k(e, b, c, d, q, 9, a[29]), + d = k(d, e, b, c, v, 14, a[30]), + c = k(c, d, e, b, A, 20, a[31]), + b = l(b, c, d, e, t, 4, a[32]), + e = l(e, b, c, d, w, 11, a[33]), + d = l(d, e, b, c, z, 16, a[34]), + c = l(c, d, e, b, C, 23, a[35]), + b = l(b, c, d, e, p, 4, a[36]), + e = l(e, b, c, d, s, 11, a[37]), + d = l(d, e, b, c, v, 16, a[38]), + c = l(c, d, e, b, y, 23, a[39]), + b = l(b, c, d, e, B, 4, a[40]), + e = l(e, b, c, d, j, 11, a[41]), + d = l(d, e, b, c, r, 16, a[42]), + c = l(c, d, e, b, u, 23, a[43]), + b = l(b, c, d, e, x, 4, a[44]), + e = l(e, b, c, d, A, 11, a[45]), + d = l(d, e, b, c, D, 16, a[46]), + c = l(c, d, e, b, q, 23, a[47]), + b = n(b, c, d, e, j, 6, a[48]), + e = n(e, b, c, d, v, 10, a[49]), + d = n(d, e, b, c, C, 15, a[50]), + c = n(c, d, e, b, t, 21, a[51]), + b = n(b, c, d, e, A, 6, a[52]), + e = n(e, b, c, d, r, 10, a[53]), + d = n(d, e, b, c, y, 15, a[54]), + c = n(c, d, e, b, p, 21, a[55]), + b = n(b, c, d, e, w, 6, a[56]), + e = n(e, b, c, d, D, 10, a[57]), + d = n(d, e, b, c, u, 15, a[58]), + c = n(c, d, e, b, B, 21, a[59]), + b = n(b, c, d, e, s, 6, a[60]), + e = n(e, b, c, d, z, 10, a[61]), + d = n(d, e, b, c, q, 15, a[62]), + c = n(c, d, e, b, x, 21, a[63]); + g[0] = (g[0] + b) | 0; + g[1] = (g[1] + c) | 0; + g[2] = (g[2] + d) | 0; + g[3] = (g[3] + e) | 0; + }, + _9: function() { + var a = this._2, + f = a.words, + g = 8 * this._22, + j = 8 * a.sigBytes; + f[j >>> 5] |= 128 << (24 - (j % 32)); + var h = E.floor(g / 4294967296); + f[(((j + 64) >>> 9) << 4) + 15] = + (((h << 8) | (h >>> 24)) & 16711935) | + (((h << 24) | (h >>> 8)) & 4278255360); + f[(((j + 64) >>> 9) << 4) + 14] = + (((g << 8) | (g >>> 24)) & 16711935) | + (((g << 24) | (g >>> 8)) & 4278255360); + a.sigBytes = 4 * (f.length + 1); + this._3(); + a = this._7; + f = a.words; + for (g = 0; 4 > g; g++) + (j = f[g]), + (f[g] = + (((j << 8) | (j >>> 24)) & 16711935) | + (((j << 24) | (j >>> 8)) & 4278255360)); + return a; + }, + clone: function() { + var a = s.clone.call(this); + a._7 = this._7.clone(); + return a; + } + }); + r.MD5 = s._6(q); + r.HmacMD5 = s._30(q); +})(Math); +(function() { + for ( + var q = CryptoJS, + x = q.lib.BlockCipher, + r = q.algo, + j = [], + y = [], + z = [], + A = [], + B = [], + C = [], + s = [], + u = [], + v = [], + w = [], + g = [], + k = 0; + 256 > k; + k++ + ) + g[k] = 128 > k ? k << 1 : (k << 1) ^ 283; + for (var n = 0, l = 0, k = 0; 256 > k; k++) { + var f = l ^ (l << 1) ^ (l << 2) ^ (l << 3) ^ (l << 4), + f = (f >>> 8) ^ (f & 255) ^ 99; + j[n] = f; + y[f] = n; + var t = g[n], + D = g[t], + E = g[D], + b = (257 * g[f]) ^ (16843008 * f); + z[n] = (b << 24) | (b >>> 8); + A[n] = (b << 16) | (b >>> 16); + B[n] = (b << 8) | (b >>> 24); + C[n] = b; + b = (16843009 * E) ^ (65537 * D) ^ (257 * t) ^ (16843008 * n); + s[f] = (b << 24) | (b >>> 8); + u[f] = (b << 16) | (b >>> 16); + v[f] = (b << 8) | (b >>> 24); + w[f] = b; + n ? ((n = t ^ g[g[g[E ^ t]]]), (l ^= g[g[l]])) : (n = l = 1); + } + var F = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54], + r = (r.AES = x.extend({ + _5: function() { + for ( + var c = this._12, + e = c.words, + a = c.sigBytes / 4, + c = 4 * ((this._26 = a + 6) + 1), + b = (this._27 = []), + h = 0; + h < c; + h++ + ) + if (h < a) b[h] = e[h]; + else { + var d = b[h - 1]; + h % a + ? 6 < a && + 4 == h % a && + (d = + (j[d >>> 24] << 24) | + (j[(d >>> 16) & 255] << 16) | + (j[(d >>> 8) & 255] << 8) | + j[d & 255]) + : ((d = (d << 8) | (d >>> 24)), + (d = + (j[d >>> 24] << 24) | + (j[(d >>> 16) & 255] << 16) | + (j[(d >>> 8) & 255] << 8) | + j[d & 255]), + (d ^= F[(h / a) | 0] << 24)); + b[h] = b[h - a] ^ d; + } + e = this._24 = []; + for (a = 0; a < c; a++) + (h = c - a), + (d = a % 4 ? b[h] : b[h - 4]), + (e[a] = + 4 > a || 4 >= h + ? d + : s[j[d >>> 24]] ^ + u[j[(d >>> 16) & 255]] ^ + v[j[(d >>> 8) & 255]] ^ + w[j[d & 255]]); + }, + encryptBlock: function(c, e) { + this._4(c, e, this._27, z, A, B, C, j); + }, + decryptBlock: function(c, e) { + var a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a; + this._4(c, e, this._24, s, u, v, w, y); + a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a; + }, + _4: function(c, e, a, b, h, d, j, m) { + for ( + var n = this._26, + f = c[e] ^ a[0], + g = c[e + 1] ^ a[1], + k = c[e + 2] ^ a[2], + p = c[e + 3] ^ a[3], + l = 4, + t = 1; + t < n; + t++ + ) + var q = + b[f >>> 24] ^ + h[(g >>> 16) & 255] ^ + d[(k >>> 8) & 255] ^ + j[p & 255] ^ + a[l++], + r = + b[g >>> 24] ^ + h[(k >>> 16) & 255] ^ + d[(p >>> 8) & 255] ^ + j[f & 255] ^ + a[l++], + s = + b[k >>> 24] ^ + h[(p >>> 16) & 255] ^ + d[(f >>> 8) & 255] ^ + j[g & 255] ^ + a[l++], + p = + b[p >>> 24] ^ + h[(f >>> 16) & 255] ^ + d[(g >>> 8) & 255] ^ + j[k & 255] ^ + a[l++], + f = q, + g = r, + k = s; + q = + ((m[f >>> 24] << 24) | + (m[(g >>> 16) & 255] << 16) | + (m[(k >>> 8) & 255] << 8) | + m[p & 255]) ^ + a[l++]; + r = + ((m[g >>> 24] << 24) | + (m[(k >>> 16) & 255] << 16) | + (m[(p >>> 8) & 255] << 8) | + m[f & 255]) ^ + a[l++]; + s = + ((m[k >>> 24] << 24) | + (m[(p >>> 16) & 255] << 16) | + (m[(f >>> 8) & 255] << 8) | + m[g & 255]) ^ + a[l++]; + p = + ((m[p >>> 24] << 24) | + (m[(f >>> 16) & 255] << 16) | + (m[(g >>> 8) & 255] << 8) | + m[k & 255]) ^ + a[l++]; + c[e] = q; + c[e + 1] = r; + c[e + 2] = s; + c[e + 3] = p; + }, + keySize: 8 + })); + q.AES = x._6(r); +})(); +(function() { + function j(b, c) { + var a = ((this._1 >>> b) ^ this._0) & c; + this._0 ^= a; + this._1 ^= a << b; + } + function l(b, c) { + var a = ((this._0 >>> b) ^ this._1) & c; + this._1 ^= a; + this._0 ^= a << b; + } + var h = CryptoJS, + e = h.lib, + n = e.WordArray, + e = e.BlockCipher, + g = h.algo, + q = [ + 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 + ], + p = [ + 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 + ], + r = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28], + s = [ + { + "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 + } + ], + t = [ + 4160749569, + 528482304, + 33030144, + 2064384, + 129024, + 8064, + 504, + 2147483679 + ], + m = (g.DES = e.extend({ + _5: function() { + for (var b = this._12.words, c = [], a = 0; 56 > a; a++) { + var f = q[a] - 1; + c[a] = (b[f >>> 5] >>> (31 - (f % 32))) & 1; + } + b = this._28 = []; + for (f = 0; 16 > f; f++) { + for (var d = (b[f] = []), e = r[f], a = 0; 24 > a; a++) + (d[(a / 6) | 0] |= c[(p[a] - 1 + e) % 28] << (31 - (a % 6))), + (d[4 + ((a / 6) | 0)] |= + c[28 + ((p[a + 24] - 1 + e) % 28)] << (31 - (a % 6))); + d[0] = (d[0] << 1) | (d[0] >>> 31); + for (a = 1; 7 > a; a++) d[a] >>>= 4 * (a - 1) + 3; + d[7] = (d[7] << 5) | (d[7] >>> 27); + } + c = this._29 = []; + for (a = 0; 16 > a; a++) c[a] = b[15 - a]; + }, + encryptBlock: function(b, c) { + this._4(b, c, this._28); + }, + decryptBlock: function(b, c) { + this._4(b, c, this._29); + }, + _4: function(b, c, a) { + this._1 = b[c]; + this._0 = b[c + 1]; + j.call(this, 4, 252645135); + j.call(this, 16, 65535); + l.call(this, 2, 858993459); + l.call(this, 8, 16711935); + j.call(this, 1, 1431655765); + for (var f = 0; 16 > f; f++) { + for (var d = a[f], e = this._1, h = this._0, g = 0, k = 0; 8 > k; k++) + g |= s[k][((h ^ d[k]) & t[k]) >>> 0]; + this._1 = h; + this._0 = e ^ g; + } + a = this._1; + this._1 = this._0; + this._0 = a; + j.call(this, 1, 1431655765); + l.call(this, 8, 16711935); + l.call(this, 2, 858993459); + j.call(this, 16, 65535); + j.call(this, 4, 252645135); + b[c] = this._1; + b[c + 1] = this._0; + }, + keySize: 2, + ivSize: 2, + blockSize: 2 + })); + h.DES = e._6(m); + g = g.TripleDES = e.extend({ + _5: function() { + var b = this._12.words; + this._17 = m.createEncryptor(n.create(b.slice(0, 2))); + this._21 = m.createEncryptor(n.create(b.slice(2, 4))); + this._23 = m.createEncryptor(n.create(b.slice(4, 6))); + }, + encryptBlock: function(b, c) { + this._17.encryptBlock(b, c); + this._21.decryptBlock(b, c); + this._23.encryptBlock(b, c); + }, + decryptBlock: function(b, c) { + this._23.decryptBlock(b, c); + this._21.encryptBlock(b, c); + this._17.decryptBlock(b, c); + }, + keySize: 6, + ivSize: 2, + blockSize: 2 + }); + h.TripleDES = e._6(g); +})(); +var getParam = (function() { + var AES = { + encrypt: function(text) { + var secretkey = CryptoJS.MD5("cGFsbWNsaWVudA==") + .toString() + .substr(16, 16); + var secretiv = CryptoJS.MD5("Y2xpZW50cGFsbQ==") + .toString() + .substr(0, 16); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.AES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(); + } + }; + var DES = { + encrypt: function(text) { + var secretkey = CryptoJS.MD5("emhlbnFpcGFsbQ==") + .toString() + .substr(0, 16); + var secretiv = CryptoJS.MD5("emhlbnFp") + .toString() + .substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(); + }, + decrypt: function(text) { + var secretkey = CryptoJS.MD5("emhlbnFpcGFsbQ==") + .toString() + .substr(0, 16); + var secretiv = CryptoJS.MD5("emhlbnFp") + .toString() + .substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.decrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(CryptoJS.enc.Utf8); + } + }; + function ObjectSort(obj) { + var newObject = {}; + Object.keys(obj) + .sort() + .map(function(key) { + newObject[key] = obj[key]; + }); + return newObject; + } + function MyEncode(str) { + var arr = akb33.split('') + var b = new Base64; + arr.forEach(times => { + switch(times) { + case "1": + str = AES.encrypt(str) + break; + case "2": + str = DES.encrypt(str) + break; + case "3": + str = b.encode(str) + break; + } + }) + return str; + } + + return function(method, obj) { + var appId = "4f0e3a273d547ce6b7147bfa7ceb4b6e"; + var timestamp = new Date().getTime(); + var need = { + appId: appId, + method: method, + timestamp: timestamp, + clienttype: "WEB", + object: obj, + secret: hex_md5(appId + method + timestamp + "WEB" + obj) + }; + return AES.encrypt(JSON.stringify(need)); + }; +})(); +var decryptData = (function() { + var akb33 = "32223"; + var akb34 = "N4EDAQpO2ejqgCoX"; + var akb35 = "=qoKNLgdAjJbU8zx"; + var akb36 = "mAkJqt8coXQ96zML"; + var akb48 = "t4ABRmeN" + var DES = { + encrypt: function(text) { + var secretkey = (CryptoJS.MD5(akb36).toString()).substr(0, 16); + var secretiv = (CryptoJS.MD5(akb48).toString()).substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString() + }, + decrypt: function(text) { + var secretkey = (CryptoJS.MD5(akb36).toString()).substr(0, 16); + var secretiv = (CryptoJS.MD5(akb48).toString()).substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.decrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(CryptoJS.enc.Utf8) + } + }; + var AES = { + encrypt: function(text) { + var secretkey = (CryptoJS.MD5(akb34).toString()).substr(16, 16); + var secretiv = (CryptoJS.MD5(akb35).toString()).substr(0, 16); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.AES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString() + }, + decrypt: function(text) { + var secretkey = (CryptoJS.MD5(akb34).toString()).substr(16, 16); + var secretiv = (CryptoJS.MD5(akb35).toString()).substr(0, 16); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.AES.decrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(CryptoJS.enc.Utf8) + }, + }; + + function MyDecode(str, nopop) { + var arr = akb33.split('').reverse() + var b = new Base64; + arr.forEach(times => { + switch(times) { + case "1": + str = AES.decrypt(str) + break; + case "2": + str = DES.decrypt(str) + break; + case "3": + str = b.decode(str) + break; + } + }) + if (!nopop) { + str = b.encode(str) + } + return str; + } + + return function(data) { + return MyDecode(data) + } +})(); + +var AES = { + encrypt: function(text) { + var secretkey = CryptoJS.MD5("cGFsbWNsaWVudA==") + .toString() + .substr(16, 16); + var secretiv = CryptoJS.MD5("Y2xpZW50cGFsbQ==") + .toString() + .substr(0, 16); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.AES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(); + }, + decrypt: function(text) { + var secretkey = CryptoJS.MD5("cGFsbXNlcnZlcg==") + .toString() + .substr(16, 16); + var secretiv = CryptoJS.MD5("c2VydmVycGFsbQ==") + .toString() + .substr(0, 16); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.AES.decrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(CryptoJS.enc.Utf8); + } +}; + +var DES = { + encrypt: function(text) { + var secretkey = CryptoJS.MD5("emhlbnFpcGFsbQ==") + .toString() + .substr(0, 16); + var secretiv = CryptoJS.MD5("emhlbnFp") + .toString() + .substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(); + }, + decrypt: function(text) { + var secretkey = CryptoJS.MD5("emhlbnFpcGFsbQ==") + .toString() + .substr(0, 16); + var secretiv = CryptoJS.MD5("emhlbnFp") + .toString() + .substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.decrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString(CryptoJS.enc.Utf8); + } +}; + +var b = new Base64(); + + + +function hex_md5(a) { + return binl2hex(core_md5(str2binl(a), a.length * chrsz)); +} + +function b64_md5(a) { + return binl2b64(core_md5(str2binl(a), a.length * chrsz)); +} + +function str_md5(a) { + return binl2str(core_md5(str2binl(a), a.length * chrsz)); +} + +function hex_hmac_md5(a, b) { + return binl2hex(core_hmac_md5(a, b)); +} + +function b64_hmac_md5(a, b) { + return binl2b64(core_hmac_md5(a, b)); +} + +function str_hmac_md5(a, b) { + return binl2str(core_hmac_md5(a, b)); +} + +function md5_vm_test() { + return "900150983cd24fb0d6963f7d28e17f72" == hex_md5("abc"); +} + +function core_md5(a, b) { + var c, d, e, f, g, h, i, j, k; + for ( + a[b >> 5] |= 128 << b % 32, + a[(((b + 64) >>> 9) << 4) + 14] = b, + c = 1732584193, + d = -271733879, + e = -1732584194, + f = 271733878, + g = 0; + g < a.length; + g += 16 + ) + (h = c), + (i = d), + (j = e), + (k = f), + (c = md5_ff(c, d, e, f, a[g + 0], 7, -680876936)), + (f = md5_ff(f, c, d, e, a[g + 1], 12, -389564586)), + (e = md5_ff(e, f, c, d, a[g + 2], 17, 606105819)), + (d = md5_ff(d, e, f, c, a[g + 3], 22, -1044525330)), + (c = md5_ff(c, d, e, f, a[g + 4], 7, -176418897)), + (f = md5_ff(f, c, d, e, a[g + 5], 12, 1200080426)), + (e = md5_ff(e, f, c, d, a[g + 6], 17, -1473231341)), + (d = md5_ff(d, e, f, c, a[g + 7], 22, -45705983)), + (c = md5_ff(c, d, e, f, a[g + 8], 7, 1770035416)), + (f = md5_ff(f, c, d, e, a[g + 9], 12, -1958414417)), + (e = md5_ff(e, f, c, d, a[g + 10], 17, -42063)), + (d = md5_ff(d, e, f, c, a[g + 11], 22, -1990404162)), + (c = md5_ff(c, d, e, f, a[g + 12], 7, 1804603682)), + (f = md5_ff(f, c, d, e, a[g + 13], 12, -40341101)), + (e = md5_ff(e, f, c, d, a[g + 14], 17, -1502002290)), + (d = md5_ff(d, e, f, c, a[g + 15], 22, 1236535329)), + (c = md5_gg(c, d, e, f, a[g + 1], 5, -165796510)), + (f = md5_gg(f, c, d, e, a[g + 6], 9, -1069501632)), + (e = md5_gg(e, f, c, d, a[g + 11], 14, 643717713)), + (d = md5_gg(d, e, f, c, a[g + 0], 20, -373897302)), + (c = md5_gg(c, d, e, f, a[g + 5], 5, -701558691)), + (f = md5_gg(f, c, d, e, a[g + 10], 9, 38016083)), + (e = md5_gg(e, f, c, d, a[g + 15], 14, -660478335)), + (d = md5_gg(d, e, f, c, a[g + 4], 20, -405537848)), + (c = md5_gg(c, d, e, f, a[g + 9], 5, 568446438)), + (f = md5_gg(f, c, d, e, a[g + 14], 9, -1019803690)), + (e = md5_gg(e, f, c, d, a[g + 3], 14, -187363961)), + (d = md5_gg(d, e, f, c, a[g + 8], 20, 1163531501)), + (c = md5_gg(c, d, e, f, a[g + 13], 5, -1444681467)), + (f = md5_gg(f, c, d, e, a[g + 2], 9, -51403784)), + (e = md5_gg(e, f, c, d, a[g + 7], 14, 1735328473)), + (d = md5_gg(d, e, f, c, a[g + 12], 20, -1926607734)), + (c = md5_hh(c, d, e, f, a[g + 5], 4, -378558)), + (f = md5_hh(f, c, d, e, a[g + 8], 11, -2022574463)), + (e = md5_hh(e, f, c, d, a[g + 11], 16, 1839030562)), + (d = md5_hh(d, e, f, c, a[g + 14], 23, -35309556)), + (c = md5_hh(c, d, e, f, a[g + 1], 4, -1530992060)), + (f = md5_hh(f, c, d, e, a[g + 4], 11, 1272893353)), + (e = md5_hh(e, f, c, d, a[g + 7], 16, -155497632)), + (d = md5_hh(d, e, f, c, a[g + 10], 23, -1094730640)), + (c = md5_hh(c, d, e, f, a[g + 13], 4, 681279174)), + (f = md5_hh(f, c, d, e, a[g + 0], 11, -358537222)), + (e = md5_hh(e, f, c, d, a[g + 3], 16, -722521979)), + (d = md5_hh(d, e, f, c, a[g + 6], 23, 76029189)), + (c = md5_hh(c, d, e, f, a[g + 9], 4, -640364487)), + (f = md5_hh(f, c, d, e, a[g + 12], 11, -421815835)), + (e = md5_hh(e, f, c, d, a[g + 15], 16, 530742520)), + (d = md5_hh(d, e, f, c, a[g + 2], 23, -995338651)), + (c = md5_ii(c, d, e, f, a[g + 0], 6, -198630844)), + (f = md5_ii(f, c, d, e, a[g + 7], 10, 1126891415)), + (e = md5_ii(e, f, c, d, a[g + 14], 15, -1416354905)), + (d = md5_ii(d, e, f, c, a[g + 5], 21, -57434055)), + (c = md5_ii(c, d, e, f, a[g + 12], 6, 1700485571)), + (f = md5_ii(f, c, d, e, a[g + 3], 10, -1894986606)), + (e = md5_ii(e, f, c, d, a[g + 10], 15, -1051523)), + (d = md5_ii(d, e, f, c, a[g + 1], 21, -2054922799)), + (c = md5_ii(c, d, e, f, a[g + 8], 6, 1873313359)), + (f = md5_ii(f, c, d, e, a[g + 15], 10, -30611744)), + (e = md5_ii(e, f, c, d, a[g + 6], 15, -1560198380)), + (d = md5_ii(d, e, f, c, a[g + 13], 21, 1309151649)), + (c = md5_ii(c, d, e, f, a[g + 4], 6, -145523070)), + (f = md5_ii(f, c, d, e, a[g + 11], 10, -1120210379)), + (e = md5_ii(e, f, c, d, a[g + 2], 15, 718787259)), + (d = md5_ii(d, e, f, c, a[g + 9], 21, -343485551)), + (c = safe_add(c, h)), + (d = safe_add(d, i)), + (e = safe_add(e, j)), + (f = safe_add(f, k)); + return Array(c, d, e, f); +} + +function md5_cmn(a, b, c, d, e, f) { + return safe_add(bit_rol(safe_add(safe_add(b, a), safe_add(d, f)), e), c); +} + +function md5_ff(a, b, c, d, e, f, g) { + return md5_cmn((b & c) | (~b & d), a, b, e, f, g); +} + +function md5_gg(a, b, c, d, e, f, g) { + return md5_cmn((b & d) | (c & ~d), a, b, e, f, g); +} + +function md5_hh(a, b, c, d, e, f, g) { + return md5_cmn(b ^ c ^ d, a, b, e, f, g); +} + +function md5_ii(a, b, c, d, e, f, g) { + return md5_cmn(c ^ (b | ~d), a, b, e, f, g); +} + +function core_hmac_md5(a, b) { + var d, + e, + f, + g, + c = str2binl(a); + for ( + c.length > 16 && (c = core_md5(c, a.length * chrsz)), + d = Array(16), + e = Array(16), + f = 0; + 16 > f; + f++ + ) + (d[f] = 909522486 ^ c[f]), (e[f] = 1549556828 ^ c[f]); + return ( + (g = core_md5(d.concat(str2binl(b)), 512 + b.length * chrsz)), + core_md5(e.concat(g), 640) + ); +} + +function safe_add(a, b) { + var c = (65535 & a) + (65535 & b), + d = (a >> 16) + (b >> 16) + (c >> 16); + return (d << 16) | (65535 & c); +} + +function bit_rol(a, b) { + return (a << b) | (a >>> (32 - b)); +} + +function str2binl(a) { + var d, + b = Array(), + c = (1 << chrsz) - 1; + for (d = 0; d < a.length * chrsz; d += chrsz) + b[d >> 5] |= (a.charCodeAt(d / chrsz) & c) << d % 32; + return b; +} + +function binl2str(a) { + var d, + b = "", + c = (1 << chrsz) - 1; + for (d = 0; d < 32 * a.length; d += chrsz) + b += String.fromCharCode((a[d >> 5] >>> d % 32) & c); + return b; +} + +function binl2hex(a) { + var d, + b = hexcase ? "0123456789ABCDEF" : "0123456789abcdef", + c = ""; + for (d = 0; d < 4 * a.length; d++) + c += + b.charAt(15 & (a[d >> 2] >> (8 * (d % 4) + 4))) + + b.charAt(15 & (a[d >> 2] >> (8 * (d % 4)))); + return c; +} + +function binl2b64(a) { + var d, + e, + f, + b = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", + c = ""; + for (d = 0; d < 4 * a.length; d += 3) + for ( + e = + ((255 & (a[d >> 2] >> (8 * (d % 4)))) << 16) | + ((255 & (a[(d + 1) >> 2] >> (8 * ((d + 1) % 4)))) << 8) | + (255 & (a[(d + 2) >> 2] >> (8 * ((d + 2) % 4)))), + f = 0; + 4 > f; + f++ + ) + c += + 8 * d + 6 * f > 32 * a.length + ? b64pad + : b.charAt(63 & (e >> (6 * (3 - f)))); + return c; +} + +function encode_param(a) { + var b = new Base64(); + var akb33 = "32223"; + var akb34 = "N4EDAQpO2ejqgCoX"; + var akb35 = "=qoKNLgdAjJbU8zx"; + var akb36 = "mAkJqt8coXQ96zML"; + var akb48 = "t4ABRmeN" + var CryptoJS = CryptoJS || function(h, r) { + var k = {}, + l = k.lib = {}, + n = function() {}, + f = l.Base = { + extend: function(a) { + n.prototype = this; + var b = new n; + a && b.mixIn(a); + b.hasOwnProperty("init") || (b.init = function() { + b.s.init.apply(this, arguments) + }); + b.init.prototype = b; + b.s = this; + return b + }, + create: function() { + var a = this.extend(); + a.init.apply(a, arguments); + return a + }, + init: function() {}, + mixIn: function(a) { + for (var b in a) a.hasOwnProperty(b) && (this[b] = a[b]); + a.hasOwnProperty("toString") && (this.toString = a.toString) + }, + clone: function() { + return this.init.prototype.extend(this) + } + }, + j = l.WordArray = f.extend({ + init: function(a, b) { + a = this.words = a || []; + this.sigBytes = b != r ? b : 4 * a.length + }, + toString: function(a) { + return (a || s).stringify(this) + }, + concat: function(a) { + var b = this.words, + d = a.words, + c = this.sigBytes; + a = a.sigBytes; + this.clamp(); + if (c % 4) + for (var e = 0; e < a; e++) b[c + e >>> 2] |= (d[e >>> 2] >>> 24 - 8 * (e % 4) & 255) << 24 - 8 * ((c + e) % 4); + else if (65535 < d.length) + for (e = 0; e < a; e += 4) b[c + e >>> 2] = d[e >>> 2]; + else b.push.apply(b, d); + this.sigBytes += a; + return this + }, + clamp: function() { + var a = this.words, + b = this.sigBytes; + a[b >>> 2] &= 4294967295 << 32 - 8 * (b % 4); + a.length = h.ceil(b / 4) + }, + clone: function() { + var a = f.clone.call(this); + a.words = this.words.slice(0); + return a + }, + random: function(a) { + for (var b = [], d = 0; d < a; d += 4) b.push(4294967296 * h.random() | 0); + return new j.init(b, a) + } + }), + m = k.enc = {}, + s = m.Hex = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) { + var e = b[c >>> 2] >>> 24 - 8 * (c % 4) & 255; + d.push((e >>> 4).toString(16)); + d.push((e & 15).toString(16)) + } + return d.join("") + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c += 2) d[c >>> 3] |= parseInt(a.substr(c, 2), 16) << 24 - 4 * (c % 8); + return new j.init(d, b / 2) + } + }, + p = m.Latin1 = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) d.push(String.fromCharCode(b[c >>> 2] >>> 24 - 8 * (c % 4) & 255)); + return d.join("") + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c++) d[c >>> 2] |= (a.charCodeAt(c) & 255) << 24 - 8 * (c % 4); + return new j.init(d, b) + } + }, + t = m.Utf8 = { + stringify: function(a) { + try { + return decodeURIComponent(escape(p.stringify(a))) + } catch (b) { + throw Error("Malformed UTF-8 data") + } + }, + parse: function(a) { + return p.parse(unescape(encodeURIComponent(a))) + } + }, + q = l.BufferedBlockAlgorithm = f.extend({ + reset: function() { + this._2 = new j.init; + this._22 = 0 + }, + _8: function(a) { + "string" == typeof a && (a = t.parse(a)); + this._2.concat(a); + this._22 += a.sigBytes + }, + _3: function(a) { + var b = this._2, + d = b.words, + c = b.sigBytes, + e = this.blockSize, + f = c / (4 * e), + f = a ? h.ceil(f) : h.max((f | 0) - this._18, 0); + a = f * e; + c = h.min(4 * a, c); + if (a) { + for (var g = 0; g < a; g += e) this._20(d, g); + g = d.splice(0, a); + b.sigBytes -= c + } + return new j.init(g, c) + }, + clone: function() { + var a = f.clone.call(this); + a._2 = this._2.clone(); + return a + }, + _18: 0 + }); + l.Hasher = q.extend({ + cfg: f.extend(), + init: function(a) { + this.cfg = this.cfg.extend(a); + this.reset() + }, + reset: function() { + q.reset.call(this); + this._5() + }, + update: function(a) { + this._8(a); + this._3(); + return this + }, + finalize: function(a) { + a && this._8(a); + return this._9() + }, + blockSize: 16, + _6: function(a) { + return function(b, d) { + return (new a.init(d)).finalize(b) + } + }, + _30: function(a) { + return function(b, d) { + return (new u.HMAC.init(a, d)).finalize(b) + } + } + }); + var u = k.algo = {}; + return k + }(Math); + (function() { + var h = CryptoJS, + j = h.lib.WordArray; + h.enc.Base64 = { + stringify: function(b) { + var e = b.words, + f = b.sigBytes, + c = this._13; + b.clamp(); + b = []; + for (var a = 0; a < f; a += 3) + for (var d = (e[a >>> 2] >>> 24 - 8 * (a % 4) & 255) << 16 | (e[a + 1 >>> 2] >>> 24 - 8 * ((a + 1) % 4) & 255) << 8 | e[a + 2 >>> 2] >>> 24 - 8 * ((a + 2) % 4) & 255, g = 0; 4 > g && a + 0.75 * g < f; g++) b.push(c.charAt(d >>> 6 * (3 - g) & 63)); + if (e = c.charAt(64)) + for (; b.length % 4;) b.push(e); + return b.join("") + }, + parse: function(b) { + var e = b.length, + f = this._13, + c = f.charAt(64); + c && (c = b.indexOf(c), -1 != c && (e = c)); + for (var c = [], a = 0, d = 0; d < e; d++) + if (d % 4) { + var g = f.indexOf(b.charAt(d - 1)) << 2 * (d % 4), + h = f.indexOf(b.charAt(d)) >>> 6 - 2 * (d % 4); + c[a >>> 2] |= (g | h) << 24 - 8 * (a % 4); + a++ + } + return j.create(c, a) + }, + _13: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" + } + })(); + CryptoJS.lib.Cipher || function(u) { + var g = CryptoJS, + f = g.lib, + k = f.Base, + l = f.WordArray, + q = f.BufferedBlockAlgorithm, + r = g.enc.Base64, + v = g.algo.EvpKDF, + n = f.Cipher = q.extend({ + cfg: k.extend(), + createEncryptor: function(a, b) { + return this.create(this._11, a, b) + }, + createDecryptor: function(a, b) { + return this.create(this._25, a, b) + }, + init: function(a, b, c) { + this.cfg = this.cfg.extend(c); + this._15 = a; + this._12 = b; + this.reset() + }, + reset: function() { + q.reset.call(this); + this._5() + }, + process: function(a) { + this._8(a); + return this._3() + }, + finalize: function(a) { + a && this._8(a); + return this._9() + }, + keySize: 4, + ivSize: 4, + _11: 1, + _25: 2, + _6: function(a) { + return { + encrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).encrypt(a, b, c, d) + }, + decrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).decrypt(a, b, c, d) + } + } + } + }); + f.StreamCipher = n.extend({ + _9: function() { + return this._3(!0) + }, + blockSize: 1 + }); + var m = g.mode = {}, + t = function(a, b, c) { + var d = this._16; + d ? this._16 = u : d = this._19; + for (var e = 0; e < c; e++) a[b + e] ^= d[e] + }, + h = (f.BlockCipherMode = k.extend({ + createEncryptor: function(a, b) { + return this.Encryptor.create(a, b) + }, + createDecryptor: function(a, b) { + return this.Decryptor.create(a, b) + }, + init: function(a, b) { + this._10 = a; + this._16 = b + } + })).extend(); + h.Encryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize; + t.call(this, a, b, d); + c.encryptBlock(a, b); + this._19 = a.slice(b, b + d) + } + }); + h.Decryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize, + e = a.slice(b, b + d); + c.decryptBlock(a, b); + t.call(this, a, b, d); + this._19 = e + } + }); + m = m.CBC = h; + h = (g.pad = {}).Pkcs7 = { + pad: function(a, b) { + for (var c = 4 * b, c = c - a.sigBytes % c, d = c << 24 | c << 16 | c << 8 | c, e = [], f = 0; f < c; f += 4) e.push(d); + c = l.create(e, c); + a.concat(c) + }, + unpad: function(a) { + a.sigBytes -= a.words[a.sigBytes - 1 >>> 2] & 255 + } + }; + f.BlockCipher = n.extend({ + cfg: n.cfg.extend({ + mode: m, + padding: h + }), + reset: function() { + n.reset.call(this); + var a = this.cfg, + b = a.iv, + a = a.mode; + if (this._15 == this._11) var c = a.createEncryptor; + else c = a.createDecryptor, this._18 = 1; + this._31 = c.call(a, this, b && b.words) + }, + _20: function(a, b) { + this._31.processBlock(a, b) + }, + _9: function() { + var a = this.cfg.padding; + if (this._15 == this._11) { + a.pad(this._2, this.blockSize); + var b = this._3(!0) + } else b = this._3(!0), a.unpad(b); + return b + }, + blockSize: 4 + }); + var p = f.CipherParams = k.extend({ + init: function(a) { + this.mixIn(a) + }, + toString: function(a) { + return (a || this.formatter).stringify(this) + } + }), + m = (g.format = {}).OpenSSL = { + stringify: function(a) { + var b = a.ciphertext; + a = a.salt; + return (a ? l.create([1398893684, 1701076831]).concat(a).concat(b) : b).toString(r) + }, + parse: function(a) { + a = r.parse(a); + var b = a.words; + if (1398893684 == b[0] && 1701076831 == b[1]) { + var c = l.create(b.slice(2, 4)); + b.splice(0, 4); + a.sigBytes -= 16 + } + return p.create({ + ciphertext: a, + salt: c + }) + } + }, + j = f.SerializableCipher = k.extend({ + cfg: k.extend({ + format: m + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + var e = a.createEncryptor(c, d); + b = e.finalize(b); + e = e.cfg; + return p.create({ + ciphertext: b, + key: c, + iv: e.iv, + algorithm: a, + mode: e.mode, + padding: e.padding, + blockSize: a.blockSize, + formatter: d.format + }) + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + return a.createDecryptor(c, d).finalize(b.ciphertext) + }, + _14: function(a, b) { + return "string" == typeof a ? b.parse(a, this) : a + } + }), + g = (g.kdf = {}).OpenSSL = { + execute: function(a, b, c, d) { + d || (d = l.random(8)); + a = v.create({ + keySize: b + c + }).compute(a, d); + c = l.create(a.words.slice(b), 4 * c); + a.sigBytes = 4 * b; + return p.create({ + key: a, + iv: c, + salt: d + }) + } + }, + s = f.PasswordBasedCipher = j.extend({ + cfg: j.cfg.extend({ + kdf: g + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + c = d.kdf.execute(c, a.keySize, a.ivSize); + d.iv = c.iv; + a = j.encrypt.call(this, a, b, c.key, d); + a.mixIn(c); + return a + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + c = d.kdf.execute(c, a.keySize, a.ivSize, b.salt); + d.iv = c.iv; + return j.decrypt.call(this, a, b, c.key, d) + } + }) + }(); + CryptoJS.mode.ECB = function() { + var a = CryptoJS.lib.BlockCipherMode.extend(); + a.Encryptor = a.extend({ + processBlock: function(a, b) { + this._10.encryptBlock(a, b) + } + }); + a.Decryptor = a.extend({ + processBlock: function(a, b) { + this._10.decryptBlock(a, b) + } + }); + return a + }(); + (function(E) { + function h(a, f, g, j, p, h, k) { + a = a + (f & g | ~f & j) + p + k; + return (a << h | a >>> 32 - h) + f + } + + function k(a, f, g, j, p, h, k) { + a = a + (f & j | g & ~j) + p + k; + return (a << h | a >>> 32 - h) + f + } + + function l(a, f, g, j, h, k, l) { + a = a + (f ^ g ^ j) + h + l; + return (a << k | a >>> 32 - k) + f + } + + function n(a, f, g, j, h, k, l) { + a = a + (g ^ (f | ~j)) + h + l; + return (a << k | a >>> 32 - k) + f + } + for (var r = CryptoJS, q = r.lib, F = q.WordArray, s = q.Hasher, q = r.algo, a = [], t = 0; 64 > t; t++) a[t] = 4294967296 * E.abs(E.sin(t + 1)) | 0; + q = q.MD5 = s.extend({ + _5: function() { + this._7 = new F.init([1732584193, 4023233417, 2562383102, 271733878]) + }, + _20: function(m, f) { + for (var g = 0; 16 > g; g++) { + var j = f + g, + p = m[j]; + m[j] = (p << 8 | p >>> 24) & 16711935 | (p << 24 | p >>> 8) & 4278255360 + } + var g = this._7.words, + j = m[f + 0], + p = m[f + 1], + q = m[f + 2], + r = m[f + 3], + s = m[f + 4], + t = m[f + 5], + u = m[f + 6], + v = m[f + 7], + w = m[f + 8], + x = m[f + 9], + y = m[f + 10], + z = m[f + 11], + A = m[f + 12], + B = m[f + 13], + C = m[f + 14], + D = m[f + 15], + b = g[0], + c = g[1], + d = g[2], + e = g[3], + b = h(b, c, d, e, j, 7, a[0]), + e = h(e, b, c, d, p, 12, a[1]), + d = h(d, e, b, c, q, 17, a[2]), + c = h(c, d, e, b, r, 22, a[3]), + b = h(b, c, d, e, s, 7, a[4]), + e = h(e, b, c, d, t, 12, a[5]), + d = h(d, e, b, c, u, 17, a[6]), + c = h(c, d, e, b, v, 22, a[7]), + b = h(b, c, d, e, w, 7, a[8]), + e = h(e, b, c, d, x, 12, a[9]), + d = h(d, e, b, c, y, 17, a[10]), + c = h(c, d, e, b, z, 22, a[11]), + b = h(b, c, d, e, A, 7, a[12]), + e = h(e, b, c, d, B, 12, a[13]), + d = h(d, e, b, c, C, 17, a[14]), + c = h(c, d, e, b, D, 22, a[15]), + b = k(b, c, d, e, p, 5, a[16]), + e = k(e, b, c, d, u, 9, a[17]), + d = k(d, e, b, c, z, 14, a[18]), + c = k(c, d, e, b, j, 20, a[19]), + b = k(b, c, d, e, t, 5, a[20]), + e = k(e, b, c, d, y, 9, a[21]), + d = k(d, e, b, c, D, 14, a[22]), + c = k(c, d, e, b, s, 20, a[23]), + b = k(b, c, d, e, x, 5, a[24]), + e = k(e, b, c, d, C, 9, a[25]), + d = k(d, e, b, c, r, 14, a[26]), + c = k(c, d, e, b, w, 20, a[27]), + b = k(b, c, d, e, B, 5, a[28]), + e = k(e, b, c, d, q, 9, a[29]), + d = k(d, e, b, c, v, 14, a[30]), + c = k(c, d, e, b, A, 20, a[31]), + b = l(b, c, d, e, t, 4, a[32]), + e = l(e, b, c, d, w, 11, a[33]), + d = l(d, e, b, c, z, 16, a[34]), + c = l(c, d, e, b, C, 23, a[35]), + b = l(b, c, d, e, p, 4, a[36]), + e = l(e, b, c, d, s, 11, a[37]), + d = l(d, e, b, c, v, 16, a[38]), + c = l(c, d, e, b, y, 23, a[39]), + b = l(b, c, d, e, B, 4, a[40]), + e = l(e, b, c, d, j, 11, a[41]), + d = l(d, e, b, c, r, 16, a[42]), + c = l(c, d, e, b, u, 23, a[43]), + b = l(b, c, d, e, x, 4, a[44]), + e = l(e, b, c, d, A, 11, a[45]), + d = l(d, e, b, c, D, 16, a[46]), + c = l(c, d, e, b, q, 23, a[47]), + b = n(b, c, d, e, j, 6, a[48]), + e = n(e, b, c, d, v, 10, a[49]), + d = n(d, e, b, c, C, 15, a[50]), + c = n(c, d, e, b, t, 21, a[51]), + b = n(b, c, d, e, A, 6, a[52]), + e = n(e, b, c, d, r, 10, a[53]), + d = n(d, e, b, c, y, 15, a[54]), + c = n(c, d, e, b, p, 21, a[55]), + b = n(b, c, d, e, w, 6, a[56]), + e = n(e, b, c, d, D, 10, a[57]), + d = n(d, e, b, c, u, 15, a[58]), + c = n(c, d, e, b, B, 21, a[59]), + b = n(b, c, d, e, s, 6, a[60]), + e = n(e, b, c, d, z, 10, a[61]), + d = n(d, e, b, c, q, 15, a[62]), + c = n(c, d, e, b, x, 21, a[63]); + g[0] = g[0] + b | 0; + g[1] = g[1] + c | 0; + g[2] = g[2] + d | 0; + g[3] = g[3] + e | 0 + }, + _9: function() { + var a = this._2, + f = a.words, + g = 8 * this._22, + j = 8 * a.sigBytes; + f[j >>> 5] |= 128 << 24 - j % 32; + var h = E.floor(g / 4294967296); + f[(j + 64 >>> 9 << 4) + 15] = (h << 8 | h >>> 24) & 16711935 | (h << 24 | h >>> 8) & 4278255360; + f[(j + 64 >>> 9 << 4) + 14] = (g << 8 | g >>> 24) & 16711935 | (g << 24 | g >>> 8) & 4278255360; + a.sigBytes = 4 * (f.length + 1); + this._3(); + a = this._7; + f = a.words; + for (g = 0; 4 > g; g++) j = f[g], f[g] = (j << 8 | j >>> 24) & 16711935 | (j << 24 | j >>> 8) & 4278255360; + return a + }, + clone: function() { + var a = s.clone.call(this); + a._7 = this._7.clone(); + return a + } + }); + r.MD5 = s._6(q); + r.HmacMD5 = s._30(q) + })(Math); + (function() { + for (var q = CryptoJS, x = q.lib.BlockCipher, r = q.algo, j = [], y = [], z = [], A = [], B = [], C = [], s = [], u = [], v = [], w = [], g = [], k = 0; 256 > k; k++) g[k] = 128 > k ? k << 1 : k << 1 ^ 283; + for (var n = 0, l = 0, k = 0; 256 > k; k++) { + var f = l ^ l << 1 ^ l << 2 ^ l << 3 ^ l << 4, + f = f >>> 8 ^ f & 255 ^ 99; + j[n] = f; + y[f] = n; + var t = g[n], + D = g[t], + E = g[D], + b = 257 * g[f] ^ 16843008 * f; + z[n] = b << 24 | b >>> 8; + A[n] = b << 16 | b >>> 16; + B[n] = b << 8 | b >>> 24; + C[n] = b; + b = 16843009 * E ^ 65537 * D ^ 257 * t ^ 16843008 * n; + s[f] = b << 24 | b >>> 8; + u[f] = b << 16 | b >>> 16; + v[f] = b << 8 | b >>> 24; + w[f] = b; + n ? (n = t ^ g[g[g[E ^ t]]], l ^= g[g[l]]) : n = l = 1 + } + var F = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54], + r = r.AES = x.extend({ + _5: function() { + for (var c = this._12, e = c.words, a = c.sigBytes / 4, c = 4 * ((this._26 = a + 6) + 1), b = this._27 = [], h = 0; h < c; h++) + if (h < a) b[h] = e[h]; + else { + var d = b[h - 1]; + h % a ? 6 < a && 4 == h % a && (d = j[d >>> 24] << 24 | j[d >>> 16 & 255] << 16 | j[d >>> 8 & 255] << 8 | j[d & 255]) : (d = d << 8 | d >>> 24, d = j[d >>> 24] << 24 | j[d >>> 16 & 255] << 16 | j[d >>> 8 & 255] << 8 | j[d & 255], d ^= F[h / a | 0] << 24); + b[h] = b[h - a] ^ d + } + e = this._24 = []; + for (a = 0; a < c; a++) h = c - a, d = a % 4 ? b[h] : b[h - 4], e[a] = 4 > a || 4 >= h ? d : s[j[d >>> 24]] ^ u[j[d >>> 16 & 255]] ^ v[j[d >>> 8 & 255]] ^ w[j[d & 255]] + }, + encryptBlock: function(c, e) { + this._4(c, e, this._27, z, A, B, C, j) + }, + decryptBlock: function(c, e) { + var a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a; + this._4(c, e, this._24, s, u, v, w, y); + a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a + }, + _4: function(c, e, a, b, h, d, j, m) { + for (var n = this._26, f = c[e] ^ a[0], g = c[e + 1] ^ a[1], k = c[e + 2] ^ a[2], p = c[e + 3] ^ a[3], l = 4, t = 1; t < n; t++) var q = b[f >>> 24] ^ h[g >>> 16 & 255] ^ d[k >>> 8 & 255] ^ j[p & 255] ^ a[l++], + r = b[g >>> 24] ^ h[k >>> 16 & 255] ^ d[p >>> 8 & 255] ^ j[f & 255] ^ a[l++], + s = b[k >>> 24] ^ h[p >>> 16 & 255] ^ d[f >>> 8 & 255] ^ j[g & 255] ^ a[l++], + p = b[p >>> 24] ^ h[f >>> 16 & 255] ^ d[g >>> 8 & 255] ^ j[k & 255] ^ a[l++], + f = q, + g = r, + k = s; + q = (m[f >>> 24] << 24 | m[g >>> 16 & 255] << 16 | m[k >>> 8 & 255] << 8 | m[p & 255]) ^ a[l++]; + r = (m[g >>> 24] << 24 | m[k >>> 16 & 255] << 16 | m[p >>> 8 & 255] << 8 | m[f & 255]) ^ a[l++]; + s = (m[k >>> 24] << 24 | m[p >>> 16 & 255] << 16 | m[f >>> 8 & 255] << 8 | m[g & 255]) ^ a[l++]; + p = (m[p >>> 24] << 24 | m[f >>> 16 & 255] << 16 | m[g >>> 8 & 255] << 8 | m[k & 255]) ^ a[l++]; + c[e] = q; + c[e + 1] = r; + c[e + 2] = s; + c[e + 3] = p + }, + keySize: 8 + }); + q.AES = x._6(r) + })(); + (function() { + function j(b, c) { + var a = (this._1 >>> b ^ this._0) & c; + this._0 ^= a; + this._1 ^= a << b + } + + function l(b, c) { + var a = (this._0 >>> b ^ this._1) & c; + this._1 ^= a; + this._0 ^= a << b + } + var h = CryptoJS, + e = h.lib, + n = e.WordArray, + e = e.BlockCipher, + g = h.algo, + q = [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], + p = [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], + r = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28], + s = [{ + "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 + }], + t = [4160749569, 528482304, 33030144, 2064384, 129024, 8064, 504, 2147483679], + m = g.DES = e.extend({ + _5: function() { + for (var b = this._12.words, c = [], a = 0; 56 > a; a++) { + var f = q[a] - 1; + c[a] = b[f >>> 5] >>> 31 - f % 32 & 1 + } + b = this._28 = []; + for (f = 0; 16 > f; f++) { + for (var d = b[f] = [], e = r[f], a = 0; 24 > a; a++) d[a / 6 | 0] |= c[(p[a] - 1 + e) % 28] << 31 - a % 6, d[4 + (a / 6 | 0)] |= c[28 + (p[a + 24] - 1 + e) % 28] << 31 - a % 6; + d[0] = d[0] << 1 | d[0] >>> 31; + for (a = 1; 7 > a; a++) d[a] >>>= 4 * (a - 1) + 3; + d[7] = d[7] << 5 | d[7] >>> 27 + } + c = this._29 = []; + for (a = 0; 16 > a; a++) c[a] = b[15 - a] + }, + encryptBlock: function(b, c) { + this._4(b, c, this._28) + }, + decryptBlock: function(b, c) { + this._4(b, c, this._29) + }, + _4: function(b, c, a) { + this._1 = b[c]; + this._0 = b[c + 1]; + j.call(this, 4, 252645135); + j.call(this, 16, 65535); + l.call(this, 2, 858993459); + l.call(this, 8, 16711935); + j.call(this, 1, 1431655765); + for (var f = 0; 16 > f; f++) { + for (var d = a[f], e = this._1, h = this._0, g = 0, k = 0; 8 > k; k++) g |= s[k][((h ^ d[k]) & t[k]) >>> 0]; + this._1 = h; + this._0 = e ^ g + } + a = this._1; + this._1 = this._0; + this._0 = a; + j.call(this, 1, 1431655765); + l.call(this, 8, 16711935); + l.call(this, 2, 858993459); + j.call(this, 16, 65535); + j.call(this, 4, 252645135); + b[c] = this._1; + b[c + 1] = this._0 + }, + keySize: 2, + ivSize: 2, + blockSize: 2 + }); + h.DES = e._6(m); + g = g.TripleDES = e.extend({ + _5: function() { + var b = this._12.words; + this._17 = m.createEncryptor(n.create(b.slice(0, 2))); + this._21 = m.createEncryptor(n.create(b.slice(2, 4))); + this._23 = m.createEncryptor(n.create(b.slice(4, 6))) + }, + encryptBlock: function(b, c) { + this._17.encryptBlock(b, c); + this._21.decryptBlock(b, c); + this._23.encryptBlock(b, c) + }, + decryptBlock: function(b, c) { + this._23.decryptBlock(b, c); + this._21.encryptBlock(b, c); + this._17.decryptBlock(b, c) + }, + keySize: 6, + ivSize: 2, + blockSize: 2 + }); + h.TripleDES = e._6(g) + })(); + var DES = { + encrypt: function(text) { + var secretkey = (CryptoJS.MD5(akb36).toString()).substr(0, 16); + var secretiv = (CryptoJS.MD5(akb48).toString()).substr(24, 8); + secretkey = CryptoJS.enc.Utf8.parse(secretkey); + secretiv = CryptoJS.enc.Utf8.parse(secretiv); + var result = CryptoJS.DES.encrypt(text, secretkey, { + iv: secretiv, + mode: CryptoJS.mode.CBC, + padding: CryptoJS.pad.Pkcs7 + }); + return result.toString() + }, + }; + return b.encode(DES.encrypt(DES.encrypt(DES.encrypt(b.encode(a))))); +} + +function encode_secret() { + var b, + a = appId; + for (b = 0; b < arguments.length; b++) a += arguments[b]; + return (a = a.replace(/\s/g, "")), hex_md5(a); +} + +function decode_result(a) { + var b = new Base64(); + var akb33 = "32223"; + var akb34 = "N4EDAQpO2ejqgCoX"; + var akb35 = "=qoKNLgdAjJbU8zx"; + var akb36 = "mAkJqt8coXQ96zML"; + var akb48 = "t4ABRmeN" + return b.decode(b.decode(b.decode(a))); +} +var hexcase = 0, + b64pad = "", + chrsz = 8, + appId = "a01901d3caba1f362d69474674ce477f"; + +var encode_param = encode_param + + + + +var CryptoJS = CryptoJS || function(h, r) { + var k = {}, + l = k.lib = {}, + n = function() {}, + f = l.Base = { + extend: function(a) { + n.prototype = this; + var b = new n; + a && b.mixIn(a); + b.hasOwnProperty("init") || (b.init = function() { + b.s.init.apply(this, arguments) + }); + b.init.prototype = b; + b.s = this; + return b + }, + create: function() { + var a = this.extend(); + a.init.apply(a, arguments); + return a + }, + init: function() {}, + mixIn: function(a) { + for (var b in a) a.hasOwnProperty(b) && (this[b] = a[b]); + a.hasOwnProperty("toString") && (this.toString = a.toString) + }, + clone: function() { + return this.init.prototype.extend(this) + } + }, + j = l.WordArray = f.extend({ + init: function(a, b) { + a = this.words = a || []; + this.sigBytes = b != r ? b : 4 * a.length + }, + toString: function(a) { + return (a || s).stringify(this) + }, + concat: function(a) { + var b = this.words, + d = a.words, + c = this.sigBytes; + a = a.sigBytes; + this.clamp(); + if (c % 4) + for (var e = 0; e < a; e++) b[c + e >>> 2] |= (d[e >>> 2] >>> 24 - 8 * (e % 4) & 255) << 24 - 8 * ((c + e) % 4); + else if (65535 < d.length) + for (e = 0; e < a; e += 4) b[c + e >>> 2] = d[e >>> 2]; + else b.push.apply(b, d); + this.sigBytes += a; + return this + }, + clamp: function() { + var a = this.words, + b = this.sigBytes; + a[b >>> 2] &= 4294967295 << 32 - 8 * (b % 4); + a.length = h.ceil(b / 4) + }, + clone: function() { + var a = f.clone.call(this); + a.words = this.words.slice(0); + return a + }, + random: function(a) { + for (var b = [], d = 0; d < a; d += 4) b.push(4294967296 * h.random() | 0); + return new j.init(b, a) + } + }), + m = k.enc = {}, + s = m.Hex = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) { + var e = b[c >>> 2] >>> 24 - 8 * (c % 4) & 255; + d.push((e >>> 4).toString(16)); + d.push((e & 15).toString(16)) + } + return d.join("") + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c += 2) d[c >>> 3] |= parseInt(a.substr(c, 2), 16) << 24 - 4 * (c % 8); + return new j.init(d, b / 2) + } + }, + p = m.Latin1 = { + stringify: function(a) { + var b = a.words; + a = a.sigBytes; + for (var d = [], c = 0; c < a; c++) d.push(String.fromCharCode(b[c >>> 2] >>> 24 - 8 * (c % 4) & 255)); + return d.join("") + }, + parse: function(a) { + for (var b = a.length, d = [], c = 0; c < b; c++) d[c >>> 2] |= (a.charCodeAt(c) & 255) << 24 - 8 * (c % 4); + return new j.init(d, b) + } + }, + t = m.Utf8 = { + stringify: function(a) { + try { + return decodeURIComponent(escape(p.stringify(a))) + } catch (b) { + throw Error("Malformed UTF-8 data") + } + }, + parse: function(a) { + return p.parse(unescape(encodeURIComponent(a))) + } + }, + q = l.BufferedBlockAlgorithm = f.extend({ + reset: function() { + this._2 = new j.init; + this._22 = 0 + }, + _8: function(a) { + "string" == typeof a && (a = t.parse(a)); + this._2.concat(a); + this._22 += a.sigBytes + }, + _3: function(a) { + var b = this._2, + d = b.words, + c = b.sigBytes, + e = this.blockSize, + f = c / (4 * e), + f = a ? h.ceil(f) : h.max((f | 0) - this._18, 0); + a = f * e; + c = h.min(4 * a, c); + if (a) { + for (var g = 0; g < a; g += e) this._20(d, g); + g = d.splice(0, a); + b.sigBytes -= c + } + return new j.init(g, c) + }, + clone: function() { + var a = f.clone.call(this); + a._2 = this._2.clone(); + return a + }, + _18: 0 + }); + l.Hasher = q.extend({ + cfg: f.extend(), + init: function(a) { + this.cfg = this.cfg.extend(a); + this.reset() + }, + reset: function() { + q.reset.call(this); + this._5() + }, + update: function(a) { + this._8(a); + this._3(); + return this + }, + finalize: function(a) { + a && this._8(a); + return this._9() + }, + blockSize: 16, + _6: function(a) { + return function(b, d) { + return (new a.init(d)).finalize(b) + } + }, + _30: function(a) { + return function(b, d) { + return (new u.HMAC.init(a, d)).finalize(b) + } + } + }); + var u = k.algo = {}; + return k +}(Math); +(function() { + var h = CryptoJS, + j = h.lib.WordArray; + h.enc.Base64 = { + stringify: function(b) { + var e = b.words, + f = b.sigBytes, + c = this._13; + b.clamp(); + b = []; + for (var a = 0; a < f; a += 3) + for (var d = (e[a >>> 2] >>> 24 - 8 * (a % 4) & 255) << 16 | (e[a + 1 >>> 2] >>> 24 - 8 * ((a + 1) % 4) & 255) << 8 | e[a + 2 >>> 2] >>> 24 - 8 * ((a + 2) % 4) & 255, g = 0; 4 > g && a + 0.75 * g < f; g++) b.push(c.charAt(d >>> 6 * (3 - g) & 63)); + if (e = c.charAt(64)) + for (; b.length % 4;) b.push(e); + return b.join("") + }, + parse: function(b) { + var e = b.length, + f = this._13, + c = f.charAt(64); + c && (c = b.indexOf(c), -1 != c && (e = c)); + for (var c = [], a = 0, d = 0; d < e; d++) + if (d % 4) { + var g = f.indexOf(b.charAt(d - 1)) << 2 * (d % 4), + h = f.indexOf(b.charAt(d)) >>> 6 - 2 * (d % 4); + c[a >>> 2] |= (g | h) << 24 - 8 * (a % 4); + a++ + } + return j.create(c, a) + }, + _13: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" + } +})(); +CryptoJS.lib.Cipher || function(u) { + var g = CryptoJS, + f = g.lib, + k = f.Base, + l = f.WordArray, + q = f.BufferedBlockAlgorithm, + r = g.enc.Base64, + v = g.algo.EvpKDF, + n = f.Cipher = q.extend({ + cfg: k.extend(), + createEncryptor: function(a, b) { + return this.create(this._11, a, b) + }, + createDecryptor: function(a, b) { + return this.create(this._25, a, b) + }, + init: function(a, b, c) { + this.cfg = this.cfg.extend(c); + this._15 = a; + this._12 = b; + this.reset() + }, + reset: function() { + q.reset.call(this); + this._5() + }, + process: function(a) { + this._8(a); + return this._3() + }, + finalize: function(a) { + a && this._8(a); + return this._9() + }, + keySize: 4, + ivSize: 4, + _11: 1, + _25: 2, + _6: function(a) { + return { + encrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).encrypt(a, b, c, d) + }, + decrypt: function(b, c, d) { + return ("string" == typeof c ? s : j).decrypt(a, b, c, d) + } + } + } + }); + f.StreamCipher = n.extend({ + _9: function() { + return this._3(!0) + }, + blockSize: 1 + }); + var m = g.mode = {}, + t = function(a, b, c) { + var d = this._16; + d ? this._16 = u : d = this._19; + for (var e = 0; e < c; e++) a[b + e] ^= d[e] + }, + h = (f.BlockCipherMode = k.extend({ + createEncryptor: function(a, b) { + return this.Encryptor.create(a, b) + }, + createDecryptor: function(a, b) { + return this.Decryptor.create(a, b) + }, + init: function(a, b) { + this._10 = a; + this._16 = b + } + })).extend(); + h.Encryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize; + t.call(this, a, b, d); + c.encryptBlock(a, b); + this._19 = a.slice(b, b + d) + } + }); + h.Decryptor = h.extend({ + processBlock: function(a, b) { + var c = this._10, + d = c.blockSize, + e = a.slice(b, b + d); + c.decryptBlock(a, b); + t.call(this, a, b, d); + this._19 = e + } + }); + m = m.CBC = h; + h = (g.pad = {}).Pkcs7 = { + pad: function(a, b) { + for (var c = 4 * b, c = c - a.sigBytes % c, d = c << 24 | c << 16 | c << 8 | c, e = [], f = 0; f < c; f += 4) e.push(d); + c = l.create(e, c); + a.concat(c) + }, + unpad: function(a) { + a.sigBytes -= a.words[a.sigBytes - 1 >>> 2] & 255 + } + }; + f.BlockCipher = n.extend({ + cfg: n.cfg.extend({ + mode: m, + padding: h + }), + reset: function() { + n.reset.call(this); + var a = this.cfg, + b = a.iv, + a = a.mode; + if (this._15 == this._11) var c = a.createEncryptor; + else c = a.createDecryptor, this._18 = 1; + this._31 = c.call(a, this, b && b.words) + }, + _20: function(a, b) { + this._31.processBlock(a, b) + }, + _9: function() { + var a = this.cfg.padding; + if (this._15 == this._11) { + a.pad(this._2, this.blockSize); + var b = this._3(!0) + } else b = this._3(!0), a.unpad(b); + return b + }, + blockSize: 4 + }); + var p = f.CipherParams = k.extend({ + init: function(a) { + this.mixIn(a) + }, + toString: function(a) { + return (a || this.formatter).stringify(this) + } + }), + m = (g.format = {}).OpenSSL = { + stringify: function(a) { + var b = a.ciphertext; + a = a.salt; + return (a ? l.create([1398893684, 1701076831]).concat(a).concat(b) : b).toString(r) + }, + parse: function(a) { + a = r.parse(a); + var b = a.words; + if (1398893684 == b[0] && 1701076831 == b[1]) { + var c = l.create(b.slice(2, 4)); + b.splice(0, 4); + a.sigBytes -= 16 + } + return p.create({ + ciphertext: a, + salt: c + }) + } + }, + j = f.SerializableCipher = k.extend({ + cfg: k.extend({ + format: m + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + var e = a.createEncryptor(c, d); + b = e.finalize(b); + e = e.cfg; + return p.create({ + ciphertext: b, + key: c, + iv: e.iv, + algorithm: a, + mode: e.mode, + padding: e.padding, + blockSize: a.blockSize, + formatter: d.format + }) + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + return a.createDecryptor(c, d).finalize(b.ciphertext) + }, + _14: function(a, b) { + return "string" == typeof a ? b.parse(a, this) : a + } + }), + g = (g.kdf = {}).OpenSSL = { + execute: function(a, b, c, d) { + d || (d = l.random(8)); + a = v.create({ + keySize: b + c + }).compute(a, d); + c = l.create(a.words.slice(b), 4 * c); + a.sigBytes = 4 * b; + return p.create({ + key: a, + iv: c, + salt: d + }) + } + }, + s = f.PasswordBasedCipher = j.extend({ + cfg: j.cfg.extend({ + kdf: g + }), + encrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + c = d.kdf.execute(c, a.keySize, a.ivSize); + d.iv = c.iv; + a = j.encrypt.call(this, a, b, c.key, d); + a.mixIn(c); + return a + }, + decrypt: function(a, b, c, d) { + d = this.cfg.extend(d); + b = this._14(b, d.format); + c = d.kdf.execute(c, a.keySize, a.ivSize, b.salt); + d.iv = c.iv; + return j.decrypt.call(this, a, b, c.key, d) + } + }) +}(); +CryptoJS.mode.ECB = function() { + var a = CryptoJS.lib.BlockCipherMode.extend(); + a.Encryptor = a.extend({ + processBlock: function(a, b) { + this._10.encryptBlock(a, b) + } + }); + a.Decryptor = a.extend({ + processBlock: function(a, b) { + this._10.decryptBlock(a, b) + } + }); + return a +}(); +(function(E) { + function h(a, f, g, j, p, h, k) { + a = a + (f & g | ~f & j) + p + k; + return (a << h | a >>> 32 - h) + f + } + + function k(a, f, g, j, p, h, k) { + a = a + (f & j | g & ~j) + p + k; + return (a << h | a >>> 32 - h) + f + } + + function l(a, f, g, j, h, k, l) { + a = a + (f ^ g ^ j) + h + l; + return (a << k | a >>> 32 - k) + f + } + + function n(a, f, g, j, h, k, l) { + a = a + (g ^ (f | ~j)) + h + l; + return (a << k | a >>> 32 - k) + f + } + for (var r = CryptoJS, q = r.lib, F = q.WordArray, s = q.Hasher, q = r.algo, a = [], t = 0; 64 > t; t++) a[t] = 4294967296 * E.abs(E.sin(t + 1)) | 0; + q = q.MD5 = s.extend({ + _5: function() { + this._7 = new F.init([1732584193, 4023233417, 2562383102, 271733878]) + }, + _20: function(m, f) { + for (var g = 0; 16 > g; g++) { + var j = f + g, + p = m[j]; + m[j] = (p << 8 | p >>> 24) & 16711935 | (p << 24 | p >>> 8) & 4278255360 + } + var g = this._7.words, + j = m[f + 0], + p = m[f + 1], + q = m[f + 2], + r = m[f + 3], + s = m[f + 4], + t = m[f + 5], + u = m[f + 6], + v = m[f + 7], + w = m[f + 8], + x = m[f + 9], + y = m[f + 10], + z = m[f + 11], + A = m[f + 12], + B = m[f + 13], + C = m[f + 14], + D = m[f + 15], + b = g[0], + c = g[1], + d = g[2], + e = g[3], + b = h(b, c, d, e, j, 7, a[0]), + e = h(e, b, c, d, p, 12, a[1]), + d = h(d, e, b, c, q, 17, a[2]), + c = h(c, d, e, b, r, 22, a[3]), + b = h(b, c, d, e, s, 7, a[4]), + e = h(e, b, c, d, t, 12, a[5]), + d = h(d, e, b, c, u, 17, a[6]), + c = h(c, d, e, b, v, 22, a[7]), + b = h(b, c, d, e, w, 7, a[8]), + e = h(e, b, c, d, x, 12, a[9]), + d = h(d, e, b, c, y, 17, a[10]), + c = h(c, d, e, b, z, 22, a[11]), + b = h(b, c, d, e, A, 7, a[12]), + e = h(e, b, c, d, B, 12, a[13]), + d = h(d, e, b, c, C, 17, a[14]), + c = h(c, d, e, b, D, 22, a[15]), + b = k(b, c, d, e, p, 5, a[16]), + e = k(e, b, c, d, u, 9, a[17]), + d = k(d, e, b, c, z, 14, a[18]), + c = k(c, d, e, b, j, 20, a[19]), + b = k(b, c, d, e, t, 5, a[20]), + e = k(e, b, c, d, y, 9, a[21]), + d = k(d, e, b, c, D, 14, a[22]), + c = k(c, d, e, b, s, 20, a[23]), + b = k(b, c, d, e, x, 5, a[24]), + e = k(e, b, c, d, C, 9, a[25]), + d = k(d, e, b, c, r, 14, a[26]), + c = k(c, d, e, b, w, 20, a[27]), + b = k(b, c, d, e, B, 5, a[28]), + e = k(e, b, c, d, q, 9, a[29]), + d = k(d, e, b, c, v, 14, a[30]), + c = k(c, d, e, b, A, 20, a[31]), + b = l(b, c, d, e, t, 4, a[32]), + e = l(e, b, c, d, w, 11, a[33]), + d = l(d, e, b, c, z, 16, a[34]), + c = l(c, d, e, b, C, 23, a[35]), + b = l(b, c, d, e, p, 4, a[36]), + e = l(e, b, c, d, s, 11, a[37]), + d = l(d, e, b, c, v, 16, a[38]), + c = l(c, d, e, b, y, 23, a[39]), + b = l(b, c, d, e, B, 4, a[40]), + e = l(e, b, c, d, j, 11, a[41]), + d = l(d, e, b, c, r, 16, a[42]), + c = l(c, d, e, b, u, 23, a[43]), + b = l(b, c, d, e, x, 4, a[44]), + e = l(e, b, c, d, A, 11, a[45]), + d = l(d, e, b, c, D, 16, a[46]), + c = l(c, d, e, b, q, 23, a[47]), + b = n(b, c, d, e, j, 6, a[48]), + e = n(e, b, c, d, v, 10, a[49]), + d = n(d, e, b, c, C, 15, a[50]), + c = n(c, d, e, b, t, 21, a[51]), + b = n(b, c, d, e, A, 6, a[52]), + e = n(e, b, c, d, r, 10, a[53]), + d = n(d, e, b, c, y, 15, a[54]), + c = n(c, d, e, b, p, 21, a[55]), + b = n(b, c, d, e, w, 6, a[56]), + e = n(e, b, c, d, D, 10, a[57]), + d = n(d, e, b, c, u, 15, a[58]), + c = n(c, d, e, b, B, 21, a[59]), + b = n(b, c, d, e, s, 6, a[60]), + e = n(e, b, c, d, z, 10, a[61]), + d = n(d, e, b, c, q, 15, a[62]), + c = n(c, d, e, b, x, 21, a[63]); + g[0] = g[0] + b | 0; + g[1] = g[1] + c | 0; + g[2] = g[2] + d | 0; + g[3] = g[3] + e | 0 + }, + _9: function() { + var a = this._2, + f = a.words, + g = 8 * this._22, + j = 8 * a.sigBytes; + f[j >>> 5] |= 128 << 24 - j % 32; + var h = E.floor(g / 4294967296); + f[(j + 64 >>> 9 << 4) + 15] = (h << 8 | h >>> 24) & 16711935 | (h << 24 | h >>> 8) & 4278255360; + f[(j + 64 >>> 9 << 4) + 14] = (g << 8 | g >>> 24) & 16711935 | (g << 24 | g >>> 8) & 4278255360; + a.sigBytes = 4 * (f.length + 1); + this._3(); + a = this._7; + f = a.words; + for (g = 0; 4 > g; g++) j = f[g], f[g] = (j << 8 | j >>> 24) & 16711935 | (j << 24 | j >>> 8) & 4278255360; + return a + }, + clone: function() { + var a = s.clone.call(this); + a._7 = this._7.clone(); + return a + } + }); + r.MD5 = s._6(q); + r.HmacMD5 = s._30(q) +})(Math); +(function() { + for (var q = CryptoJS, x = q.lib.BlockCipher, r = q.algo, j = [], y = [], z = [], A = [], B = [], C = [], s = [], u = [], v = [], w = [], g = [], k = 0; 256 > k; k++) g[k] = 128 > k ? k << 1 : k << 1 ^ 283; + for (var n = 0, l = 0, k = 0; 256 > k; k++) { + var f = l ^ l << 1 ^ l << 2 ^ l << 3 ^ l << 4, + f = f >>> 8 ^ f & 255 ^ 99; + j[n] = f; + y[f] = n; + var t = g[n], + D = g[t], + E = g[D], + b = 257 * g[f] ^ 16843008 * f; + z[n] = b << 24 | b >>> 8; + A[n] = b << 16 | b >>> 16; + B[n] = b << 8 | b >>> 24; + C[n] = b; + b = 16843009 * E ^ 65537 * D ^ 257 * t ^ 16843008 * n; + s[f] = b << 24 | b >>> 8; + u[f] = b << 16 | b >>> 16; + v[f] = b << 8 | b >>> 24; + w[f] = b; + n ? (n = t ^ g[g[g[E ^ t]]], l ^= g[g[l]]) : n = l = 1 + } + var F = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54], + r = r.AES = x.extend({ + _5: function() { + for (var c = this._12, e = c.words, a = c.sigBytes / 4, c = 4 * ((this._26 = a + 6) + 1), b = this._27 = [], h = 0; h < c; h++) + if (h < a) b[h] = e[h]; + else { + var d = b[h - 1]; + h % a ? 6 < a && 4 == h % a && (d = j[d >>> 24] << 24 | j[d >>> 16 & 255] << 16 | j[d >>> 8 & 255] << 8 | j[d & 255]) : (d = d << 8 | d >>> 24, d = j[d >>> 24] << 24 | j[d >>> 16 & 255] << 16 | j[d >>> 8 & 255] << 8 | j[d & 255], d ^= F[h / a | 0] << 24); + b[h] = b[h - a] ^ d + } + e = this._24 = []; + for (a = 0; a < c; a++) h = c - a, d = a % 4 ? b[h] : b[h - 4], e[a] = 4 > a || 4 >= h ? d : s[j[d >>> 24]] ^ u[j[d >>> 16 & 255]] ^ v[j[d >>> 8 & 255]] ^ w[j[d & 255]] + }, + encryptBlock: function(c, e) { + this._4(c, e, this._27, z, A, B, C, j) + }, + decryptBlock: function(c, e) { + var a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a; + this._4(c, e, this._24, s, u, v, w, y); + a = c[e + 1]; + c[e + 1] = c[e + 3]; + c[e + 3] = a + }, + _4: function(c, e, a, b, h, d, j, m) { + for (var n = this._26, f = c[e] ^ a[0], g = c[e + 1] ^ a[1], k = c[e + 2] ^ a[2], p = c[e + 3] ^ a[3], l = 4, t = 1; t < n; t++) var q = b[f >>> 24] ^ h[g >>> 16 & 255] ^ d[k >>> 8 & 255] ^ j[p & 255] ^ a[l++], + r = b[g >>> 24] ^ h[k >>> 16 & 255] ^ d[p >>> 8 & 255] ^ j[f & 255] ^ a[l++], + s = b[k >>> 24] ^ h[p >>> 16 & 255] ^ d[f >>> 8 & 255] ^ j[g & 255] ^ a[l++], + p = b[p >>> 24] ^ h[f >>> 16 & 255] ^ d[g >>> 8 & 255] ^ j[k & 255] ^ a[l++], + f = q, + g = r, + k = s; + q = (m[f >>> 24] << 24 | m[g >>> 16 & 255] << 16 | m[k >>> 8 & 255] << 8 | m[p & 255]) ^ a[l++]; + r = (m[g >>> 24] << 24 | m[k >>> 16 & 255] << 16 | m[p >>> 8 & 255] << 8 | m[f & 255]) ^ a[l++]; + s = (m[k >>> 24] << 24 | m[p >>> 16 & 255] << 16 | m[f >>> 8 & 255] << 8 | m[g & 255]) ^ a[l++]; + p = (m[p >>> 24] << 24 | m[f >>> 16 & 255] << 16 | m[g >>> 8 & 255] << 8 | m[k & 255]) ^ a[l++]; + c[e] = q; + c[e + 1] = r; + c[e + 2] = s; + c[e + 3] = p + }, + keySize: 8 + }); + q.AES = x._6(r) +})(); +(function() { + function j(b, c) { + var a = (this._1 >>> b ^ this._0) & c; + this._0 ^= a; + this._1 ^= a << b + } + + function l(b, c) { + var a = (this._0 >>> b ^ this._1) & c; + this._1 ^= a; + this._0 ^= a << b + } + var h = CryptoJS, + e = h.lib, + n = e.WordArray, + e = e.BlockCipher, + g = h.algo, + q = [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], + p = [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], + r = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28], + s = [{ + "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 + }], + t = [4160749569, 528482304, 33030144, 2064384, 129024, 8064, 504, 2147483679], + m = g.DES = e.extend({ + _5: function() { + for (var b = this._12.words, c = [], a = 0; 56 > a; a++) { + var f = q[a] - 1; + c[a] = b[f >>> 5] >>> 31 - f % 32 & 1 + } + b = this._28 = []; + for (f = 0; 16 > f; f++) { + for (var d = b[f] = [], e = r[f], a = 0; 24 > a; a++) d[a / 6 | 0] |= c[(p[a] - 1 + e) % 28] << 31 - a % 6, d[4 + (a / 6 | 0)] |= c[28 + (p[a + 24] - 1 + e) % 28] << 31 - a % 6; + d[0] = d[0] << 1 | d[0] >>> 31; + for (a = 1; 7 > a; a++) d[a] >>>= 4 * (a - 1) + 3; + d[7] = d[7] << 5 | d[7] >>> 27 + } + c = this._29 = []; + for (a = 0; 16 > a; a++) c[a] = b[15 - a] + }, + encryptBlock: function(b, c) { + this._4(b, c, this._28) + }, + decryptBlock: function(b, c) { + this._4(b, c, this._29) + }, + _4: function(b, c, a) { + this._1 = b[c]; + this._0 = b[c + 1]; + j.call(this, 4, 252645135); + j.call(this, 16, 65535); + l.call(this, 2, 858993459); + l.call(this, 8, 16711935); + j.call(this, 1, 1431655765); + for (var f = 0; 16 > f; f++) { + for (var d = a[f], e = this._1, h = this._0, g = 0, k = 0; 8 > k; k++) g |= s[k][((h ^ d[k]) & t[k]) >>> 0]; + this._1 = h; + this._0 = e ^ g + } + a = this._1; + this._1 = this._0; + this._0 = a; + j.call(this, 1, 1431655765); + l.call(this, 8, 16711935); + l.call(this, 2, 858993459); + j.call(this, 16, 65535); + j.call(this, 4, 252645135); + b[c] = this._1; + b[c + 1] = this._0 + }, + keySize: 2, + ivSize: 2, + blockSize: 2 + }); + h.DES = e._6(m); + g = g.TripleDES = e.extend({ + _5: function() { + var b = this._12.words; + this._17 = m.createEncryptor(n.create(b.slice(0, 2))); + this._21 = m.createEncryptor(n.create(b.slice(2, 4))); + this._23 = m.createEncryptor(n.create(b.slice(4, 6))) + }, + encryptBlock: function(b, c) { + this._17.encryptBlock(b, c); + this._21.decryptBlock(b, c); + this._23.encryptBlock(b, c) + }, + decryptBlock: function(b, c) { + this._23.decryptBlock(b, c); + this._21.encryptBlock(b, c); + this._17.decryptBlock(b, c) + }, + keySize: 6, + ivSize: 2, + blockSize: 2 + }); + h.TripleDES = e._6(g) +})(); \ No newline at end of file diff --git a/adata/common/js/ths.js b/adata/common/js/ths.js new file mode 100644 index 0000000..9fb8a00 --- /dev/null +++ b/adata/common/js/ths.js @@ -0,0 +1,989 @@ +var TOKEN_SERVER_TIME = 1572845499.629; +function v_cookie (r, n, t, e, a) { + var u = n[0], + c = n[1], + v = a[0], + s = t[0], + f = t[1], + l = r[0], + d = hr(a[1], e[0], t[2]), + p = t[3], + h = e[1], + g = yr(a[2], a[3], e[2]), + m = yr(a[4], r[1], t[4]), + w = r[2], + I = a[5], + _ = a[6], + y = a[7], + E = hr(n[2], r[3], r[4]), + A = t[5], + C = e[3], + b = e[4], + B = t[6], + R = a[8], + T = a[9], + S = n[3], + k = t[7], + x = t[8], + O = a[10], + L = n[4], + M = n[5], + N = a[11], + P = e[5], + j = hr(n[6], e[6], t[9], r[5]), + D = t[10], + W = e[7], + $ = r[6], + F = yr(r[7], t[11], e[8], n[7]), + X = r[8], + H = t[12], + K = r[9], + U = n[8], + V = e[9], + Y = r[10], + J = e[10], + q = r[11], + Q = a[12], + Z = n[9], + G = t[13], + z = t[14], + rr = t[15], + nr = n[10], + tr = a[13], + er = a[14], + ar = e[11], + or = r[12], + ir = yr(t[16], r[13], r[14], r[15]), + ur = t[17], + cr = t[18]; + function vr () { + var r = arguments[n[11]]; + return r.split(n[12]).reverse().join(e[12]) + } + var sr = [new e[13](hr(a[15], n[13], a[16])), new e[13](a[17])]; + function fr () { + var n = arguments[a[18]]; + if (!n) return a[19]; + for (var o = t[19], i = e[14], u = e[15]; u < n.length; u++) + { + var c = n.charCodeAt(u), + v = c ^ i; + i = c, + o += r[16].fromCharCode(v) + } + return o + } + var lr = '', + dr; ! + function (o) { + var i = e[18], + c = e[19]; + o[e[20]] = a[21]; + function v (t, a, o, i, u) { + var c, v, s; + c = v = s = r; + var f, l, d; + f = l = d = n; + var p, h, g; + p = h = g = e; + var m = t + g[21] + a; + i && (m += l[15] + i), + u && (m += h[22] + u), + o && (m += v[17] + o), + l[14][g[23]] = m + } + o[e[24]] = l; + function s (t, e, a) { + var o = n[16]; + this.setCookie(t, r[18], i + o + c, e, a) + } + o[t[22]] = f; + function f (o) { + var i = vr(e[25], a[22]), + c = a[23][n[17]], + v = u + i + o + t[23], + s = ''; + if (s == -r[19]) + { + if (v = o + t[23], c.substr(a[24], v.length) != v) return; + s = a[24] + } + var f = s + v[r[20]], + l = ''; + return l == -e[26] && (l = c[t[24]]) + + } + o[e[27]] = v; + function l () { + var r, t, a; + r = t = a = e; + var i, u, c; + i = u = c = n; + var v = u[18]; + this.setCookie(v, a[28]), + this.getCookie(v) || (o[i[19]] = u[20]), + this.delCookie(v) + } + o[n[21]] = s + }(dr || (dr = {})); + var pr; + function hr () { + var r = arguments[a[25]]; + if (!r) return a[19]; + for (var e = a[19], o = t[25], i = n[22], u = t[18]; u < r.length; u++) + { + var c = r.charCodeAt(u); + i = (i + t[26]) % o.length, + c ^= o.charCodeAt(i), + e += String.fromCharCode(c) + } + return e + } ! + function (o) { + var i, u, d; + i = u = d = a; + var p, h, g; + p = h = g = t; + var m, w, I; + m = w = I = r; + var _, y, E; + _ = y = E = n; + var b, B, R; + b = B = R = e; + var T = B[29], + S = y[23], + k = m[22], + x = w[0], + O = E[24], + L = (C, Ar, R[30]), + M = b[31], + N = T + S, + P = p[28], + j, + W = m[23][y[25]], + $, + F; + function X (r) { + return function () { + F.appendChild(j), + j.addBehavior(u[26]), + j.load(N); + var n = r(); + return F.removeChild(j), + n + } + } + function H () { + var r = A; + r = D; + try + { + return !!(N in B[32] && b[32][N]) + } catch (n) + { + return void B[15] + } + } + function K (r) { + return P ? G(r) : j ? Y(r) : void _[26] + } + function U () { + if (P = H(), P) j = _[27][N]; + else if (W[k + c][I[24]]) try + { + $ = new ActiveXObject(vr(I[25], y[28], w[26])), + $.open(), + $.write(y[29]), + $.close(), + F = $.w[B[33]][I[27]][_[30]], + j = F.createElement(I[28]) + } catch (r) + { + j = W.createElement(N), + F = W[vr(I[29], d[27])] || W.getElementsByTagName(b[17])[I[27]] || W[m[30]] + } + } + o[w[31]] = U; + function V (r, n) { + var t = J; + if (void 0 === n) return Z(r); + if (t = sr, P) z(r, n); + else + { + if (!j) return void B[15]; + Q(r, n) + } + } + o[v + x] = V; + function Y (r) { + X(function () { + return r = J(r), + j.getAttribute(r) + })() + } + function J (r) { + var n = z; + n = v; + var t = vr(Ir, w[32]), + e = new y[31](t + O + s + L, b[31]); + return r.replace(new B[13](d[28]), b[34]).replace(e, p[29]) + } + function q (r) { + try + { + j.removeItem(r) + } catch (n) { } + } + o[M + f + l] = K; + function Q (r, n) { + var t = G; + t = cr, + X(function () { + var t = M; + r = J(r), + t = K; + try + { + j.setAttribute(r, n), + j.save(N) + } catch (e) { } + })() + } + function Z (r) { + var n, t, e; + if (n = t = e = g, P) q(r); + else + { + if (!j) return void t[18]; + rr(r) + } + } + function G (r) { + try + { + return j.getItem(r) + } catch (n) + { + return y[20] + } + } + o[fr(w[33], p[30], R[35])] = Z; + function z (r, n) { + try + { + j.setItem(r, n) + } catch (t) { } + } + function rr (r) { + X(function () { + r = J(r), + j.removeAttribute(r), + j.save(N) + })() + } + }(pr || (pr = {})); + var gr = function () { + var o, i, u; + o = i = u = e; + var c, v, s; + c = v = s = a; + var f, l, g; + f = l = g = n; + var m, w, I; + m = w = I = t; + var _, E, A; + _ = E = A = r; + var C = yr(Cr, U, _[34]), + b = vr(A[35], m[31]), + R = hr(g[32], c[29], i[36]), + T = hr(l[33], g[34], i[37], tr); + function S (r) { + this[m[32]] = r; + for (var n = o[15], t = r[i[38]]; t > n; n++) this[n] = i[15] + } + return S[d + p + C][b + h] = function () { + for (var r = this[vr(h, E[36], E[37])], n = [], t = -I[26], e = o[15], a = r[A[20]]; a > e; e++) for (var u = this[e], f = r[e], d = t += f; n[d] = u & parseInt(v[30], l[35]), --f != s[24];)--d, + u >>= parseInt(i[39], c[31]); + return n + }, + S[vr(w[33], v[32])][_[38]] = function (r) { + var n = dr, + t = this[vr(y, l[36], A[39])], + e = f[26]; + n = B; + for (var a = v[24], o = t[l[37]]; o > a; a++) + { + var i = t[a], + u = l[26]; + do u = (u << parseInt(R + T, g[35])) + r[e++]; + while (--i > w[18]); + this[a] = u >>> w[18] + } + }, + S + }(), + mr; ! + function (o) { + var i, u, c; + i = u = c = n; + var v, s, f; + v = s = f = e; + var l, d, p; + l = d = p = a; + var h, w, I; + h = w = I = r; + var _, y, E; + _ = y = E = t; + var A = y[34], + C = (nr, U, h[40]), + b = p[25]; + function B (r) { + for (var n = y[35], t = f[15], e = r[vr(c[38], I[41], H)], a = []; e > t;) + { + var o = k[r.charAt(t++)] << parseInt(g + A, d[31]) | k[r.charAt(t++)] << parseInt(n + m, h[42]) | k[r.charAt(t++)] << parseInt(I[43], i[35]) | k[r.charAt(t++)]; + a.push(o >> parseInt(_[36], h[42]), o >> l[31] & parseInt(u[39], i[40]), o & parseInt(d[30], c[35])) + } + return a + } + function T (r) { + for (var n = (O, R, p[24]), t = I[27], e = r[E[24]]; e > t; t++) n = (n << E[37]) - n + r[t]; + return n & parseInt(E[38], p[33]) + } + for (var S = s[40], k = {}, + x = s[15]; x < parseInt(I[44], l[34]); x++) k[S.charAt(x)] = x; + function L (r) { + var n = B(r), + t = n[u[26]]; + if (t != b) return error = yr(V, u[41], s[41], v[42]), + void 0; + var e = n[s[26]], + a = []; + return P(n, +_[39], a, +_[18], e), + T(a) == e ? a : void 0 + } + function M (r) { + var n = T(r), + t = [b, n]; + return P(r, +l[24], t, +p[25], n), + N(t) + } + function N (r) { + var n, t, e; + n = t = e = f; + var a, o, u; + a = o = u = y; + var c, v, s; + c = v = s = h; + var d, p, g; + d = p = g = l; + var m, w, I; + m = w = I = i; + for (var _ = m[42], E = d[24], A = r[c[20]], b = []; A > E;) + { + var B = r[E++] << parseInt(fr(Z, d[35]), o[39]) | r[E++] << g[31] | r[E++]; + b.push(S.charAt(B >> parseInt(m[43], t[43])), S.charAt(B >> parseInt(p[36], o[40]) & parseInt(I[44], I[45])), S.charAt(B >> n[44] & parseInt(_ + C, n[42])), S.charAt(B & parseInt(fr(d[37], c[45], or), a[41]))) + } + return b.join(o[19]) + } + function P (r, n, t, e, a) { + var o, i, u; + o = i = u = w; + var c, v, s; + c = v = s = E; + for (var f = r[v[24]]; f > n;) t[e++] = r[n++] ^ a & parseInt(u[46], s[42]), + a = ~(a * parseInt(v[43], v[40])) + } + o[E[44]] = N, + o[_[45]] = B, + o[v[45]] = M, + o[y[46]] = L + }(mr || (mr = {})); + var wr; ! + function (o) { + var i = a[38], + u = r[47], + c = t[47], + v = vr(n[46], a[39], a[40]), + s = e[46], + f = e[47], + l = a[41], + d = a[42]; + function p (o) { + var i = a[43], + u = vr(n[47], e[48], n[48]), + c = {}, + v = function (o, c) { + var s, f, l, d; + for (c = c.replace(n[49], n[12]), c = c.substring(e[26], c[e[38]] - e[26]), s = c.split(e[49]), l = a[24]; l < s[yr(v, sr, t[48])]; l++) if (f = s[l].split(n[50]), f && !(f[a[44]] < t[39])) + { + for (d = n[35]; d < f[r[20]]; d++) f[n[11]] = f[n[11]] + r[48] + f[d]; + f[n[26]] = new a[45](r[49]).test(f[n[26]]) ? f[e[15]].substring(r[19], f[e[15]][a[44]] - n[11]) : f[n[26]], + f[n[11]] = new r[50](i + u + w).test(f[n[11]]) ? f[e[26]].substring(t[26], f[r[19]][n[37]] - t[26]) : f[a[18]], + o[f[r[27]]] = f[n[11]] + } + return o + }; + return new a[45](I + _).test(o) && (c = v(c, o)), + c + } + function h (n) { + for (var t = [], e = a[24]; e < n[r[20]]; e++) t.push(n.charCodeAt(e)); + return t + } + function g (o) { + var u = a[46]; + if (typeof o === vr(O, a[47], or) && o[a[48]]) try + { + var c = parseInt(o[a[48]]); + switch (c) + { + case parseInt(i + u, t[42]): break; + case parseInt(yr(t[49], r[51], e[50]), e[43]): top[t[50]][n[51]] = o[e[51]]; + break; + case parseInt(yr(a[25], j, e[52]), n[52]): top[n[53]][t[51]] = o[t[52]] + } + } catch (v) { } + } + function m (r, n, t) { + + } + function L () { + var e, a, o; + e = a = o = r; + var i, u, c; + i = u = c = n; + var v, s, f; + v = s = f = t; + var l = f[53], + d = c[54], + p = new e[52]; + return typeof TOKEN_SERVER_TIME == y + l + d ? s[18] : (time = parseInt(TOKEN_SERVER_TIME), time) + } + function M () { + var o = new t[54]; + try + { + return time = n[2].now(), + time / parseInt(fr(a[50], a[51], r[53]), t[40]) >>> e[15] + } catch (i) + { + return time = o.getTime(), + time / parseInt(e[53], a[25]) >>> r[27] + } + } + function N (r) { + for (var a = t[18], o = r[t[24]] - n[11]; o >= e[15]; o--) a = a << e[26] | +r[o]; + return a + } + function P (a) { + var o = new r[50](n[55]); + if (K(a)) return a; + var i = o.test(a) ? -e[54] : -t[39], + u = a.split(r[54]); + return u.slice(i).join(fr(n[56], t[55], E)) + } + function j (t) { + for (var o = n[26], i = e[15], u = t[vr(r[55], a[52], D)]; u > i; i++) o = (o << r[56]) - o + t.charCodeAt(i), + o >>>= n[26]; + return o + } + function W (n, o) { + var i = new a[45](t[56], yr(r[57], $, t[57], r[58])), + u = new a[45](t[58]); + if (n) + { + var c = n.match(i); + if (c) + { + var v = c[e[26]]; + return o && u.test(v) && (v = v.split(t[59]).pop().split(r[48])[e[15]]), + v + } + } + } + function $ (o) { + var i = n[57], + u = vr(e[55], e[56]), + f = e[4]; + if (!(o > t[60])) + { + o = o || a[24]; + var l = parseInt(E + c + A, r[42]), + d = n[14].createElement(e[57]); + d[r[59]] = n[58] + parseInt((new a[53]).getTime() / l) + r[60], + d[r[61]] = function () { + var n = a[46]; + cr = r[19], + setTimeout(function () { + $(++o) + }, + o * parseInt(C + n, a[33])) + }, + d[t[61]] = d[hr(a[54], a[55], t[62])] = function () { + var a = n[59]; + this[i + v + u + b] && this[e[58]] !== n[60] && this[s + B + a + f] !== e[59] && this[t[63]] !== n[61] || (cr = e[15], d[hr(N, r[62], n[62], e[25])] = d[t[64]] = r[63]) + }, + e[60][e[61]].appendChild(d) + } + } + function F () { + var r = a[56]; + return Math.random() * parseInt(R + T + f + r, t[42]) >>> n[26] + } + function X (r) { + var e = new n[31](fr(t[65], t[66], a[57]), yr(c, n[63], t[57])); + if (r) + { + var o = r.match(e); + return o + } + } + o[S + k] = p, + o[r[64]] = $, + o[t[67]] = g, + o[t[68]] = h, + o[t[69]] = j, + o[t[70]] = F, + o[r[65]] = K, + o[x + l] = P, + o[t[71]] = W, + o[t[72]] = X, + o[hr(r[66], t[73], r[67], C)] = N, + o[t[74]] = M, + o[d + O] = L; + function K (n) { + return new r[50](t[75]).test(n) + } + o[r[68]] = m + }(wr || (wr = {})); + var Ir; ! + function (o) { + var i = t[76], + u = t[77], + c = n[65], + v = t[78], + s = a[24], + f = n[26], + l = t[18], + d = t[18], + p = e[15], + h = a[24], + g = r[69], + m = ''; + wr.eventBind(e[60], n[67], E), + wr.eventBind(r[71], t[79], E), + wr.eventBind(t[20], hr(e[64], A, a[59]), b), + wr.eventBind(e[60], r[72], y); + function w () { + return f + } + function I (r) { + f++ + } + function _ () { + return { + x: p, + y: h, + trusted: g + } + } + function y (r) { + d++ + } + function E (r) { + s++ + } + function C () { + return l + } + function b (r) { + var o, i, u; + o = i = u = n; + var c, s, f; + c = s = f = t; + var d, m, w; + d = m = w = e; + var I, _, y; + I = _ = y = a; + var E = I[60], + A = d[65]; + l++ , + g = void 0 == r[E + A + v] || r[yr(f[80], s[81], i[68])], + p = r[s[82]], + h = r[c[83]] + } + function B () { + return d + } + function R () { + return s + } + o[r[73]] = R, + o[a[61]] = w, + o[fr(a[62], n[69])] = C, + o[n[70]] = B, + o[r[74]] = _ + }(Ir || (Ir = {})); + var _r; ! + function (u) { + var v = fr(n[71], t[84]), + s = r[75], + f = yr(dr, n[72], e[66], $), + l = r[76], + d = e[67], + p = r[77], + h = hr(dr, r[78], a[63], n[73]), + g = r[79], + m = n[74]; + BROWSER_LIST = { + + }; + function w () { + var t, e, a; + t = e = a = r; + var o, i, u; + o = i = u = n; + return wr.booleanToDecimal(c) + } + function I (t) { + for (var o = n[26]; o < y[e[38]]; o++) + { + var i = y[o][r[94]]; + if (t.test(i)) return !a[24] + } + return !a[18] + } + function E (t) { + + } + function A () { + return a[73] + } + + function B () { + return n[20] + } + + function T () { + return I(new t[93](r[96])) + } + function S () { + return I(new a[45](t[98], r[97])) + } + function k () { + for (var r in BROWSER_LIST) if (BROWSER_LIST.hasOwnProperty(r)) + { + var n = BROWSER_LIST[r]; + if (n()) return + r.substr(a[18]) + } + return e[15] + } + function x () { + var n, a, o; + n = a = o = r; + var i, u, c; + i = u = c = t; + var v, s, f; + v = s = f = e; + var l = s[75], + d = s[76]; + return I(new u[93](o[98], v[71])) || E(l + F + d + X) + } + function O () { + + } + function L () { + var r, n, t; + r = n = t = a; + var o, i, u; + o = i = u = e; + var c = l; + return c = p + } + function M () { + var r, n, a; + r = n = a = t; + var o, i, u; + o = i = u = e; + var c; + try + { + c = i[60].createElement(a[99]).getContext(i[78]) + } catch (v) { } + return !!c + } + + + function J () { + var t, e, o; + t = e = o = n; + var i, u, c; + i = u = c = a; + var v, s, f; + return v = s = f = r, + -parseInt(s[100], c[31]) === (new e[2]).getTimezoneOffset() + } + + function Q () { + try + { + } catch (e) + { + return r[101] + } + } + function Z () { + var n, a, o; + n = a = o = e; + var i, u, c; + i = u = c = r; + var v, s, f; + return v = s = f = t, + plugin_num = s[18], + plugin_num + } + var z = [R, x, S, T, L, Q, b, V, O, J, M, q, Y, B, tr, A]; + + var nr = [new e[13](n[85]), new n[31](e[82]), new r[50](e[83]), new r[50](t[102]), new n[31](e[84]), new a[45](a[78]), new a[45](e[85]), new e[13](t[103]), new a[45](r[103]), new t[93](r[104]), new a[45](r[105])]; + function tr () { + return e[86] + } + u[e[87]] = rr, + u[a[79]] = k, + u[yr(c, e[88], r[106])] = Z, + u[K + U + m] = w + }(_r || (_r = {})); + function yr () { + var o = arguments[a[25]]; + if (!o) return t[19]; + for (var i = a[19], u = e[14], c = r[27]; c < o.length; c++) + { + var v = o.charCodeAt(c), + s = v ^ u; + u = u * c % a[80] + e[89], + i += n[86].fromCharCode(s) + } + return i + } + var Er; ! + function (o) { + var i = a[81], + u = t[35], + c = r[107], + v = vr(S, a[56]), + f = r[27], + l = r[19], + d = a[25], + p = n[87], + h = parseInt(e[90], r[108]), + g = a[82], + m = parseInt(vr(s, t[104]), t[39]), + w = r[109], + I = t[40], + _ = parseInt(i + V, n[45]), + y = parseInt(u + c, n[52]), + E = parseInt(t[105], r[42]), + A = e[91], + C = parseInt(Y + v, r[42]), + b = parseInt(e[92], e[93]), + B = t[106], + R = parseInt(vr(e[94], e[95]), t[41]), + T = parseInt(a[83], e[93]), + k; + function x () { + var r = M(); + return r + } + function O () { + var r = t[26], + a = n[35], + o = e[54], + i = n[88]; + k = new gr([i, i, i, i, r, r, r, o, a, a, a, a, a, a, a, i, a, r]), + k[l] = wr.serverTimeNow(), + L(), + k[B] = cr, + k[T] = ur, + k[R] = e[15], + k[C] = _r.getBrowserFeature(), + k[g] = _r.getBrowserIndex(), + k[m] = _r.getPluginNum() + } + function L () { + var a = dr.getCookie(tr) || pr.get(ar); + if (a && a[r[20]] == parseInt(e[96], n[52])) + { + var o = mr.decode(a); + if (o && (k.decodeBuffer(o), k[f] != t[18])) return + } + k[f] = wr.random() + } + o[a[84]] = O; + function M () { + k[R]++ , + k[l] = wr.serverTimeNow(), + k[d] = wr.timeNow(), + k[B] = cr, + k[w] = Ir.getMouseMove(), + k[I] = Ir.getMouseClick(), + k[_] = Ir.getMouseWhell(), + k[y] = Ir.getKeyDown(), + k[E] = Ir.getClickPos().x, + k[A] = Ir.getClickPos().y; + var r = k.toBuffer(); + return mr.encode(r) + } + o[yr(r[3], n[89], e[97])] = x + }(Er || (Er = {})); + var Ar; ! + function (o) { + var i = n[90], + u = a[85], + v = r[110], + s = a[86], + f = t[107], + p, + h, + m, + w, + I, + _; + function E (r) { + return N(r) && dr[a[87]] + } + function A (o) { + var i = wr.getOriginFromUrl(o); + return i ? !new n[31](yr(r[42], c, t[110]) + w).test(i[r[108]]) || !new e[13](I).test(i[a[18]]) : t[111] + } + function C (e) { + var o = (_r, g, Er.update()); + return e + (new r[50](vr(a[88], a[89])).test(e) ? n[91] : vr(P, a[90], t[112])) + er + t[23] + r[111](o) + } + function b (o, i, u) { + if (r[112] in i) return i.apply(o, u); + switch (u[n[37]]) + { + case n[26]: + return i(); + case a[18]: + return i(u[n[26]]); + case r[108]: + return i(u[e[15]], u[r[19]]); + default: + return i(u[n[26]], u[r[108]], u[t[17]]) + } + } + function B () { + var r = Er.update(); + return r + } + function k (r, e, o) { + if (!r) return n[20]; + var i = r[e]; + if (!i) return t[111]; + var u = o(i); + return d || (u[a[97]] = i + t[19]), + u[n[97]] = i, + r[e] = u, + a[21] + } + function M (o) { + var i, u, c; + i = u = c = n; + var v, s, l; + v = s = l = r; + var d, p, h; + d = p = h = e; + var g, m, w; + g = m = w = a; + var I, _, y; + I = _ = y = t; + var R = hr(I[121], w[106], d[109]), + T; + k(o, _[122], + function (r) { + var n = w[107]; + return function () { + var t, e, a; + t = e = a = _; + var o, i, u; + o = i = u = l; + var c, v, s; + c = v = s = w; + var f = s[108]; + try + { + A(arguments[s[18]]) && !E(arguments[o[19]]) ? arguments[a[26]] = C(arguments[s[18]]) : T = B(), + r.apply(this, arguments), + A(arguments[i[19]]) || this.setRequestHeader(ar, T) + } catch (d) + { + return n + f + } + } + }), + k(o, g[109], + function (r) { + var n = b; + n = M; + var t = vr(_[123], u[107]); + return function () { + var n = fr(f, c[108], I[124]), + e = s[122]; + try + { + if (parseInt(this.status) === parseInt(h[110], v[123])) + { + for (var a = r.apply(this, arguments), o = new p[13](i[109], n + R), u, l, d = {}; u = o.exec(a);) d[u[m[18]].toLowerCase()] = u[v[108]]; + wr.analysisRst(wr.parse(d[ir.toLowerCase()])) + } + } catch (g) + { + return e + t + } + return r.apply(this, arguments) + } + }) + } + function N (r) { + var n = wr.getHostFromUrl(r, e[28]); + return n ? _.test(n) : e[28] + } + function j () { + var cookie_v; + cookie_v = B() + return cookie_v + } + o[n[111]] = j + }(Ar || (Ar = {})); + var Cr; + var cookie = (function (a) { + function _ () { + var cookie_v; + Er.Init(); + cookie_v = Ar.Init(); + return cookie_v + } + return function y () { + try + { + return _() + } catch (r) + { + return r + } + } + })() + return cookie() +} +function v () { + var v; + v = v_cookie( + ["t", 34, '"$', 36, "\fb", 55, "ure", "lJ#K", "Flash", "getBro", "1", "analys", "CHAMELEON_CALLBACK", 30, "\u256f\u0930\u097b\u09ff\u09a4\u0934\u099d\u09c1\u099d\u09d9\u09a7\u09c3\u0995\u09f0\u09d3\u0a62\u0a6f\u09bc\u09ad\u0934", "F,sp-", String, "; expires=", "", 1, "length", "; ", '', '', "addBehavior", ";^l", ">*]+", 0, "div", "&~!", "", "Init", "('&%$#\"![", ">NJ", "\u254e\u096d\u095f", "W$R", "sdelif_esab", "Or)E", "decodeBuffer", 84, "f", "htgnel", 8, "110", "40", "\u2504\u2562", "255", "o", ":", '^".*"$', RegExp, 40, Date, "e9", ".", 19, 5, "t8JOi", "}B", "src", ".js", "onerror", "*q:", null, "getServerTime", "isIPAddr", "8-", "ZX9Y]V8aWs3VQZ7Y", "eventBind", !0, "wheel", '', "keydown", "getMouseMove", "getClickPos", "vent", "me", "MSG", 41, "th", "safari", "ActiveXObject", "maxHeight", "head", "Google Inc.", "vendor", "sgAppName", "opr", 94, "tugw`pj", "chrome", "2345Explorer", "ome", "TheWorld", "name", "\u2553\u253c\u2572\u251d\u2569\u253d\u254f\u252e\u254d\u2526", "Native Client", "i", "Shockwave", "systemLanguage", "740", !1, "plugins", "^ARM", "^iPod", "^BlackBerry", "\u2550\u0978\u094e\u09c1\u09bc\u0928\u0989\u09d8\u099a\u09f3\u09b7\u09dc", "0", 2, 7, "c", encodeURIComponent, "apply", "headers", "8S:+", "\u2560\u2509\u2567\u2503\u256c\u251b", "\u255e\u2530\u2543\u2526\u2554\u2520\u2562\u2507\u2561\u250e\u257c\u2519", "a", 14, ":dB2", "href", "click", "err", 16, "hostname", "`60w", "\fbf", "&X "], + [";", "Element", Date, "par", "i", "DOMMous", 21, "xmT", "wserFe", "h", !0, 1, "", Boolean, '', "; domain=", "n 1970 00:", "cookie", "checkcookie", "allow", !1, "delCookie", 2333, "torage", ")*+,/\\\\:;", '', 0, '', "eliflmth", '', "ducument", RegExp, "W", "qsU", 61, 2, "sdelif_esab", "length", "I", "ff", 16, 45, "3", "10010", "77", 8, "6e%d", "DT{e", "$", / /g, ":", "href", 10, "location", "ned", "\\.com\\.cn$|\\.com\\.hk$", 63, "rea", "https://s.thsi.cn/js/chameleon/time.1", "tat", "loaded", "interactive", "WY:ZYS", "E?`a", "addEventListener", "eScroll", "onmousewheel", "mousemove", "\u255e\u096e\u096e\u09e3\u09a5\u092e\u099a\u09d4\u0990", "\u2550\u2535\u2541\u250c\u2563\u2516\u2565\u2500\u2543\u252f\u2546\u2525\u254e", "getKeyDown", "H69?@[\\]^", "e", "HE9", "tot", "\u2503", "0", "dyS", "se", "getRoot", "NR", "nd", 60, "ng", "s", "get", "mit", 13, 3, 0, "", '', "\u255f\u253a\u255b\u253f", "getCookie", "=", "length", "V587", 1, String, !0, "___", "\u2553\u2536\u255a", "uBot", "base_fileds", 32, "2", "1", "20", 5, "255", 2, 8, 16, 10, "203", "base64Encode", "base64Decode", "decode", "760", "\u255b\u0978\u0954\u09f6\u09a4\u0935", 70, "location", "href", "redirect_url", "efi", Date, "\u2519", "^\\s*(?:https?:)?\\/{2,}([^\\/\\?\\#\\\\]+)", "\u255e", "[@:]", "@", 7, "onload", 'WY$PYS/FLV"P[_7[_R', "readyState", "onreadystatechange", '"^w', "\u2569\u2535\u2546\u256c\u2544\u257b\u2541\u2569\u2501\u2575\u2501\u2571\u2502\u253d\u2507\u252e\u2507\u2538\u2564\u254b\u2530\u2502\u252e\u2553\u257b\u2520\u257e\u2522\u250d\u2551\u256e\u2532\u2511\u254d\u2511\u254c\u2567\u254e", "analysisRst", "strToBytes", "strhash", "random", "getHostFromUrl", "getOriginFromUrl", 83, "timeNow", "^(\\d+\\.)+\\d+$", "d", "v", "ted", "touchmove", 85, "F(K9i", "clientX", "clientY", "\u257a\u2515\u256f\u253c", "postMessage", '', "ActiveXObject", "Apple Computer, Inc.", "Q", "chr", "\u2558\u2535\u2550", "BIDUBrowser", RegExp, "QQBrowser", "ro", "aef", "msDoNotTrack", "PDF|Acrobat", "canvas", "yE", "\u255b\u253a\u2554\u2533\u2546\u2527\u2540\u2525\u2556", "^Android", "^Linux [ix]\\d+", "011", "13", 15, "sub", "addEventListener", "jsonp_ignore", "\u2569", !1, 'L"', "Sj", "T{_,", "q*", "i", "tagName", "et", "{'K", "Pp<", "#x'", "open", "rS", "KN3", "#", "protocol", "\\.", "DEDAOL_NOELEMAHC"], + [83, "ffer", "\u2505", "20", "e", "ngsE", Error, "est", "\u2552\u095b\u0956\u09f0\u09a3\u0935\u09c0\u09e2", "1", "sr", "hexin-v", "", RegExp, 9527, 0, "**l>", "head", "Thu, 01 Ja", "00:00 GMT", "allow", "=", "; path=", "cookie", "Init", 33, 1, "setCookie", !0, "localS", "`{|}~]", "g", '', "frames", "___$&", 56, " ", "\b", "length", "10", "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_", "\u2552\u096f\u0948\u09fe\u09a2", 16, 2, 6, "encode", "rea", "729", "*.", ",", "\u2506\u092c\u090b\u09a0\u09e1\u096d\u09df\u0981\u09c4\u098c", "redirect_url", "\u2506\u092d\u090a\u09a3", "1111101000", 3, 47, "tat", "script", "readyState", "complete", '', "body", "onwheel", "mousewheel", 37, "rus", "\u2554\u0975", "chr", "ActiveXObject", "WeakMap", "aT1Kg", "i", 24, "\u2554\u253c\u254e\u2521\u254c\u2529", "\u2547\u0971\u094f\u09f6\u09b9\u0933\u099d", "Shockwav", "hockwave", "$cdc_asdjflasutopfhvcZLmcfl_", "webgl2", "2>n|", "plugins", "platform", "^Win64", "^Linux armv|Android", "^iPhone", "^MacIntel", !1, "getPlatform", "6Y,", 2333, "100", 12, "14", 10, 36, "01", "60", "\u2542\u096d\u095e\u09f0\u09a4\u0938", "j", 17, "Request", "prototype", "`z}lc", "error", "s", "r", "target", "\u255e", "A", "U", "193", "host", "$"], + ["se", "g@g?", Array, "*Y", Number, "^{.", "*}$", "und", "429", "496", "imeNow", "etti", "rg", "v", "hexin-v", Error, "L_%\\T8", ".baidu.", 1, "", Function, !0, " ", '', 0, 2, "#default#userData", "ydob", "^d", 89, "11111111", 8, "epytotorp", 10, 16, "\u2506\u2536\u2506\u2536\u2506", "14", 13, "10", "Syd", 44, "Domain", "serverT", '^"', "length", RegExp, "00", "tcejbo", "status_code", "n", 66, "\u2506\u2531\u2504\u2534", "htgnel", Date, "L%", 67, "5", "?)'", '', "[[?VS", "isT", "getMouseWhell", "}}", "TR", "ActiveXObject", "WE", "python", "Maxthon", 97, "chrome", "Ryp", "UBrowser", 54, !1, "ontouchstart", "\u254d\u0975\u0917\u09f2\u09be", "iso-8859-1", "defaultCharset", "^iPad", "getBrowserIndex", 256, "1", 5, "17", "Init", "XMLHttp", "tar", "allow", "@*", "?\\", "?", "\u2571\u2503\u256a\u2546\u2566\u2556\u2567\u2547\u2501\u2564\u2506\u2526\u2514\u2524\u2511\u2521\u2501\u2531\u2501\u253b\u250b\u253b\u2501\u2531\u2501\u2521\u2566\u252b\u257f", "den", "tia", 94, "ls", "\u2554\u2526\u2543", "_str", 37, "append", "Child", "\u255f", "\u2569\u0975\u094e\u09e5\u09a0\u092e\u09d1\u09ed\u09ce", "srcElement", "parentNode", "\u2543\u2522\u2545\u250b\u256a\u2507\u2562", "}*", "err", "or", "getAllResponseHeaders", "\\.?", "\\."] + ); + return v +} diff --git a/adata/common/utils/__init__.py b/adata/common/utils/__init__.py new file mode 100644 index 0000000..44e4be5 --- /dev/null +++ b/adata/common/utils/__init__.py @@ -0,0 +1,13 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +from .snowflake import worker +from .sunrequests import SunRequests + +requests = SunRequests() + + diff --git a/adata/common/utils/cookie.py b/adata/common/utils/cookie.py new file mode 100644 index 0000000..f9cd129 --- /dev/null +++ b/adata/common/utils/cookie.py @@ -0,0 +1,30 @@ +# -*- coding: utf-8 -*- +""" +@desc: 获取cookie的工具类 +@author: 1nchaos +@time: 2023/5/5 +@log: change log +""" +from importlib import resources + +from py_mini_racer import py_mini_racer + + +def ths_cookie(): + """获取同花顺cookie""" + js_code = py_mini_racer.MiniRacer() + js_content = _get_file_content_ths(file_path="ths.js") + js_code.eval(js_content) + return 'v='+js_code.call("v") + + +def _get_file_content_ths(file_path: str = None) -> str: + """ + 获取 JS 文件的内容 + :param file_path: JS 文件名 + :return: 文件内容 + """ + with resources.path("adata.common.js", file_path) as f_path: + with open(f_path) as f: + file_data = f.read() + return file_data diff --git a/adata/common/utils/snowflake.py b/adata/common/utils/snowflake.py new file mode 100644 index 0000000..a7052d6 --- /dev/null +++ b/adata/common/utils/snowflake.py @@ -0,0 +1,109 @@ +# -*- coding: utf-8 -*- +""" +@desc: 雪花算法 生成唯一 全局id + 使用方式 单例模式使用 + import worker +@author: 1nchaos +@time: 2022/4/8 +@log: change log +""" + +import logging +import random +import time + +# 64位ID的划分 +WORKER_ID_BITS = 5 +DATACENTER_ID_BITS = 5 +SEQUENCE_BITS = 12 + +# 最大取值计算 # 2**5-1 0b11111 +MAX_WORKER_ID = -1 ^ (-1 << WORKER_ID_BITS) +MAX_DATACENTER_ID = -1 ^ (-1 << DATACENTER_ID_BITS) + +# 移位偏移计算 +WORKER_ID_SHIFT = SEQUENCE_BITS +DATACENTER_ID_SHIFT = SEQUENCE_BITS + WORKER_ID_BITS +TIMESTAMP_LEFT_SHIFT = SEQUENCE_BITS + WORKER_ID_BITS + DATACENTER_ID_BITS + +# 序号循环掩码 +SEQUENCE_MASK = -1 ^ (-1 << SEQUENCE_BITS) + +# Twitter元年时间戳 +TWEPOCH = 1580885600337 + +logger = logging.getLogger('flask.app') + + +class _IdWorker(object): + """ + 用于生成雪花算法 id的对象 + """ + + def __init__(self, datacenter_id=1, worker_id=1, sequence=0): + """ + 初始化 + :param datacenter_id: 数据中心(机器区域)ID + :param worker_id: 机器ID + :param sequence: 其实序号 + """ + # sanity check + if worker_id > MAX_WORKER_ID or worker_id < 0: + raise ValueError('worker_id值越界') + if datacenter_id > MAX_DATACENTER_ID or datacenter_id < 0: + raise ValueError('datacenter_id值越界') + + self.worker_id = worker_id + self.datacenter_id = datacenter_id + self.sequence = sequence + # 上次计算的时间戳 + self.last_timestamp = -1 + + + def _gen_timestamp(self): + """ + 生成整数时间戳 + :return:int timestamp + """ + return int(time.time() * 1000) + + def _til_next_millis(self, last_timestamp): + """ + 等到下一毫秒 + """ + timestamp = self._gen_timestamp() + while timestamp <= last_timestamp: + timestamp = self._gen_timestamp() + return timestamp + + def id(self): + """ + 获取新ID + :return: + """ + timestamp = self._gen_timestamp() + + # 时钟回拨 + if timestamp < self.last_timestamp: + logging.error('clock is moving backwards. Rejecting requests until {}'.format(self.last_timestamp)) + raise + + if timestamp == self.last_timestamp: + self.sequence = (self.sequence + 1) & SEQUENCE_MASK + if self.sequence == 0: + timestamp = self._til_next_millis(self.last_timestamp) + else: + self.sequence = 0 + + self.last_timestamp = timestamp + + new_id = ((timestamp - TWEPOCH) << TIMESTAMP_LEFT_SHIFT) | (self.datacenter_id << DATACENTER_ID_SHIFT) | \ + (self.worker_id << WORKER_ID_SHIFT) | self.sequence + return new_id + + +# 随机分配机器id 和 数据中心 +worker = _IdWorker(random.randint(0, 31), random.randint(0, 31)) + +if __name__ == '__main__': + print(worker.id()) diff --git a/adata/common/utils/sunrequests.py b/adata/common/utils/sunrequests.py new file mode 100644 index 0000000..c95b752 --- /dev/null +++ b/adata/common/utils/sunrequests.py @@ -0,0 +1,34 @@ +# -*- coding: utf-8 -*- +""" +@desc: adata 请求工具类 +@author: 1nchaos +@time:2023/3/30 +@log: 封装请求次数 +""" + +import time + +import requests + + +class SunRequests(object): + def __init__(self) -> None: + super().__init__() + + def request(self, method='get', url=None, times=3, sleep_time=1588, **kwargs): + """ + 简单封装的请求,参考requests,增加循环次数和次数之间的等待时间 + :param method: 请求方法: get;post + :param url: url + :param times: 次数,int + :param sleep_time: 循环的等待时间,毫秒 + :param kwargs: 其它 requests 参数,用法相同 + :return: res + """ + res = None + for i in range(times): + res = requests.request(method=method, url=url, **kwargs) + if res.status_code in (200, 404): + return res + time.sleep(sleep_time / 1000) + return res diff --git a/adata/fund/__init__.py b/adata/fund/__init__.py new file mode 100644 index 0000000..9f6e38e --- /dev/null +++ b/adata/fund/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: 场内ETF相关数据 +@author: 1nchaos +@time: 2023/4/4 +@log: change log +""" diff --git a/adata/fund/etf_market.py b/adata/fund/etf_market.py new file mode 100644 index 0000000..d3673c2 --- /dev/null +++ b/adata/fund/etf_market.py @@ -0,0 +1,14 @@ +# -*- coding: utf-8 -*- +""" +@desc: +@author: 1nchaos +@time:2023/4/5 +@log: +""" + + +class ETFMarket(object): + """ETF 行情""" + + def __init__(self) -> None: + super().__init__() diff --git a/adata/message/__init__.py b/adata/message/__init__.py new file mode 100644 index 0000000..6b09deb --- /dev/null +++ b/adata/message/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/4/4 +@log: change log +""" diff --git a/adata/stock/__init__.py b/adata/stock/__init__.py new file mode 100644 index 0000000..7d142e6 --- /dev/null +++ b/adata/stock/__init__.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- +""" +@desc: 专注股票相关的数据,为量化而生 +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +from .info import info +from .market import market + + +class Stock(object): + + def __init__(self) -> None: + self.info = info + self.market = market + + +stock = Stock() diff --git a/adata/stock/index/__init__.py b/adata/stock/index/__init__.py new file mode 100644 index 0000000..6ca522a --- /dev/null +++ b/adata/stock/index/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: 指数相关数据 +@author: 1nchaos +@time:2022/9/19 +@log: +""" diff --git a/adata/stock/info/__init__.py b/adata/stock/info/__init__.py new file mode 100644 index 0000000..45530e5 --- /dev/null +++ b/adata/stock/info/__init__.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- +""" +@desc: 基本信息相关数据 +@author: 1nchaos +@time: 2023/3/28 +@log: change log +""" +from .stock_code import StockCode +from .stock_concept import StockConcept +from .trade_calendar import TradeCalendar + + +class Info(StockCode, StockConcept, TradeCalendar): + + def __init__(self) -> None: + super().__init__() + + +info = Info() diff --git a/adata/stock/info/stock_code.py b/adata/stock/info/stock_code.py new file mode 100644 index 0000000..0e0d2a5 --- /dev/null +++ b/adata/stock/info/stock_code.py @@ -0,0 +1,71 @@ +# -*- coding: utf-8 -*- +""" +@desc: 股票代码 +@author: 1nchaos +@time: 2023/3/28 +@log: change log +""" +import time + +import pandas as pd +import requests +from tqdm import tqdm + +from adata.common.headers import baidu_headers + + +class StockCode(object): + """ + 股票代码 + """ + + def __init__(self) -> None: + super().__init__() + + def all_code(self): + """ + 获取所有股票的代码 ,后续补充多数据源 + :return: 所有股票的代码信息: ['stock_code','short_name','exchange'] + """ + return self.__market_rank_baidu() + + def __market_rank_baidu(self): + """ + 获取百度当前涨幅排名的代码 + web: https://gushitong.baidu.com/top/ab-increase-%E6%B6%A8%E5%B9%85%E6%A6%9C + url:https://finance.pae.baidu.com/selfselect/getmarketrank?sort_type=1&sort_key=14&from_mid=1&pn=0&rn=200&group=pclist&type=ab&finClientType=pc + 其中:pn 起始数 rn 翻页数,最大200 + :return 代码列表:['stock_code','short_name','exchange'] + """ + # 1. 请求市场排名的 url + api_url = f"https://finance.pae.baidu.com/selfselect/getmarketrank" \ + f"?sort_type=1&sort_key=14&from_mid=1&group=pclist&type=ab&finClientType=pc" + max_page_size = 200 + data = [] + + # 2. 一直翻页请求数据,股票目前数据5000,50页一共1w只,后续增加了可以再加 + for page_no in tqdm(range(49)): + api_url = f"{api_url}&pn={page_no * max_page_size}&rn={max_page_size}" + try: + res = requests.get(api_url, headers=baidu_headers.json_headers, proxies={}) + res_json = res.json() + if res.status_code != 200 or res_json['ResultCode'] != '0': + continue + # 3. 解析数据 + result = res_json['Result']['Result'] + # 结果为空跳出循环 + if not result: + break + code_list = result[0]['DisplayData']['resultData']['tplData']['result']['rank'] + data.extend(code_list) + except Exception as e: + time.sleep(2) + print(e) + continue + # 4. 封装数据 + rename = {'name': 'short_name', 'code': 'stock_code'} + return pd.DataFrame(data=data)[['code', 'name', 'exchange']].rename(columns=rename) + + +if __name__ == '__main__': + print(StockCode().all_code()) diff --git a/adata/stock/info/stock_concept.py b/adata/stock/info/stock_concept.py new file mode 100644 index 0000000..ad8231e --- /dev/null +++ b/adata/stock/info/stock_concept.py @@ -0,0 +1,207 @@ +# -*- coding: utf-8 -*- +""" +@summary: 股票概念 +同花顺概念更及时和完整,所以目前暂只基于同花顺的股票概念抓取 + +概念,指数成分 +来源于同花顺 +http://q.10jqka.com.cn/gn +@author: 1nchaos +@date: 2023/3/30 16:17 +""" +import copy +import math + +import pandas as pd +from bs4 import BeautifulSoup + +from adata.common.headers import ths_headers +from adata.common.utils import cookie +from adata.common.utils import requests + + +class StockConcept(object): + """ + 股票概念 + """ + CONCEPT_CONSTITUENT_COLUMNS = ['stock_code', 'short_name'] + CONCEPT_CODE_COLUMNS = ['concept_code', 'index_code', 'name', 'source'] + + def __init__(self) -> None: + super().__init__() + + def all_concept_code_ths(self): + """ + 获取同花顺概念列表:名称,指数代码,概念代码 + 特别注意: + 同花顺概念指数代码是8开头 + 概念代码是3开头 + 这两个不要混淆啦,同花顺的网站获取数据需要用到这两个代码 + :return: 概念[[name,index_code,concept_code]] + """ + index_df = self.__concept_index_code_ths() + code_df = self.__concept_code_ths() + result_df_l = pd.merge(index_df, code_df, how='left', on='name') + result_df_r = pd.merge(index_df, code_df, how='right', on='name') + result_df = result_df_l.append(result_df_r).drop_duplicates(keep='first', inplace=False, ignore_index=True) + + index_df.drop(index_df.index, inplace=True) + code_df.drop(code_df.index, inplace=True) + result_df_l.drop(result_df_l.index, inplace=True) + result_df_r.drop(result_df_r.index, inplace=True) + result_df['source'] = '同花顺' + return result_df + + def __concept_code_ths(self): + """ + 获取同花顺的所有概念和概念代码,暂时废弃 + web: http://q.10jqka.com.cn/gn/ + """ + # 1. 请求接口 url + api_url = f"http://q.10jqka.com.cn/gn/" + for i in range(3): + res = requests.request('get', api_url, headers=ths_headers.text_headers, proxies={}) + # 2. 判断请求是否正确 + text = res.text + if res.status_code != 200 or len(text) < 1: + continue + # 3. 解析数据 + soup = BeautifulSoup(text, 'html.parser') + data = [] + for a in soup.find_all('a'): + href = str(a['href']) + if href.startswith(api_url + 'detail/code/'): + data.append([href[-7: -1], a.string, href]) + + # 4. 封装数据 + data_df = pd.DataFrame(data=data, columns=['concept_code', 'name', 'href'])[['concept_code', 'name']] + return data_df + + def __concept_index_code_ths(self): + """ + 获取app的概率列表,通过问财询问得到结果 + :return: app的概念列表: concept_code,name + """ + data = [] + for i in range(1, 10): + api_url = f"http://search.10jqka.com.cn/gateway/urp/v7/landing/getDataList?perpage=100&page={i}&query=%E6%89%80%E6%9C%89%E6%A6%82%E5%BF%B5&condition=%5B%7B%22indexName%22%3A%22%E6%8C%87%E6%95%B0%40%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22indexProperties%22%3A%5B%5D%2C%22source%22%3A%22new_parser%22%2C%22type%22%3A%22index%22%2C%22indexPropertiesMap%22%3A%7B%7D%2C%22reportType%22%3A%22null%22%2C%22chunkedResult%22%3A%22%E6%89%80%E6%9C%89%E6%A6%82%E5%BF%B5%22%2C%22valueType%22%3A%22_%E6%8C%87%E6%95%B0%E7%B1%BB%E5%9E%8B%22%2C%22domain%22%3A%22abs_a%E6%8C%87%E9%A2%86%E5%9F%9F%22%2C%22uiText%22%3A%22%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22sonSize%22%3A0%2C%22queryText%22%3A%22%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22relatedSize%22%3A0%7D%5D&urp_sort_index=%E6%8C%87%E6%95%B0%E4%BB%A3%E7%A0%81&source=Ths_iwencai_Xuangu&urp_sort_way=desc&codelist=&page_id=&logid=35df00ee5ae706d0dfcd0dbfdb846e0c&ret=json_all&sessionid=35df00ee5ae706d0dfcd0dbfdb846e0c&iwc_token=0ac9667016801698001765831&user_id=Ths_iwencai_Xuangu_7fahywzhbkrh4lwwkwfw936njqbjzsly&uuids%5B0%5D=23119&query_type=zhishu&comp_id=6367801&business_cat=soniu&uuid=23119" + res = requests.request('get', url=api_url, headers=ths_headers.c_headers) + res_json = res.json() + if res_json['status_msg'] == 'ok': + data_list = res_json['answer']['components'][0]['data']['datas'] + if len(data_list) < 1: + break + for d in data_list: + data.append([d['code'], d['指数简称']]) + data_df = pd.DataFrame(data=data, columns=['index_code', 'name']).drop_duplicates(keep='first', inplace=False, + ignore_index=True) + return data_df + + def concept_constituent_ths(self, concept_code=None, name=None): + """ + 获取同花顺概念成分,推荐使用概念名称进行查询,名称查询来自问财,概念代码来自网页 + :param concept_code: 概念代码,3开头 + :param name: 概念名称 + :return: 概念的成分股 + """ + if concept_code: + return self.__concept_constituent_ths_by_code(concept_code=concept_code) + elif name: + return self.__index_constituent_ths_by_name(name=name) + else: + return pd.DataFrame(data=[], columns=self.CONCEPT_CONSTITUENT_COLUMNS) + + def __concept_constituent_ths_by_code(self, concept_code=None): + """ + 同花顺概念成分股 + web_url :http://q.10jqka.com.cn/gn/detail/field/199112/order/desc/page/1/ajax/1/code/301539 + answer: http://www.iwencai.com/gateway/urp/v7/landing/getDataList?query=chatgpt%20%E6%A6%82%E5%BF%B5%E6%88%90%E5%88%86&page=1&perpage=100&query_type=stock&comp_id=6734520&uuid=24087 + :param concept_code: 概念代码: 301539 + :return:['concept_code', 'stock_code', 'short_name'] + """ + # 1. url拼接页码等参数 + data = [] + total_pages = 1 + curr_page = 1 + while curr_page <= total_pages: + api_url = f"http://q.10jqka.com.cn/gn/detail/field/199112/order/desc/page/" \ + f"{curr_page}/ajax/1/code/{concept_code}" + headers = copy.deepcopy(ths_headers.text_headers) + headers['Cookie'] = cookie.ths_cookie() + res = requests.request(method='get', url=api_url, headers=headers, proxies={}) + curr_page += 1 + # 2. 判断请求是否成功 + if res.status_code != 200: + continue + text = res.text + if '暂无成份股数据' in text or '概念板块' in text or '概念时间表' in text: + break + soup = BeautifulSoup(text, 'html.parser') + # 3 .获取总的页数 + if total_pages == 1: + page_info = soup.find('span', {'class': 'page_info'}) + if page_info: + total_pages = int(page_info.text.split("/")[1]) + # 4. 解析数据 + page_data = [] + for idx, tr in enumerate(soup.find_all('tr')): + if idx != 0: + tds = tr.find_all('td') + page_data.append({'stock_code': tds[1].contents[0].text, 'short_name': tds[2].contents[0].text}) + data.extend(page_data) + # 5. 封装数据 + if not data: + return pd.DataFrame(data=data, columns=self.CONCEPT_CONSTITUENT_COLUMNS) + result_df = pd.DataFrame(data=data) + data.clear() + return result_df[self.CONCEPT_CONSTITUENT_COLUMNS] + + def __index_constituent_ths_by_name(self, name=None): + """ + 同花顺概念成分股,通过问财询问 + answer: http://www.iwencai.com/gateway/urp/v7/landing/getDataList?query=chatgpt%20%E6%A6%82%E5%BF%B5%E6%88%90%E5%88%86&page=1&perpage=100&query_type=stock&comp_id=6734520&uuid=24087 + :param name: 概念名称 + :return:['concept_code', 'stock_code', 'short_name'] + """ + # 1. url拼接页码等参数 + data = [] + total_pages = 1 + curr_page = 1 + while curr_page <= total_pages: + api_url = f"https://www.iwencai.com/gateway/urp/v7/landing/getDataList?query={name} 概念成分&" \ + f"page={curr_page}&perpage=100&query_type=stock&comp_id=6734520&uuid=24087" + headers = copy.deepcopy(ths_headers.json_headers) + headers['Host'] = 'www.iwencai.com' + headers['Sec-Fetch-Mode'] = 'navigate' + res = requests.request(method='get', url=api_url, headers=headers, proxies={}) + curr_page += 1 + # 2. 判断请求是否成功 + if res.status_code != 200: + continue + text = res.text.encode('utf-8').decode('unicode escape') + if name not in text: + break + res_json = res.json() + data_dic = res_json['answer']['components'][0]['data'] + # 3 .获取总的页数 + if total_pages == 1: + total_pages = math.ceil(data_dic['meta']['extra']['code_count'] / 100) + # 4. 解析数据 + page_data = [] + data_list = data_dic['datas'] + for one in data_list: + if (name == one['所属概念']) or \ + ('所属指数类' in one.keys() and (name == one['所属指数类'] or f"{name};" in one['所属指数类'])): + page_data.append({'stock_code': one['code'], 'short_name': one['股票简称'], '': ''}) + data.extend(page_data) + # 5. 封装数据 + if not data: + return pd.DataFrame(data=data, columns=self.CONCEPT_CONSTITUENT_COLUMNS) + result_df = pd.DataFrame(data=data) + data.clear() + return result_df[self.CONCEPT_CONSTITUENT_COLUMNS] + + +if __name__ == '__main__': + print(StockConcept().all_concept_code_ths()) + print(StockConcept().concept_constituent_ths(name='东数西算(算力)')) diff --git a/adata/stock/info/trade_calendar.py b/adata/stock/info/trade_calendar.py new file mode 100644 index 0000000..cf7ee98 --- /dev/null +++ b/adata/stock/info/trade_calendar.py @@ -0,0 +1,63 @@ +# -*- coding: utf-8 -*- +""" +@desc: 交易日历 +@author: 1nchaos +@time: 2023/3/28 +@log: change log +""" +import pandas as pd +from tqdm import tqdm + +from adata.common import requests + + +class TradeCalendar(object): + """ + 交易日历 + """ + COLUMNS = ['trade_date', 'trade_status', 'day_week'] + + def __init__(self) -> None: + super().__init__() + + def trade_calendar(self, year=None): + """ + 获取股票交易日历 + :return: 交易日历信息: + trade_date: 交易日; + day_week: 一周的第几天,从星期日开始; + trade_status: 交易状态:1,交易日;0,非交易日 + """ + return self.__calendar_szse(year=year) + + def __calendar_szse(self, year=None): + """ + 获取深交所交易日历 + web_url :http://www.szse.cn/api/report/exchange/onepersistenthour/monthList?month=2023-1 + :param year: 年份:'2023' + :return: ['trade_date','day_week','trade_status'] + """ + # 1. url,拼接月份 + data = [] + for i in tqdm(range(12)): + api_url = f"http://www.szse.cn/api/report/exchange/onepersistenthour/monthList?month={year}-{i + 1}" + res = requests.request(method='get', url=api_url, headers={}, proxies={}) + # 2. 判断请求是否成功 + if res.status_code != 200: + continue + res_json = res.json() + # 3. 解析数据 + result = res_json['data'] + # 结果为空跳出循环 + if not result: + break + data.extend(result) + # 4. 封装数据 + rename = {'jyrq': 'trade_date', 'jybz': 'trade_status', 'zrxh': 'day_week'} + if not data: + return pd.DataFrame(data=data, columns=self.COLUMNS) + return pd.DataFrame(data=data).rename(columns=rename)[self.COLUMNS] + + +if __name__ == '__main__': + print(TradeCalendar().trade_calendar(year=2024)) diff --git a/adata/stock/market/__init__.py b/adata/stock/market/__init__.py new file mode 100644 index 0000000..aa3aaa6 --- /dev/null +++ b/adata/stock/market/__init__.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- +""" +@desc: 行情相关的数据 +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" +from .stock_dividend import StockDividend +from .stock_market import StockMarket +from .stock_market_concept import StockMarketConcept + + +class Market(StockMarket, StockMarketConcept, StockDividend): + + def __init__(self) -> None: + super().__init__() + + +market = Market() diff --git a/adata/stock/market/stock_dividend.py b/adata/stock/market/stock_dividend.py new file mode 100644 index 0000000..406ec8a --- /dev/null +++ b/adata/stock/market/stock_dividend.py @@ -0,0 +1,83 @@ +# -*- coding: utf-8 -*- +""" +@desc: 股票分红信息 +数据来源:1. 百度 + +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" + +import pandas as pd + +from adata.common.headers import baidu_headers +from adata.common.utils import requests + + +class StockDividend(object): + """ + 股票分红 + """ + + def __init__(self) -> None: + super().__init__() + + def get_dividend(self, stock_code='000001'): + """ + 获取当个股票的分红信息 + :param stock_code: 股票代码 + :return: 股票分红信息 + """ + return self.__dividend_baidu(stock_code) + + def __dividend_baidu(self, stock_code): + """ + 获取百度的股票分红数据:公告日;分红方案;除权除息日 + web: https://gushitong.baidu.com/stock/ab-300033 + url: https://gushitong.baidu.com/opendata?openapi=1&dspName=iphone&tn=tangram& + client=app&query=300033&code=300033&word=300033&resource_id=5429&ma_ver=4&finClientType=pc + :param stock_code: 6位股票代码 + :return: 股票分红信息 + """ + columns = ['report_date', 'dividend_plan', 'ex_dividend_date'] + null_df = pd.DataFrame(data=[], columns=columns) + # 1.请求接口 url + api_url = f"https://gushitong.baidu.com/opendata?openapi=1&dspName=iphone&tn=tangram&client=app&" \ + f"query={stock_code}&code={stock_code}&word={stock_code}&resource_id=5429&ma_ver=4&finClientType=pc" + res = requests.request('get', api_url, headers=baidu_headers.text_headers) + + # 2. 判断结果是否正确 + if len(res.text) < 1 or res.status_code != 200: + return pd.DataFrame() + res_json = res.json() + if res_json['ResultCode'] != '0': + return null_df + # 3.解析数据 + # 3.1 空数据时返回为空 + result = res_json['Result'] + if not result: + return null_df + + # 3.2 正常解析数据 basicInfo,shareholderEquity,organRating,executiveInfo,bonusTransfer + try: + new_company = result[-1]['DisplayData']['resultData']['tplData']['result']['tabs'][-1]['content'][ + 'newCompany'] + bonus_transfer = new_company['bonusTransfer'] + header = bonus_transfer['header'] + body = bonus_transfer['body'] + except KeyError: + # TODO logger + return null_df + + # 4. 封装数据 + result_df = pd.DataFrame(data=body, columns=header)[['公告日', '分红方案', '除权除息日']] + result_df['stock_code'] = stock_code + rename_columns = {'公告日': 'report_date', '分红方案': 'dividend_plan', '除权除息日': 'ex_dividend_date'} + result_df = result_df.rename(columns=rename_columns) + # 5. 数据清洗 + result_df = result_df[result_df.dividend_plan != '利润不分配'] + return result_df + + +if __name__ == '__main__': + print(StockDividend().get_dividend(stock_code='000001')) diff --git a/adata/stock/market/stock_market.py b/adata/stock/market/stock_market.py new file mode 100644 index 0000000..23e25cb --- /dev/null +++ b/adata/stock/market/stock_market.py @@ -0,0 +1,225 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/3/29 +@log: change log +""" + +import time + +import pandas as pd + +from adata.common.headers import baidu_headers, sina_headers +from adata.common.utils import requests + + +class StockMarket(object): + """ + 股票行情 TODO 数据返回类型转换 + """ + MARKET_COLUMNS = ['trade_time', 'open', 'close', 'volume', 'high', 'low', 'amount', 'change', 'change_pct', + 'turnover_ratio', 'pre_close'] + MARKET_MIN_COLUMNS = ['stock_code', 'trade_time', 'price', 'change', 'change_pct', 'volume', 'avg_price', 'amount'] + MARKET_CURRENT_COLUMNS = ['stock_code', 'short_name', 'price', 'change', 'change_pct', 'volume', 'amount'] + + def __init__(self) -> None: + super().__init__() + + def get_market(self, stock_code: str = '000001', start_date='1990-01-01', k_type=1, adjust_type: int = 1): + """ + 获取单个股票的行情 + :param stock_code: 股票代码 + :param start_date: 开始时间 + :param k_type: k线类型:1.日;2.周;3.月 默认:1 日k + :param adjust_type: k线复权类型:0.不复权;1.前复权;2.后复权 默认:1 前复权 (目前:只有前复权,作为股票交易已经可用) + :return: k线行情数据 + """ + return self.__market_baidu(stock_code, start_date, k_type) + + def get_market_min(self, stock_code: str = '000001'): + """ + 获取单个股票的今日分时行情 + :param stock_code: 股票代码 + :return: 当日分钟行情数据 + """ + return self.__market_baidu_today_min(stock_code) + + def list_market_current(self, code_list=None): + """ + 获取多个股票最新行情信息 + :param code_list: 股票代码 + :return: 当前最新的行情价格信息 + """ + if code_list is None: + return pd.DataFrame() + return self.__market_sina_current(code_list=code_list) + + def __market_baidu(self, stock_code, start_date, k_type=1): + """ + 获取百度的股票行情数据 + web: https://gushitong.baidu.com/stock/ab-002926 + url:quotation_fiveday_ab 5日分时,quotation_kline_ab K线, quotation_minute_ab 当日分钟 + k线 + https://finance.pae.baidu.com/selfselect/getstockquotation?all=1&isIndex=false&isBk=false&isBlock=false& + isFutures=false&isStock=true&newFormat=1&group=quotation_kline_ab&finClientType=pc& + code=002926&start_time=2018-02-05 00:00:00&ktype=1 + 分钟 + https://finance.pae.baidu.com/selfselect/getstockquotation? + all=1&code=601318&isIndex=false&isBk=false&isBlock=false&isFutures=false&isStock=true&newFormat=1& + group=quotation_minute_ab&finClientType=pc + "ma5均价","ma5成交量","ma10均价","ma10成交量","ma20均价","ma20成交量" + :param stock_code: 6位股票代码 + :param start_date: 开始时间 + :param k_type: k线类型:1.日;2.周;3.月 + # :param adjust_type: k线复权类型:0.不复权;1.前复权;2.后复权 默认:1 前复权 TODO + :return: k线行情数据:"时间戳", "时间","开盘","收盘","成交量","最高","最低","成交额","涨跌额","涨跌幅","换手率","昨收" + """ + # 1. 请求接口 url + api_url = f"https://finance.pae.baidu.com/selfselect/getstockquotation?all=1&isIndex=false&isBk=false&" \ + f"isBlock=false&isFutures=false&isStock=true&newFormat=1&group=quotation_kline_ab&finClientType=pc&" \ + f"code={stock_code}&start_time={start_date} 00:00:00&ktype={k_type}" + + res_json = None + for i in range(3): + res = requests.request('get', api_url, headers=baidu_headers.json_headers, proxies={}) + # 2. 校验请求结果数据 + res_json = res.json() + if res_json['ResultCode'] == '0': + break + time.sleep(2) + # 3.解析数据 + # 3.1 空数据时返回为空 + result = res_json['Result'] + if not result: + return pd.DataFrame(data=[], columns=self.MARKET_COLUMNS) + + # 3.2. 正常解析数据 + keys = res_json['Result']['newMarketData']['keys'] + market_data = res_json['Result']['newMarketData']['marketData'] + market_data_list = str(market_data).split(';') + data = [] + for one in market_data_list: + data.append(one.split(',')) + + # 4. 封装数据 + rename_columns = {'turnoverratio': 'turnover_ratio', 'preClose': 'pre_close', 'range': 'change', + 'ratio': 'change_pct', 'time': 'trade_time'} + result_df = pd.DataFrame(data=data, columns=keys).rename(columns=rename_columns)[self.MARKET_COLUMNS] + result_df['stock_code'] = stock_code + result_df['trade_date'] = result_df['trade_time'] + result_df['trade_time'] = pd.to_datetime(result_df['trade_time']).dt.strftime('%Y-%m-%d %H:%M:%S') + result_df.replace('--', None, inplace=True) + result_df.replace('', None, inplace=True) + result_df['change'] = result_df['change'].str.replace('+', '', regex=True) + result_df['change_pct'] = result_df['change_pct'].str.replace('+', '', regex=True) + # 5. 数据清洗,剔除成交量为0的异常数据 + result_df['amount'] = result_df['amount'].astype(float) + result_df = result_df[result_df['amount'] > 0] + result_df.replace('--', None, inplace=True) + result_df.replace('', None, inplace=True) + result_df['change'] = result_df['change'].str.replace('+', '', regex=True).astype(float) + result_df['change_pct'] = result_df['change_pct'].str.replace('+', '', regex=True).astype(float) + return result_df + + def __market_baidu_today_min(self, stock_code): + """ + 获取百度的股票行情数据 + web: https://gushitong.baidu.com/stock/ab-002926 + url: https://finance.pae.baidu.com/selfselect/getstockquotation? + all=1&code=601318&isIndex=false&isBk=false&isBlock=false&isFutures=false&isStock=true&newFormat=1 + &group=quotation_minute_ab&finClientType=pc + time, price, ratio, increase, volume, avgPrice, amount, timeKey, datetime, oriAmount + :param stock_code: 6位股票代码 + :return: k线行情数据:"时间","价格","涨跌率","涨幅","均价","成交量", "成交额" + """ + # 1. 请求接口 url + api_url = f"https://finance.pae.baidu.com/selfselect/getstockquotation?all=1&isIndex=false&isBk=false&" \ + f"isBlock=false&isFutures=false&isStock=true&newFormat=1&group=quotation_minute_ab&" \ + f"finClientType=pc&code={stock_code}" + + res_json = None + for i in range(3): + res = requests.request('get', api_url, headers=baidu_headers.json_headers, proxies={}) + # 2. 校验请求结果数据 + res_json = res.json() + if res_json['ResultCode'] == '0': + break + time.sleep(2) + # 3.解析数据 + # 3.1 空数据时返回为空 + result = res_json['Result'] + if not result: + return pd.DataFrame(data=[], columns=self.MARKET_MIN_COLUMNS) + + # 3.2. 正常解析数据 + market_data_list = res_json['Result']['priceinfo'] + + # 4. 封装数据 + field = ['time', 'price', 'ratio', 'increase', 'volume', 'avgPrice', 'amount', 'timeKey', 'datetime', + 'oriAmount'] + rename_columns = {'avgPrice': 'avg_price', 'oriAmount': 'ori_amount', 'ratio': 'change_pct', + 'increase': 'change'} + result_df = pd.DataFrame(data=market_data_list, columns=field).rename(columns=rename_columns) + result_df['amount'] = result_df['ori_amount'] + result_df['stock_code'] = stock_code + # 这里是分钟均价,数据存在四舍五入的情况 + result_df['volume'] = result_df['volume'].astype(int) * 100 + result_df['trade_time'] = pd.to_datetime(result_df['time'], unit='s', utc=True).dt.tz_convert( + 'Asia/Shanghai') + result_df['trade_time'] = pd.to_datetime(result_df['trade_time']).dt.strftime("%Y-%m-%d %H:%M:%S") + result_df['trade_date'] = result_df['trade_time'].str[:10] + result_df['change'] = result_df['change'].str.replace('+', '', regex=True).astype(float) + result_df['change_pct'] = result_df['change_pct'].str.replace('+', '', regex=True).astype(float) + return result_df[self.MARKET_MIN_COLUMNS] + + def __market_sina_current(self, code_list): + """ + 获取新浪的最新股票行情 + url : https://hq.sinajs.cn/list=s_sh600905,s_sz000725,s_sz000100,s_sh601919 + :param code_list: 代码列表 + :return: 最新行情数据:代码,简称,当前价格(元),涨跌额(元),涨跌幅(%),成交量(股),成交额(元) + """ + # 0.进行参数拼接处理 + api_url = f"https://hq.sinajs.cn/list=" + for code in code_list: + if code.startswith('0') or code.startswith('3'): + api_url += 's_sz' + code + ',' + elif code.startswith('6') or code.startswith('9'): + api_url += 's_sh' + code + ',' + elif code.startswith('4') or code.startswith('8'): + api_url += 's_bj' + code + ',' + + # 1.请求接口 + res = requests.request('get', api_url, headers=sina_headers.c_headers) + + # 2. 判断结果是否正确 + if len(res.text) < 1 or res.status_code != 200: + return pd.DataFrame(data=[], columns=self.MARKET_CURRENT_COLUMNS) + # 3.解析数据 + + # 正常解析数据 var hq_str_s_bj872925="平安银行,14.840,0.480,3.343,374847,5483780.180"; + data_list = res.text.split(';') + data = [] + for data_str in data_list: + if len(data_str) < 8: + continue + idx = data_str.index('=') + code = [data_str[idx - 6:idx]] + code.extend(data_str[idx + 2:-1].split(',')) + if len(code) == 7: + data.append(code) + + # 4. 封装数据 + result_df = pd.DataFrame(data=data, columns=self.MARKET_CURRENT_COLUMNS) + # 北京的单位是股和万元 + mask = result_df['stock_code'].str.startswith(('0', '3', '6', '9')) + result_df.loc[mask, 'volume'] = result_df['volume'].astype(int) * 100 + result_df.loc[mask, 'amount'] = result_df['amount'].astype(float) * 10000 + return result_df + + +if __name__ == '__main__': + print(StockMarket().get_market(stock_code='000001', start_date='2021-01-01', k_type=1)) + # print(StockMarket().get_market_min(stock_code='000001')) + # print(StockMarket().list_market_current(code_list=['000001', '600001', '000795', '872925'])) diff --git a/adata/stock/market/stock_market_concept.py b/adata/stock/market/stock_market_concept.py new file mode 100644 index 0000000..5926509 --- /dev/null +++ b/adata/stock/market/stock_market_concept.py @@ -0,0 +1,172 @@ +# -*- coding: utf-8 -*- +""" +@summary: 股票概念 行情 +同花顺概念更及时和完整,所以目前暂只基于同花顺的股票概念抓取,网页数据中心和手机概念板块 +http://d.10jqka.com.cn/v6/line/48_885772/01/last1800.js +http://search.10jqka.com.cn/gateway/urp/v7/landing/getDataList?query=%E6%89%80%E6%9C%89%E6%A6%82%E5%BF%B5&condition=%5B%7B%22indexName%22%3A%22%E6%8C%87%E6%95%B0%40%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22indexProperties%22%3A%5B%5D%2C%22source%22%3A%22new_parser%22%2C%22type%22%3A%22index%22%2C%22indexPropertiesMap%22%3A%7B%7D%2C%22reportType%22%3A%22null%22%2C%22chunkedResult%22%3A%22%E6%89%80%E6%9C%89%E6%A6%82%E5%BF%B5%22%2C%22valueType%22%3A%22_%E6%8C%87%E6%95%B0%E7%B1%BB%E5%9E%8B%22%2C%22domain%22%3A%22abs_a%E6%8C%87%E9%A2%86%E5%9F%9F%22%2C%22uiText%22%3A%22%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22sonSize%22%3A0%2C%22queryText%22%3A%22%E5%90%8C%E8%8A%B1%E9%A1%BA%E6%A6%82%E5%BF%B5%E6%8C%87%E6%95%B0%22%2C%22relatedSize%22%3A0%7D%5D&urp_sort_index=%E6%8C%87%E6%95%B0%E4%BB%A3%E7%A0%81&source=Ths_iwencai_Xuangu&perpage=500&page=1&urp_sort_way=desc&codelist=&page_id=&logid=35df00ee5ae706d0dfcd0dbfdb846e0c&ret=json_all&sessionid=35df00ee5ae706d0dfcd0dbfdb846e0c&iwc_token=0ac9667016801698001765831&user_id=Ths_iwencai_Xuangu_7fahywzhbkrh4lwwkwfw936njqbjzsly&uuids%5B0%5D=23119&query_type=zhishu&comp_id=6367801&business_cat=soniu&uuid=23119 +885772 表示同花顺的概念指数的代码 +@author: 1nchaos +@date: 2023/3/30 16:17 +""" +import copy +import json +import time + +import numpy as np +import pandas as pd + +from adata.common.headers import ths_headers +from adata.common.utils import requests, cookie + + +class StockMarketConcept(object): + """ + 股票概念 行情 + """ + COLUMNS = ['trade_date', 'open', 'high', 'low', 'close', 'volume', 'amount'] + + def __init__(self) -> None: + super().__init__() + + def get_market_concept_ths(self, index_code: str = '886013', k_type: int = 1, adjust_type: int = 1): + """ + 获取同花顺的概率的行情 + web: http://q.10jqka.com.cn/gn/ + pc: http://d.10jqka.com.cn/v4/line/bk_885772/21/last.js + app: http://d.10jqka.com.cn/v6/line/48_886013/01/last1800.js + 00 日k不复权;01日k前复权;02日k后复权;11周k前复权;21月k前复权 + :param index_code: 同花顺概念指数代码 + :param k_type: k线类型:1.日;2.周;3.月 默认:1 日k + :param adjust_type: k线复权类型:0.不复权;1.前复权;2.后复权 默认:1 前复权 + :return: k线行情数据 [日期,开,高,低,收,成交量,成交额] + ;20230419,958.901,981.118,958.449,961.107,521143220,20442229000.000 + 成交量:股 820953530 821万手 + 成交额:元 16959251000.000 169.6亿 + """ + # 0.参数校验 + if not index_code.startswith('8'): + raise RuntimeError('index_code错误,是8开头的指数代码,') + # 1.接口 url + api_url = f"http://d.10jqka.com.cn/v6/line/48_{index_code}/{k_type - 1}{adjust_type}/last1800.js" + # 同花顺可能ip限制,降低请求次数 + text = self.__get_text(api_url, index_code) + if '

Nginx forbidden.

' in text: + raise Exception('ip被限制了:请降低频率或更换ip') + result_text = text[text.index('{'):-1] + data_list = json.loads(result_text)['data'].split(';') + data = [] + for d in data_list: + data.append(str(d).split(',')[0:7]) + result_df = pd.DataFrame(data=data, columns=self.COLUMNS) + result_df['index_code'] = index_code + result_df['trade_time'] = pd.to_datetime(result_df['trade_date']).dt.strftime('%Y-%m-%d %H:%M:%S') + result_df['trade_date'] = pd.to_datetime(result_df['trade_date'], format='%Y%m%d').dt.strftime('%Y-%m-%d') + result_df['close'] = result_df['close'].astype(float) + result_df['change'] = result_df['close'] - result_df['close'].shift(1) + result_df['change_pct'] = result_df['change'] / result_df['close'].shift(1) * 100 + result_df.replace('--', None, inplace=True) + result_df.replace('', None, inplace=True) + result_df.replace(np.nan, None, inplace=True) + return result_df + + def get_market_concept_min_ths(self, index_code): + """ + 获取概念行情当日分时 + web: http://d.10jqka.com.cn/v6/time/48_886013/last.js + 0930,958.901,74456973,36.807,2022925; "pre": "960.374", + :param index_code: 概念指数代码 + :return 时间,现价,成交额(元),均价,成交量(股) 涨跌额,涨跌幅 + 'index_code', 'trade_time', 'price', 'change', 'change_pct', 'volume', 'avg_price', 'amount' + """ + # 1.接口 url + api_url = f"http://d.10jqka.com.cn/v6/time/48_{index_code}/last.js" + text = self.__get_text(api_url, index_code) + if '

Nginx forbidden.

' in text: + raise Exception('ip被限制了:请降低频率或更换ip') + # 2. 解析数据 + result_json = json.loads(text[text.index('{'):-1])[f"48_{index_code}"] + pre_price = result_json['pre'] + trade_date = result_json['date'] + data_list = result_json['data'].split(';') + data = [] + for d in data_list: + data.append(str(d).split(',')) + # 3. 封装数据 + result_df = pd.DataFrame(data=data, columns=['trade_time', 'price', 'amount', 'avg_price', 'volume']) + result_df['index_code'] = index_code + result_df['trade_time'] = trade_date + result_df['trade_time'] + result_df['trade_date'] = pd.to_datetime(trade_date, format='%Y%m%d').strftime('%Y-%m-%d') + result_df['trade_time'] = pd.to_datetime(result_df['trade_time'], format='%Y%m%d%H%M').dt.strftime( + '%Y-%m-%d %H:%M:%S') + result_df['price'] = result_df['price'] + result_df['change'] = result_df['price'].astype(float) - float(pre_price) + result_df['change_pct'] = result_df['change'] / float(pre_price) * 100 + result_df.replace('--', None, inplace=True) + result_df.replace('', None, inplace=True) + result_df.replace(np.nan, None, inplace=True) + return result_df + + def get_market_concept_today_ths(self, index_code: str = '886013', k_type: int = 1, adjust_type: int = 1): + """ + 获取同花顺当前的概念行情 + web: http://q.10jqka.com.cn/gn/ + pc: http://d.10jqka.com.cn/v6/line/48_886042/01/today.js + quotebridge_v6_line_48_886042_01_today({"48_886042":{"1":"20230425","7":"891.344","8":"892.350","9":"853.800", + "11":"860.076","13":491708080,"19":"17647511000.000","74":"","1968584":"","66":"","open":1,"dt":"2244", + "name":"\u5b58\u50a8\u82af\u7247","marketType":""}}) + + :param index_code: 同花顺概念指数代码 + :param k_type: k线类型:1.日;2.周;3.月 默认:1 日k + :param adjust_type: k线复权类型:0.不复权;1.前复权;2.后复权 默认:1 前复权 + :return: k线行情数据 [概念代码,交易时间,交易日期,开,高,低,当前价格,成交量,成交额] + ;20230419,958.901,981.118,958.449,961.107,521143220,20442229000.000,存储芯片 + k: 1, 7, 8, 9, 11, 13, 19, name + 成交量:股 820953530 821万手 + 成交额:元 16959251000.000 169.6亿 + """ + # 1.接口 url + api_url = f"http://d.10jqka.com.cn/v6/line/48_{index_code}/{k_type - 1}{adjust_type}/today.js" + headers = copy.deepcopy(ths_headers.text_headers) + headers['Host'] = 'd.10jqka.com.cn' + # 同花顺可能ip限制,降低请求次数 + text = self.__get_text(api_url, index_code) + if '

Nginx forbidden.

' in text: + raise Exception('ip被限制了:请降低频率或更换ip') + result_text = text[text.index('{'):-1] + data_list = [json.loads(result_text)[f"48_{index_code}"]] + rename = {'1': 'trade_date', '7': 'open', '8': 'high', '9': 'low', '11': 'price', '13': 'volume', + '19': 'amount', 'open': 'status'} + result_df = pd.DataFrame(data=data_list).rename(columns=rename) + result_df['trade_time'] = result_df['trade_date'] + result_df['dt'] + result_df['trade_time'] = pd.to_datetime(result_df['trade_time'], format='%Y%m%d%H%M').dt.strftime( + '%Y-%m-%d %H:%M:%S') + columns = ['trade_time', 'trade_date', 'open', 'high', 'low', 'price', 'volume', 'amount'] + result_df = result_df[columns] + result_df['index_code'] = index_code + result_df['trade_date'] = pd.to_datetime(result_df['trade_date'], format='%Y%m%d').dt.strftime('%Y-%m-%d') + return result_df + + def __get_text(self, api_url, code): + """ + 获取同花顺的请求 text + :param api_url: url + :param code: 代码 + :return: + """ + headers = copy.deepcopy(ths_headers.text_headers) + headers['Host'] = 'd.10jqka.com.cn' + headers['Cookie'] = cookie.ths_cookie() + text = '' + for i in range(2): + res = requests.request('get', api_url, headers=headers, proxies={}) + text = res.text + if code in text: + break + time.sleep(2) + return text + + +if __name__ == '__main__': + print(StockMarketConcept().get_market_concept_ths(index_code='886041')) + print(StockMarketConcept().get_market_concept_min_ths(index_code='886041')) + print(StockMarketConcept().get_market_concept_today_ths(index_code='886041')) diff --git a/adata/stock/sentiment/__init__.py b/adata/stock/sentiment/__init__.py new file mode 100644 index 0000000..d08784f --- /dev/null +++ b/adata/stock/sentiment/__init__.py @@ -0,0 +1,7 @@ +# -*- coding: utf-8 -*- +""" +@desc: 新闻舆情相关的数据 +@author: 1nchaos +@time:2023/04/06 +@log: +""" diff --git a/config.toml b/config.toml new file mode 100644 index 0000000..e69de29 diff --git a/docs/DIC.md b/docs/DIC.md new file mode 100644 index 0000000..054aa05 --- /dev/null +++ b/docs/DIC.md @@ -0,0 +1,154 @@ +# AData 字典表 + +> 整个项目API的数据字典,按照模块层级分类命名,描述尽量精简,以便进行查阅。 + +## 股票-stock + +### 一、基本信息-Info + +#### 1. 股票代码信息(info) + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------ | ------ | --------------------------- | +| stock_code | string | 代码 | 600001 | +| short_name | string | 简称 | 中国平安 | +| exchange | string | 交易所 | SH:上交;BJ:北交;SZ:深交 | + +#### 2. 概念指数信息(index-concept) + +| 字段 | 类型 | 注释 | 说明 | +| ------------ | ------ | -------- | --------------------------------------------------- | +| name | string | 名称 | 物联网 | +| index_code | string | 指数代码 | 同花顺的概念指数代码是:8开头;例:885312 | +| concept_code | string | 概念代码 | 同花顺的概念代码是:3开头;例:309061;注意不要混淆 | +| soruce | string | 来源 | | + +#### 11. 交易日历 + +| 字段 | 类型 | 注释 | 说明 | +| ------------ | ---- | ------------------------------ | -------------- | +| trade_date | date | 交易日 | 2023-05-20 | +| trade_status | int | 交易状态:0.非交易日;1.交易日 | 1 | +| day_week | int | 一周第几天 | 从星期天开始的 | + +### 二、行情信息-Market + +#### 1. 分红(dividend) + +| 字段 | 类型 | 注释 | 说明 | +| ---------------- | ------ | ---------- | ---------------------------- | +| stock_code | string | 代码 | 600001 | +| report_date | date | 公告日 | 1990-01-01 | +| dividend_plan | string | 分红方案 | 10股派3.00元,10股转赠5.00股 | +| ex_dividend_date | date | 除权除息日 | 1990-01-01 | + + + +#### 2. 行情(market) + +##### 2.1 k线 + +| 字段 | 类型 | 注释 | 说明 | +| -------------- | ------- | ---------- | ----------------------------------------- | +| stock_code | string | 代码 | 600001 | +| trade_time | time | 交易时间 | 1990-01-01 00:00:00;分时图使用具体的时间 | +| trade_date | date | 交易日期 | 1990-01-01 | +| open | decimal | 开盘价(元) | 9.98 | +| close | decimal | 收盘价(元) | 9.98 | +| high | decimal | 最高价(元) | 9.98 | +| low | decimal | 最低价(元) | 9.98 | +| volume | decimal | 成交量(股) | 64745722 | +| amount | decimal | 成交额(元) | 934285179.00 | +| change | decimal | 涨跌额(元) | -0.02 | +| change_pct | decimal | 涨跌幅(%) | -0.16 | +| turnover_ratio | decimal | 换手率(%) | 0.38 | +| pre_close | decimal | 昨收(元) | 10.00 | + +##### 2.2 分时 + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------- | ---------- | ----------------------------------------- | +| stock_code | string | 代码 | 600001 | +| trade_time | time | 交易时间 | 1990-01-01 00:00:00;分时图使用具体的时间 | +| trade_date | date | 交易日期 | 1990-01-01 | +| price | decimal | 价格(元) | 9.98 | +| avg_price | decimal | 平均价(元) | 9.98 | +| change | decimal | 涨跌额(元) | -0.02 | +| change_pct | decimal | 涨跌幅(%) | -0.16 | +| volume | decimal | 成交量(股) | 64745722 | +| amount | decimal | 成交额(元) | 934285179.00 | + +##### 2.3 实时 + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------- | ------------ | -------- | +| stock_code | string | 代码 | 600001 | +| short_name | string | 简称 | 平安银行 | +| price | decimal | 当前价格(元) | 12.36 | +| change | decimal | 涨跌额(元) | 0.02 | +| change_pct | decimal | 涨跌幅(%) | 0.16 | +| volume | decimal | 成交量(股) | 34452500 | +| amount | decimal | 成交额(元) | | + +#### 3. 概念行情(concept market) + +##### 3.1 k线 + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------- | ---------- | ----------------------------------------- | +| index_code | string | 代码 | 886041 | +| trade_time | time | 交易时间 | 1990-01-01 00:00:00;分时图使用具体的时间 | +| trade_date | date | 交易日期 | 1990-01-01 | +| open | decimal | 开盘价(元) | 9.98 | +| close | decimal | 收盘价(元) | 9.98 | +| high | decimal | 最高价(元) | 9.98 | +| low | decimal | 最低价(元) | 9.98 | +| volume | decimal | 成交量(股) | 64745722 | +| amount | decimal | 成交额(元) | 934285179.00 | +| change | decimal | 涨跌额(元) | -0.02 | +| change_pct | decimal | 涨跌幅(%) | -0.16 | + +##### 3.2 分时 + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------- | ---------- | ----------------------------------------- | +| index_code | string | 代码 | 886041 | +| trade_time | time | 交易时间 | 1990-01-01 00:00:00;分时图使用具体的时间 | +| trade_date | date | 交易日期 | 1990-01-01 | +| price | decimal | 现价(元) | 9.98 | +| avg_price | decimal | 均价价(元) | 9.98 | +| high | decimal | 最高价(元) | 9.98 | +| low | decimal | 最低价(元) | 9.98 | +| volume | decimal | 成交量(股) | 64745722 | +| amount | decimal | 成交额(元) | 934285179.00 | +| change | decimal | 涨跌额(元) | -0.02 | +| change_pct | decimal | 涨跌幅(%) | -0.16 | + +##### 3.3 实时 + +| 字段 | 类型 | 注释 | 说明 | +| ---------- | ------- | ---------- | ----------------------------------- | +| index_code | string | 代码 | 886041 | +| trade_time | time | 交易时间 | 1990-01-01 00:00:00;返回当前的时间 | +| trade_date | date | 交易日期 | 1990-01-01 | +| open | decimal | 开盘价(元) | 9.98 | +| price | decimal | 现价(元) | 9.98 | +| high | decimal | 最高价(元) | 9.98 | +| low | decimal | 最低价(元) | 9.98 | +| volume | decimal | 成交量(股) | 64745722 | +| amount | decimal | 成交额(元) | 934285179.00 | + +## 债券-Bond + +## 基金-ETF + +## 舆情 + +### 更新记录 + +| 相关版本 | 更新日期 | 更新内容 | 备注 | +| -------- | -------- | -------- | ---- | +| | | | | +| | | | | +| | | | | + diff --git a/docs/temp.md b/docs/temp.md new file mode 100644 index 0000000..802e76c --- /dev/null +++ b/docs/temp.md @@ -0,0 +1,33 @@ + +### 打包上传的步骤 +4、安装打包工具 + +python -m pip install --upgrade setuptools wheel + + 5、打包模块 + +# 创建存放模块的目录,执行如下命令 +python setup.py sdist bdist_wheel + + 6、上传模块 + +6.1、安装用于发布模块的工具:twine 【已安装无需重复安装】 + +python -m pip install --upgrade twine +或 +pip install --upgrade twine + +提示:python -m 的作用是 run library module as a script (terminates option list)[作为脚本运行库模块(终止选项列表)] + + 6.2、发布(上传) + +python -m twine upload --repository-url https://upload.pypi.org/legacy/ dist/* +或 +twine upload --repository-url https://upload.pypi.org/legacy/ dist/* + + 注意:上传时,提示需要输入PyPI的用户名和密码. + +7、测试在线安装模块 + + + diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 0000000..04adda8 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,5 @@ +tqdm~=4.65.0 +requests~=2.26.0 +pandas~=1.5.3 +beautifulsoup4~=4.11.2 +py_mini_racer>=0.6.0 \ No newline at end of file diff --git a/setup.py b/setup.py new file mode 100644 index 0000000..eb2324b --- /dev/null +++ b/setup.py @@ -0,0 +1,65 @@ +# -*- coding: utf-8 -*- +""" +@desc: setup +@author: 1nchaos +@time: 2023/04/05 +""" + +import os + +from setuptools import find_packages + +here = os.path.abspath(os.path.dirname(__file__)) +about = {} +with open(os.path.join(here, "adata", "__version__.py"), "r") as f: + exec(f.read(), about) + +with open("README.md", "r", encoding='utf-8') as f: + readme = f.read() + +requires = [ + "tqdm~=4.65.0", + "requests~=2.26.0", + "pandas~=1.5.3", + "beautifulsoup4~=4.11.2", + "py_mini_racer~=0.6.0", +] + + +def setup_package(): + metadata = dict( + name=about["__title__"], + version=about["__version__"], + description=about["__description__"], + long_description=readme, + long_description_content_type="text/markdown", + url=about["__url__"], + author=about["__author__"], + author_email=about["__author_email__"], + license=about["__license__"], + packages=find_packages(exclude=("tests", "docs")), + install_requires=requires, + include_package_data=True, + classifiers=[ + # Trove classifiers + # Full list: https://pypi.python.org/pypi?%3Aaction=list_classifiers + "License :: OSI Approved :: MIT License", + "Programming Language :: Python :: 3.7", + "Programming Language :: Python :: 3.8", + "Programming Language :: Python :: 3.9", + "Programming Language :: Python :: 3.10", + "Programming Language :: Python :: 3.11", + "Programming Language :: Python :: 3.12", + ], + ) + + try: + from setuptools import setup + except ImportError: + from distutils.core import setup + + setup(**metadata) + + +if __name__ == "__main__": + setup_package() diff --git a/tests/__init__.py b/tests/__init__.py new file mode 100644 index 0000000..a2e4c7a --- /dev/null +++ b/tests/__init__.py @@ -0,0 +1,6 @@ +# -*- coding: utf-8 -*- +""" +@summary: +@author: 1nchaos +@date: 2023/3/30 10:00 +""" diff --git a/tests/bs4_test.py b/tests/bs4_test.py new file mode 100644 index 0000000..ff59974 --- /dev/null +++ b/tests/bs4_test.py @@ -0,0 +1,23 @@ +# -*- coding: utf-8 -*- +""" +@desc: readme +@author: 1nchaos +@time: 2023/5/8 +@log: change log +""" +import re + +from bs4 import BeautifulSoup + +if __name__ == '__main__': + html = '''
+  1  2  3  4  5  下一页尾页1/10 +
''' + + soup = BeautifulSoup(html, 'html.parser') + + # 获取总页数 + page_info = soup.find('span', {'class': 'page_info'}).text + total_pages = int(page_info.split("/")[1]) + + print(total_pages) # 输出: 10 diff --git a/tests/stock_test.py b/tests/stock_test.py new file mode 100644 index 0000000..699eaa6 --- /dev/null +++ b/tests/stock_test.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +""" +@summary: +@author: 1nchaos +@date: 2023/3/30 10:00 +""" + +from adata import * +from adata.stock.market import * + +# from adata.stock import dividend + +if __name__ == '__main__': + # print(stock.market.dividend.get_dividend('000001')) + # print(code.all_code()) + # print(sd.stock.info.all_gn_code_ths()) + # print(stock.info.all_gn_code_ths()) + # print(sd.stock.info.code.all_code()) + # print(sd.stock.market.gn_market.get_market_gn_ths()) + # print(stock.market.stock_market.get_market()) + print(market.get_market())