From 77851275ab63661ed96325df6abf6f27d30ca08e Mon Sep 17 00:00:00 2001 From: smallfawn <860562056@QQ.COM> Date: Wed, 1 Apr 2026 19:38:45 +0800 Subject: [PATCH] Remove kfh/kfw scripts and exchange modules Delete four scripts related to the kfh and kfw integrations: kfh/kfh.js, kfh/kfh_exchange.js, kfw/kfw.js, and kfw/kfw_exchange.js. These files implemented daily sign-in, sharing/help features, and E-card exchange logic (including an Env helper and HTTP request wrappers). This commit removes those legacy scripts and their associated helper code. --- kfh/kfh.js | 187 -------------------- kfh/kfh_exchange.js | 380 ----------------------------------------- kfw/kfw.js | 408 -------------------------------------------- kfw/kfw_exchange.js | 382 ----------------------------------------- 4 files changed, 1357 deletions(-) delete mode 100644 kfh/kfh.js delete mode 100644 kfh/kfh_exchange.js delete mode 100644 kfw/kfw.js delete mode 100644 kfw/kfw_exchange.js diff --git a/kfh/kfh.js b/kfh/kfh.js deleted file mode 100644 index 3be34bb..0000000 --- a/kfh/kfh.js +++ /dev/null @@ -1,187 +0,0 @@ -/** - * cron 9 9 * * * - * Show:重写请求函数 在got环境或axios环境都可以请求 - * 卡夫亨 微信网页 https://fscrm.kraftheinz.net.cn/?from=Yk0bMRVg1XmcWpJp6N5OkA== 每日签到分享领积分换卡券 - * - * 变量名:kafufeng - * 变量值:多账号& 或换行 或新建同名变量 fscrm.kraftheinz.net.cn 抓请求头Headers中的token - * scriptVersionNow = "0.0.1"; - */ - -const $ = new Env("卡夫亨"); -const notify = $.isNode() ? require('./sendNotify') : ''; -let ckName = "kafufeng"; -let envSplitor = ["&", "\n"]; //多账号分隔符 -let strSplitor = "#"; //多变量分隔符 -let userIdx = 0; -let userList = []; -let shareList = [] -let msg = "" -class Task { - constructor(str) { - this.index = ++userIdx; - this.ck = str.split(strSplitor)[0]; //单账号多变量分隔符 - this.ckStatus = true; - //定义在这里的headers会被get请求删掉content-type 而不会重置 - } - async main() { - await this.userInfo(); - await this.signIn() - await this.getShareUrl() - } - async taskRequest(method, url, body = "") { - // - let headers = { - "Host": "fscrm.kraftheinz.net.cn", - "Connection": "keep-alive", - "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/116.0.0.0 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6309092b) XWEB/9079 Flue", - "token": this.ck, - "Content-Type": "application/x-www-form-urlencoded", - "Accept": "*/*", - "Origin": "https://fscrm.kraftheinz.net.cn", - "Referer": "https://fscrm.kraftheinz.net.cn/?code=081dcPGa1MYgaH0yI6Ga1Rw39X0dcPGg&state=&appid=wx65da983ae179e97b", - - } - const reqeuestOptions = { - url: url, - method: method, - headers: headers - } - body == "" ? "" : Object.assign(reqeuestOptions, { body: body }) - let { body: result } = await $.httpRequest(reqeuestOptions) - return result - } - async userInfo() { - try { - let result = await this.taskRequest("get", `https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/getUserInfo`) - //console.log(result); - if (result.error_code == 0) { - $.log(`✅账号[${this.index}] 欢迎用户 ${result.data.nickname} 积分 => ${result.data.memberInfo.score}🎉`) - this.ckStatus = true; - } else { - $.log(`❌账号[${this.index}] 用户查询失败[${result.msg}]`); - this.ckStatus = false; - } - } catch (e) { - console.log(e); - } - } - async signIn() { - try { - let result = await this.taskRequest("post", `https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/dailySign`, ``) - //console.log(result); - if (result.error_code == 0) { - $.log(`✅账号[${this.index}] [${result.msg}] 当前积分[${result.data.res}]🎉`) - } else { - $.log(`❌账号[${this.index}] 签到失败[${result.msg}]`); - } - } catch (e) { - console.log(e); - } - } - randomInt(min, max) { - return Math.round(Math.random() * (max - min) + min); - } - async getShareUrl() { - try { - let result = await this.taskRequest("post", `https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/getCookbookIndex`, "page=1&pagesize=10") - //console.log(result); - if (result.error_code == 0) { - let shareid = result.data.chineseCookbook.data[this.randomInt(0, 9)].id - let getShareCodeResult = await this.taskRequest("post", `https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/createCookbookCode`, `cookbook_id=${shareid}`) - if (getShareCodeResult?.error_code == 0) { - //console.log(getShareCodeResult) - let code_url = getShareCodeResult?.data.code_url.replace("https://fscrm.kraftheinz.net.cn/?", "") - shareList.push(code_url) - $.log(`✅账号[${this.index}]${code_url}获取分享文章链接成功,添加到内部助力池成功 🎉`); - } - } else { - $.log(`❌账号[${this.index}] 签到失败[${result.msg}]`); - } - } catch (e) { - console.log(e); - } - } - //首账号助力作者?,//得到助力码数组后 账号一助力账号二 .....最后一个账号助力账号1 - async help(params) { - try { - let result = await this.taskRequest("post", `https://fscrm.kraftheinz.net.cn/crm/public/index.php/api/v1/recordScoreShare`, params) - //console.log(result); - if (result.error_code == 0) { - //console.log(`✅账号[${this.index}] 欢迎用户: ${result.errcode}🎉`); - $.log(`✅账号[${this.index}] 助力情况${result.msg}🎉`) - } else { - $.log(`❌账号[${this.index}] 助力失败[${result.msg}]`); - } - } catch (e) { - console.log(e); - } - } -} - - - -!(async () => { - if (!(await checkEnv())) return; - if (userList.length > 0) { - let taskall = []; - for (let user of userList) { - if (user.ckStatus) { - taskall.push(await user.main()); - } - } - await Promise.all(taskall); - taskall = []; - for (let i in userList) { - if (userList[i].ckStatus) { - let sharCode = shareList[Number(i) + 1] - - if (sharCode !== undefined) { - console.log(userList[i].ck + "=>" + sharCode) - taskall.push(await userList[i].help(sharCode)); - } else { - if (userList.length > 1) { - console.log(userList[i].ck + "=>" + shareList[0]) - taskall.push(await userList[i].help(shareList[0])); - } else { - $.log(`账号数目为1 不执行内部助力`) - - } - } - } - } - await Promise.all(taskall); - } - await $.sendMsg($.logs.join("\n")) -})() - .catch((e) => console.log(e)) - .finally(() => $.done()); - -//******************************************************** -/** - * 变量检查与处理 - * @returns - */ -async function checkEnv() { - let userCookie = ($.isNode() ? process.env[ckName] : $.getdata(ckName)) || ""; - if (userCookie) { - let e = envSplitor[0]; - for (let o of envSplitor) - if (userCookie.indexOf(o) > -1) { - e = o; - break; - } - for (let n of userCookie.split(e)) n && userList.push(new Task(n)); - } else { - console.log(`未找到CK【${ckName}】`); - return; - } - return console.log(`共找到${userList.length}个账号`), true; //true == !0 -} -//Env Api ============================= -/* -* @modifyAuthor @smallfawn -* @modifyTime 2024-03-23 -* @modifyInfo 重写请求函数 在got环境或axios环境都可以请求 -*/ -function Env(t, s) { return new (class { constructor(t, s) { this.name = t; this.data = null; this.dataFile = "box.dat"; this.logs = []; this.logSeparator = "\n"; this.startTime = new Date().getTime(); Object.assign(this, s); this.log("", `\ud83d\udd14${this.name},\u5f00\u59cb!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"); this.path = this.path ? this.path : require("path"); const 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 {}; { const i = e ? t : s; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"); this.path = this.path ? this.path : require("path"); const 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), o = JSON.stringify(this.data); e ? this.writeFileSync(t, o) : i ? this.fs.writeFileSync(s, o) : this.fs.writeFileSync(t, o) } } lodash_get(t, s, e) { const i = s.replace(/\[(\d+)\]/g, ".$1").split("."); let o = t; for (const t of i) if (((o = Object(o)[t]), void 0 === o)) return e; return o } lodash_set(t, s, e) { return Object(t) !== t ? t : (Array.isArray(s) || (s = s.toString().match(/[^.[\]]+/g) || []), (s.slice(0, -1).reduce((t, e, i) => Object(t[e]) === t[e] ? t[e] : (t[e] = Math.abs(s[i + 1]) >> 0 == +s[i + 1] ? [] : {}), t)[s[s.length - 1]] = e), t) } getdata(t) { let s = this.getval(t); if (/^@/.test(t)) { const [, e, i] = /^@(.*?)\.(.*?)$/.exec(t), o = e ? this.getval(e) : ""; if (o) try { const t = JSON.parse(o); s = t ? this.lodash_get(t, i, "") : s } catch (t) { s = "" } } return s } setdata(t, s) { let e = !1; if (/^@/.test(s)) { const [, i, o] = /^@(.*?)\.(.*?)$/.exec(s), h = this.getval(i), a = i ? ("null" === h ? null : h || "{}") : "{}"; try { const s = JSON.parse(a); this.lodash_set(s, o, t), (e = this.setval(JSON.stringify(s), i)) } catch (s) { const h = {}; this.lodash_set(h, o, t), (e = this.setval(JSON.stringify(h), i)) } } else e = this.setval(t, s); return e } getval(t) { if (this.isSurge() || this.isLoon()) { return $persistentStore.read(t) } else if (this.isQuanX()) { return $prefs.valueForKey(t) } else if (this.isNode()) { this.data = this.loaddata(); return this.data[t] } else { return this.data && this.data[t] || null } } setval(t, s) { if (this.isSurge() || this.isLoon()) { return $persistentStore.write(t, s) } else if (this.isQuanX()) { return $prefs.setValueForKey(t, s) } else if (this.isNode()) { this.data = this.loaddata(); this.data[s] = t; this.writedata(); return true } else { return this.data && this.data[s] || null } } initRequestEnv(t) { try { require.resolve('got') && (this.requset = require("got"), this.requestModule = "got") } catch (e) { } try { require.resolve('axios') && (this.requset = require("axios"), this.requestModule = "axios") } catch (e) { } this.cktough = this.cktough ? this.cktough : require("tough-cookie"); this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar(); if (t) { t.headers = t.headers ? t.headers : {}; if (typeof t.headers.Cookie === "undefined" && typeof t.cookieJar === "undefined") { t.cookieJar = this.ckjar } } } queryStr(options) { return Object.entries(options).map(([key, value]) => `${key}=${typeof value === 'object' ? JSON.stringify(value) : value}`).join('&') } getURLParams(url) { const params = {}; const queryString = url.split('?')[1]; if (queryString) { const paramPairs = queryString.split('&'); paramPairs.forEach(pair => { const [key, value] = pair.split('='); params[key] = value }) } return params } isJSONString(str) { try { return JSON.parse(str) && typeof JSON.parse(str) === 'object' } catch (e) { return false } } isJson(obj) { var isjson = typeof (obj) == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length; return isjson } async sendMsg(message) { if (!message) return; if ($.isNode()) { await notify.sendNotify($.name, message) } else { $.msg($.name, '', message) } } async httpRequest(options) { let t = { ...options }; t.headers = t.headers || {}; if (t.params) { t.url += '?' + this.queryStr(t.params) } t.method = t.method.toLowerCase(); if (t.method === 'get') { delete t.headers['Content-Type']; delete t.headers['Content-Length']; delete t.headers['content-type']; delete t.headers['content-length']; delete t.body } else if (t.method === 'post') { let ContentType; if (!t.body) { t.body = "" } else if (typeof t.body === "string") { ContentType = this.isJSONString(t.body) ? 'application/json' : 'application/x-www-form-urlencoded' } else if (this.isJson(t.body)) { t.body = JSON.stringify(t.body); ContentType = 'application/json' } if (!t.headers['Content-Type'] && !t.headers['content-type']) { t.headers['Content-Type'] = ContentType } } if (this.isNode()) { this.initRequestEnv(t); if (this.requestModule === "axios" && t.method === "post") { t.data = t.body; delete t.body } let httpResult; if (this.requestModule === "got") { httpResult = await this.requset(t); if (this.isJSONString(httpResult.body)) { httpResult.body = JSON.parse(httpResult.body) } } else if (this.requestModule === "axios") { httpResult = await this.requset(t); httpResult.body = httpResult.data } return httpResult } if (this.isQuanX()) { t.method = t.method.toUpperCase(); return new Promise((resolve, reject) => { $task.fetch(t).then(response => { if (this.isJSONString(response.body)) { response.body = JSON.parse(response.body) } resolve(response) }) }) } } randomNumber(length) { const characters = '0123456789'; return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join('') } randomString(length) { const characters = 'abcdefghijklmnopqrstuvwxyz0123456789'; return Array.from({ length }, () => characters[Math.floor(Math.random() * characters.length)]).join('') } timeStamp() { return new Date().getTime() } uuid() { return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) { var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8); return v.toString(16) }) } time(t) { let s = { "M+": new Date().getMonth() + 1, "d+": new Date().getDate(), "H+": new Date().getHours(), "m+": new Date().getMinutes(), "s+": new Date().getSeconds(), "q+": Math.floor((new Date().getMonth() + 3) / 3), S: new Date().getMilliseconds(), }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (new Date().getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in s) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? s[e] : ("00" + s[e]).substr(("" + s[e]).length))); return t } msg(s = t, e = "", i = "", o) { const h = (t) => !t || (!this.isLoon() && this.isSurge()) ? t : "string" == typeof t ? this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : void 0 : "object" == typeof t && (t["open-url"] || t["media-url"]) ? this.isLoon() ? t["open-url"] : this.isQuanX() ? t : void 0 : void 0; this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(s, e, i, h(o)) : this.isQuanX() && $notify(s, e, i, h(o))); let logs = ['', '==============📣系统通知📣==============']; logs.push(t); e ? logs.push(e) : ''; i ? logs.push(i) : ''; console.log(logs.join('\n')); this.logs = this.logs.concat(logs) } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, s) { const e = !this.isSurge() && !this.isQuanX() && !this.isLoon(); e ? this.log("", `\u2757\ufe0f${this.name},\u9519\u8bef!`, t.stack) : this.log("", `\u2757\ufe0f${this.name},\u9519\u8bef!`, t) } wait(t) { return new Promise((s) => setTimeout(s, t)) } done(t = {}) { const s = new Date().getTime(), e = (s - this.startTime) / 1e3; this.log("", `\ud83d\udd14${this.name},\u7ed3\u675f!\ud83d\udd5b ${e}\u79d2`); this.log(); if (this.isNode()) { process.exit(1) } if (this.isQuanX()) { $done(t) } } })(t, s) } diff --git a/kfh/kfh_exchange.js b/kfh/kfh_exchange.js deleted file mode 100644 index 843a49d..0000000 --- a/kfh/kfh_exchange.js +++ /dev/null @@ -1,380 +0,0 @@ -/** - * - * 卡夫亨 兑换E卡 - * - * cron 0 0,7 * * * kfh_exchange.js - * 多账号并行执行任务模板 - */ -//=====================================================// -const $ = new Env("卡夫亨兑换E卡"); -const notify = $.isNode() ? require("./sendNotify") : ""; -const Notify = 1 -const debug = 0 -let ckStr = ($.isNode() ? process.env.kfh_data : $.getdata('kfh_data')) || ''; //检测CK 外部 -let msg, ck; -let host = 'fscrm.kraftheinz.net.cn'; -let hostname = 'https://' + host; -//---------------------------------------------------// -async function tips(ckArr) { - //DoubleLog(`当前脚本版本${Version}\n📌,如果脚本版本不一致请及时更新`); - console.log(`\n============= 共找到 ${ckArr.length} 个账号 =============`); - debugLog(`【debug】 这是你的账号数组:\n ${ckArr}`); -} -!(async () => { - let ckArr = await checkEnv(ckStr, "kfh_data"); //检查CK - await tips(ckArr); //脚本提示 - await start(); //开始任务 - await SendMsg(msg); //发送通知 - -})() - .catch((e) => $.logErr(e)) - .finally(() => $.done()); - - -//---------------------------------------------------------------------------------封装循环测试 -async function newstart(name, taskname, time) { //任务名 函数名 等待时间 - let ckArr = await checkEnv(ckStr, "kfh_data"); //检查CK - console.log("\n📌📌📌📌📌📌📌📌" + name + "📌📌📌📌📌📌📌📌"); - for (i = 0; i < ckArr.length; i++) { - ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - //let CK = ckArr[i] - await taskname(); - await $.wait(time * 1000); - } -} -//-------------------------------------------------------------------------------封装循环测试 - -async function start() { - //console.log("\n📌📌📌📌📌📌📌📌执行任务1📌📌📌📌📌📌📌📌"); - //for (i = 0; i < ckArr.length; i++) { - // ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - // let CK = ckArr[i] - // await userinfo(); - // await $.wait(2 * 1000); - //} - - await newstart("兑换", userinfo, 10) - -} - - - - -//------------------------------------------------------------------------------------------ -//用户信息查询 -async function userinfo() { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/getUserInfo`, - headers: { - "Host": host, - "token": ck[0] - }, - - }; - let result = await httpGet(url, `用户信息查询`); - - //console.log(result); - if (result?.error_code == 0) { - //console.log(`账号[` + Number(i + 1) + `]` + `用户:${result.data.nickname} 🎉`); - let nickname = result.data.nickname - await exchange(nickname); - } else { - DoubleLog(`账号[` + Number(i + 1) + `]查询失败!可能是CK失效!`); - //console.log(result); - } - } catch (error) { - //console.log(error); - console.log("卡夫亨服务器卡爆啦"); - } - -} - - -//兑换 -async function exchange(nickname) { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/exchangeIntegralNew`, - headers: { - "Host": host, - "token": ck[0], - "Content-Length": 84, - "Content-Type": "application/x-www-form-urlencoded" - }, - body: "value=%E4%BA%AC%E4%B8%9CE%E5%8D%A12%E5%85%83&phone=&type=%E8%A7%86%E9%A2%91%E5%8D%A1" - - }; - let result = await httpPost(url, `兑换`); - - //console.log(result); - if (result?.error_code == 0) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `用户为:[` + nickname + `]兑换成功🎉`); - await wait(2); - } else if (result?.error_code == 80005) { - console.log(`账号[` + Number(i + 1) + `]` + `用户为:[` + nickname + `]兑换:${result.msg}`); //兑换一次上限 - } else if (result?.error_code == 30002) { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!${result.msg}`);//积分不足 - //console.log(result); - } else if (result?.error_code == 80007) { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!${result.msg}`);//有兑换在队列中 - } else { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!`) - } - } catch (error) { - //console.log(error); - console.log("卡夫亨服务器卡爆啦"); - } - -} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -// #region ******************************************************** 固定代码 ******************************************************** -/** - * 变量检查 - */ -async function checkEnv(ck, Variables) { - return new Promise((resolve) => { - let ckArr = [] - if (ck) { - if (ck.indexOf("@") !== -1) { - - ck.split("@").forEach((item) => { - ckArr.push(item); - }); - } else if (ck.indexOf("\n") !== -1) { - - ck.split("\n").forEach((item) => { - ckArr.push(item); - }); - } else { - ckArr.push(ck); - } - resolve(ckArr) - } else { - console.log(` ${$.neme}:未填写变量 ${Variables} ,请仔细阅读脚本说明!`) - } - } - ) -} -/** - * 发送消息 - */ -async function SendMsg(message) { - if (!message) return; - if (Notify > 0) { - if ($.isNode()) { - var notify = require("./sendNotify"); - await notify.sendNotify($.name, message); - } else { - // $.msg(message); - $.msg($.name, '', message) - } - } else { - console.log(message); - } -} - -/** - * 双平台log输出 - */ -function DoubleLog(data) { - if ($.isNode()) { - if (data) { - console.log(`${data}`); - msg += `\n${data}`; - } - } else { - console.log(`${data}`); - msg += `\n${data}`; - } - -} -/** -* 等待 X 秒 -*/ -function wait(n) { - return new Promise(function (resolve) { - setTimeout(resolve, n * 1000); - }); -} - -/** - * get请求 - */ -async function httpGet(getUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = getUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.get( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫亨服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * post请求 - */ -async function httpPost(postUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = postUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.post( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫亨服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * 网络请求 (get, post等) - */ -async function httpRequest(postOptionsObject, tip, timeout = 3) { - return new Promise((resolve) => { - - let Options = postOptionsObject; - let request = require('request'); - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 信息 ===============`); - console.log(Options); - } - - request(Options, async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回数据==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (!result) return; - resolve(result); - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫亨服务器卡爆啦"); - } finally { - resolve(); - } - }), timeout - - }); -} - - -/** - * debug调试 - */ -function debugLog(...args) { - if (debug) { - console.log(...args); - } -} - -// 完整 Env -function Env(t, e) { "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0); class s { constructor(t) { this.env = t } send(t, e = "GET") { t = "string" == typeof t ? { url: t } : t; let s = this.get; return "POST" === e && (s = this.post), new Promise((e, i) => { s.call(this, t, (t, s, r) => { t ? i(t) : e(s) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } return new class { constructor(t, e) { this.name = t, this.http = new s(this), this.data = null, this.dataFile = "box.dat", this.logs = [], this.isMute = !1, this.isNeedRewrite = !1, this.logSeparator = "\n", this.startTime = (new Date).getTime(), Object.assign(this, e), this.log("", `🔔${this.name}, 开始!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } runScript(t, e) { return new Promise(s => { let i = this.getdata("@chavy_boxjs_userCfgs.httpapi"); i = i ? i.replace(/\n/g, "").trim() : i; let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout"); r = r ? 1 * r : 20, r = e && e.timeout ? e.timeout : r; const [o, h] = i.split("@"), n = { url: `http://${h}/v1/scripting/evaluate`, body: { script_text: t, mock_type: "cron", timeout: r }, headers: { "X-Key": o, Accept: "*/*" } }; this.post(n, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e); if (!s && !i) return {}; { const i = s ? t : e; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e), r = JSON.stringify(this.data); s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r) } } lodash_get(t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } lodash_set(t, e, s) { return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t) } getdata(t) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } initGotEnv(t) { this.got = this.got ? this.got : require("got"), this.cktough = this.cktough ? this.cktough : require("tough-cookie"), this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar, t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar)) } get(t, e = (() => { })) { t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]), this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.get(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) })) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { this.logErr(t) } }).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) })) } post(t, e = (() => { })) { if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon()) this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) }); else if (this.isQuanX()) t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { this.initGotEnv(t); const { url: s, ...i } = t; this.got.post(s, i).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) }) } } time(t, e = null) { const s = e ? new Date(e) : new Date; let i = { "M+": s.getMonth() + 1, "d+": s.getDate(), "H+": s.getHours(), "m+": s.getMinutes(), "s+": s.getSeconds(), "q+": Math.floor((s.getMonth() + 3) / 3), S: s.getMilliseconds() }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in i) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { const e = (new Date).getTime(), s = (e - this.startTime) / 1e3; this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`), this.log(), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } }(t, e) } diff --git a/kfw/kfw.js b/kfw/kfw.js deleted file mode 100644 index b67f093..0000000 --- a/kfw/kfw.js +++ /dev/null @@ -1,408 +0,0 @@ -/** - * - * 卡夫味 - * - * cron 0 0,7 * * * kfw_v2.js - * 多账号并行执行任务模板 - * 抓域名kraftheinzcrm.kraftheinz.net.cn/crm/public下 请求token - */ - - -//=====================================================// -const $ = new Env("卡夫味"); -const notify = $.isNode() ? require("./sendNotify") : ""; -const Notify = 1 -const debug = 0 -let ckStr = ($.isNode() ? process.env.kfw_data : $.getdata('kfw_data')) || ''; //检测CK 外部 -let msg, ck; -let host = 'kraftheinzcrm.kraftheinz.net.cn'; -let hostname = 'https://' + host; -//---------------------------------------------------// -async function tips(ckArr) { - //DoubleLog(`当前脚本版本${Version}\n📌,如果脚本版本不一致请及时更新`); - console.log("日6积分 可换VIP卡等") - DoubleLog(`\n========== 共找到 ${ckArr.length} 个账号 ==========`); - debugLog(`【debug】 这是你的账号数组:\n ${ckArr}`); -} -!(async () => { - let ckArr = await checkEnv(ckStr, "kfw_data"); //检查CK - await tips(ckArr); //脚本提示 - await start(); //开始任务 - await SendMsg(msg); //发送通知 - -})() - .catch((e) => $.logErr(e)) - .finally(() => $.done()); - - -//---------------------------------------------------------------------------------封装循环测试 -async function newstart(name, taskname, time) { //任务名 函数名 等待时间 - let ckArr = await checkEnv(ckStr, "kfw_data"); //检查CK - console.log("\n📌📌📌📌📌📌📌📌" + name + "📌📌📌📌📌📌📌📌"); - for (i = 0; i < ckArr.length; i++) { - ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - //let CK = ckArr[i] - await taskname(); - await $.wait(time * 1000); - } -} -//-------------------------------------------------------------------------------封装循环测试 - -async function start() { - //console.log("\n📌📌📌📌📌📌📌📌执行任务1📌📌📌📌📌📌📌📌"); - //for (i = 0; i < ckArr.length; i++) { - // ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - // let CK = ckArr[i] - // await userinfo(); - // await $.wait(2 * 1000); - //} - - await newstart("登录/CK检测", userinfo, 3) - await newstart("签到", dailySign, 5) - await newstart("分享", share, 5) - -} - - - - -//------------------------------------------------------------------------------------------ -//用户信息查询 -async function userinfo() { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/getUserInfo`, - headers: { - "Host": host, - "token": ck[0] - }, - - }; - let result = await httpGet(url, `用户信息查询`); - - //console.log(result); - if (result?.error_code == 0) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `当前用户为[${result.data.nickname}] 积分${result?.data.memberInfo.totalScore}🎉`); - //let nickname = result.data.nickname - //let jifen = result?.data.memberInfo.totalScore - } else { - DoubleLog(`账号[` + Number(i + 1) + `]` + `查询失败,可能是CK失效!`); - //console.log(result); - } - } catch (error) { - //console.log(error); - console.log("卡夫味服务器卡爆啦"); - } - -} - -//用户签到 POST -async function dailySign() { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/dailySign`, - headers: { - "Host": host, - "token": ck[0], - }, - }; - let result = await httpPost(url, `签到`); - - //console.log(result); - if (result?.error_code == 0) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `签到成功:${result.msg}🎉`); - await wait(2); - } else if (result?.error_code == 30001) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `签到失败:${result.msg}`); - //console.log(result); - } - } catch (error) { - //console.log(error); - console.log("卡夫味服务器卡爆啦"); - } - -} - - -//用户分享 POST -async function share() { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/recordScoreShare`, - headers: { - "Host": host, - "token": ck[0], - "Content-Length": 57, //如果没有 length 则判定为 点开自己的分享链接 - "Content-Type": "application/x-www-form-urlencoded" - - }, - body: "invite_id=" + ck[0] + "&cookbook_id=20" - - }; - let result = await httpPost(url, `分享`); - - //console.log(result); - if (result?.error_code == 0) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `执行分享成功:${result.msg}🎉`); - await wait(2); - } else { - DoubleLog(`账号[` + Number(i + 1) + `]` + `执行分享失败${result.msg}`); - //console.log(result); - } - } catch (error) { - //console.log(error); - console.log("卡夫味服务器卡爆啦"); - } - -} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -// #region ******************************************************** 固定代码 ******************************************************** -/** - * 变量检查 - */ -async function checkEnv(ck, Variables) { - return new Promise((resolve) => { - let ckArr = [] - if (ck) { - if (ck.indexOf("@") !== -1) { - - ck.split("@").forEach((item) => { - ckArr.push(item); - }); - } else if (ck.indexOf("\n") !== -1) { - - ck.split("\n").forEach((item) => { - ckArr.push(item); - }); - } else { - ckArr.push(ck); - } - resolve(ckArr) - } else { - console.log(` ${$.neme}:未填写变量 ${Variables} ,请仔细阅读脚本说明!`) - } - } - ) -} -/** - * 发送消息 - */ -async function SendMsg(message) { - if (!message) return; - if (Notify > 0) { - if ($.isNode()) { - var notify = require("./sendNotify"); - await notify.sendNotify($.name, message); - } else { - // $.msg(message); - $.msg($.name, '', message) - } - } else { - console.log(message); - } -} - -/** - * 双平台log输出 - */ -function DoubleLog(data) { - if ($.isNode()) { - if (data) { - console.log(`${data}`); - msg += `\n${data}`; - } - } else { - console.log(`${data}`); - msg += `\n${data}`; - } - -} -/** -* 等待 X 秒 -*/ -function wait(n) { - return new Promise(function (resolve) { - setTimeout(resolve, n * 1000); - }); -} - -/** - * get请求 - */ -async function httpGet(getUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = getUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.get( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * post请求 - */ -async function httpPost(postUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = postUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.post( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * 网络请求 (get, post等) - */ -async function httpRequest(postOptionsObject, tip, timeout = 3) { - return new Promise((resolve) => { - - let Options = postOptionsObject; - let request = require('request'); - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 信息 ===============`); - console.log(Options); - } - - request(Options, async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回数据==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (!result) return; - resolve(result); - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }), timeout - - }); -} - - -/** - * debug调试 - */ -function debugLog(...args) { - if (debug) { - console.log(...args); - } -} - -// 完整 Env -function Env(t, e) { "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0); class s { constructor(t) { this.env = t } send(t, e = "GET") { t = "string" == typeof t ? { url: t } : t; let s = this.get; return "POST" === e && (s = this.post), new Promise((e, i) => { s.call(this, t, (t, s, r) => { t ? i(t) : e(s) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } return new class { constructor(t, e) { this.name = t, this.http = new s(this), this.data = null, this.dataFile = "box.dat", this.logs = [], this.isMute = !1, this.isNeedRewrite = !1, this.logSeparator = "\n", this.startTime = (new Date).getTime(), Object.assign(this, e), this.log("", `🔔${this.name}, 开始!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } runScript(t, e) { return new Promise(s => { let i = this.getdata("@chavy_boxjs_userCfgs.httpapi"); i = i ? i.replace(/\n/g, "").trim() : i; let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout"); r = r ? 1 * r : 20, r = e && e.timeout ? e.timeout : r; const [o, h] = i.split("@"), n = { url: `http://${h}/v1/scripting/evaluate`, body: { script_text: t, mock_type: "cron", timeout: r }, headers: { "X-Key": o, Accept: "*/*" } }; this.post(n, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e); if (!s && !i) return {}; { const i = s ? t : e; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e), r = JSON.stringify(this.data); s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r) } } lodash_get(t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } lodash_set(t, e, s) { return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t) } getdata(t) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } initGotEnv(t) { this.got = this.got ? this.got : require("got"), this.cktough = this.cktough ? this.cktough : require("tough-cookie"), this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar, t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar)) } get(t, e = (() => { })) { t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]), this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.get(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) })) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { this.logErr(t) } }).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) })) } post(t, e = (() => { })) { if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon()) this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) }); else if (this.isQuanX()) t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { this.initGotEnv(t); const { url: s, ...i } = t; this.got.post(s, i).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) }) } } time(t, e = null) { const s = e ? new Date(e) : new Date; let i = { "M+": s.getMonth() + 1, "d+": s.getDate(), "H+": s.getHours(), "m+": s.getMinutes(), "s+": s.getSeconds(), "q+": Math.floor((s.getMonth() + 3) / 3), S: s.getMilliseconds() }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in i) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { const e = (new Date).getTime(), s = (e - this.startTime) / 1e3; this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`), this.log(), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } }(t, e) } diff --git a/kfw/kfw_exchange.js b/kfw/kfw_exchange.js deleted file mode 100644 index 82be73e..0000000 --- a/kfw/kfw_exchange.js +++ /dev/null @@ -1,382 +0,0 @@ -/** - * - * 卡夫味 兑换E卡 - * - * cron 0 0,7 * * * kfw_exchange.js - * 多账号并行执行任务模板 - */ -//=====================================================// -const $ = new Env("卡夫味兑换E卡"); -const notify = $.isNode() ? require("./sendNotify") : ""; -const Notify = 1 -const debug = 0 -let ckStr = ($.isNode() ? process.env.kfw_data : $.getdata('kfw_data')) || ''; //检测CK 外部 -let msg, ck; -let host = 'kraftheinzcrm.kraftheinz.net.cn'; -let hostname = 'https://' + host; -//---------------------------------------------------// -async function tips(ckArr) { - //DoubleLog(`当前脚本版本${Version}\n📌,如果脚本版本不一致请及时更新`); - console.log(`\n============= 共找到 ${ckArr.length} 个账号 =============`); - debugLog(`【debug】 这是你的账号数组:\n ${ckArr}`); -} -!(async () => { - let ckArr = await checkEnv(ckStr, "kfw_data"); //检查CK - await tips(ckArr); //脚本提示 - await start(); //开始任务 - await SendMsg(msg); //发送通知 - -})() - .catch((e) => $.logErr(e)) - .finally(() => $.done()); - - -//---------------------------------------------------------------------------------封装循环测试 -async function newstart(name, taskname, time) { //任务名 函数名 等待时间 - let ckArr = await checkEnv(ckStr, "kfw_data"); //检查CK - console.log("\n📌📌📌📌📌📌📌📌" + name + "📌📌📌📌📌📌📌📌"); - for (i = 0; i < ckArr.length; i++) { - ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - //let CK = ckArr[i] - await taskname(); - await $.wait(time * 1000); - } -} -//-------------------------------------------------------------------------------封装循环测试 - -async function start() { - //console.log("\n📌📌📌📌📌📌📌📌执行任务1📌📌📌📌📌📌📌📌"); - //for (i = 0; i < ckArr.length; i++) { - // ck = ckArr[i].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - // let CK = ckArr[i] - // await userinfo(); - // await $.wait(2 * 1000); - //} - - await newstart("兑换", userinfo, 10) - -} - - - - -//------------------------------------------------------------------------------------------ -//用户信息查询 -async function userinfo() { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/getUserInfo`, - headers: { - "Host": host, - "token": ck[0] - }, - - }; - let result = await httpGet(url, `用户信息查询`); - - //console.log(result); - if (result?.error_code == 0) { - //console.log(`账号[` + Number(i + 1) + `]` + `用户:${result.data.nickname} 🎉`); - let nickname = result.data.nickname - await exchange(nickname); - } else { - DoubleLog(`账号[` + Number(i + 1) + `]查询失败!可能是CK失效!`); - //console.log(result); - } - } catch (error) { - //console.log(error); - console.log("卡夫味服务器卡爆啦"); - } - -} - - -//兑换 -async function exchange(nickname) { - try { - let url = { - url: `${hostname}/crm/public/index.php/api/v1/exchangeIntegral`, - headers: { - "Host": host, - "token": ck[0], - "Content-Length": 84, - "Content-Type": "application/x-www-form-urlencoded" - }, - body: "value=%E4%BA%AC%E4%B8%9CE%E5%8D%A12%E5%85%83&phone=&type=%E8%A7%86%E9%A2%91%E5%8D%A1" - - }; - let result = await httpPost(url, `兑换`); - - //console.log(result); - if (result?.error_code == 0) { - DoubleLog(`账号[` + Number(i + 1) + `]` + `用户为:[` + nickname + `]兑换成功🎉`); - await wait(2); - } else if (result?.error_code == 80005) { - console.log(`账号[` + Number(i + 1) + `]` + `用户为:[` + nickname + `]兑换:${result.msg}`); //兑换一次上限 - } else if (result?.error_code == 30002) { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!${result.msg}`);//积分不足 - //console.log(result); - } else if (result?.error_code == 80007) { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!${result.msg}`);//有兑换在队列中 - } else if (result?.error_code == -1000) { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!,可能目前缺货`) - } else { - console.log(`账号[` + Number(i + 1) + `]用户为:[` + nickname + `]兑换失败!${result.msg},可能目前缺货`) - } - } catch (error) { - //console.log(error); - console.log("卡夫味服务器卡爆啦"); - } - -} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -// #region ******************************************************** 固定代码 ******************************************************** -/** - * 变量检查 - */ -async function checkEnv(ck, Variables) { - return new Promise((resolve) => { - let ckArr = [] - if (ck) { - if (ck.indexOf("@") !== -1) { - - ck.split("@").forEach((item) => { - ckArr.push(item); - }); - } else if (ck.indexOf("\n") !== -1) { - - ck.split("\n").forEach((item) => { - ckArr.push(item); - }); - } else { - ckArr.push(ck); - } - resolve(ckArr) - } else { - console.log(` ${$.neme}:未填写变量 ${Variables} ,请仔细阅读脚本说明!`) - } - } - ) -} -/** - * 发送消息 - */ -async function SendMsg(message) { - if (!message) return; - if (Notify > 0) { - if ($.isNode()) { - var notify = require("./sendNotify"); - await notify.sendNotify($.name, message); - } else { - // $.msg(message); - $.msg($.name, '', message) - } - } else { - console.log(message); - } -} - -/** - * 双平台log输出 - */ -function DoubleLog(data) { - if ($.isNode()) { - if (data) { - console.log(`${data}`); - msg += `\n${data}`; - } - } else { - console.log(`${data}`); - msg += `\n${data}`; - } - -} -/** -* 等待 X 秒 -*/ -function wait(n) { - return new Promise(function (resolve) { - setTimeout(resolve, n * 1000); - }); -} - -/** - * get请求 - */ -async function httpGet(getUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = getUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.get( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * post请求 - */ -async function httpPost(postUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = postUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.post( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }, - timeout - ); - }); -} - -/** - * 网络请求 (get, post等) - */ -async function httpRequest(postOptionsObject, tip, timeout = 3) { - return new Promise((resolve) => { - - let Options = postOptionsObject; - let request = require('request'); - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 信息 ===============`); - console.log(Options); - } - - request(Options, async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回数据==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (!result) return; - resolve(result); - } catch (e) { - //console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - //msg = `\n ${tip} 失败了!请稍后尝试!!` - console.log("卡夫味服务器卡爆啦"); - } finally { - resolve(); - } - }), timeout - - }); -} - - -/** - * debug调试 - */ -function debugLog(...args) { - if (debug) { - console.log(...args); - } -} - -// 完整 Env -function Env(t, e) { "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0); class s { constructor(t) { this.env = t } send(t, e = "GET") { t = "string" == typeof t ? { url: t } : t; let s = this.get; return "POST" === e && (s = this.post), new Promise((e, i) => { s.call(this, t, (t, s, r) => { t ? i(t) : e(s) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } return new class { constructor(t, e) { this.name = t, this.http = new s(this), this.data = null, this.dataFile = "box.dat", this.logs = [], this.isMute = !1, this.isNeedRewrite = !1, this.logSeparator = "\n", this.startTime = (new Date).getTime(), Object.assign(this, e), this.log("", `🔔${this.name}, 开始!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } runScript(t, e) { return new Promise(s => { let i = this.getdata("@chavy_boxjs_userCfgs.httpapi"); i = i ? i.replace(/\n/g, "").trim() : i; let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout"); r = r ? 1 * r : 20, r = e && e.timeout ? e.timeout : r; const [o, h] = i.split("@"), n = { url: `http://${h}/v1/scripting/evaluate`, body: { script_text: t, mock_type: "cron", timeout: r }, headers: { "X-Key": o, Accept: "*/*" } }; this.post(n, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e); if (!s && !i) return {}; { const i = s ? t : e; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e), r = JSON.stringify(this.data); s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r) } } lodash_get(t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } lodash_set(t, e, s) { return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t) } getdata(t) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } initGotEnv(t) { this.got = this.got ? this.got : require("got"), this.cktough = this.cktough ? this.cktough : require("tough-cookie"), this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar, t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar)) } get(t, e = (() => { })) { t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]), this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.get(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) })) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { this.logErr(t) } }).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) })) } post(t, e = (() => { })) { if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon()) this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) }); else if (this.isQuanX()) t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { this.initGotEnv(t); const { url: s, ...i } = t; this.got.post(s, i).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) }) } } time(t, e = null) { const s = e ? new Date(e) : new Date; let i = { "M+": s.getMonth() + 1, "d+": s.getDate(), "H+": s.getHours(), "m+": s.getMinutes(), "s+": s.getSeconds(), "q+": Math.floor((s.getMonth() + 3) / 3), S: s.getMilliseconds() }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in i) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { const e = (new Date).getTime(), s = (e - this.startTime) / 1e3; this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`), this.log(), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } }(t, e) }