gandartExchange.js 59 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137
  1. const config = {
  2. "PATH_IMG_V2_PRO": "https://cdn-image.gandart.com/",
  3. "RUN_TYPE": 1,
  4. "BOTTOM_LOAD_MORE_THROTTLE": 100,
  5. "BASE_API": "https://api.gandart.com/base",
  6. "RESALE_API": "https://api.gandart.com/market",
  7. "RESALE_API_V2": "https://api2.gandart.com/market/api/v2",
  8. "RESALE_API_V3": "https://api2.gandart.com/market/api/v3",
  9. "SALE_API": "https://api.gandart.com/read/api",
  10. "ORDER_API": "https://api.gandart.com",
  11. "WALLET_API": "https://api.gandart.com/api",
  12. "HXT_API": "https://api.gandart.com/wallet",
  13. "PATH_IMG_V2": "https://cdn-image.gandart.com/",
  14. "SAND_RECHARGE_ACTION": "https://cap.sandpay.com.cn/v4/front-electrans/ceas.elec.trans.quick.deposit.apply",
  15. "GAME_ElF_API": "https://elf.pentajam.cn/api",
  16. "GAME_ELF_URL": "https://elf.pentajam.cn",
  17. "CORECENTER_URL": "https://api.gandart.com/corecenter"
  18. };
  19. const lk = new ToolKit(`光予分解手`, `GandartExchanger`, `gandartExchange.js`);
  20. const GandartConstKey = {
  21. // -----通用助手相关的-----
  22. Token: 'lkGandartToken',
  23. UserData: 'lkGandartUserData',
  24. PrivCollectionBrief: 'lkGandartPrivCollectionBrief',
  25. PrivCollectionDetail: 'lkGandartPrivCollectionDetail',
  26. CollectionName: 'lkGandartCollectionName',
  27. CastingId: 'lkGandartCastingId',
  28. LimitPrice: 'lkGandartLimitPrice',
  29. TransactionRecordId: 'lkGandartTransactionRecordId',
  30. CollectionCateLst: 'lkGandartCollectionCateLst',
  31. FloatPriceIntaval: 'lkGandartFloatPriceIntaval',
  32. IsCollectionWatchLocked: 'lkIsGandartCollectionWatchLocked',
  33. PrivWalletListInUse: 'lkGandartPrivWalletListInUse',
  34. IsCollectionMaxNumLimit: 'lkGandartIsCollectionMaxNumLimit',
  35. CollectionLockMaxNum: 'lkGandartCollectionLockMaxNum',
  36. // -----置换分解脚本增加的-----
  37. ExchangeFuncEnalbleList: 'lkGandartExchangeFuncEnalbleList',
  38. ExchangeTaskList0: 'lkGandartExchangeTaskList0',
  39. ExchangeTaskList1: 'lkGandartExchangeTaskList1',
  40. ExchangeTaskList2: 'lkGandartExchangeTaskList2',
  41. ExchangeTaskId: 'lkGandartExchangeTaskId',
  42. ExchangeTaskSearchEnable: 'lkIsExchangeTaskSearchEnable',
  43. ExchangeTaskSearchKey: 'lkGandartExchangeTaskSearchKey',
  44. ExchangeTaskNameDisplay: 'lkGandartExchangeTaskNameDisplay',
  45. ExchangeCountArray: 'lkGandartExchangeCountArray',
  46. ExchangeTaskMateList: 'lkGandartExchangeTaskMateList',
  47. ExchangeTaskFinalList: 'lkGandartExchangeTaskFinalList',
  48. ExchangeTaskListStatus: 'lkGandartExchangeTaskListStatus',
  49. ExchangeTaskListCache: 'lkIsExchangeTaskListCache',
  50. ExchangeMaterialCache: 'lkIsExchangeMaterialCache',
  51. ExchangeTaskMode: 'lkGandartExchangeTaskMode',
  52. ExchangeBatchEnable: 'lkIsExchangeBatchEnable',
  53. ExchangeBatchGroupCount: 'lkGandartExchangeBatchGroupCount',
  54. };
  55. let gandartToken = lk.getVal(GandartConstKey.Token, '');
  56. let gandartUserAgent = `Mozilla/5.0 (iPhone; CPU iPhone OS 16_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.3 Mobile/15E148 Safari/604.1`;
  57. const GCommonGandartHeads = {
  58. 'Accept': `application/json, text/plain, */*`,
  59. 'Origin': `https://www.gandart.com`,
  60. 'Accept-Encoding': `gzip, deflate, br`,
  61. 'Content-Type': `application/x-www-form-urlencoded;charset=UTF-8`,
  62. 'Connection': `keep-alive`,
  63. 'Host': `api2.gandart.com`,
  64. 'User-Agent': gandartUserAgent,
  65. 'Referer': `https://www.gandart.com/`,
  66. 'Accept-Language': `zh-CN,zh-Hans;q=0.9`,
  67. 'token': gandartToken
  68. };
  69. let gAllMaterialDetails = null;
  70. const gUsedMaterialDetails = {};
  71. let gFuncEnables = lk.getVal(GandartConstKey.ExchangeFuncEnalbleList);
  72. if (!lk.isEmpty(gFuncEnables)) {
  73. gFuncEnables = gFuncEnables.split(',');
  74. } else {
  75. gFuncEnables = ["TaskList", "MateList", "DecidedList"];
  76. }
  77. if (!lk.isExecComm) {
  78. if (!lk.isRequest()) {
  79. all();
  80. }
  81. }
  82. async function all() {
  83. let taskLst = [];
  84. if (isGetTaskListEnable()) {
  85. let status = getExchangeTaskListStatus();
  86. let tmpLst = [];
  87. switch (status) {
  88. case 0:
  89. tmpLst = await checkGetExchangeTaskList(status);
  90. if (tmpLst) {
  91. taskLst = taskLst.concat(tmpLst);
  92. }
  93. break;
  94. case 1:
  95. tmpLst = await checkGetExchangeTaskList(status);
  96. if (tmpLst) {
  97. taskLst = taskLst.concat(tmpLst);
  98. }
  99. break;
  100. case 2:
  101. tmpLst = await checkGetExchangeTaskList(status);
  102. if (tmpLst) {
  103. taskLst = taskLst.concat(tmpLst);
  104. }
  105. break;
  106. case 3:
  107. tmpLst = await checkGetExchangeTaskList(1);
  108. if (tmpLst) {
  109. taskLst = taskLst.concat(tmpLst);
  110. }
  111. tmpLst = await checkGetExchangeTaskList(0);
  112. if (tmpLst) {
  113. taskLst = taskLst.concat(tmpLst);
  114. }
  115. break;
  116. default:
  117. break;
  118. }
  119. }
  120. if (taskLst.length == 0) {
  121. lk.log('置换分解任务列表为空');
  122. }
  123. if (isCaclMateListEnable()) {
  124. let isFoundOnce = await checkToExchangeConformingTasks(taskLst);
  125. if (!isFoundOnce) {
  126. lk.log('没有任何相符合的置换分解任务');
  127. }
  128. }
  129. lk.msg('');
  130. lk.done();
  131. }
  132. async function checkToExchangeConformingTasks(taskLst) {
  133. let taskIds = getWillExchangeTaskIds();
  134. let isFoundOnce = false;
  135. let found = false;
  136. for (let i = 0; i < taskIds.length; i++) {
  137. let taskId = taskIds[i];
  138. found = false;
  139. if (taskId > 0) {
  140. for (let j = 0; j < taskLst.length; j++) {
  141. let taskInfo = taskLst[j];
  142. if (taskInfo.id == taskId) {
  143. found = true;
  144. lk.setVal(GandartConstKey.ExchangeTaskNameDisplay, taskInfo.compositeTaskName);
  145. await tryToExecExchangeTask(taskInfo.id, taskInfo, i);
  146. break;
  147. }
  148. }
  149. if (!found) {
  150. lk.log(`[${i}]当前任务列表找不到指定任务[${taskId}]`);
  151. found = await checkTrySearchToExchangeTask(taskLst, i);
  152. }
  153. } else {
  154. lk.log(`[${i}]没有设置指定任务ID,检查是否需进行检索合成`);
  155. await checkTrySearchToExchangeTask(taskLst, i);
  156. }
  157. if (found) {
  158. isFoundOnce = found;
  159. }
  160. }
  161. found = false;
  162. let keyNames = getWillExchangeTaskSearchKeys();
  163. for (let i = taskIds.length; i < keyNames.length; i++) {
  164. lk.log(`[${i}]没有设置指定任务ID,检查是否需进行检索合成`);
  165. found = await checkTrySearchToExchangeTask(taskLst, i);
  166. if (found) {
  167. isFoundOnce = found;
  168. }
  169. }
  170. return isFoundOnce;
  171. }
  172. async function checkTrySearchToExchangeTask(taskLst, sortIdx) {
  173. if (!isTaskNameSearchMode()) {
  174. return;
  175. }
  176. lk.log('开始尝试通过名称来检索任务进行合成');
  177. let keyNames = getWillExchangeTaskSearchKeys();
  178. let keyName = keyNames[sortIdx];
  179. if (lk.isEmpty(keyName)) {
  180. lk.log(`当前检索关键字为空`);
  181. return;
  182. }
  183. let found = false;
  184. for (let i = 0; i < taskLst.length; i++) {
  185. let taskInfo = taskLst[i];
  186. let taskName = taskInfo.compositeTaskName;
  187. if (taskName.indexOf(keyName) > -1) {
  188. found = true;
  189. lk.log(`检索到相符的任务[${taskName}#${taskInfo.id}]`);
  190. lk.setVal(GandartConstKey.ExchangeTaskNameDisplay, taskName);
  191. await tryToExecExchangeTask(taskInfo.id, taskInfo, sortIdx);
  192. }
  193. }
  194. if (!found) {
  195. lk.log(`当前关键字[${keyName}]没有检索到相关的任务`);
  196. }
  197. return found;
  198. }
  199. function getExchangeTaskListStatus() {
  200. let val = lk.getVal(GandartConstKey.ExchangeTaskListStatus);
  201. if (lk.isEmpty(val)) {
  202. val = 1;
  203. } else {
  204. val = Number(val);
  205. }
  206. return val;
  207. }
  208. function getExchangeTaskMode() {
  209. let val = lk.getVal(GandartConstKey.ExchangeTaskMode);
  210. if (lk.isEmpty(val)) {
  211. val = 0;
  212. } else {
  213. val = Number(val);
  214. }
  215. return val;
  216. }
  217. function isGetTaskListEnable() {
  218. if (gFuncEnables.indexOf('TaskList') > -1) {
  219. return true;
  220. }
  221. return false;
  222. }
  223. function isCaclMateListEnable() {
  224. if (gFuncEnables.indexOf('MateList') > -1) {
  225. return true;
  226. }
  227. return false;
  228. }
  229. function isGenFinalLisstEnable() {
  230. if (gFuncEnables.indexOf('DecidedList') > -1) {
  231. return true;
  232. }
  233. return false;
  234. }
  235. function isExecFinalExchange() {
  236. if (gFuncEnables.indexOf('ExecExchange') > -1) {
  237. return true;
  238. }
  239. return false;
  240. }
  241. function checkIsExchangeTaskExec(taskInfo) {
  242. if (taskInfo) {
  243. if (taskInfo.endTime && taskInfo.startTime) {
  244. let nowDate = new Date();
  245. let endDate = new Date(taskInfo.endTime);
  246. if (nowDate.getTime() >= endDate.getTime()) {
  247. return true;
  248. }
  249. let startDate = new Date(taskInfo.startTime);
  250. if (nowDate.getTime() > startDate.getTime() - 1000) {
  251. return true;
  252. }
  253. return false;
  254. }
  255. }
  256. return true;
  257. }
  258. function getWillExchangeTaskIds() {
  259. let valArr = lk.getVal(GandartConstKey.ExchangeTaskId);
  260. if (!lk.isEmpty(valArr)) {
  261. let segments = valArr.split('|');
  262. valArr = [];
  263. for (let vstr of segments) {
  264. valArr.push(Number(vstr));
  265. }
  266. } else {
  267. valArr = [];
  268. }
  269. return valArr;
  270. }
  271. function getWillExchangeTaskSearchKeys() {
  272. let keyArr = lk.getVal(GandartConstKey.ExchangeTaskSearchKey)
  273. if (!lk.isEmpty(keyArr)) {
  274. let segments = keyArr.split('|');
  275. keyArr = [];
  276. for (let vstr of segments) {
  277. keyArr.push(vstr);
  278. }
  279. } else {
  280. keyArr = [];
  281. }
  282. return keyArr;
  283. }
  284. function isTaskNameSearchMode() {
  285. let enabled = lk.getVal(GandartConstKey.ExchangeTaskSearchEnable);
  286. if (!lk.isEmpty(enabled)) {
  287. enabled = JSON.parse(enabled);
  288. } else {
  289. enabled = true;
  290. }
  291. return enabled;
  292. }
  293. function isExchangeBatchEnable() {
  294. let enabled = lk.getVal(GandartConstKey.ExchangeBatchEnable);
  295. if (!lk.isEmpty(enabled)) {
  296. enabled = JSON.parse(enabled);
  297. } else {
  298. enabled = true;
  299. }
  300. return enabled;
  301. }
  302. function printMaterialGroupsInfo(materialGroups) {
  303. let detailStr = '组合详情如下:\n';
  304. for (let i = 0; i < materialGroups.length; i++) {
  305. let group = materialGroups[i];
  306. let needStr = '';
  307. for (let j = 0; j < group.length; j++) {
  308. needStr += `${group[j].collectionName}x${group[j].number},`
  309. }
  310. detailStr += `组合${i}:${needStr.substring(0, needStr.length - 1)}\n`;
  311. }
  312. lk.log(detailStr);
  313. }
  314. async function checkGetMaterialDetails(gUsedMaterialDetails, materialDict) {
  315. let useCache = lk.getVal(GandartConstKey.ExchangeMaterialCache);
  316. if (!lk.isEmpty(useCache)) {
  317. useCache = JSON.parse(useCache);
  318. } else {
  319. useCache = false;
  320. }
  321. lk.log(`置换分解材料列表本地缓存:${useCache}`);
  322. let isReqServerData = false;
  323. if (useCache) {
  324. let jsonStr = lk.getVal(GandartConstKey.PrivCollectionDetail);
  325. if (!lk.isEmpty(jsonStr)) {
  326. try {
  327. let data = JSON.parse(jsonStr);
  328. gAllMaterialDetails = data;
  329. for (let k in materialDict) {
  330. gUsedMaterialDetails[k] = data[k];
  331. }
  332. } catch (error) {
  333. lk.logErr(error);
  334. isReqServerData = true;
  335. }
  336. } else {
  337. isReqServerData = true;
  338. }
  339. } else {
  340. isReqServerData = true;
  341. }
  342. if (isReqServerData) {
  343. for (let k in materialDict) {
  344. let mInfo = materialDict[k];
  345. gUsedMaterialDetails[k] = await getDetailByCasting(mInfo.castingId, mInfo.collectionName);
  346. }
  347. }
  348. return gUsedMaterialDetails;
  349. }
  350. async function tryToExecExchangeTask(taskId, taskInfo = {}, sortIdx = 0) {
  351. if (getExchangeTaskMode() == 1) {
  352. lk.log('开始极速模式执行置换分解任务');
  353. let data = getExchangeTaskFinalList();
  354. if (data) {
  355. let taskInfo = data.taskInfo;
  356. let finalGroups = data.finalGroups;
  357. if (finalGroups.length == 0) {
  358. lk.log('暂无可行的置换分解组合,请检查');
  359. lk.appendNotifyInfo('⚠️暂无可行的置换分解组合');
  360. return;
  361. }
  362. lk.log(`最终选择可执行置换分解数:${finalGroups.length}`);
  363. let tmpJsonStr = JSON.stringify(finalGroups, null, 2);
  364. lk.log(`详情如下:\n${tmpJsonStr}`);
  365. if (isExecFinalExchange() && checkIsExchangeTaskExec(taskInfo)) {
  366. await doExecFinalExchange(taskInfo.id, taskInfo, finalGroups);
  367. } else {
  368. lk.log('暂未进行最后一步置换分解');
  369. }
  370. }
  371. return;
  372. }
  373. lk.log('开始普通模式执行置换分解任务');
  374. let materialSelLst = await getCompositeMaterial(taskId, taskInfo);
  375. if (materialSelLst && materialSelLst.length > 0) {
  376. let ret = calcCompositeGroups(materialSelLst);
  377. // 材料排列组合
  378. let materialGroups = ret[0];
  379. lk.log(`排列组合组数:${materialGroups.length}`);
  380. // printMaterialGroupsInfo(materialGroups);
  381. let materialDict = ret[1];
  382. // 获取用户材料拥有详情
  383. await checkGetMaterialDetails(gUsedMaterialDetails, materialDict);
  384. // 找出可行的合成搭配
  385. let validCompositeGroups = findValidGroupMaterialGroups(materialGroups, gUsedMaterialDetails);
  386. setExchangeTaskMateListForDisplay(validCompositeGroups);
  387. // printMaterialGroupsInfo(validCompositeGroups, '预估可行组合数');
  388. if (isGenFinalLisstEnable()) {
  389. let exchangeCountDict = getExchangeCountDict(sortIdx);
  390. let finalGroups = [];
  391. for (let k in exchangeCountDict) {
  392. let mGroup = validCompositeGroups[k];
  393. if (mGroup) {
  394. let arr = checkPickMaterialForExchange(mGroup, gUsedMaterialDetails, exchangeCountDict[k]);
  395. finalGroups = finalGroups.concat(arr);
  396. }
  397. }
  398. lk.log(`最终选择可执行置换分解数:${finalGroups.length}`);
  399. let tmpJsonStr = JSON.stringify(finalGroups, null, 2);
  400. lk.log(`详情如下:\n${tmpJsonStr}`);
  401. if (isExecFinalExchange() && checkIsExchangeTaskExec(taskInfo)) {
  402. if (finalGroups.length == 0) {
  403. lk.log('暂无可行的置换分解组合,请检查');
  404. // lk.appendNotifyInfo('⚠️暂无可行的合成组合');
  405. return;
  406. }
  407. await doExecFinalExchange(taskId, taskInfo, finalGroups);
  408. } else {
  409. lk.log('暂未进行最后一步置换分解');
  410. setExchangeTaskFinalList(taskInfo, finalGroups);
  411. }
  412. } else {
  413. lk.execFail();
  414. lk.appendNotifyInfo('⚠️请设置光予置换分解任务ID');
  415. }
  416. }
  417. return;
  418. }
  419. function setExchangeTaskMateListForDisplay(validCompositeGroups) {
  420. lk.log(`预估可行组合数:${validCompositeGroups.length}`);
  421. let disText = '';
  422. for (let i = 0; i < validCompositeGroups.length; i++) {
  423. let group = validCompositeGroups[i];
  424. let rowText = `[${i}]`;
  425. for (let j = 0; j < group.length; j++) {
  426. let mInfo = group[j];
  427. rowText += `${mInfo.collectionName}x${mInfo.number},`;
  428. }
  429. disText += rowText.substring(0, rowText.length - 1) + '\n';
  430. }
  431. lk.log(disText);
  432. lk.setVal(GandartConstKey.ExchangeTaskMateList, disText);
  433. }
  434. function getBatchExchangeGroupCount() {
  435. let numStr = lk.getVal(GandartConstKey.ExchangeBatchGroupCount);
  436. if (lk.isEmpty(numStr)) {
  437. return 5;
  438. }
  439. return Number(numStr);
  440. }
  441. async function doExecFinalExchange(taskId, taskInfo, finalGroups) {
  442. let retOrderLst = [];
  443. let retWillDelLst = [];
  444. let batchGroupCnt = getBatchExchangeGroupCount();
  445. let startIdx = 0;
  446. // 检查是否进行多个批量合成
  447. if (isExchangeBatchEnable() && finalGroups.length >= batchGroupCnt) {
  448. let batchMaxNum = Math.floor(finalGroups.length / batchGroupCnt);
  449. for (let i = 0; i < batchMaxNum; i++) {
  450. let compositeList = [];
  451. for (let j = 0; j < batchGroupCnt; j++) {
  452. compositeList.push({
  453. materialDetailList: finalGroups[startIdx]
  454. });
  455. startIdx += 1;
  456. }
  457. let ret = await confirmCompositeV2(taskId, taskInfo, compositeList);
  458. if (ret) {
  459. for (let idx = startIdx - batchMaxNum; idx < startIdx; idx++) {
  460. retWillDelLst.push(idx);
  461. }
  462. retOrderLst.push(ret);
  463. }
  464. }
  465. }
  466. // 剩下的进行单个合成
  467. for (let i = startIdx; i < finalGroups.length; i++) {
  468. let idx = i;
  469. let compositeList = [
  470. {
  471. materialDetailList: finalGroups[i]
  472. }
  473. ];
  474. let ret = await confirmCompositeV2(taskId, taskInfo, compositeList);
  475. if (ret) {
  476. retWillDelLst.push(idx);
  477. retOrderLst.push(ret);
  478. }
  479. }
  480. if (retOrderLst.length > 0) {
  481. let successCnt = 0;
  482. let noStockCnt = 0;
  483. for (let i = 0; i < retOrderLst.length; i++) {
  484. const orderNum = retOrderLst[i];
  485. lk.log(`[${i}]单号:${orderNum}`);
  486. if (orderNum.indexOf('#') > -1) {
  487. successCnt += 1;
  488. } else if (orderNum.indexOf('!') > -1) {
  489. noStockCnt += 1;
  490. } else {
  491. successCnt += 1;
  492. await checkCompositeResult(orderNum);
  493. }
  494. }
  495. lk.log(`分解成功单数:${successCnt}`);
  496. lk.log(`库存不足单数:${noStockCnt}`);
  497. // 从高的序号删除
  498. let usedGroups = [];
  499. for (let i = retWillDelLst.length - 1; i >= 0; i--) {
  500. let idx = retWillDelLst[i];
  501. lk.log(`编号[${idx}]一组的材料分解销毁删除`);
  502. usedGroups.push(finalGroups[idx]);
  503. finalGroups.splice(idx, 1);
  504. }
  505. let tmpJsonStr = JSON.stringify(finalGroups, null, 2);
  506. lk.log(`剩余未完成的组合如下:\n${tmpJsonStr}`);
  507. setExchangeTaskFinalList(taskInfo, finalGroups);
  508. refreshMaterialAfterComposite(usedGroups);
  509. } else {
  510. lk.log('置换分解成功单数:0');
  511. }
  512. }
  513. function setExchangeTaskFinalList(taskInfo, finalGroups) {
  514. let simpleInfo = {
  515. id: taskInfo.id,
  516. compositeLabel: taskInfo.compositeLabel,
  517. compositeTaskName: taskInfo.compositeTaskName,
  518. surplus: taskInfo.surplus,
  519. }
  520. let finalCacheData = {
  521. taskInfo: simpleInfo,
  522. finalGroups: finalGroups,
  523. };
  524. lk.setVal(GandartConstKey.ExchangeTaskFinalList, JSON.stringify(finalCacheData, null, 2));
  525. }
  526. function refreshMaterialAfterComposite(usedGroups) {
  527. if (usedGroups.length == 0) {
  528. return;
  529. }
  530. if (!gAllMaterialDetails) {
  531. let jsonStr = lk.getVal(GandartConstKey.PrivCollectionDetail);
  532. if (!lk.isEmpty(jsonStr)) {
  533. try {
  534. let data = JSON.parse(jsonStr);
  535. gAllMaterialDetails = data;
  536. } catch (error) {
  537. lk.logErr(error);
  538. }
  539. for (let group of usedGroups) {
  540. for (let one of group) {
  541. deleteUsedMaterial(one.castingId, one.orderList);
  542. }
  543. }
  544. jsonStr = JSON.stringify(gAllMaterialDetails, null, 2);
  545. lk.setVal(GandartConstKey.PrivCollectionDetail, jsonStr);
  546. }
  547. }
  548. }
  549. function deleteUsedMaterial(castingId, recordIdLst) {
  550. let itemLst = gAllMaterialDetails[castingId];
  551. if (itemLst) {
  552. let remainLst = [];
  553. for (let i = 0; i < itemLst.length; i++) {
  554. if (recordIdLst.indexOf(itemLst[i].id) == -1) {
  555. remainLst.push(itemLst[i]);
  556. }
  557. }
  558. gAllMaterialDetails[castingId] = remainLst;
  559. }
  560. }
  561. function getExchangeTaskFinalList() {
  562. let data;
  563. let jsonStr = lk.getVal(GandartConstKey.ExchangeTaskFinalList);
  564. if (!lk.isEmpty(jsonStr)) {
  565. data = JSON.parse(jsonStr);
  566. }
  567. return data;
  568. }
  569. function getExchangeCountDict(sortIdx) {
  570. let str = lk.getVal(GandartConstKey.ExchangeCountArray, '0#1');
  571. let arr0 = str.split('|');
  572. let ret = {};
  573. if (sortIdx < arr0.length) {
  574. let arr1 = arr0[sortIdx].split(',');
  575. for (let i = 0; i < arr1.length; i++) {
  576. let arr2 = arr1[i].split('#');
  577. let key = arr2[0];
  578. ret[key] = Number(arr2[1] || 1);
  579. }
  580. } else {
  581. ret[0] = 1;
  582. }
  583. return ret;
  584. }
  585. function findValidGroupMaterialGroups(materialGroups, materialDetails) {
  586. let validGroups = [];
  587. for (let i = 0; i < materialGroups.length; i++) {
  588. let canCount = checkMaterialEnough(materialGroups[i], materialDetails);
  589. if (canCount > 0) {
  590. validGroups.push(materialGroups[i]);
  591. }
  592. }
  593. return validGroups;
  594. }
  595. function checkMaterialEnough(materialGroup, materialDetails) {
  596. let minCount = 99999;
  597. for (let i = 0; i < materialGroup.length; i++) {
  598. const materialObj = materialGroup[i];
  599. const castingId = materialObj.castingId;
  600. const ownLst = materialDetails[castingId];
  601. if (!ownLst) {
  602. minCount = 0;
  603. break;
  604. }
  605. if (ownLst.length >= materialObj.number) {
  606. let maxCount = Math.floor(ownLst.length / materialObj.number);
  607. if (maxCount < minCount) {
  608. minCount = maxCount;
  609. }
  610. } else {
  611. minCount = 0;
  612. break;
  613. }
  614. }
  615. if (minCount == 99999) {
  616. minCount = 0;
  617. }
  618. return minCount
  619. }
  620. function checkPickMaterialForExchange(materialGroup, materialDetails, wantCount) {
  621. let needNumDict = {};
  622. for (let i = 0; i < materialGroup.length; i++) {
  623. const materialObj = materialGroup[i];
  624. const castingId = materialObj.castingId;
  625. if (!needNumDict[castingId]) {
  626. needNumDict[castingId] = materialObj.number;
  627. } else {
  628. needNumDict[castingId] += materialObj.number;
  629. }
  630. }
  631. let minCount = 99999;
  632. for (let kid in needNumDict) {
  633. const ownLst = materialDetails[kid] || [];
  634. const maxCount = Math.floor(ownLst.length / needNumDict[kid]);
  635. if (maxCount < minCount) {
  636. minCount = maxCount;
  637. }
  638. }
  639. minCount = Math.min(minCount, wantCount);
  640. let nCompositeGroup = [];
  641. for (let n = 0; n < minCount; n++) {
  642. let resultMaterialLst = [];
  643. let interrupt = false;
  644. for (let i = 0; i < materialGroup.length; i++) {
  645. const materialObj = materialGroup[i];
  646. const castingId = materialObj.castingId;
  647. let ownLst = materialDetails[castingId];
  648. let num = materialObj.number;
  649. if (ownLst.length < num) {
  650. interrupt = true;
  651. break;
  652. }
  653. let materialSeries = {
  654. castingId: castingId,
  655. orderList: [],
  656. };
  657. for (let j = ownLst.length - 1; j >= 0; j--) {
  658. num -= 1;
  659. let info = ownLst[j];
  660. materialSeries.orderList.push(info.id);
  661. ownLst.splice(j, 1);
  662. if (num == 0) {
  663. break;
  664. }
  665. }
  666. resultMaterialLst.push(materialSeries);
  667. }
  668. if (interrupt) {
  669. break;
  670. }
  671. nCompositeGroup.push(resultMaterialLst);
  672. }
  673. return nCompositeGroup;
  674. }
  675. function calcCompositeGroups(materialSelLst) {
  676. let materialDict = {};
  677. let materialGroups = [];
  678. function doArrangeMeterialGroup(transArr, index, resultArr, resultTmp) {
  679. for (let i = 0; i < transArr[index].length; i++) {
  680. const materialInfo = transArr[index][i];
  681. resultTmp[index] = materialInfo;
  682. const castingId = materialInfo.castingId;
  683. materialDict[castingId] = materialInfo;
  684. if (index != transArr.length - 1) {
  685. doArrangeMeterialGroup(transArr, index + 1, resultArr, resultTmp);
  686. } else {
  687. resultArr.push([].concat(resultTmp));
  688. }
  689. }
  690. return resultArr;
  691. }
  692. doArrangeMeterialGroup(materialSelLst, 0, materialGroups, []);
  693. return [materialGroups, materialDict];
  694. }
  695. async function checkGetExchangeTaskList(status) {
  696. let taskLst;
  697. let useCache = lk.getVal(GandartConstKey.ExchangeTaskListCache);
  698. if (!lk.isEmpty(useCache)) {
  699. useCache = JSON.parse(useCache);
  700. } else {
  701. useCache = false;
  702. }
  703. lk.log(`置换分解任务列表本地缓存:${useCache}`);
  704. if (useCache) {
  705. taskLst = getExchangeTaskListByCache(status);
  706. } else {
  707. taskLst = [];
  708. let taskDetail = await getExchangeTaskListByServer(status, 10, 1);
  709. if (taskDetail && taskDetail.rows) {
  710. taskLst = concatTaskList(taskLst, taskDetail.rows, 1);
  711. let totalPage = taskDetail.totalPage;
  712. for (let i = 2; i < totalPage + 1; i++) {
  713. taskDetail = await getExchangeTaskListByServer(status, 10, i);
  714. if (taskDetail && taskDetail.rows) {
  715. taskLst = concatTaskList(taskLst, taskDetail.rows, i);
  716. }
  717. }
  718. }
  719. cacheExchangeTaskList(status, taskLst);
  720. }
  721. return taskLst;
  722. }
  723. function concatTaskList(latestLst, newLst, page) {
  724. for (let i = 0; i < newLst.length; i++) {
  725. newLst[i].page = page;
  726. latestLst.push(newLst[i]);
  727. }
  728. return latestLst;
  729. }
  730. function getExchangeTaskListByCache(status, pageSize = 10, page = 1) {
  731. try {
  732. let jsonStr = '';
  733. if (status == 0) {
  734. jsonStr = lk.getVal(GandartConstKey.ExchangeTaskList0);
  735. } else if (status == 1) {
  736. jsonStr = lk.getVal(GandartConstKey.ExchangeTaskList1);
  737. } else if (status == 2) {
  738. jsonStr = lk.getVal(GandartConstKey.ExchangeTaskList2);
  739. }
  740. if (!lk.isEmpty(jsonStr)) {
  741. return JSON.parse(jsonStr);
  742. }
  743. } catch (error) {
  744. lk.logErr(error);
  745. }
  746. }
  747. function cacheExchangeTaskList(status, taskLst) {
  748. // 精简一下内容
  749. let simpleLst = [];
  750. for (let i = 0; i < taskLst.length; i++) {
  751. let info = taskLst[i];
  752. let item = {
  753. id: info.id,
  754. compositeLabel: info.compositeLabel,
  755. compositeTaskName: info.compositeTaskName,
  756. surplus: info.surplus,
  757. startTime: info.startTime,
  758. endTime: info.endTime,
  759. page: info.page,
  760. };
  761. simpleLst.push(item);
  762. }
  763. let jsonStr = JSON.stringify(simpleLst, null, 2);
  764. if (status == 0) {
  765. lk.setVal(GandartConstKey.ExchangeTaskList0, jsonStr);
  766. } else if (status == 1) {
  767. lk.setVal(GandartConstKey.ExchangeTaskList1, jsonStr);
  768. } else if (status == 2) {
  769. lk.setVal(GandartConstKey.ExchangeTaskList2, jsonStr);
  770. }
  771. }
  772. async function getExchangeTaskListByServer(status, pageSize = 10, page = 1) {
  773. return new Promise((resolve, _reject) => {
  774. try {
  775. const headers = GCommonGandartHeads;
  776. headers['Host'] = 'api.gandart.com';
  777. headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
  778. let body = `page=${page}&pageSize=${pageSize}&total=0&status=${status}&labelName=`;
  779. let url = {
  780. url: `${config.WALLET_API}/v2/composite/v3/list/v3`,
  781. headers: headers,
  782. body: body
  783. };
  784. let tagNames = [
  785. '待开始',
  786. '进行中',
  787. '已结束',
  788. ];
  789. lk.log(`获取置换分解任务[${tagNames[status]}]列表:${body}`);
  790. lk.post(url, async (error, _response, data) => {
  791. let ret = {};
  792. try {
  793. if (error) {
  794. lk.log(`获取置换分解任务列表发生错误`);
  795. lk.execFail();
  796. lk.appendNotifyInfo(`❌获取置换分解任务列表失败,请稍后再试`);
  797. } else {
  798. ret = JSON.parse(data);
  799. lk.log(`获取置换分解任务列表成功`);
  800. }
  801. } catch (e) {
  802. lk.log(`获取置换分解任务列表发生错误`);
  803. lk.logErr(e);
  804. lk.execFail();
  805. } finally {
  806. resolve(ret);
  807. }
  808. });
  809. } catch (e) {
  810. lk.log(`获取置换分解任务列表发生错误`);
  811. lk.logErr(e);
  812. resolve();
  813. }
  814. });
  815. }
  816. async function getCompositeMaterial(taskId, taskInfo) {
  817. return new Promise((resolve, _reject) => {
  818. try {
  819. const headers = GCommonGandartHeads;
  820. headers['Host'] = 'api.gandart.com';
  821. headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
  822. let body = `taskId=${taskId}`;
  823. let url = {
  824. url: `${config.BASE_API}/v2/composite/v3/compositeMaterial`,
  825. headers: headers,
  826. body: body
  827. };
  828. let taskName = taskInfo.compositeTaskName || ''; //合成标题
  829. lk.log(`获取置换分解任务[${taskName}#${taskId}]材料详情:${body}`);
  830. lk.post(url, async (error, _response, data) => {
  831. let retItemLst = [];
  832. try {
  833. if (error) {
  834. lk.log(`获取置换分解任务材料详情发生错误`);
  835. lk.execFail();
  836. lk.appendNotifyInfo(`❌获取置换分解任务材料详情失败,请稍后再试`);
  837. } else {
  838. let ret = JSON.parse(data);
  839. if (ret.success) {
  840. let obj = ret.obj;
  841. retItemLst = obj;
  842. lk.log(`获取置换分解任务材料详情成功`);
  843. } else {
  844. lk.log(`获取置换分解任务材料详情失败,响应:${data}`);
  845. }
  846. }
  847. } catch (e) {
  848. lk.log(`获取置换分解任务材料详情发生错误`);
  849. lk.logErr(e);
  850. lk.execFail();
  851. } finally {
  852. resolve(retItemLst);
  853. }
  854. });
  855. } catch (e) {
  856. lk.log(`获取置换分解任务材料详情发生错误`);
  857. lk.logErr(e);
  858. resolve();
  859. }
  860. });
  861. }
  862. async function getDetailByCasting(castingId, collectionName, pageSize = 50, page = 1) {
  863. return new Promise((resolve, _reject) => {
  864. try {
  865. const headers = GCommonGandartHeads;
  866. headers['Host'] = 'api.gandart.com';
  867. headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
  868. let params = {
  869. castingId: castingId,
  870. page: page,
  871. pageSize: pageSize,
  872. };
  873. let signData = getSign();
  874. signData = Object.assign(signData, params);
  875. let body = lk.objToQueryStr(signData);
  876. let url = {
  877. url: `${config.SALE_API}/composite/getDetailByCasting?${lk.objToQueryStr(params)}`,
  878. headers: headers,
  879. body: body
  880. };
  881. collectionName = collectionName || getCollectionNameById(castingId);
  882. lk.log(`获取个人产品[${collectionName}(${castingId})]拥有详情:${body}`);
  883. lk.post(url, async (error, _response, data) => {
  884. let retItemLst = [];
  885. try {
  886. if (error) {
  887. lk.log(`获取个人产品拥有详情发生错误`);
  888. lk.execFail();
  889. lk.appendNotifyInfo(`❌获取个人产品拥有详情失败,请稍后再试`);
  890. } else {
  891. let ret = JSON.parse(data);
  892. if (ret.success) {
  893. let obj = ret.obj;
  894. retItemLst = obj.list;
  895. lk.log(`获取个人产品拥有详情成功`);
  896. } else {
  897. lk.log(`获取个人产品拥有详情失败,响应:${data}`);
  898. }
  899. }
  900. } catch (e) {
  901. lk.log(`获取个人产品拥有详情发生错误`);
  902. lk.logErr(e);
  903. lk.execFail();
  904. } finally {
  905. resolve(retItemLst);
  906. }
  907. });
  908. } catch (e) {
  909. lk.log(`获取个人产品拥有详情发生错误`);
  910. lk.logErr(e);
  911. resolve();
  912. }
  913. });
  914. }
  915. async function confirmCompositeV2(taskId, taskInfo, compositeList) {
  916. return new Promise((resolve, _reject) => {
  917. try {
  918. const headers = GCommonGandartHeads;
  919. headers['Host'] = 'api.gandart.com';
  920. headers['Content-Type'] = 'application/json;charset=UTF-8;';
  921. let data = {
  922. taskId: Number(taskId),
  923. compositeList: compositeList,
  924. };
  925. let body = JSON.stringify(data);
  926. let url = {
  927. url: `${config.BASE_API}/v2/composite/v3/confirmCompositeV2`,
  928. headers: headers,
  929. body: body
  930. };
  931. let taskName = taskInfo.compositeTaskName || ''; //合成标题
  932. lk.log(`请求置换分解任务[${taskName}#${taskId}]:\n${body}`);
  933. lk.post(url, async (error, _response, data) => {
  934. let retOrder;
  935. try {
  936. if (error) {
  937. lk.log(`置换分解发生错误`);
  938. lk.execFail();
  939. lk.appendNotifyInfo(`❌置换分解失败,请稍后再试`);
  940. } else {
  941. let ret = JSON.parse(data);
  942. if (ret.success) {
  943. retOrder = ret.obj;
  944. let dismsg = `置换分解任务[${taskId}]成功,订单号:${retOrder}`;
  945. lk.log(dismsg);
  946. lk.appendNotifyInfo(`🎉${dismsg}`);
  947. } else {
  948. lk.log(`合置换分解失败,响应:${data}`);
  949. let respMsg = ret.msg;
  950. if (respMsg) {
  951. if (respMsg.indexOf('合成中') > -1 || respMsg.indexOf('已合成') > -1) {
  952. lk.appendNotifyInfo(`🎉${respMsg}`);
  953. retOrder = '#HC123456789';
  954. } else if (respMsg.indexOf('不足') > -1) {
  955. lk.appendNotifyInfo(`⚠️${respMsg}`);
  956. retOrder = '!HC123456789';
  957. }
  958. }
  959. }
  960. }
  961. } catch (e) {
  962. lk.log(`置换分解发生错误`);
  963. lk.logErr(e);
  964. lk.execFail();
  965. } finally {
  966. resolve(retOrder);
  967. }
  968. });
  969. } catch (e) {
  970. lk.log(`合置换分解发生错误`);
  971. lk.logErr(e);
  972. resolve();
  973. }
  974. });
  975. }
  976. async function checkCompositeResult(orderNum) {
  977. return new Promise((resolve, _reject) => {
  978. try {
  979. const headers = GCommonGandartHeads;
  980. headers['Host'] = 'api.gandart.com';
  981. headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
  982. let body = `orderNum=${orderNum}`;
  983. let url = {
  984. url: `${config.BASE_API}/v2/composite/v3/compositeResult`,
  985. headers: headers,
  986. body: body
  987. };
  988. lk.log(`获取合成结果[${orderNum}]:${body}`);
  989. lk.post(url, async (error, _response, data) => {
  990. let retItemLst;
  991. try {
  992. if (error) {
  993. lk.log(`获取合成结果发生错误`);
  994. lk.execFail();
  995. lk.appendNotifyInfo(`❌获取合成结果失败,请稍后再试`);
  996. } else {
  997. let ret = JSON.parse(data);
  998. if (ret.success) {
  999. lk.log(`获取合成结果成功,响应:${data}`);
  1000. if (typeof ret.obj == 'object') {
  1001. retItemLst = ret.obj;
  1002. let cName = '';
  1003. for (let i = 0; i < retItemLst.length; i++) {
  1004. cName += retItemLst[i].collectionName + ",";
  1005. }
  1006. cName = cName.substring(0, cName.length - 1);
  1007. lk.appendNotifyInfo(`🎉合成产品:${cName}`);
  1008. } else {
  1009. if (ret.msg && ret.msg.length > 0) {
  1010. lk.appendNotifyInfo(`🎉${ret.msg}`);
  1011. }
  1012. }
  1013. } else {
  1014. lk.log(`获取合成结果失败,响应:${data}`);
  1015. }
  1016. }
  1017. } catch (e) {
  1018. lk.log(`获取合成结果发生错误`);
  1019. lk.logErr(e);
  1020. lk.execFail();
  1021. } finally {
  1022. resolve(retItemLst);
  1023. }
  1024. });
  1025. } catch (e) {
  1026. lk.log(`获取合成结果发生错误`);
  1027. lk.logErr(e);
  1028. resolve();
  1029. }
  1030. });
  1031. }
  1032. function getCollectionMInfoById(castingId) {
  1033. let ret;
  1034. try {
  1035. let clst = JSON.parse(lk.getVal(GandartConstKey.CollectionCateLst, "[]"));
  1036. for (const d of clst) {
  1037. if (d.castingId == castingId) {
  1038. ret = d;
  1039. break;
  1040. }
  1041. }
  1042. } catch (error) {
  1043. lk.logErr(error);
  1044. }
  1045. return ret;
  1046. }
  1047. function getCollectionNameById(castingId) {
  1048. let name = '未获取';
  1049. let info = getCollectionMInfoById(castingId);
  1050. if (info) {
  1051. name = info.collectionName;
  1052. }
  1053. return name;
  1054. }
  1055. function getSign() {
  1056. const now = new Date().getTime();
  1057. let s1 = now - 20000;
  1058. let s2 = now;
  1059. let s3 = now + 20000;
  1060. let s4 = now + 40000;
  1061. const sssfffeee = 'e9'; //localStorage.getItem('sssfffeee');
  1062. const aggaaa = '9'; //localStorage.getItem('aggaaa');
  1063. const yyhhhasdww = '0a';
  1064. let arr = [sssfffeee, yyhhhasdww, aggaaa, '29', 'e', 'c', 3];
  1065. let crypto = createCrypto();
  1066. let s5 = crypto.md5(s3 + arr.join(''));
  1067. return {
  1068. 's1': s1,
  1069. 's2': s2,
  1070. 's3': s3,
  1071. 's4': s4,
  1072. 's5': s5
  1073. };
  1074. }
  1075. //---SyncByPyScript---ToolKit-start
  1076. function ToolKit(t,s,e){return new class{constructor(t,s,e){this.tgEscapeCharMapping={"&":"&","#":"#"},this.userAgent="Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0.2 Safari/605.1.15",this.prefix="lk",this.name=t,this.id=s,this.data=null,this.dataFile=this.getRealPath(""+this.prefix+this.id+".dat"),this.boxJsJsonFile=this.getRealPath(""+this.prefix+this.id+".boxjs.json"),this.options=e,this.isExecComm=!1,this.isEnableLog=this.getVal(this.prefix+"IsEnableLog"+this.id),this.isEnableLog=!!this.isEmpty(this.isEnableLog)||JSON.parse(this.isEnableLog),this.isNotifyOnlyFail=this.getVal(this.prefix+"NotifyOnlyFail"+this.id),this.isNotifyOnlyFail=!this.isEmpty(this.isNotifyOnlyFail)&&JSON.parse(this.isNotifyOnlyFail),this.isEnableTgNotify=this.getVal(this.prefix+"IsEnableTgNotify"+this.id),this.isEnableTgNotify=!this.isEmpty(this.isEnableTgNotify)&&JSON.parse(this.isEnableTgNotify),this.tgNotifyUrl=this.getVal(this.prefix+"TgNotifyUrl"+this.id),this.isEnableTgNotify=this.isEnableTgNotify&&!this.isEmpty(this.tgNotifyUrl),this.costTotalStringKey=this.prefix+"CostTotalString"+this.id,this.costTotalString=this.getVal(this.costTotalStringKey),this.costTotalString=this.isEmpty(this.costTotalString)?"0,0":this.costTotalString.replace('"',""),this.costTotalMs=this.costTotalString.split(",")[0],this.execCount=this.costTotalString.split(",")[1],this.costTotalMs=this.isEmpty(this.costTotalMs)?0:parseInt(this.costTotalMs),this.execCount=this.isEmpty(this.execCount)?0:parseInt(this.execCount),this.logSeparator="\n██",this.now=new Date,this.startTime=this.now.getTime(),this.node=this.isNode()?{request:require("request")}:null,this.execStatus=!0,this.notifyInfo=[],this.log(this.name+", 开始执行!"),this.initCache(),this.checkRecordRequestBody(),this.execComm()}checkRecordRequestBody(){var t,s;this.isRequest()&&(t=$request.body)&&(s=$request.path,s=this.id+"#"+s.replace("/","_"),this.isQuanX()&&$prefs.setValueForKey(t,s),(this.isLoon()||this.isSurge())&&$persistentStore.write(t,s),this.isNode())&&this.node.fs.writeFileSync(s+".json",t,{flag:"w"},t=>console.log(t))}getRequestBody(){var t=$request.path,t=this.id+"#"+t.replace("/","_");if(this.isSurge()||this.isLoon())return $persistentStore.read(t);if(this.isQuanX())return $prefs.valueForKey(t);if(this.isNode()){t=t+".json";if(!this.node.fs.existsSync(t))return JSON.parse(this.node.fs.readFileSync(t))}}initCache(){var t,s=this.getPersistKey();this.isQuanX()&&(this.cache=JSON.parse($prefs.valueForKey(s)||"{}")),(this.isLoon()||this.isSurge())&&(this.cache=JSON.parse($persistentStore.read(s)||"{}")),this.isNode()&&(this.node.fs.existsSync(t="root.json")||this.node.fs.writeFileSync(t,JSON.stringify({}),{flag:"wx"},t=>console.log(t)),this.root={},this.node.fs.existsSync(t=s+".json")?this.cache=JSON.parse(this.node.fs.readFileSync(s+".json")):(this.node.fs.writeFileSync(t,JSON.stringify({}),{flag:"wx"},t=>console.log(t)),this.cache={}))}getPersistKey(){return this.id+"#privateCache"}persistCache(){var t=this.getPersistKey(),s=JSON.stringify(this.cache,null,2);this.isQuanX()&&$prefs.setValueForKey(s,t),(this.isLoon()||this.isSurge())&&$persistentStore.write(s,t),this.isNode()&&(this.node.fs.writeFileSync(t+".json",s,{flag:"w"},t=>console.log(t)),this.node.fs.writeFileSync("root.json",JSON.stringify(this.root,null,2),{flag:"w"},t=>console.log(t)))}write(t,s){if(this.log("SET "+s),-1!==s.indexOf("#")){if(s=s.substr(1),isSurge||this.isLoon())return $persistentStore.write(t,s);if(this.isQuanX())return $prefs.setValueForKey(t,s);this.isNode()&&(this.root[s]=t)}else this.cache[s]=t;this.persistCache()}read(t){return this.log("READ "+t),-1!==t.indexOf("#")?(t=t.substr(1),this.isSurge()||this.isLoon()?$persistentStore.read(t):this.isQuanX()?$prefs.valueForKey(t):this.isNode()?this.root[t]:void 0):this.cache[t]}delete(t){if(this.log("DELETE "+t),-1!==t.indexOf("#")){if(t=t.substr(1),this.isSurge()||this.isLoon())return $persistentStore.write(null,t);if(this.isQuanX())return $prefs.removeValueForKey(t);this.isNode()&&delete this.root[t]}else delete this.cache[t];this.persistCache()}getRealPath(t){var s;return this.isNode()?((s=process.argv.slice(1,2)[0].split("/"))[s.length-1]=t,s.join("/")):t}getUrlHost(t){return t.slice(0,t.indexOf("/",8))}getUrlPath(t){var s=t.lastIndexOf("/")===t.length-1?-1:void 0;return t.slice(t.indexOf("/",8),s)}async execComm(){if(this.isNode()){this.comm=process.argv.slice(1);let t=!1;"p"==this.comm[1]&&(this.isExecComm=!0,this.log(`开始执行指令【${this.comm[1]}】=> 发送到手机测试脚本!`),this.isEmpty(this.options)||this.isEmpty(this.options.httpApi)?(this.log("未设置options,使用默认值"),this.isEmpty(this.options)&&(this.options={}),this.options.httpApi="[email protected]:6166"):/.*?@.*?:[0-9]+/.test(this.options.httpApi)||(t=!0,this.log("❌httpApi格式错误!格式:[email protected]:6166"),this.done()),t||this.callApi(this.comm[2]))}}callApi(t){let i=this.comm[0],s=(this.log(`获取【${i}】内容传给手机`),"");this.fs=this.fs||require("fs"),this.path=this.path||require("path");var e=this.path.resolve(i),r=this.path.resolve(process.cwd(),i),o=this.fs.existsSync(e),h=!o&&this.fs.existsSync(r);if(o||h){h=o?e:r;try{s=this.fs.readFileSync(h)}catch(t){s=""}}else s="";o={url:`http://${this.options.httpApi.split("@")[1]}/v1/scripting/evaluate`,headers:{"X-Key":""+this.options.httpApi.split("@")[0]},body:{script_text:""+s,mock_type:"cron",timeout:!this.isEmpty(t)&&5<t?t:5},json:!0};this.post(o,(t,s,e)=>{this.log(`已将脚本【${i}】发给手机!`),this.done()})}getCallerFileNameAndLine(){let s;try{throw Error("")}catch(t){s=t}var t=s.stack.split("\n")[1];return this.path=this.path||require("path"),`[${t.substring(t.lastIndexOf(this.path.sep)+1,t.lastIndexOf(":"))}]`}getFunName(t){t=t.toString();return t=(t=t.substr("function ".length)).substr(0,t.indexOf("("))}boxJsJsonBuilder(s,r){if(this.isNode()){let i="/Users/lowking/Desktop/Scripts/lowking.boxjs.json";if(r&&r.hasOwnProperty("target_boxjs_json_path")&&(i=r.target_boxjs_json_path),this.fs.existsSync(i))if(this.isJsonObject(s)&&this.isJsonObject(r)){this.log("using node");var o=["settings","keys"],h="https://raw.githubusercontent.com/Orz-3";let e={},t="#lk{script_url}";if(r&&r.hasOwnProperty("script_url")&&(t=this.isEmpty(r.script_url)?"#lk{script_url}":r.script_url),e.id=""+this.prefix+this.id,e.name=this.name,e.desc_html=`⚠️使用说明</br>详情【<a href='${t}?raw=true'><font class='red--text'>点我查看</font></a>】`,e.icons=[h+`/mini/master/Alpha/${this.id.toLocaleLowerCase()}.png`,h+`/mini/master/Color/${this.id.toLocaleLowerCase()}.png`],e.keys=[],e.settings=[{id:this.prefix+"IsEnableLog"+this.id,name:"开启/关闭日志",val:!0,type:"boolean",desc:"默认开启"},{id:this.prefix+"NotifyOnlyFail"+this.id,name:"只当执行失败才通知",val:!1,type:"boolean",desc:"默认关闭"},{id:this.prefix+"IsEnableTgNotify"+this.id,name:"开启/关闭Telegram通知",val:!1,type:"boolean",desc:"默认关闭"},{id:this.prefix+"TgNotifyUrl"+this.id,name:"Telegram通知地址",val:"",type:"text",desc:"Tg的通知地址,如:https://api.telegram.org/bot-token/sendMessage?chat_id=-100140&parse_mode=Markdown&text="}],e.author="#lk{author}",e.repo="#lk{repo}",e.script=t+"?raw=true",!this.isEmpty(s))for(var n in o){var a=o[n];if(!this.isEmpty(s[a])){if("settings"===a)for(let t=0;t<s[a].length;t++){var l=s[a][t];for(let t=0;t<e.settings.length;t++){var p=e.settings[t];l.id===p.id&&e.settings.splice(t,1)}}e[a]=e[a].concat(s[a])}delete s[a]}if(Object.assign(e,s),this.isNode()){this.fs=this.fs||require("fs"),this.path=this.path||require("path");var h=this.path.resolve(this.boxJsJsonFile),u=this.path.resolve(process.cwd(),this.boxJsJsonFile),c=this.fs.existsSync(h),d=!c&&this.fs.existsSync(u),f=JSON.stringify(e,null,"\t"),c=(!c&&d?this.fs.writeFileSync(u,f):this.fs.writeFileSync(h,f),JSON.parse(this.fs.readFileSync(i)));if(c.hasOwnProperty("apps")&&Array.isArray(c.apps)&&0<c.apps.length){d=c.apps,u=d.indexOf(d.filter(t=>t.id==e.id)[0]);0<=u?c.apps[u]=e:c.apps.push(e);let s=JSON.stringify(c,null,2);if(!this.isEmpty(r))for(const m in r){let t="";r.hasOwnProperty(m)?t=r[m]:"author"===m?t="@lowking":"repo"===m&&(t="https://github.com/lowking/Scripts"),s=s.replace(`#lk{${m}}`,t)}for(var g,y=/(?:#lk\{)(.+?)(?=\})/,S=(null!==y.exec(s)&&this.log("生成BoxJs还有未配置的参数,请参考https://github.com/lowking/Scripts/blob/master/util/example/ToolKitDemo.js#L17-L18传入参数:\n"),new Set);null!==(g=y.exec(s));)S.add(g[1]),s=s.replace(`#lk{${g[1]}}`,"");S.forEach(t=>{console.log(t+" ")}),this.fs.writeFileSync(i,s)}}}else this.log("构建BoxJsJson传入参数格式错误,请传入json对象")}}isJsonObject(t){return"object"==typeof t&&"[object object]"==Object.prototype.toString.call(t).toLowerCase()&&!t.length}appendNotifyInfo(t,s){1==s?this.notifyInfo=t:this.notifyInfo.push(t)}prependNotifyInfo(t){this.notifyInfo.splice(0,0,t)}execFail(){this.execStatus=!1}isRequest(){return"undefined"!=typeof $request}isSurge(){return"undefined"!=typeof $httpClient}isQuanX(){return"undefined"!=typeof $task}isLoon(){return"undefined"!=typeof $loon}isJSBox(){return"undefined"!=typeof $app&&"undefined"!=typeof $http}isStash(){return"undefined"!=typeof $environment&&$environment["stash-version"]}isNode(){return"function"==typeof require&&!this.isJSBox()}sleep(s){return new Promise(t=>setTimeout(t,s))}log(t){this.isEnableLog&&console.log(""+this.logSeparator+t)}logErr(t){this.execStatus=!0,this.isEnableLog&&(console.log(""+this.logSeparator+this.name+"执行异常:"),console.log(t),console.log("\n"+t.message))}msg(t,s,e,i){if((this.isRequest()||!this.isNotifyOnlyFail||!this.execStatus)&&(this.isEmpty(s)&&(s=Array.isArray(this.notifyInfo)?this.notifyInfo.join("\n"):this.notifyInfo),!this.isEmpty(s)))if(this.isEnableTgNotify){for(var r in this.log(this.name+"Tg通知开始"),this.tgEscapeCharMapping)this.tgEscapeCharMapping.hasOwnProperty(r)&&(s=s.replace(r,this.tgEscapeCharMapping[r]));this.get({url:encodeURI(this.tgNotifyUrl+"📌"+this.name+"\n"+s)},(t,s,e)=>{this.log("Tg通知完毕")})}else{var o={},h=!this.isEmpty(e),n=!this.isEmpty(i);this.isQuanX()&&(h&&(o["open-url"]=e),n&&(o["media-url"]=i),$notify(this.name,t,s,o)),(this.isSurge()||this.isStash())&&(h&&(o.url=e),$notification.post(this.name,t,s,o)),this.isNode()&&this.log("⭐️"+this.name+"\n"+t+"\n"+s),this.isJSBox()&&$push.schedule({title:this.name,body:t?t+"\n"+s:s})}}pushWxMsg(t,s,e,i=()=>{}){s={appToken:"AT_rTc93GQYIdMU8XLRnoJaSea8WkfhSzhX",content:s,summary:t,contentType:1,topicIds:[],uids:["UID_6P4B00X6Zv8U2oKC0I2R09emxtqq"],url:"",verifyPay:!1},e&&(s.url=e),t=this.getJsonDoneHeaders(),t.Host="wxpusher.zjiecode.com",t["Content-Type"]="application/json;charset=UTF-8",e={url:"https://wxpusher.zjiecode.com/api/send/message",headers:t,body:JSON.stringify(s)};this.post(e,i)}getVal(t,s=""){let e;return(e=this.isSurge()||this.isLoon()||this.isStash()?$persistentStore.read(t):this.isQuanX()?$prefs.valueForKey(t):this.isNode()?(this.data=this.loadData(),process.env[t]||this.data[t]):this.data&&this.data[t]||null)||s}setVal(t,s){return this.isSurge()||this.isLoon()||this.isStash()?$persistentStore.write(s,t):this.isQuanX()?$prefs.setValueForKey(s,t):this.isNode()?(this.data=this.loadData(),this.data[t]=s,this.writeData(),!0):this.data&&this.data[t]||null}loadData(){if(!this.isNode())return{};this.fs=this.fs||require("fs"),this.path=this.path||require("path");var t=this.path.resolve(this.dataFile),s=this.path.resolve(process.cwd(),this.dataFile),e=this.fs.existsSync(t),i=!e&&this.fs.existsSync(s);if(!e&&!i)return{};i=e?t:s;try{return JSON.parse(this.fs.readFileSync(i))}catch(t){return{}}}writeData(){var t,s,e,i,r;this.isNode()&&(this.fs=this.fs||require("fs"),this.path=this.path||require("path"),t=this.path.resolve(this.dataFile),s=this.path.resolve(process.cwd(),this.dataFile),i=!(e=this.fs.existsSync(t))&&this.fs.existsSync(s),r=JSON.stringify(this.data),!e&&i?this.fs.writeFileSync(s,r):this.fs.writeFileSync(t,r))}adapterStatus(t){return t&&(t.status?t.statusCode=t.status:t.statusCode&&(t.status=t.statusCode)),t}get(t,i=()=>{}){this.isQuanX()&&((t="string"==typeof t?{url:t}:t).method="GET",$task.fetch(t).then(t=>{i(null,this.adapterStatus(t),t.body)},t=>i(t.error,null,null))),(this.isSurge()||this.isLoon()||this.isStash())&&$httpClient.get(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)}),this.isNode()&&this.node.request(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)}),this.isJSBox()&&((t="string"==typeof t?{url:t}:t).header=t.headers,t.handler=function(t){let s=t.error,e=(s=s&&JSON.stringify(t.error),t.data);"object"==typeof e&&(e=JSON.stringify(t.data)),i(s,this.adapterStatus(t.response),e)},$http.get(t))}post(t,i=()=>{}){this.isQuanX()&&((t="string"==typeof t?{url:t}:t).method="POST",$task.fetch(t).then(t=>{i(null,this.adapterStatus(t),t.body)},t=>i(t.error,null,null))),(this.isSurge()||this.isLoon()||this.isStash())&&$httpClient.post(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)}),this.isNode()&&this.node.request.post(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)}),this.isJSBox()&&((t="string"==typeof t?{url:t}:t).header=t.headers,t.handler=function(t){let s=t.error,e=(s=s&&JSON.stringify(t.error),t.data);"object"==typeof e&&(e=JSON.stringify(t.data)),i(s,this.adapterStatus(t.response),e)},$http.post(t))}put(t,i=()=>{}){this.isQuanX()&&((t="string"==typeof t?{url:t}:t).method="PUT",$task.fetch(t).then(t=>{i(null,this.adapterStatus(t),t.body)},t=>i(t.error,null,null))),(this.isSurge()||this.isLoon()||this.isStash())&&(t.method="PUT",$httpClient.put(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)})),this.isNode()&&(t.method="PUT",this.node.request.put(t,(t,s,e)=>{i(t,this.adapterStatus(s),e)})),this.isJSBox()&&((t="string"==typeof t?{url:t}:t).header=t.headers,t.handler=function(t){let s=t.error,e=(s=s&&JSON.stringify(t.error),t.data);"object"==typeof e&&(e=JSON.stringify(t.data)),i(s,this.adapterStatus(t.response),e)},$http.post(t))}costTime(){let t=this.name+"执行完毕!";this.isNode()&&this.isExecComm&&(t=`指令【${this.comm[1]}】执行完毕!`);var s=(new Date).getTime()-this.startTime,e=s/1e3;this.execCount++,this.costTotalMs+=s,this.log(`${t}耗时【${e}】秒\n总共执行【${this.execCount}】次,平均耗时【${(this.costTotalMs/this.execCount/1e3).toFixed(4)}】秒`),this.setVal(this.costTotalStringKey,JSON.stringify(this.costTotalMs+","+this.execCount))}done(t={}){this.costTime(),(this.isSurge()||this.isQuanX()||this.isLoon()||this.isStash())&&$done(t)}getRequestUrl(){return $request.url}getResponseBody(){if($response)return $response.body}isGetCookie(t){return!("OPTIONS"==$request.method||!this.getRequestUrl().match(t))}isEmpty(t){return void 0===t||null==t||""==t||"null"==t||"undefined"==t||0===t.length}randomString(s){s=s||32;var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890",i=e.length,r="";for(let t=0;t<s;t++)r+=e.charAt(Math.floor(Math.random()*i));return r}autoComplete(s,t,e,i,r,o,h,n,a,l){if((s+="").length<r)for(;s.length<r;)0==o?s+=i:s=i+s;if(h){let t="";for(var p=0;p<n;p++)t+=l;s=s.substring(0,a)+t+s.substring(n+a)}return this.toDBC(s=t+s+e)}customReplace(t,s,e,i){try{for(var r in this.isEmpty(e)&&(e="#{"),this.isEmpty(i)&&(i="}"),s)t=t.replace(""+e+r+i,s[r])}catch(t){this.logErr(t)}return t}toDBC(t){for(var s="",e=0;e<t.length;e++)32==t.charCodeAt(e)?s+=String.fromCharCode(12288):t.charCodeAt(e)<127&&(s+=String.fromCharCode(t.charCodeAt(e)+65248));return s}hash(t){let s=0,e,i;for(e=0;e<t.length;e++)i=t.charCodeAt(e),s=(s<<5)-s+i,s|=0;return String(s)}formatDate(t,s){var e,i={"M+":t.getMonth()+1,"d+":t.getDate(),"H+":t.getHours(),"m+":t.getMinutes(),"s+":t.getSeconds(),"q+":Math.floor((t.getMonth()+3)/3),S:t.getMilliseconds()};for(e in/(y+)/.test(s)&&(s=s.replace(RegExp.$1,(t.getFullYear()+"").substr(4-RegExp.$1.length))),i)new RegExp("("+e+")").test(s)&&(s=s.replace(RegExp.$1,1==RegExp.$1.length?i[e]:("00"+i[e]).substr((""+i[e]).length)));return s}objToQueryStr(s,e){let i="";for(const r in s){let t=s[r];null!=t&&""!==t&&("object"==typeof t?t=JSON.stringify(t):e&&(t=encodeURIComponent(t)),i+=`${r}=${t}&`)}return i=i.substring(0,i.length-1)}parseQueryStr(t){var s={},e=(t=-1<t.indexOf("?")?t.split("?")[1]:t).split("&");for(let t=0;t<e.length;t++){var i=e[t].split("=");s[i[0]]=i[1]}return s}deepClone(t,s){for(var e in s=s||{},t)"object"==typeof t[e]?(s[e]=t[e].constructor===Array?[]:{},this.deepClone(t[e],s[e])):s[e]=t[e];return s}getBaseDoneHeaders(t={}){return Object.assign({"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"POST,GET,OPTIONS,PUT,DELETE","Access-Control-Allow-Headers":"Origin, X-Requested-With, Content-Type, Accept"},t)}getHtmlDoneHeaders(){return this.getBaseDoneHeaders({"Content-Type":"text/html;charset=UTF-8"})}getJsonDoneHeaders(){return this.getBaseDoneHeaders({"Content-Type":"text/json; charset=utf-8",Connection:"keep-alive"})}}(t,s,e)}
  1077. //---SyncByPyScript---ToolKit-end
  1078. //---SyncByPyScript---Crypto-start
  1079. function createCrypto(){function o(t,n){var r=c(t[0],o=t[1],u=t[2],e=t[3],n[0],7,-680876936),e=c(e,r,o,u,n[1],12,-389564586),u=c(u,e,r,o,n[2],17,606105819),o=c(o,u,e,r,n[3],22,-1044525330);r=c(r,o,u,e,n[4],7,-176418897),e=c(e,r,o,u,n[5],12,1200080426),u=c(u,e,r,o,n[6],17,-1473231341),o=c(o,u,e,r,n[7],22,-45705983),r=c(r,o,u,e,n[8],7,1770035416),e=c(e,r,o,u,n[9],12,-1958414417),u=c(u,e,r,o,n[10],17,-42063),o=c(o,u,e,r,n[11],22,-1990404162),r=c(r,o,u,e,n[12],7,1804603682),e=c(e,r,o,u,n[13],12,-40341101),u=c(u,e,r,o,n[14],17,-1502002290),r=i(r,o=c(o,u,e,r,n[15],22,1236535329),u,e,n[1],5,-165796510),e=i(e,r,o,u,n[6],9,-1069501632),u=i(u,e,r,o,n[11],14,643717713),o=i(o,u,e,r,n[0],20,-373897302),r=i(r,o,u,e,n[5],5,-701558691),e=i(e,r,o,u,n[10],9,38016083),u=i(u,e,r,o,n[15],14,-660478335),o=i(o,u,e,r,n[4],20,-405537848),r=i(r,o,u,e,n[9],5,568446438),e=i(e,r,o,u,n[14],9,-1019803690),u=i(u,e,r,o,n[3],14,-187363961),o=i(o,u,e,r,n[8],20,1163531501),r=i(r,o,u,e,n[13],5,-1444681467),e=i(e,r,o,u,n[2],9,-51403784),u=i(u,e,r,o,n[7],14,1735328473),r=a(r,o=i(o,u,e,r,n[12],20,-1926607734),u,e,n[5],4,-378558),e=a(e,r,o,u,n[8],11,-2022574463),u=a(u,e,r,o,n[11],16,1839030562),o=a(o,u,e,r,n[14],23,-35309556),r=a(r,o,u,e,n[1],4,-1530992060),e=a(e,r,o,u,n[4],11,1272893353),u=a(u,e,r,o,n[7],16,-155497632),o=a(o,u,e,r,n[10],23,-1094730640),r=a(r,o,u,e,n[13],4,681279174),e=a(e,r,o,u,n[0],11,-358537222),u=a(u,e,r,o,n[3],16,-722521979),o=a(o,u,e,r,n[6],23,76029189),r=a(r,o,u,e,n[9],4,-640364487),e=a(e,r,o,u,n[12],11,-421815835),u=a(u,e,r,o,n[15],16,530742520),r=l(r,o=a(o,u,e,r,n[2],23,-995338651),u,e,n[0],6,-198630844),e=l(e,r,o,u,n[7],10,1126891415),u=l(u,e,r,o,n[14],15,-1416354905),o=l(o,u,e,r,n[5],21,-57434055),r=l(r,o,u,e,n[12],6,1700485571),e=l(e,r,o,u,n[3],10,-1894986606),u=l(u,e,r,o,n[10],15,-1051523),o=l(o,u,e,r,n[1],21,-2054922799),r=l(r,o,u,e,n[8],6,1873313359),e=l(e,r,o,u,n[15],10,-30611744),u=l(u,e,r,o,n[6],15,-1560198380),o=l(o,u,e,r,n[13],21,1309151649),r=l(r,o,u,e,n[4],6,-145523070),e=l(e,r,o,u,n[11],10,-1120210379),u=l(u,e,r,o,n[2],15,718787259),o=l(o,u,e,r,n[9],21,-343485551),t[0]=h(r,t[0]),t[1]=h(o,t[1]),t[2]=h(u,t[2]),t[3]=h(e,t[3])}function f(t,n,r,e,u,o){return n=h(h(n,t),h(e,o)),h(n<<u|n>>>32-u,r)}function c(t,n,r,e,u,o,c){return f(n&r|~n&e,t,n,u,o,c)}function i(t,n,r,e,u,o,c){return f(n&e|r&~e,t,n,u,o,c)}function a(t,n,r,e,u,o,c){return f(n^r^e,t,n,u,o,c)}function l(t,n,r,e,u,o,c){return f(r^(n|~e),t,n,u,o,c)}function n(t){/[\x80-\xFF]/.test(t)&&(t=unescape(encodeURI(t))),txt="";let n=t.length,r=[1732584193,-271733879,-1732584194,271733878],e;for(e=64;e<=t.length;e+=64)o(r,function(t){let n=[],r;for(r=0;r<64;r+=4)n[r>>2]=t.charCodeAt(r)+(t.charCodeAt(r+1)<<8)+(t.charCodeAt(r+2)<<16)+(t.charCodeAt(r+3)<<24);return n}(t.substring(e-64,e)));t=t.substring(e-64);var u=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];for(e=0;e<t.length;e++)u[e>>2]|=t.charCodeAt(e)<<(e%4<<3);if(u[e>>2]|=128<<(e%4<<3),55<e)for(o(r,u),e=0;e<16;e++)u[e]=0;return u[14]=8*n,o(r,u),r}let e="0123456789abcdef".split("");function r(n){for(let t=0;t<n.length;t++)n[t]=function(t){let n="",r=0;for(;r<4;r++)n+=e[t>>8*r+4&15]+e[t>>8*r&15];return n}(n[t]);return n.join("")}function h(t,n){return t+n&4294967295}return{md5:function(t){return r(n(t))}}}
  1080. //---SyncByPyScript---Crypto-end