pinganIkea.js 59 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800
  1. /*
  2. 平安银行宜家礼品卡优惠券
  3. https://b.pingan.com.cn/kuaizhan/v2/5K2422/20230925/k84123/index.html?paesuperbank=%7B%22dLinkId%22%3A%22M0P5EnN0addUoXCs240814104407%22%7D
  4. pahkebank://
  5. [Script]
  6. # > 平安银行宜家礼品卡优惠券
  7. ^https?:\/\/b\.pingan\.com\.cn url script-request-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  8. ^https?:\/\/b\.pingan\.com\.cn url script-response-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  9. ^https?:\/\/rsb\.pingan\.com\.cn url script-request-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  10. ^https?:\/\/rsb\.pingan\.com\.cn url script-response-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  11. ^https?:\/\/rmb\.pingan\.com\.cn url script-request-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  12. ^https?:\/\/rmb\.pingan\.com\.cn url script-response-body https://git.jojo21.top/shawenguan/Quantumult-X/raw/master/Scripts/pingan/pinganIkea.js
  13. [MITM]
  14. hostname = b.pingan.com.cn,rsb.pingan.com.cn,rmb.pingan.com.cn
  15. */
  16. const scriptName = `平安银行宜家礼品卡优惠券`;
  17. const magicJS = MagicJS(scriptName, "INFO");
  18. const PingAnIKEAConstKey = {
  19. // 基础数据
  20. Cookie: 'PingAnIKEACookie',
  21. DeviceId: 'PingAnIKEADeviceId',
  22. x_g_sid: 'PingAnIKEA#x_g_sid',
  23. x_g_vid: 'PingAnIKEA#x_g_vid',
  24. x_g_rid: 'PingAnIKEA#x_g_rid',
  25. PageData: 'PingAnIKEAPageData',
  26. PageActionId: 'PageActionId',
  27. };
  28. let gRetBody;
  29. let errCodeStrMap = {
  30. 900111: "notStart",
  31. 900112: "notStart",
  32. 900113: "finish",
  33. 900109: "exceed",
  34. 910179: "nonLottery",
  35. 910204: "nonBindCard",
  36. 701001: "limitFlow",
  37. 700116: "nonBindWechat",
  38. 700118: "nonInterestWechat",
  39. 960002: "nonDayStock",
  40. 900537: "nonStock",
  41. 900139: "nonWhiteList",
  42. 900320: "riskList",
  43. 900130: "nonRules",
  44. 900982: "mutex",
  45. 950010: "nonDayTimes",
  46. 950710: "nonWeekTimes",
  47. 700119: "nonMonthTimes",
  48. 900144: "nonTimes",
  49. 950008: "nonDayPrizeTimes",
  50. 900745: "nonWeekPrizeTimes",
  51. 950009: "nonMonthPrizeTimes",
  52. 900143: "nonPrizeTimes",
  53. 600056: "timesCutDown",
  54. 780001: "nonBindAliPay",
  55. 900203: "notSendAble",
  56. 999999: "stockValidateText"
  57. };
  58. const gHost = 'b.pingan.com.cn';
  59. const gTeamId = `5K2422`;
  60. const gActivityId = `PK084123`;
  61. const gPageUrlFirstPath = '/kuaizhan/v2';
  62. const gPageUrlSuffix = `5K2422/20230925/k84123`;
  63. const gHomePageUrl = `https://b.pingan.com.cn/kuaizhan/v2/${gPageUrlSuffix}/index.html?paesuperbank=%7B%22dLinkId%22%3A%22M0P5EnN0addUoXCs240814104407%22%7D`;
  64. const gWebUserAgent = `Mozilla/5.0 (iPhone; CPU iPhone OS 16_6_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.50(0x18003237) NetType/WIFI Language/zh_CN`;
  65. let gDeviceId = magicJS.data.read(PingAnIKEAConstKey.DeviceId, 'AUUID_918d439ffcef935c2fd84d3a3e593b6523c916fc');
  66. let gPageActionId = magicJS.data.read(PingAnIKEAConstKey.PageActionId, '1F908E50');
  67. let gAppUserAgent = `Mozilla/5.0 (iPhone; CPU iPhone OS 16_6_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 iphone 14 pro AladdinHybrid/4.8.77 (PAEBank 6.23.0) AladdinBridge/3.0.0 subContracting/AppStore deviceId/${gDeviceId} UnionPay/1.0 PABANK deviceType/1 networkState/WIFI KiwiBridge/1.0.0 device-dpr/3 device-dr/852*393 AppStyle/BZ bz-navbarHeight/309 dzTab-navbarHeight/327 pageActionId/${gPageActionId}`;
  68. let gTmpRequsetTimeStamp = Date.now();
  69. let gTmpRequestSortId = 100;
  70. const gCommonHeaders = {
  71. 'osVersion': `16.6.1`,
  72. 'Accept-Encoding': `gzip, deflate, br`,
  73. 'Host': `rsb.pingan.com.cn`,
  74. 'X-App-Version': `6.23.0`,
  75. 'phoneModel': `iPhone15,2`,
  76. 'Connection': `keep-alive`,
  77. 'bank-mobile-model': `iPhone15,2`,
  78. 'Accept-Language': `zh-Hans-CN;q=1`,
  79. 'nativeVersion': `6.23.0`,
  80. 'User-Agent': `${gAppUserAgent}`,
  81. 'Referer': `https://b.pingan.com.cn/kuaizhan/v2/5K2422/20230925/k84123/index.html`,
  82. 'X-Aladdin-Version': `4.8.77`,
  83. 'bank-mobile-brand': `Apple`,
  84. 'x-o-spanid': `0`,
  85. 'Accept': `*/*`,
  86. 'x-g-sid': `iSb07mg4hmSUYbUg5izmW0`,
  87. 'x-g-vid': `53mWJHzK00401M5Vv+uR3w`,
  88. 'x-g-rid': `J3/I3jF+hI6xiREInsHZlg5dn320120r`,
  89. 'X-REQUEST-ID': `${gDeviceId}-${gTmpRequsetTimeStamp}-${gTmpRequestSortId}`,
  90. 'Cookie': ``
  91. };
  92. let gPageData = {};
  93. let gIgnoreCouponGotStatus = true;
  94. async function Main() {
  95. if (magicJS.isStrictRequest) {
  96. magicJS.checkRecordRequestBody();
  97. }
  98. if (magicJS.isRequest) {
  99. checkHandleRequest();
  100. } else {
  101. gCommonHeaders[`Cookie`] = magicJS.data.read(PingAnIKEAConstKey.Cookie, '');
  102. await tryGrabCoupon();
  103. }
  104. magicJS.notification.msg('');
  105. if (gRetBody) {
  106. magicJS.done({
  107. body: JSON.stringify(gRetBody)
  108. });
  109. } else {
  110. magicJS.done();
  111. }
  112. }
  113. function checkHandleRequest() {
  114. const url = $request.url;
  115. const path = $request.path;
  116. magicJS.log(`请求url=${url}#${$request.method}`);
  117. if ($request && $request.method != 'OPTIONS') {
  118. switch (path) {
  119. case '/brop/cmp/cust/cmpsf/mgm/share/createTokenId.do':
  120. handleCreateTokenId();
  121. break;
  122. case '/brop/mop/cust/mopsf/nrp/uc/simple/rule/info/batchSatisfy':
  123. break;
  124. case '/brop/cmp/cust/cmpsf/mgm/origin/queryPageConfig.do':
  125. handlePageConfig();
  126. break;
  127. case '/brcp/uc/cust/uc-login-web.qryLoginStatus.do':
  128. case '/rmb/brcp/uc/cust/uc-login-web.qryLoginStatus.do':
  129. handleLoginStatus();
  130. break;
  131. case '/brop/mop/cust/mopsf/lottery/getLeftOfferNum':
  132. break;
  133. case '/brop/mop/cust/mopsf/uc/auth/lottery/sendCustomerOffer':
  134. handleCustomerOffer();
  135. break;
  136. default:
  137. if (path.indexOf('/kuaizhan/v2/5K2422/20230925/k84123/index.html') > -1) {
  138. handleHomePage();
  139. } else if (path.indexOf('/brop/mop/cust/mopsf/personality/activity/status/query') > -1) {
  140. handlePublicActivityStatus();
  141. } else if (path.indexOf('/bron/coss/cust/app/getSupernatant') > -1) {
  142. } else if (path.indexOf('/brop/mop/cust/mopsf/uc/auth/lottery/queryCustomerActivityStatus') > -1) {
  143. handleCustomerActivityStatus();
  144. }
  145. break;
  146. }
  147. }
  148. }
  149. function getResponsePlainData() {
  150. let data = magicJS.getResponseBody();
  151. if (!data) {
  152. return;
  153. }
  154. try {
  155. return JSON.parse(data);
  156. } catch (err) {
  157. magicJS.logger.error(err);
  158. }
  159. }
  160. function getRequestPlainData() {
  161. let data = magicJS.getRequestBody();
  162. let reqData = null;
  163. if (data) {
  164. reqData = magicJS.parseQueryStr(data);
  165. } else {
  166. reqData = magicJS.parseQueryStr($request.url);
  167. }
  168. return reqData;
  169. }
  170. function getQueryPlainData() {
  171. let params = magicJS.parseQueryStr($request.url);
  172. return params;
  173. }
  174. function getXRequestId() {
  175. gTmpRequestSortId++;
  176. return `${gDeviceId}-${gTmpRequsetTimeStamp}-${gTmpRequestSortId}`
  177. }
  178. function handleHeaders() {
  179. if ($request && $request.method != 'OPTIONS') {
  180. let headers = $request.headers;
  181. let x_g_sid = headers['x-g-sid'];
  182. if (x_g_sid) {
  183. magicJS.data.write(PingAnIKEAConstKey.x_g_sid, x_g_sid);
  184. }
  185. let x_g_vid = headers['x-g-vid'];
  186. if (x_g_sid) {
  187. magicJS.data.write(PingAnIKEAConstKey.x_g_vid, x_g_vid);
  188. }
  189. let x_g_rid = headers['x-g-rid'];
  190. if (x_g_sid) {
  191. magicJS.data.write(PingAnIKEAConstKey.x_g_rid, x_g_rid);
  192. }
  193. if (headers['X-REQUEST-ID']) {
  194. let tmpArr = headers['X-REQUEST-ID'].split('-');
  195. magicJS.data.write(PingAnIKEAConstKey.DeviceId, tmpArr[0]);
  196. }
  197. let newCookieStr = headers['Cookie'];
  198. if (newCookieStr) {
  199. let oldCookieStr = magicJS.data.read(PingAnIKEAConstKey.Cookie, null);
  200. magicJS.logger.info(`oldCookieStr=${oldCookieStr}`);
  201. magicJS.logger.info(`newCookieStr=${newCookieStr}`);
  202. if (compareCookieStr(newCookieStr, oldCookieStr) != 0) {
  203. magicJS.data.write(PingAnIKEAConstKey.Cookie, newCookieStr);
  204. magicJS.logger.info(`当前Cookie刷新到最新`);
  205. magicJS.notification.appendNotifyInfo(`🎉当前Cookie刷新到最新`);
  206. } else {
  207. magicJS.data.write(PingAnIKEAConstKey.Cookie, newCookieStr);
  208. magicJS.logger.info(`当前Cookie已经是最新无需更新`);
  209. }
  210. }
  211. }
  212. }
  213. function compareCookieStr(cookieStr1, cookieStr2) {
  214. let cookieDict1 = magicJS.parseCookies(cookieStr1);
  215. let cookieDict2 = magicJS.parseCookies(cookieStr2);
  216. let skipKeys = ['NGWhitelist', 'PAEBANK_PARAM', 'PAEBANK_PARAM_N', 'PAEBANK_PARAM_W', 'WEBTRENDS_SESSIONID', 'brcpSessionTicket', 'sdc_PABankParam', 'shuntid'];
  217. skipKeys = ['PAEBANK_PARAM', 'WEBTRENDS_SESSIONID'];
  218. let retCode = 0;
  219. for (let key in cookieDict1) {
  220. if (!skipKeys.includes(key)) {
  221. if (cookieDict1[key] != void 0 && cookieDict2[key] != void 0 && cookieDict1[key] != cookieDict2[key]) {
  222. magicJS.logger.info(`${key}`);
  223. retCode = -1;
  224. break;
  225. }
  226. }
  227. }
  228. return retCode;
  229. }
  230. function handleHomePage() {
  231. handleHeaders();
  232. }
  233. function handleCreateTokenId() {
  234. }
  235. function handlePageConfig() {
  236. let rspData = getResponsePlainData();
  237. if (!rspData) {
  238. return;
  239. }
  240. if (rspData.responseCode != "000000") {
  241. return;
  242. }
  243. let data = rspData.data;
  244. if (data.reShow) {
  245. }
  246. }
  247. function handlePublicActivityStatus() {
  248. let rspData = getResponsePlainData();
  249. if (!rspData) {
  250. return;
  251. }
  252. if (rspData.responseCode != "000000") {
  253. return;
  254. }
  255. let queryParams = getQueryPlainData();
  256. let activityCode = queryParams.activityCode;
  257. let queryNextTime = queryParams.queryNextTime;
  258. let data = rspData.data;
  259. }
  260. function handleCustomerActivityStatus() {
  261. let rspData = getResponsePlainData();
  262. if (!rspData) {
  263. return;
  264. }
  265. rspData = { pagination: null, data: null, responseCode: "000000", responseMsg: "成功" };
  266. gRetBody = rspData;
  267. }
  268. function handleCustomerOffer() {
  269. let rspData = getResponsePlainData();
  270. if (!rspData) {
  271. return;
  272. }
  273. rspData.responseCode = "000000";
  274. gRetBody = rspData;
  275. }
  276. function handleLoginStatus() {
  277. }
  278. async function getPageData() {
  279. let url = `https://b.pingan.com.cn/kuaizhan/v2/5K2422/20230925/k84123/pageData.js?v=${new Date().getTime()}`;
  280. let body = ``;
  281. let headers = {
  282. 'Cookie': magicJS.data.read(PingAnIKEAConstKey.Cookie, ''),
  283. 'Sec-Fetch-Mode': `navigate`,
  284. 'Connection': `keep-alive`,
  285. 'Accept': `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8`,
  286. 'Accept-Encoding': `gzip, deflate, br`,
  287. 'Host': `b.pingan.com.cn`,
  288. 'User-Agent': `${gAppUserAgent}`,
  289. 'Sec-Fetch-Site': `none`,
  290. 'Accept-Language': `zh-CN,zh-Hans;q=0.9`,
  291. 'Sec-Fetch-Dest': `document`,
  292. // 'If-Modified-Since': `Thu, 18 Jul 2024 11:10:01 GMT`
  293. };;
  294. let options = {
  295. url: url,
  296. headers: headers,
  297. body: body,
  298. };
  299. let result = await magicJS.http.get(options).then(response => {
  300. try {
  301. const body = response.body;
  302. let rspData = null;
  303. let retMatch = body.match(/var pageData = ([\s\S]*)/); // 正则表达式匹配
  304. if (retMatch) {
  305. rspData = JSON.parse(retMatch[1]);
  306. }
  307. // magicJS.logger.info(`rspData=${JSON.stringify(rspData)}`);
  308. return rspData;
  309. } catch (e) {
  310. magicJS.logger.error(e);
  311. }
  312. }).catch(err => {
  313. const msg = `请求页面配置数据异常\n${JSON.stringify(err)}`;
  314. magicJS.logger.error(msg);
  315. });
  316. return result;
  317. }
  318. async function checkGetPageData() {
  319. let strToday = magicJS.formatDate(new Date(), 'yyyy-MM-dd');
  320. let key = `${PingAnIKEAConstKey.PageData}`;
  321. let cacheData = magicJS.data.read(key, null);
  322. if (cacheData && cacheData.storeDate == strToday) {
  323. magicJS.logger.info(`今日已更新过活动页面数据`);
  324. gPageData = cacheData.data;
  325. } else {
  326. magicJS.logger.info(`今日首次更新活动页面数据`);
  327. gPageData = await getPageData();
  328. magicJS.data.write(key, { storeDate: strToday, data: gPageData });
  329. }
  330. if (gPageData) {
  331. let buildTime = gPageData.buildTime;
  332. magicJS.logger.info(`当前活动页面数据最新构建时间:${magicJS.formatDate(new Date(buildTime), 'yyyy-MM-dd')}`);
  333. }
  334. return gPageData;
  335. }
  336. function getResponseErrorMsg(errCode, config, responseMsg) {
  337. let key = errCodeStrMap[errCode];
  338. if (key && config && config[key]) {
  339. return config[key].toastText || responseMsg;
  340. } else {
  341. return responseMsg;
  342. }
  343. }
  344. function setActCouponStatus(activityCode, status) {
  345. let day = magicJS.formatDate(new Date(), 'yyyy-MM-dd');
  346. let key = `PingAnIKEA#${activityCode}_${day}`;
  347. magicJS.data.write(key, status);
  348. if (status == 1 || status == 2) {// 已领取
  349. key = `PingAnIKEA#${activityCode}_CouponGotTime}`;
  350. magicJS.data.write(key, new Date().getTime());
  351. }
  352. }
  353. function getActCouponStatus(activityCode) {
  354. let day = magicJS.formatDate(new Date(), 'yyyy-MM-dd');
  355. let key = `PingAnIKEA#${activityCode}_${day}`;
  356. let status = magicJS.data.read(key, -1);
  357. return Number(status);
  358. }
  359. // 今日是否执行过获取优惠券任务
  360. function isCouponExecToday(activityCode) {
  361. if (gIgnoreCouponGotStatus) {
  362. return false;
  363. }
  364. let status = getActCouponStatus(activityCode);
  365. if (status == 1 || status == 2 || status == 3) {
  366. return true;
  367. } else if (status == -1) {
  368. return false;
  369. } else {
  370. return false;
  371. }
  372. }
  373. // 当月是否领取过优惠券
  374. function hasCouponGotMonth(activityCode) {
  375. if (gIgnoreCouponGotStatus) {
  376. return false;
  377. }
  378. let key = `PingAnIKEA#${activityCode}_CouponGotTime}`;
  379. let strNum = magicJS.data.read(key, null);
  380. if (strNum) {
  381. let now = new Date();
  382. let date = new Date(Number(strNum));
  383. if (now.getFullYear() == date.getFullYear() && now.getMonth() == date.getMonth()) {
  384. return true;
  385. }
  386. return false;
  387. }
  388. return false;
  389. }
  390. function hasCouponGotWeek(activityCode) {
  391. if (gIgnoreCouponGotStatus) {
  392. return false;
  393. }
  394. let key = `PingAnIKEA#${activityCode}_CouponGotTime}`;
  395. let strNum = magicJS.data.read(key, null);
  396. if (strNum) {
  397. let now = new Date();
  398. let date = new Date(Number(strNum));
  399. if (isSameWeek(now, date)) {
  400. return true;
  401. }
  402. return false;
  403. }
  404. return false;
  405. }
  406. function hasCouponGotDay(activityCode) {
  407. if (gIgnoreCouponGotStatus) {
  408. return false;
  409. }
  410. let key = `PingAnIKEA#${activityCode}_CouponGotTime}`;
  411. let strNum = magicJS.data.read(key, null);
  412. if (strNum) {
  413. let now = new Date();
  414. let date = new Date(Number(strNum));
  415. if (now.getFullYear() == date.getFullYear() && now.getMonth() == date.getMonth() && now.getDate() == date.getDate()) {
  416. return true;
  417. }
  418. return false;
  419. }
  420. return false;
  421. }
  422. function isSameWeek(date1, date2) {
  423. // 获取每个日期的星期几
  424. const day1 = date1.getDay(); // 返回值为 0(周日)到 6(周六)
  425. const day2 = date2.getDay();
  426. // 获取每个日期的时间戳
  427. const time1 = date1.getTime();
  428. const time2 = date2.getTime();
  429. // 根据星期几和时间戳判断是否属于同一个星期
  430. const weekDiff = Math.floor(Math.abs(time1 - time2) / (1000 * 60 * 60 * 24 * 7));
  431. if (day1 <= day2) {
  432. return weekDiff === 0;
  433. } else {
  434. return weekDiff === 1;
  435. }
  436. }
  437. async function tryGrabCoupon() {
  438. gPageData = await checkGetPageData();
  439. let widgets = gPageData.widgets;
  440. let sk88Names = ['【天天88】满100减12优惠券'];
  441. // 天天88
  442. let path88 = ['pwm-kuaizhan-section', 'pwm-mkt-offer'];
  443. // 五折限量购
  444. let sk55Names = ['【五折限量购】满100减50优惠券'];
  445. let path55 = ['pwm-kuaizhan-simple-rule', 'pwm-kuaizhan-section', 'pwm-mkt-offer'];
  446. // 9.25折限量购
  447. let sk925Names = [
  448. '【9.25折限量折扣】满100减7.5优惠券',
  449. '【9.25折限量折扣】满100减15优惠券',
  450. '【9.25折限量折扣】满100减37.5优惠券',
  451. '【9.25折限量折扣】满1000减75优惠券',
  452. ];
  453. let path925 = ['pwm-kuaizhan-section-split', 'pwm-kuaizhan-section', 'pwm-mkt-offer'];
  454. let items925 = seekWidgets(widgets, path925);
  455. let isLogin = true;
  456. let strLoginFailMsg = `登录失败,请点击通知栏打开APP下载页面`;
  457. magicJS.logger.info(`########9.25折限量购########`);
  458. for (let i = items925.length - 1; i >= 0; i--) {
  459. const item = items925[i];
  460. const config = item.config;
  461. if (isCouponExecToday(config.activityCode)) {
  462. magicJS.logger.info(`${sk925Names[i]}今天已经执行过了[${config.activityCode}]`);
  463. continue;
  464. }
  465. if (hasCouponGotMonth(config.activityCode)) {
  466. magicJS.logger.info(`${sk925Names[i]}本月已经领过了[${config.activityCode}]`);
  467. continue;
  468. }
  469. // magicJS.logger.info(`activityCode=${config.activityCode} activityValue=${config.activityValue}`);
  470. let ret = await doGrabCoupon(config.activityCode, config.activityValue);
  471. let tipsText = ``;
  472. if (ret) {
  473. if (ret.responseCode == '900100') {//未登录
  474. isLogin = false;
  475. strLoginFailMsg = ret.responseMsg;
  476. // magicJS.notification.appendNotifyInfo(ret.responseMsg);
  477. break;
  478. }
  479. if (ret.responseCode == '000000') {
  480. setActCouponStatus(config.activityCode, 1);
  481. } else if (ret.responseCode == '950008' || ret.responseCode == '900745' || ret.responseCode == '950009') {//领奖机会已经用完
  482. setActCouponStatus(config.activityCode, 2);
  483. } else if (ret.responseCode == '960002') {//今天奖励已经发完
  484. setActCouponStatus(config.activityCode, 3);
  485. } else if (ret.responseCode == '900130') {//不符合领取规则
  486. setActCouponStatus(config.activityCode, 3);
  487. }
  488. if (ret.responseCode == '000000') {
  489. tipsText = `${sk925Names[i]}-领取成功`;
  490. } else {
  491. tipsText = sk925Names[i] + '-' + getResponseErrorMsg(ret.responseCode, config, ret.responseMsg)
  492. }
  493. } else {
  494. tipsText = `${sk925Names[i]}-领取失败`;
  495. }
  496. magicJS.notification.appendNotifyInfo(tipsText);
  497. }
  498. if (!isLogin) {
  499. let params = {
  500. "td": {
  501. "id": "唤醒浮层",
  502. "label": "APP下载浮层立即打开-样式2",
  503. "param": { "dlink_id": "M0P5EnN0addUoXCs240814104407" },
  504. "pageId": "PK084123"
  505. },
  506. "url": "https://b.pingan.com.cn/kuaizhan/v2/5K2422/20230925/k84123/index.html? paesuperbank=%7B%22dLinkId%22%3A%22M0P5EnN0addUoXCs240814104407%22%7D"
  507. };
  508. let schemaUrl = `paesuperbank://?paesuperbank=${encodeURIComponent(JSON.stringify(params))}`;
  509. magicJS.notification.post(scriptName, '', strLoginFailMsg, schemaUrl);
  510. return;
  511. }
  512. magicJS.logger.info(`##########天天88##########`);
  513. let items88 = seekWidgets(widgets, path88);
  514. for (let i = 0; i < items88.length; i++) {
  515. const item = items88[i];
  516. const config = item.config;
  517. if (isCouponExecToday(config.activityCode)) {
  518. magicJS.logger.info(`${sk88Names[i]}今天已经执行过了[${config.activityCode}]`);
  519. continue;
  520. }
  521. if (hasCouponGotMonth(config.activityCode)) {
  522. magicJS.logger.info(`${sk88Names[i]}本月已经领过了[${config.activityCode}]`);
  523. continue;
  524. }
  525. // magicJS.logger.info(`activityCode=${config.activityCode} activityValue=${config.activityValue}`);
  526. let ret = await doGrabCoupon(config.activityCode, config.activityValue);
  527. let tipsText = ``;
  528. if (ret) {
  529. if (ret.responseCode == '900100') {//未登录
  530. magicJS.notification.appendNotifyInfo(ret.responseMsg);
  531. break;
  532. }
  533. if (ret.responseCode == '000000') {
  534. setActCouponStatus(config.activityCode, 1);
  535. } else if (ret.responseCode == '950008' || ret.responseCode == '900745' || ret.responseCode == '950009') {//领奖机会已经用完
  536. setActCouponStatus(config.activityCode, 2);
  537. } else if (ret.responseCode == '960002') {//今天奖励已经发完
  538. setActCouponStatus(config.activityCode, 3);
  539. } else if (ret.responseCode == '900130') {//不符合领取规则
  540. setActCouponStatus(config.activityCode, 3);
  541. }
  542. if (ret.responseCode == '000000') {
  543. tipsText = `${sk88Names[i]}-领取成功`;
  544. } else {
  545. tipsText = sk88Names[i] + '-' + getResponseErrorMsg(ret.responseCode, config, ret.responseMsg)
  546. }
  547. } else {
  548. tipsText = `${sk88Names[i]}-领取失败`;
  549. }
  550. magicJS.notification.appendNotifyInfo(tipsText);
  551. }
  552. magicJS.logger.info(`########五折限量购########`);
  553. let items55 = seekWidgets(widgets, path55);
  554. for (let i = 0; i < items55.length; i++) {
  555. const item = items55[i];
  556. const config = item.config;
  557. if (isCouponExecToday(config.activityCode)) {
  558. magicJS.logger.info(`${sk55Names[i]}今天已经执行过了[${config.activityCode}]`);
  559. continue;
  560. }
  561. if (hasCouponGotMonth(config.activityCode)) {
  562. magicJS.logger.info(`${sk55Names[i]}本月已经领过了[${config.activityCode}]`);
  563. continue;
  564. }
  565. // magicJS.logger.info(`activityCode=${config.activityCode} activityValue=${config.activityValue}`);
  566. let ret = await doGrabCoupon(config.activityCode, config.activityValue);
  567. let tipsText = ``;
  568. if (ret) {
  569. if (ret.responseCode == '900100') {//未登录
  570. magicJS.notification.appendNotifyInfo(ret.responseMsg);
  571. break;
  572. }
  573. if (ret.responseCode == '000000') {
  574. setActCouponStatus(config.activityCode, 1);
  575. } else if (ret.responseCode == '950008' || ret.responseCode == '900745' || ret.responseCode == '950009') {//领奖机会已经用完
  576. setActCouponStatus(config.activityCode, 2);
  577. } else if (ret.responseCode == '960002') {//今天奖励已经发完
  578. setActCouponStatus(config.activityCode, 3);
  579. } else if (ret.responseCode == '900130') {//不符合领取规则
  580. setActCouponStatus(config.activityCode, 3);
  581. }
  582. if (ret.responseCode == '000000') {
  583. tipsText = `${sk55Names[i]}-领取成功`;
  584. } else {
  585. tipsText = sk55Names[i] + '-' + getResponseErrorMsg(ret.responseCode, config, ret.responseMsg)
  586. }
  587. } else {
  588. tipsText = `${sk55Names[i]}-领取失败`;
  589. }
  590. magicJS.notification.appendNotifyInfo(tipsText);
  591. }
  592. }
  593. function seekWidgets(widgets, namePaths, layer = 0) {
  594. let retLst = [];
  595. let name = namePaths[layer];
  596. if (namePaths.length == layer + 1) {
  597. for (let i = 0; i < widgets.length; i++) {
  598. const widget = widgets[i];
  599. if (widget.name == name) {
  600. retLst.push(widget);
  601. }
  602. }
  603. } else {
  604. for (let i = 0; i < widgets.length; i++) {
  605. const widget = widgets[i];
  606. if (widget.name == name) {
  607. retLst = retLst.concat(seekWidgets(widget.widgets, namePaths, layer + 1));
  608. }
  609. }
  610. }
  611. return retLst;
  612. }
  613. async function doGrabCoupon(activityCode, activityValue) {
  614. let result = await queryCustomerActivityStatus(activityCode, activityValue);
  615. if (result && result.responseCode == '000000') {
  616. result = await sendCustomerOffer(activityCode, activityValue);
  617. }
  618. return result;
  619. }
  620. async function queryCustomerActivityStatus(activityCode, activityValue, channelSource = 'KOUDAI', taskProVal = '') {
  621. let reqData = {
  622. activityCode: activityCode,
  623. activityValue: activityValue,
  624. channelSource: channelSource,
  625. taskProVal: taskProVal || '',
  626. };
  627. let url = `https://rsb.pingan.com.cn/brop/mop/cust/mopsf/uc/auth/lottery/queryCustomerActivityStatus?${magicJS.objToQueryStr(reqData)}`;
  628. let headers = gCommonHeaders;
  629. let options = {
  630. url: url,
  631. headers: headers,
  632. body: ``,
  633. };
  634. let result = await magicJS.http.get(options).then(response => {
  635. try {
  636. let rspData = response.body;
  637. magicJS.logger.info(`rspData=${JSON.stringify(rspData)}`);
  638. return rspData;
  639. } catch (e) {
  640. magicJS.logger.error(e);
  641. }
  642. }).catch(err => {
  643. const msg = `请求用户活动状态异常\n${JSON.stringify(err)}`;
  644. magicJS.logger.error(msg);
  645. });
  646. return result;
  647. }
  648. async function sendCustomerOffer(activityCode, activityValue, channelSource = 'KOUDAI', taskProVal = '') {
  649. let url = `https://rsb.pingan.com.cn/brop/mop/cust/mopsf/uc/auth/lottery/sendCustomerOffer`;
  650. let info = {
  651. MGM: {
  652. activity_flowid: undefined,
  653. activity_id: undefined,
  654. },
  655. N: {
  656. campaignid: undefined,
  657. channel_source: undefined,
  658. source: 'all',
  659. innerid: 'KDAPP-96SS-HDY-1',
  660. outersource: undefined,
  661. },
  662. W: {
  663. outerid: undefined,
  664. },
  665. };
  666. let orderNo = '';
  667. let traceid = 'fixed_innerid_KDAPP-96SS-HDY-1';
  668. let offerAppid = '';
  669. let buryData = {
  670. "login_type": `Mozilla/5.0 (iPhone; CPU iPhone OS 16_6_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 iphone 14 pro AladdinHybrid/4.8.77 (PAEBank 6.23.0) AladdinBridge/3.0.0 subContracting/AppStore deviceId/AUUID_918d439ffcef935c2fd84d3a3e593b6523c916fc UnionPay/1.0 PABANK deviceType/1 networkState/WIFI KiwiBridge/1.0.0 device-dpr/3 device-dr/852*393 AppStyle/BZ bz-navbarHeight/309 dzTab-navbarHeight/327 pageActionId/${gPageActionId}`,
  671. "idfa": "00000000-0000-0000-0000-000000000000",
  672. "osVersion": "16.6.1",
  673. "memoryStatus": { "totalMemory": 5644, "usedMemory": 3700 + Math.ceil(160 * Math.random()) },
  674. "language": "zh-Hans-CN",
  675. "deviceId": "AUUID_918d439ffcef935c2fd84d3a3e593b6523c916fc",
  676. "deviceType": "1",
  677. "sourceIP": "10.4.175.51",
  678. "deviceName": "iPhone",
  679. "vpn": "1",
  680. "isJailBroken": false,
  681. "deviceToken": "524be0e96038a72223cfe66c8c9044c65227c9c818225a28159100bbd9729ba4",
  682. "wifiMac": "Not Found",
  683. "appVersion": "6.23.0",
  684. "wifiSid": "Not Found",
  685. "appName": "平安口袋银行App",
  686. "idfv": "07A9900D-FBD5-4EB4-B16D-830E090913CF",
  687. "deviceModel": "iphone 14 pro",
  688. "aldDeviceId": "8A093177-C77E-49B6-B096-63F736D4B9F5",
  689. "osName": "iOS",
  690. "sourceIPType": "04",
  691. "subContracting": "AppStore"
  692. };
  693. let reqData = {
  694. activityCode: activityCode,
  695. activityValue: activityValue,
  696. activityFlowId: String(info.MGM.activity_flowid),
  697. activityId: String(info.MGM.activity_id),
  698. buryData: encodeURIComponent(JSON.stringify(buryData)),
  699. campaignId: String(info.N.campaignid),
  700. channelsource: String(info.N.channel_source),
  701. channelSource: channelSource,
  702. drawTimesQueryFLag: "1",
  703. innerid: info.N.innerid,
  704. orderNo: orderNo,
  705. outerid: String(info.W.outerid),
  706. outersource: String(info.N.outersource),
  707. source: info.N.source,
  708. taskProVal: taskProVal,
  709. offerAppid: offerAppid,
  710. traceId: traceid
  711. }
  712. let headers = gCommonHeaders;
  713. let options = {
  714. url: url,
  715. headers: headers,
  716. body: magicJS.objToQueryStr(reqData),
  717. };
  718. let result = await magicJS.http.post(options).then(response => {
  719. try {
  720. let rspData = response.body;
  721. magicJS.logger.info(`rspData=${JSON.stringify(rspData)}`);
  722. return rspData;
  723. } catch (e) {
  724. magicJS.logger.error(e);
  725. }
  726. }).catch(err => {
  727. const msg = `请求用户报单异常\n${JSON.stringify(err)}`;
  728. magicJS.logger.error(msg);
  729. });
  730. return result;
  731. }
  732. Main().catch((e) => magicJS.logger.log(`-\n ${e}`)).finally(() => magicJS.done());
  733. //---SyncByPyScript---MagicJS3-start
  734. function MagicJS(e = "MagicJS", t = "INFO") { const r = () => { const e = "undefined" != typeof $loon, t = "undefined" != typeof $task, n = "undefined" != typeof module, r = "undefined" != typeof $httpClient && !e, o = "undefined" != typeof $storm, i = "undefined" != typeof $environment && void 0 !== $environment["stash-build"]; var s = r || e || o || i; const a = "undefined" != typeof importModule; return { isLoon: e, isQuanX: t, isNode: n, isSurge: r, isStorm: o, isStash: i, isSurgeLike: s, isScriptable: a, get name() { return e ? "Loon" : t ? "QuantumultX" : n ? "NodeJS" : r ? "Surge" : a ? "Scriptable" : "unknown" }, get build() { return r ? $environment["surge-build"] : i ? $environment["stash-build"] : o ? $storm.buildVersion : void 0 }, get language() { if (r || i) return $environment.language }, get version() { return r ? $environment["surge-version"] : i ? $environment["stash-version"] : o ? $storm.appVersion : n ? process.version : void 0 }, get system() { return r ? $environment.system : n ? process.platform : void 0 }, get systemVersion() { if (o) return $storm.systemVersion }, get deviceName() { if (o) return $storm.deviceName } } }, o = (n, e = "INFO") => { let r = e, t = "\n"; const o = { SNIFFER: 6, DEBUG: 5, INFO: 4, NOTIFY: 3, WARNING: 2, ERROR: 1, CRITICAL: 0, NONE: -1 }, i = { SNIFFER: "", DEBUG: "", INFO: "", NOTIFY: "", WARNING: "❗ ", ERROR: "❌ ", CRITICAL: "❌ ", NONE: "" }, s = (e, t = "INFO") => { o[r] < o[t.toUpperCase()] || console.log(`██[${n}][${t}]` + i[t.toUpperCase()] + e + "\n") }; return { getLevel: () => r, setLevel: e => { r = e }, sniffer: (...e) => { e = e.join(t); s(e, "SNIFFER") }, log: (...e) => { e = e.join(t); console.log(`██[${n}]` + e + "\n") }, debug: (...e) => { e = e.join(t); s(e, "DEBUG") }, info: (...e) => { e = e.join(t); s(e, "INFO") }, notify: (...e) => { e = e.join(t); s(e, "NOTIFY") }, warning: (...e) => { e = e.join(t); s(e, "WARNING") }, error: (...e) => { e = e.join(t); s(e, "ERROR") }, retry: (...e) => { e = e.join(t); s(e, "RETRY") } } }; return new class { constructor(e, t) { var n; this._startTime = Date.now(), this.version = "3.0.0", this.scriptName = e, this.env = r(), this.logger = o(e, t), this.http = "function" == typeof MagicHttp ? MagicHttp(this.env, this.logger) : void 0, this.data = "function" == typeof MagicData ? MagicData(this.env, this.logger) : void 0, this.notification = "function" == typeof MagicNotification ? MagicNotification(this.scriptName, this.env, this.logger, this.http) : void 0, this.utils = "function" == typeof MagicUtils ? MagicUtils(this.env, this.logger) : void 0, this.qinglong = "function" == typeof MagicQingLong ? MagicQingLong(this.env, this.data, this.logger) : void 0, void 0 !== this.data && (t = this.data.read("magic_loglevel"), n = this.data.read("magic_bark_url"), t && this.logger.setLevel(t.toUpperCase()), n) && this.notification.setBark(n), this.logger.info(e + ", 开始执行!") } get isRequest() { return "undefined" != typeof $request } get isStrictRequest() { return "undefined" != typeof $request && "undefined" == typeof $response } get isResponse() { return "undefined" != typeof $response } get isDebug() { return "DEBUG" === this.logger.level } get request() { return "undefined" != typeof $request ? $request : void 0 } get response() { if ("undefined" != typeof $response) return $response.hasOwnProperty("status") && ($response.statusCode = $response.status), $response.hasOwnProperty("statusCode") && ($response.status = $response.statusCode), $response } log(...e) { this.logger.log(e) } toStr(e, t = null) { try { return JSON.stringify(e) } catch { return t } } toObj(e, t = null) { try { return JSON.parse(e) } catch { return t } } checkRecordRequestBody() { if (this.isRequest) { var t = $request.body; if (t) { var n = this.env, r = $request.path; let e = this.scriptName + "#" + r.replace("/", "_"); e = e.replace("?", "#"), n.isQuanX && $prefs.setValueForKey(t, e), (n.isLoon || n.isSurge) && $persistentStore.write(t, e), n.isNode && require("fs").writeFileSync(e + ".json", t, { flag: "w" }, e => console.log(e)) } } } getRequestBody() { var e = this.env, t = $request.path; let n = this.scriptName + "#" + t.replace("/", "_"); if (n = n.replace("?", "#"), e.isSurge || e.isLoon) return $persistentStore.read(n); if (e.isQuanX) return $prefs.valueForKey(n); if (e.isNode) { t = n + ".json", e = require("fs"); if (!e.existsSync(t)) return JSON.parse(e.readFileSync(t)) } } getResponseBody() { if ($response) return $response.body } parseCookies(e) { let t = {}; return e && e.split(";").forEach(function (e) { e = e.split("="); t[e.shift().trim()] = decodeURI(e.join("=")) }), t } serializeCookies(e) { var t, n = []; for (t in e) { var r = e[t], r = encodeURIComponent(t) + "=" + encodeURIComponent(r); n.push(r) } return n.join("; ") } parseSetCookies(e) { const o = ["Expires", "Max-Age", "Domain", "Path", "HttpOnly", "SameSite"]; e = e.split(";"); let i = null; const s = {}, a = []; return e.forEach(e => { var t, e = e.trim(); let n = null, r = !0; if (e.includes("=") ? (t = e.split("="), n = t[0].trim(), r = t[1].trim()) : n = e, o.includes(n)) s[i] && (s[i][n] = r, s[i].attribs[n] = r); else { i = n; let t = {}; i.includes(",") && i.split(",").forEach(e => { e = e.trim(); o.includes(e) ? t[e] = !0 : i = e }), s[i] = { name: i, value: r, attribs: t }, a.push(s[i]) } }), a } objToQueryStr(t, n) { let r = ""; for (const o in t) { let e = t[o]; null != e && "" !== e && ("object" == typeof e ? e = JSON.stringify(e) : n && (e = encodeURIComponent(e)), r += `${o}=${e}&`) } return r = r.substring(0, r.length - 1) } parseQueryStr(e) { var t = {}, n = (e = -1 < e.indexOf("?") ? e.split("?")[1] : e).split("&"); for (let e = 0; e < n.length; e++) { var r = n[e].split("="); t[r[0]] = r[1] } return t } deepClone(e, t) { for (var n in t = t || {}, e) "object" == typeof e[n] ? (t[n] = e[n].constructor === Array ? [] : {}, this.deepClone(e[n], t[n])) : t[n] = e[n]; return t } formatDate(e, t) { var n, r = { "M+": e.getMonth() + 1, "d+": e.getDate(), "H+": e.getHours(), "m+": e.getMinutes(), "s+": e.getSeconds(), "q+": Math.floor((e.getMonth() + 3) / 3), S: e.getMilliseconds() }; for (n in /(y+)/.test(t) && (t = t.replace(RegExp.$1, (e.getFullYear() + "").substr(4 - RegExp.$1.length))), r) new RegExp("(" + n + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? r[n] : ("00" + r[n]).substr(("" + r[n]).length))); return t } parseDate(a, e) { let l = { y: 0, M: 1, d: 0, H: 0, h: 0, m: 0, s: 0, S: 0 }; (e = e || "yyyy-MM-dd").replace(/([^yMdHmsS]*?)(([yMdHmsS])\3*)([^yMdHmsS]*?)/g, function (e, t, n, r, o, i, s) { return a = a.replace(new RegExp(t + "(\\d{" + n.length + "})" + o), function (e, t) { return l[r] = parseInt(t), "" }), "" }), l.M--; e = new Date(l.y, l.M, l.d, l.H, l.m, l.s); return 0 !== l.S && e.setMilliseconds(l.S), e } costTime() { var e = this.scriptName + "执行完毕!", t = (this._endTime = (new Date).getTime(), this._endTime - this._startTime); this.logger.info(e + `耗时【${t / 1e3}】秒`) } done = (e = {}) => { this.costTime(), "undefined" != typeof $done && $done(e) } }(e, t) } function MagicHttp(d, g) { var e; let p; d.isNode && (e = require("axios"), p = e.create()); class t { constructor(e = !0) { this.handlers = [], this.isRequest = e } use(e, t, n) { return "function" == typeof e && g.debug("Register fulfilled " + e.name), "function" == typeof t && g.debug("Register rejected " + t.name), this.handlers.push({ fulfilled: e, rejected: t, synchronous: !(!n || "boolean" != typeof n.synchronous) && n.synchronous, runWhen: n ? n.runWhen : null }), this.handlers.length - 1 } eject(e) { this.handlers[e] && (this.handlers[e] = null) } forEach(t) { this.handlers.forEach(e => { null !== e && t(e) }) } } function f(e) { let n = { ...e }; return n.params && !d.isNode && (e = Object.keys(n.params).map(e => { var t = encodeURIComponent(e); return n.url = n.url.replace(new RegExp(e + "=[^&]*", "ig"), ""), n.url = n.url.replace(new RegExp(t + "=[^&]*", "ig"), ""), t + "=" + encodeURIComponent(n.params[e]) }).join("&"), n.url.indexOf("?") < 0 && (n.url += "?"), /(&|\?)$/g.test(n.url) || (n.url += "&"), n.url += e, delete n.params, g.debug("Params to QueryString: " + n.url)), n } const y = (e, t = null) => { if (e) { t = { ...e, config: e.config || t, status: e.statusCode || e.status, body: e.body || e.data, headers: e.headers || e.header }; if ("string" == typeof t.body) try { t.body = JSON.parse(t.body) } catch { } return delete t.data, t } return e }; const h = (e, t = null) => { if (e && 400 <= e.status) return g.debug("Raise exception when status code is " + e.status), { name: "RequestException", message: "Request failed with status code " + e.status, config: t || e.config, response: e } }, m = { request: new t, response: new t(!1) }; let v = [], b = [], S = !0; function N(e) { return e = f(e), g.debug(`HTTP ${e.method.toUpperCase()}:` + "\n" + JSON.stringify(e)), e } function E(t) { try { t = t && y(t), g.sniffer(`HTTP ${t.config.method.toUpperCase()}:` + "\n" + JSON.stringify(t.config) + "\nSTATUS CODE:\n" + t.status + "\nRESPONSE:\n" + ("object" == typeof t.body ? JSON.stringify(t.body) : t.body)); var e = h(t); return e ? Promise.reject(e) : t } catch (e) { return g.error(e), t } } const n = (e, n) => { let r; n = ((e, t) => { let n = "object" == typeof t ? { headers: {}, ...t } : { url: t, headers: {} }; return n.method || (n.method = e), !0 === (n = f(n)).rewrite && (d.isSurge ? (n.headers["X-Surge-Skip-Scripting"] = !1, delete n.rewrite) : d.isQuanX && (n.hints = !1, delete n.rewrite)), d.isSurgeLike ? (t = n.headers["content-type"] || n.headers["Content-Type"], "GET" !== n.method && t && 0 <= t.indexOf("application/json") && n.body instanceof Array && (n.body = JSON.stringify(n.body), g.debug("Convert Array object to String: " + n.body))) : d.isQuanX ? (n.hasOwnProperty("body") && "string" != typeof n.body && (n.body = JSON.stringify(n.body)), n.method = e) : d.isNode && ("POST" === e || "PUT" === e || "PATCH" === e || "DELETE" === e ? n.data = n.data || n.body : "GET" === e && (n.params = n.params || n.body), delete n.body), n })(e.toUpperCase(), n), r = d.isNode ? p : d.isSurgeLike ? i => new Promise((r, o) => { $httpClient[e.toLowerCase()](i, (e, t, n) => { e ? (e = { name: e.name || e, message: e.message || e, stack: e.stack || e, config: i, response: y(t) }, o(e)) : (t.config = i, t.body = n, r(t)) }) }) : r => new Promise((n, t) => { $task.fetch(r).then(e => { e = y(e, r); var t = h(e, r); if (t) return Promise.reject(t); n(e) }).catch(e => { e = { name: e.message || e.error, message: e.message || e.error, stack: e.error, config: r, response: e.response ? y(e.response) : null }; t(e) }) }); let o; var t = n; try { v = [], b = [], m.request.forEach(e => { "function" == typeof e.runWhen && !1 === e.runWhen(t) || (S = S && e.synchronous, v.unshift(e.fulfilled, e.rejected)) }), m.response.forEach(e => { b.push(e.fulfilled, e.rejected) }) } catch (e) { g.error(`Failed to register interceptors: ${e}.`) } var i = [N, void 0], s = [E, void 0]; if (S) { for (g.debug("Interceptors are executed in synchronous mode"), Array.prototype.unshift.apply(v, i), v = v.concat([N, void 0]); v.length;) { var a = v.shift(), l = v.shift(); try { "function" == typeof a && g.debug("Executing request fulfilled " + a.name), n = a(n) } catch (e) { "function" == typeof l && g.debug("Executing request rejected " + l.name), l(e); break } } try { o = (!d.isNode && n.timeout ? c : r)(n) } catch (e) { return Promise.reject(e) } for (Array.prototype.unshift.apply(b, s); b.length;)o = o.then(b.shift(), b.shift()); return o } { g.debug("Interceptors are executed in asynchronous mode"); let t = [r, void 0]; for (Array.prototype.unshift.apply(t, i), Array.prototype.unshift.apply(t, v), t = (t = t.concat(s)).concat(b), o = Promise.resolve(n); t.length;)try { let e = t.shift(); var u = t.shift(); "function" == typeof (e = !d.isNode && n.timeout && e === r ? c : e) && g.debug("Executing request fulfilled " + e.name), "function" == typeof u && g.debug("Executing request rejected " + u.name), o = o.then(e, u) } catch (e) { g.error("request exception: " + e) } return o } function c(n) { try { var e = new Promise((e, t) => { setTimeout(() => { var e = { message: `timeout of ${n.timeout}ms exceeded.`, config: n }; t(e) }, n.timeout) }); return Promise.race([r(n), e]) } catch (e) { g.error(`Request Timeout exception: ${e}.`) } } }; return { request: n, interceptors: m, convertHeadersToLowerCase: n => Object.keys(n).reduce((e, t) => (e[t.toLowerCase()] = n[t], e), {}), convertHeadersToCamelCase: n => Object.keys(n).reduce((e, t) => { return e[t.split("-").map(e => e[0].toUpperCase() + e.slice(1)).join("-")] = n[t], e }, {}), modifyResponse: y, get: e => n("GET", e), post: e => n("POST", e), put: e => n("PUT", e), patch: e => n("PATCH", e), delete: e => n("DELETE", e), head: e => n("HEAD", e), options: e => n("OPTIONS", e) } } function MagicData(d, g) { let p = { fs: void 0, data: {} }; if (d.isNode) { p.fs = require("fs"); try { p.fs.accessSync("./magic.json", p.fs.constants.R_OK | p.fs.constants.W_OK) } catch (e) { p.fs.writeFileSync("./magic.json", "{}", { encoding: "utf8" }) } p.data = require("./magic.json") } const s = (e, t) => "object" != typeof t && e === t, a = e => "true" === e || "false" !== e && (void 0 === e ? null : e), l = (e, t, n, r) => { if (n) try { e = !0 === (e = "string" == typeof e ? JSON.parse(e) : e).magic_session ? e[n] : null } catch { e = null } if ("string" == typeof e && "null" !== e) try { e = JSON.parse(e) } catch { } return null == (e = !1 === r && e && !0 === e.magic_session ? null : e) && null != t && (e = t), e = a(e) }, f = t => { if ("string" != typeof t) return t instanceof Array || null == t || t != t || "boolean" == typeof t ? {} : t; { let e = {}; try { var n = typeof (e = JSON.parse(t)); ("object" != n || e instanceof Array || "bool" == n || null === e) && (e = {}) } catch { } return e } }, u = (e, t = null, n = "", r = !1, o = null) => { let i = ""; return i = o || d.isNode ? ((e, t = null, n = "", r = !1, o = null) => { o = o || p.data; return val = o && void 0 !== o[e] && null !== o[e] ? o[e] : n ? {} : null, val = l(val, t, n, r) })(e, t, n, r, o) : (d.isSurgeLike ? i = $persistentStore.read(e) : d.isQuanX && (i = $prefs.valueForKey(e)), l(i, t, n, r)), g.debug(`READ DATA [${e}]${n ? `[${n}]` : ""} <${typeof i}>` + "\n" + JSON.stringify(i)), i }, c = (e, t, n = "", r = null) => { if (void 0 === t || t != t) return !1; d.isNode || "boolean" != typeof t && "number" != typeof t || (t = String(t)); let o = ""; var i, s, a, l, u, c; if (r || d.isNode ? o = ([i, s, a = "", l = null] = [e, t, n, r], c = l || p.data, c = f(c), a ? ((u = f(c[i])).magic_session = !0, u[a] = s, c[i] = u) : c[i] = s, null !== l && (l = c), c) : n ? (d.isSurgeLike ? o = $persistentStore.read(e) ? $persistentStore.read(e) : o : d.isQuanX && (o = $prefs.valueForKey(e) ? $prefs.valueForKey(e) : o), (o = f(o)).magic_session = !0, o[n] = t) : o = t, o && "object" == typeof o && (o = JSON.stringify(o, null, 4)), g.debug(`WRITE DATA [${e}]${n ? `[${n}]` : ""} <${typeof t}>` + "\n" + JSON.stringify(t)), !r) { if (d.isSurgeLike) return $persistentStore.write(o, e); if (d.isQuanX) return $prefs.setValueForKey(o, e); if (d.isNode) try { p.fs.writeFileSync("./magic.json", o) } catch (e) { return g.error(e), !1 } } return !0 }; return { read: u, write: c, del: (e, t = "", n = null) => { let r = {}; if (n || d.isNode) r = (o = e, i = t, s = n || p.data, s = f(s), i ? (delete (obj = f(s[o]))[i], s[o] = obj) : delete s[o], s), n ? n = r : p.fs.writeFileSync("./magic.json", JSON.stringify(r, null, 4)); else if (t) { d.isSurgeLike ? r = $persistentStore.read(e) : d.isQuanX && (r = $prefs.valueForKey(e)), delete (r = f(r))[t]; i = JSON.stringify(r, null, 4); c(e, i) } else { if (d.isStorm) return $persistentStore.remove(e); if (d.isSurgeLike) return $persistentStore.write(null, e); if (d.isQuanX) return $prefs.removeValueForKey(e) } var o, i, s; g.debug(`DELETE KEY [${e}]` + (t ? `[${t}]` : "")) }, update: (e, t, n, r = s, o = null) => { var i; return t = a(t), !0 !== r(u(e, null, n, !1, o), t) && (i = c(e, t, n, o), e = u(e, null, n, !1, o), r === s && "object" == typeof e ? i : r(t, e)) }, allSessions: (e, t = null) => { let n = {}; t = u(e, null, null, !0, t); return !0 === (t = f(t)).magic_session && delete (n = { ...t }).magic_session, g.debug(`READ ALL SESSIONS [${e}] <${typeof n}>` + "\n" + JSON.stringify(n, null, 4)), n }, allSessionNames: (e, t = null) => { let n = []; t = u(e, null, null, !0, t), t = f(t); return n = !0 !== t.magic_session ? [] : Object.keys(t).filter(e => "magic_session" !== e), g.debug(`READ ALL SESSIONS [${e}] <${typeof n}>` + "\n" + JSON.stringify(n, null, 4)), n }, defaultValueComparator: s, convertToObject: f } } function MagicNotification(i, o, s, a) { let l = null, u = null, c = []; function d(e = i, t = "", n = "", r = "") { r = (t => { try { let e = {}; var n; return "string" == typeof t ? 0 < t.length && (o.isLoon ? e = { openUrl: t } : o.isQuanX ? e = { "open-url": t } : o.isSurge && (e = { url: t })) : "object" == typeof t && (o.isLoon ? (e.openUrl = t["open-url"] || "", e.mediaUrl = t["media-url"] || "") : o.isQuanX ? e = t["open-url"] || t["media-url"] ? t : {} : o.isSurge && (n = t["open-url"] || t.openUrl, e = n ? { url: n } : {})), e } catch (e) { s.error("通知选项转换失败" + e) } return t })(r), 1 === arguments.length && (e = i, t = "", n = arguments[0]), s.notify("\ntitle:" + e + "\nsubTitle:" + t + "\nbody:" + n + "\noptions:" + ("object" == typeof r ? JSON.stringify(r) : r)), o.isSurge ? $notification.post(e, t, n, r) : o.isLoon ? r ? $notification.post(e, t, n, r) : $notification.post(e, t, n) : o.isQuanX && $notify(e, t, n, r), l && u && g(e, t, n) } function g(e = i, t = "", n = "", r) { if (void 0 === a || void 0 === a.post) throw "Bark notification needs to import MagicHttp module."; e = { url: l, headers: { "content-type": "application/json; charset=utf-8" }, body: { title: e, body: t ? t + "\n" + n : n, device_key: u } }; a.post(e).catch(e => { s.error("Bark notify error: " + e) }) } return { post: d, debug: function (e = i, t = "", n = "", r = "") { "DEBUG" === s.getLevel() && (1 === arguments.length && (e = i, t = "", n = arguments[0]), this.post(e, t, n, r)) }, bark: g, setBark: e => { try { var t = e.replace(/\/+$/g, ""); l = /^https?:\/\/([^/]*)/.exec(t)[0] + "/push", u = /\/([^\/]+)\/?$/.exec(t)[1] } catch (e) { s.error(`Bark url error: ${e}.`) } }, appendNotifyInfo: function (e, t) { 1 == t ? c = e : c.push(e) }, prependNotifyInfo: function (e) { c.splice(0, 0, e) }, msg: function (e, t, n, r) { var o = {}; n && (o["open-url"] = n), r && (o["media-url"] = r), (t = t && 0 != t.length ? t : Array.isArray(c) ? c.join("\n") : c) && 0 < t.length && d(i, "", t, o) } } } function MagicUtils(r, u) { const e = (e, t = "yyyy-MM-dd hh:mm:ss") => { var n, r = { "M+": e.getMonth() + 1, "d+": e.getDate(), "h+": e.getHours(), "m+": e.getMinutes(), "s+": e.getSeconds(), "q+": Math.floor((e.getMonth() + 3) / 3), S: e.getMilliseconds() }; for (n in /(y+)/.test(t) && (t = t.replace(RegExp.$1, (e.getFullYear() + "").substr(4 - RegExp.$1.length))), r) new RegExp("(" + n + ")").test(t) && (t = t.replace(RegExp.$1, 1 === RegExp.$1.length ? r[n] : ("00" + r[n]).substr(("" + r[n]).length))); return t }; return { retry: (i, s = 5, a = 0, l = null) => (...e) => new Promise((n, r) => { function o(...t) { Promise.resolve().then(() => i.apply(this, t)).then(e => { "function" == typeof l ? Promise.resolve().then(() => l(e)).then(() => { n(e) }).catch(e => { 1 <= s ? 0 < a ? setTimeout(() => o.apply(this, t), a) : o.apply(this, t) : r(e), s-- }) : n(e) }).catch(e => { u.error(e), 1 <= s && 0 < a ? setTimeout(() => o.apply(this, t), a) : 1 <= s ? o.apply(this, t) : r(e), s-- }) } o.apply(this, e) }), formatTime: e, now: () => e(new Date, "yyyy-MM-dd hh:mm:ss"), today: () => e(new Date, "yyyy-MM-dd"), sleep: t => new Promise(e => setTimeout(e, t)), assert: (e, t = null) => { var n; r.isNode ? (n = require("assert"), t ? n(e, t) : n(e)) : !0 !== e && u.error("AssertionError: " + (t || "The expression evaluated to a falsy value.")) } } } function MagicQingLong(e, a, o) { let i = "", s = "", l = "", u = "", c = "", t = ""; const d = "magic.json", g = MagicHttp(e, o); async function n() { return l = l || a.read("magic_qlclient"), u = u || a.read("magic_qlsecrt"), s = s || a.read("magic_qlname"), c = c || a.read("magic_qlpwd"), i && l && u ? (o.info("Get token from QingLong Panel"), await g.get({ url: "/open/auth/token", headers: { "content-type": "application/json" }, params: { client_id: l, client_secret: u } }).then(e => { if (!(0 < Object.keys(e.body).length && e.body.data && e.body.data.token)) throw new Error("Get QingLong Panel token failed."); o.info("Successfully logged in to QingLong Panel"), t = e.body.data.token, a.write("magic_qltoken", t) }).catch(e => { o.error("Error logging in to QingLong Panel.\n" + (e.message || e)) })) : i && s && c && await g.post({ url: "/api/user/login", headers: { "content-type": "application/json" }, body: { username: s, password: c } }).then(e => { o.info("Successfully logged in to QingLong Panel"), t = e.body.data.token, a.write("magic_qltoken", t) }).catch(e => { o.error("Error logging in to QingLong Panel.\n" + (e.message || e)) }), t } async function p(e) { let t = []; return await g.post({ url: "/api/envs", headers: { "content-type": "application/json" }, body: e }).then(e => { 200 === e.body.code ? e.body.data.forEach(e => { o.debug(`QINGLONG ADD ENV ${e.name} <${typeof e.value}> (${e.id})` + "\n" + JSON.stringify(e)), t.push(e.id) }) : o.error("Error adding environments variable from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error adding environments variable from QingLong Panel.\n" + (e.message || e)) }), t } async function r(r = null, e = "", t) { let o = []; return await g.get({ url: "/api/envs", headers: { "content-type": "application/json" }, params: { searchValue: e } }).then(e => { if (200 !== e.body.code) throw new Error("Error reading environment variable from QingLong Panel.\n" + JSON.stringify(e)); e = e.body.data; if (r) { var t = []; for (const n of e) n.name === r && o.push(n); o = t } o = e }).catch(e => { throw new Error("Error reading environments variable from QingLong Panel.\n" + (e.message || e)) }), o } async function f(e, t = "") { let n = ""; return await g.get({ url: "/api/scripts/" + e, params: { path: t } }).then(e => { if (200 !== e.body.code) throw new Error("Error reading data from QingLong Panel.\n" + JSON.stringify(e)); n = e.body.data }).catch(e => { throw new Error("Error reading data from QingLong Panel.\n" + (e.message || e)) }), n } async function y(e, t = "", n = "") { let r = !1; return await g.put({ url: "/api/scripts", headers: { "content-type": "application/json" }, body: { filename: e, path: t, content: n } }).then(e => { 200 === e.body.code ? r = !0 : o.error("Error reading data from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error reading data from QingLong Panel.\n" + (e.message || e)) }), r } return g.interceptors.request.use(function (e) { return i = i || a.read("magic_qlurl"), e.url.indexOf(i) < 0 && (e.url = "" + i + e.url), { ...e, timeout: 3e3 } }, void 0), g.interceptors.request.use(function (e) { return (l = l || a.read("magic_qlclient")) && (e.url = e.url.replace("/api/", "/open/")), e }, void 0, { runWhen: e => e.url.indexOf("api/user/login") < 0 && e.url.indexOf("open/auth/token") < 0 }), g.interceptors.request.use(async function (e) { return (t = t || a.read("magic_qltoken", "")) || await n(), e.headers.authorization = "Bearer " + t, e }, void 0, { runWhen: e => e.url.indexOf("api/user/login") < 0 && e.url.indexOf("open/auth/token") < 0 }), g.interceptors.request.use(function (e) { return e.params = { ...e.params, t: Date.now() }, e }, void 0, { runWhen: e => e.url.indexOf("open/auth/token") < 0 }), g.interceptors.request.use(function (e) { return i = i || a.read("magic_qlurl"), t = t || a.read("magic_qltoken"), o.debug("QingLong url: " + i + "\nQingLong token: " + t), e }, void 0), g.interceptors.response.use(void 0, async function (e) { try { var t = e.message || e.error || JSON.stringify(e); return (0 <= t.indexOf("NSURLErrorDomain") && 0 <= t.indexOf("-1012") || e.response && 401 === e.response.status) && e.config && !0 !== e.config.refreshToken ? (o.warning("QingLong Panel token has expired"), o.info("Refreshing the QingLong Panel token"), await n(), e.config.refreshToken = !0, o.info("Call the previous method again"), await g.request(e.config.method, e.config)) : Promise.reject(e) } catch (e) { return Promise.reject(e) } }), { url: i || a.read("magic_qlurl"), init: (e, t, n, r, o) => { i = e, l = t, u = n, s = r, c = o }, getToken: n, setEnv: async function (t, n, r = null) { if (i = i || a.read("magic_qlurl"), null === r) { var e = await p([{ name: t, value: n }]); if (e && 1 === e.length) return e[0] } else await g.put({ url: "/api/envs", headers: { "content-type": "application/json" }, body: { name: t, value: n, id: r } }).then(e => { if (200 === e.body.code) return o.debug(`QINGLONG UPDATE ENV ${t} <${typeof n}> (${r})` + "\n" + JSON.stringify(n)), !0; o.error("Error adding environment variable from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => (o.error("Error adding environment variable from QingLong Panel.\n" + (e.message || e)), !1)) }, setEnvs: p, getEnv: async function (e) { let t = null; for (const n of await r()) if (n.id === e) { t = n; break } return t }, getEnvs: r, delEnvs: async function (t) { return g.delete({ url: "/api/envs", headers: { accept: "application/json", "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6", connection: "keep-alive", "content-type": "application/json;charset=UTF-8", "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.63 Safari/537.36 Edg/102.0.1245.30" }, body: t }).then(e => 200 === e.body.code ? (o.debug("QINGLONG DELETE ENV IDS: " + t), !0) : (o.error("Error deleting environments variable from QingLong Panel.\n" + JSON.stringify(e)), !1)).catch(e => { o.error("Error deleting environments variable from QingLong Panel.\n" + (e.message || e)) }) }, disableEnvs: async function (t) { let n = !1; return await g.put({ url: "/api/envs/disable", headers: { accept: "application/json", "accept-Language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6", connection: "keep-alive", "content-type": "application/json;charset=UTF-8", "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.63 Safari/537.36 Edg/102.0.1245.30" }, body: t }).then(e => { 200 === e.body.code ? (o.debug("QINGLONG DISABLED ENV IDS: " + t), n = !0) : o.error("Error disabling environments variable from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error disabling environments variable from QingLong Panel.\n" + (e.message || e)) }), n }, enableEnvs: async function (t) { let n = !1; return await g.put({ url: "/api/envs/enable", headers: { accept: "application/json", "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6", connection: "keep-alive", "content-type": "application/json;charset=UTF-8", "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.63 Safari/537.36 Edg/102.0.1245.30" }, body: t }).then(e => { 200 === e.body.code ? (o.debug("QINGLONG ENABLED ENV IDS: " + t), n = !0) : o.error("Error enabling environments variable from Qilong panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error enabling environments variable from Qilong panel.\n" + (e.message || e)) }), n }, addScript: async function (e, t = "", n = "") { let r = !1; return await g.post({ url: "/api/scripts", headers: { "content-type": "application/json" }, body: { filename: e, path: t, content: n } }).then(e => { 200 === e.body.code ? r = !0 : o.error("Error reading data from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error reading data from QingLong Panel.\n" + (e.message || e)) }), r }, getScript: f, editScript: y, delScript: async function (e, t = "") { let n = !1; return await g.delete({ url: "/api/scripts", headers: { "content-type": "application/json" }, body: { filename: e, path: t } }).then(e => { 200 === e.body.code ? n = !0 : o.error("Error reading data from QingLong Panel.\n" + JSON.stringify(e)) }).catch(e => { o.error("Error reading data from QingLong Panel.\n" + (e.message || e)) }), n }, write: async function (e, t, n = "") { var r = await f(d, ""), o = a.convertToObject(r), e = a.write(e, t, n, o), r = JSON.stringify(o, null, 4); return await y(d, "", r) && e }, read: async function (e, t, n = "", r = !1) { var o = await f(d, ""), o = a.convertToObject(o); return a.read(e, t, n, r, o) }, del: async function (e, t = "") { var n = await f(d, ""), r = a.convertToObject(n), e = a.del(e, t, r), n = JSON.stringify(r, null, 4), t = await y(d, "", n); return e && t }, update: async function (e, t, n, r = a.defaultValueComparator) { var o = await f(d, ""), i = a.convertToObject(o), e = a.update(e, t, n, r, i); let s = !1; return !0 === e && (o = JSON.stringify(i, null, 4), s = await y(d, "", o)), e && s }, batchWrite: async function (...e) { var t, n = await f(d, ""), r = a.convertToObject(n); for (t of e) a.write(t[0], t[1], void 0 !== t[2] ? t[2] : "", r); return n = JSON.stringify(r, null, 4), y(d, "", n) }, batchRead: async function (...e) { var t, n = await f(d, ""), r = a.convertToObject(n), o = []; for (t of e) { var i = a.read(t[0], t[1], void 0 !== t[2] ? t[2] : "", "boolean" == typeof t[3] && t[3], r); o.push(i) } return o }, batchUpdate: async function (...e) { var t, n = await f(d, ""), r = a.convertToObject(n); for (t of e) a.update(t[0], t[1], void 0 !== t[2] ? t[2] : "", void 0 !== t[3] ? t.comparator : a.defaultValueComparator, r); return n = JSON.stringify(r, null, 4), y(d, "", n) }, batchDel: async function (...e) { var t, n = await f(d, ""), r = a.convertToObject(n); for (t of e) a.del(t[0], void 0 !== t[1] ? t[1] : "", r); return n = JSON.stringify(r, null, 4), y(d, "", n) }, allSessions: async function (e) { var t = await f(d, ""), t = a.convertToObject(t); return a.allSessions(e, t) }, allSessionNames: async function (e) { var t = await f(d, ""), t = a.convertToObject(t); return a.allSessionNames(e, t) } } }
  735. //---SyncByPyScript---MagicJS3-end