From 21802d8f95267a1012701a9e6d743412832fb9ac Mon Sep 17 00:00:00 2001 From: haptear Date: Fri, 18 Feb 2022 10:54:07 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BD=BF=E7=94=A8fqkkSetting=E5=AD=98=E5=82=A8?= =?UTF-8?q?=E5=A4=9A=E4=B8=AAck,=20=E6=AF=8F=E6=AC=A1=E6=89=A7=E8=A1=8C?= =?UTF-8?q?=E4=B8=80=E4=B8=AACK?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- fqkk.js | 858 +++++++++++++++++++++++++++++++------------------------- 1 file changed, 480 insertions(+), 378 deletions(-) diff --git a/fqkk.js b/fqkk.js index de738d1..9657465 100644 --- a/fqkk.js +++ b/fqkk.js @@ -1,6 +1,7 @@ /* 微信阅读:番茄看看 +入口链接 http://m.hg365.top/entry http://m.scytpos.top 被封后重写获取地址 推荐阅读 -> http://m.earthmembery.club/r?upuid=6769481 备用链接 -> http://m.ppapp.fun/r?upuid=6769481 @@ -19,6 +20,14 @@ https://open.weixin.qq.com/connect/oauth2/authorize fqkk.js MITM: open.weixin.qq.com +{ + currKey:"613123", + 613123:{ + fqkkWxParam:"", + fqkkCookie:"", + finish:true + } +} 如果之后番茄看看的域名换了,把域名写到变量fqkkHost里 */ // @grant require @@ -36,7 +45,7 @@ let user let userIdx = 0 let userCount = 0 -process.env.v2pUrl='http://47.106.101.70:6800/store?token=haptear' +// process.env.v2pUrl = 'http://47.106.101.70:6800/store?token=xxx' let fqkkHost = ($.isNode() ? process.env.fqkkHost : $.getdata('fqkkHost')) || 'm.kekqcx.bar'; let fqkkWxParam = ($.isNode() ? process.env.fqkkWxParam : $.getdata('fqkkWxParam')) || ''; @@ -45,128 +54,128 @@ let v2pUrl = ($.isNode() ? process.env.v2pUrl : $.getdata('v2pUrl')) || ''; /////////////////////////////////////////////////////////////////// class UserInfo { - constructor(wxParam,cookie) { + constructor(wxParam, cookie) { this.index = ++userIdx this.flag = true this.gold = 0 this.jkey = '' this.helpee = '' - + this.cookie = cookie - + let wxParamJSON = req2json(wxParam) this.uin = wxParamJSON.uin this.key = wxParamJSON.key this.version = wxParamJSON.version this.pass_ticket = wxParamJSON.pass_ticket - + this.wxAuthLink = '' this.wxReplyLink = '' } - - - async finishTask() { + + + async finishTask () { let url = `http://${fqkkHost}/reada/finishTask` let body = `readLastKey=` - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'X-Requested-With' : 'XMLHttpRequest', - 'Accept' : '*/*', - 'Cookie' : this.cookie, - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', - 'Content-Type' : 'application/x-www-form-urlencoded', - 'Content-Length' : body.length, + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': '*/*', + 'Cookie': this.cookie, + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Content-Length': body.length, }, body: body, } - await httpRequest('post',urlObject) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} + await httpRequest('post', urlObject) + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } let result = JSON.parse(httpResult.body); - if(!result) return + if (!result) return //console.log(result) - if(result.data) { + if (result.data) { console.log(`本轮剩余${result.data.infoView.rest}可读,今日已读${result.data.infoView.num},今日收益${result.data.infoView.score}币`) - if(result.data.infoView.msg) { - let str1 = result.data.infoView.msg.replace(/<.*?>/g,'') + if (result.data.infoView.msg) { + let str1 = result.data.infoView.msg.replace(/<.*?>/g, '') console.log(str1); } - if(result.data.infoView.rest==0) this.flag=false; + if (result.data.infoView.rest == 0) this.flag = false; } else { console.log(`查询今日阅读情况失败`) console.log(result) } } - - async do_read() { + + async do_read () { let url = `http://${fqkkHost}/fast_reada/do_read?for=${this.helpee}&zs=&pageshow&r=0.${randomString(17)}` - if(this.jkey) url += `&jkey=${this.jkey}` - let host = url.replace('//','/').split('/')[1] + if (this.jkey) url += `&jkey=${this.jkey}` + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'X-Requested-With' : 'XMLHttpRequest', - 'Accept' : '*/*', - 'Cookie' : this.cookie, - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': '*/*', + 'Cookie': this.cookie, + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } let result = JSON.parse(httpResult.body); - if(!result) return + if (!result) return //console.log(result) - if(result.jkey) { + if (result.jkey) { this.jkey = result.jkey this.wxAuthLink = result.url - if(result.success_msg) console.log(result.success_msg) + if (result.success_msg) console.log(result.success_msg) await $.wait(200); - await this.wxAuth(); + await this.wxAuth(); } else { console.log(`开始阅读失败`) console.log(result) this.flag = false } } - - async wxAuth() { - if(!this.wxAuthLink) return; - let url = this.wxAuthLink.replace('#wechat_redirect','') + `&uin=${this.uin}&key=${this.key}&version=${this.version}&pass_ticket=${this.pass_ticket}` - let host = url.replace('//','/').split('/')[1] + + async wxAuth () { + if (!this.wxAuthLink) return; + let url = this.wxAuthLink.replace('#wechat_redirect', '') + `&uin=${this.uin}&key=${this.key}&version=${this.version}&pass_ticket=${this.pass_ticket}` + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'Upgrade-Insecure-Requests' : '1', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', - 'Sec-Fetch-Site' : 'none', - 'Sec-Fetch-Mode' : 'navigate', - 'Sec-Fetch-User' : '?1', - 'Sec-Fetch-Dest' : 'document', - 'Accept-Encoding' : 'gzip, deflate, br', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Connection': 'keep-alive', + 'Upgrade-Insecure-Requests': '1', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Sec-Fetch-Site': 'none', + 'Sec-Fetch-Mode': 'navigate', + 'Sec-Fetch-User': '?1', + 'Sec-Fetch-Dest': 'document', + 'Accept-Encoding': 'gzip, deflate, br', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } let result = httpResult.body; - if(!result) return + if (!result) return //console.log(result) - for(let lines of result.split('\n')) { - if(lines.indexOf('var authUrl =') > -1) { + for (let lines of result.split('\n')) { + if (lines.indexOf('var authUrl =') > -1) { let replyLink = '' let cmds = lines + '\nreplyLink = authUrl;' eval(cmds) @@ -174,121 +183,121 @@ class UserInfo { } } await $.wait(200); - await this.wxReply(); + await this.wxReply(); } - - async wxReply() { - if(!this.wxReplyLink) return; + + async wxReply () { + if (!this.wxReplyLink) return; let url = this.wxReplyLink - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'Upgrade-Insecure-Requests' : '1', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', - 'Sec-Fetch-Site' : 'same-origin', - 'Sec-Fetch-Mode' : 'navigate', - 'Sec-Fetch-Dest' : 'document', - 'Accept-Encoding' : 'gzip, deflate, br', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Connection': 'keep-alive', + 'Upgrade-Insecure-Requests': '1', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Sec-Fetch-Site': 'same-origin', + 'Sec-Fetch-Mode': 'navigate', + 'Sec-Fetch-Dest': 'document', + 'Accept-Encoding': 'gzip, deflate, br', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 301) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 301) { this.flag = false; return; } await $.wait(10) await this.wxRedirect1(httpResult.headers.location) } - - async wxRedirect1(redirectUrl) { + + async wxRedirect1 (redirectUrl) { let url = redirectUrl - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'Upgrade-Insecure-Requests' : '1', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', - 'Sec-Fetch-Site' : 'same-origin', - 'Sec-Fetch-Mode' : 'navigate', - 'Sec-Fetch-Dest' : 'document', - 'Accept-Encoding' : 'gzip, deflate, br', - 'Cookie' : this.cookie, - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Connection': 'keep-alive', + 'Upgrade-Insecure-Requests': '1', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Sec-Fetch-Site': 'same-origin', + 'Sec-Fetch-Mode': 'navigate', + 'Sec-Fetch-Dest': 'document', + 'Accept-Encoding': 'gzip, deflate, br', + 'Cookie': this.cookie, + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 302) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 302) { this.flag = false; return; } await $.wait(10) await this.wxRedirect2(httpResult.headers.location) } - - async wxRedirect2(redirectUrl) { + + async wxRedirect2 (redirectUrl) { let url = redirectUrl - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'Upgrade-Insecure-Requests' : '1', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', - 'Sec-Fetch-Site' : 'same-origin', - 'Sec-Fetch-Mode' : 'navigate', - 'Sec-Fetch-Dest' : 'document', - 'Accept-Encoding' : 'gzip, deflate, br', - 'Cookie' : this.cookie, - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Connection': 'keep-alive', + 'Upgrade-Insecure-Requests': '1', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Sec-Fetch-Site': 'same-origin', + 'Sec-Fetch-Mode': 'navigate', + 'Sec-Fetch-Dest': 'document', + 'Accept-Encoding': 'gzip, deflate, br', + 'Cookie': this.cookie, + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 302) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 302) { this.flag = false; return; } let url_wx = httpResult.headers.location - if(url_wx.indexOf('#wechat_redirect') == -1) {this.flag=false;return;} - let url_0 = url_wx.replace('#wechat_redirect','') + `&key=${this.key}&ascene=1&uin=${this.uin}&devicetype=Windows+11+x64&version=${this.version}&lang=zh_CN&exportkey=A1dUeR%2F7MZ6AWOjf558r11s%3D&acctmode=0&pass_ticket=${this.pass_ticket}&wx_header=0&fontgear=2` + if (url_wx.indexOf('#wechat_redirect') == -1) { this.flag = false; return; } + let url_0 = url_wx.replace('#wechat_redirect', '') + `&key=${this.key}&ascene=1&uin=${this.uin}&devicetype=Windows+11+x64&version=${this.version}&lang=zh_CN&exportkey=A1dUeR%2F7MZ6AWOjf558r11s%3D&acctmode=0&pass_ticket=${this.pass_ticket}&wx_header=0&fontgear=2` //await $.wait(10) //await this.wxRedirect2(url_0) - - let rndTime = Math.floor(Math.random()*5) + 8 + + let rndTime = Math.floor(Math.random() * 5) + 8 console.log(`等待${rndTime}秒完成阅读...`) - await $.wait(rndTime*1000); + await $.wait(rndTime * 1000); } - - async getGold() { + + async getGold () { let url = `http://${fqkkHost}/fast_reada` - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'Upgrade-Insecure-Requests' : 1, - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', - 'Cookie' : this.cookie, + 'Connection': 'keep-alive', + 'Upgrade-Insecure-Requests': 1, + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', + 'Cookie': this.cookie, // 'Referer': `http://${fqkkHost}/?upuid=6769481`, - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', }, } - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) //console.log(httpResult) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } console.log('\n================================') - for(let lines of httpResult.body.split('\n')) { - if(lines.indexOf('div class="userinfo-score"') > -1) { + for (let lines of httpResult.body.split('\n')) { + if (lines.indexOf('div class="userinfo-score"') > -1) { this.gold = parseFloat(lines.match(/积分:(.*?)= 40) { + if (this.gold >= 40) { console.log('准备提现...') await $.wait(300) await this.withdraw() @@ -296,39 +305,39 @@ class UserInfo { console.log('余额不足,不提现') } break; - } else if(lines.indexOf('div class="userinfo-name"') > -1) { + } else if (lines.indexOf('div class="userinfo-name"') > -1) { this.nickname = lines.match(/
(.*)<\/div>/)[1] console.log(`账号昵称:${this.nickname}`) } } } - - async withdraw() { + + async withdraw () { let url = `http://${fqkkHost}/withdrawal/doWithdraw` let body = `amount=${Math.floor(this.gold)}` - let host = url.replace('//','/').split('/')[1] + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { 'Host': host, - 'Connection' : 'keep-alive', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'X-Requested-With' : 'XMLHttpRequest', - 'Accept' : '*/*', - 'Cookie' : this.cookie, - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', - 'Content-Type' : 'application/x-www-form-urlencoded', - 'Content-Length' : body.length, + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': '*/*', + 'Cookie': this.cookie, + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Content-Length': body.length, }, body: body, } - await httpRequest('post',urlObject) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} + await httpRequest('post', urlObject) + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } let result = JSON.parse(httpResult.body); - if(!result) return + if (!result) return //console.log(result) - if(result.code == 0) { + if (result.code == 0) { console.log(`成功提现${this.money}元`) } else { console.log(`提现失败:${result.msg}`) @@ -339,135 +348,227 @@ class UserInfo { !(async () => { if (typeof $request !== "undefined") { await GetRewrite() - }else { - if(!(await checkEnv())) return; - await user.finishTask(); + } else { + if (!(await checkEnv())) return; + await user.finishTask(); await $.wait(300); - while(user.flag) { - await user.do_read(); + while (user.flag) { + await user.do_read(); await $.wait(200); } await user.getGold(); } })() -.catch((e) => $.logErr(e)) -.finally(() => $.done()) + .catch((e) => $.logErr(e)) + .finally(() => $.done()) /////////////////////////////////////////////////////////////////// -async function GetRewrite() { - if($request.url.indexOf(`connect/oauth2/authorize`) > -1) { +async function GetRewrite () { + if ($request.url.indexOf(`connect/oauth2/authorize`) > -1) { let ck = $request.url.split('authorize?')[1] - $.setdata(ck, 'fqkkWxParam'); - $.msg(jsname+` 获取到微信授权参数`) - } else if($request.url.indexOf(`fast_reada/do_read`) > -1) { + //$.setdata(ck, 'fqkkWxParam'); + setStore('fqkkWxParam', ck); + $.msg(jsname + ` 获取到微信授权参数`) + } else if ($request.url.indexOf(`fast_reada/do_read`) > -1) { let ck = $request.headers.Cookie - $.setdata(ck, 'fqkkCookie'); - $.msg(jsname+` 获取到fqkkCookie`) - } + //$.setdata(ck, 'fqkkCookie'); + setStore('fqkkCookie', ck); + $.msg(jsname + ` 获取到fqkkCookie`) + } else if ($request.url.indexOf(`fast_reada?upuid=`) > -1) { + //http://m.isehrp.bar/fast_reada?upuid=6769481 + let upuid = $request.url.split('upuid=')[1]; + resetStore(upuid); + } } -async function getV2pValue(key) - { - let url = `${v2pUrl}&key=${key}` - let host = url.replace('//','/').split('/')[1] - let urlObject = { - url: url, - headers: { - 'Host': host, - 'Connection' : 'keep-alive', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'X-Requested-With' : 'XMLHttpRequest', - 'Accept' : '*/*', - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', - }, +// { +// currKey:"613123", +// 613123:{ +// fqkkWxParam:"", +// fqkkCookie:"", +// finish:true +// } +// } + +async function setStore (key, value) { + var fqkkSettingStr = $.getdata("fqkkSetting"); + if (!fqkkSettingStr) { + $.msg(jsname + `setStore fqkkSetting无数据`) + return; + } + var fqkkSetting = JSON.parse(fqkkSettingStr); + if (!fqkkSetting.currKey) { + $.msg(jsname + `setStore fqkkSetting currKey 无数据`) + return; + } + let currKey = fqkkSetting.currKey; + if (!fqkkSetting[currKey]) { + fqkkSetting[currKey] = { fqkkWxParam: "", fqkkCookie: "", finish: false }; + return; + } + fqkkSetting[currKey][key] = value; + $.setdata(JSON.stringify(fqkkSetting), "fqkkSetting"); +} + +async function resetStore (upuid) { + var fqkkSettingStr = $.getdata("fqkkSetting"); + var fqkkSetting = fqkkSettingStr ? JSON.parse(fqkkSettingStr) : {}; + fqkkSetting.currKey = upuid; + fqkkSetting[upuid] = { fqkkWxParam: "", fqkkCookie: "", finish: false }; + $.setdata(JSON.stringify(fqkkSetting), "fqkkSetting"); +} + +async function getV2pValue (key) { + let url = `${v2pUrl}&key=${key}` + let host = url.replace('//', '/').split('/')[1] + let urlObject = { + url: url, + headers: { + 'Host': host, + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': '*/*', + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + }, + } + await httpRequest('get', urlObject) + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } + if (!httpResult || !httpResult.body) + return ""; + + let result = JSON.parse(httpResult.body); + if (!result) return "" + return result.value +} + +//{"type":"save","data":{"key":"fqkkCookie","value":{"type":"string","value":"{a:'aaa',b:'cc'}","belong":"fqkk.js","update":"2022-02-18 09:10:14"}}} + +async function updateV2pValue (setting) { + let url = `${v2pUrl}` + let body = { + "type": "save", "data": { + "key": "fqkkSetting", "value": { + "type": "string", + "value": JSON.stringify(setting), + "belong": "fqkk.js", + "update": "2022-02-18 09:10:14" + } } - await httpRequest('get',urlObject) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} - if(!httpResult || !httpResult.body) - return ""; - - let result = JSON.parse(httpResult.body); - if(!result) return "" - return result.value + }; + let host = url.replace('//', '/').split('/')[1]; + let urlObject = { + url: url, + headers: { + 'Host': host, + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': 'application/json, text/plain, */*', + "content-type": "application/json", + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + }, + json: body } + await httpRequest('put', urlObject) + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } + let result = JSON.parse(httpResult.body); + if (result) + console.log(result.message); - async function deleteV2pValue(key) - { - let url = `${v2pUrl}` - let host = url.replace('//','/').split('/')[1] - var body={type:"delete",data:key}; - let urlObject = { - url: url, - headers: { - 'Host': host, - 'Connection' : 'keep-alive', - 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', - 'X-Requested-With' : 'XMLHttpRequest', - 'Accept' : 'application/json, text/plain, */*', - "content-type": "application/json", - 'Accept-Encoding' : 'gzip, deflate', - 'Accept-Language' : 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', - }, - json:body +} + +async function deleteV2pValue (key) { + let url = `${v2pUrl}` + let host = url.replace('//', '/').split('/')[1] + var body = { type: "delete", data: key }; + let urlObject = { + url: url, + headers: { + 'Host': host, + 'Connection': 'keep-alive', + 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept': 'application/json, text/plain, */*', + "content-type": "application/json", + 'Accept-Encoding': 'gzip, deflate', + 'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7', + }, + json: body + } + await httpRequest('put', urlObject) + if (!httpResult || httpResult.statusCode != 200) { this.flag = false; return; } + let result = JSON.parse(httpResult.body); + if (result) + console.log(result.message); + +} +async function checkEnv () { + var fqkkSettingStr = await getV2pValue('fqkkSetting'); + if (fqkkSettingStr) { + var fqkkSetting = JSON.parse(fqkkSettingStr); + for (let key in fqkkSetting) { + if (key == 'currKey') + continue; + if (!fqkkSetting[key].finish) { + fqkkWxParam = fqkkSetting[key]['fqkkWxParam']; + fqkkCookie = fqkkSetting[key]['fqkkCookie']; + fqkkSetting[key].finish = true; + + updateV2pValue(fqkkSetting) + break; + } } - await httpRequest('put',urlObject) - if(!httpResult || httpResult.statusCode != 200) {this.flag=false;return;} - let result = JSON.parse(httpResult.body); - if(result) - console.log(result.message); - } -async function checkEnv() { - fqkkWxParam=await getV2pValue('fqkkWxParam'); - fqkkCookie=await getV2pValue('fqkkCookie'); - if(fqkkWxParam && fqkkCookie) { - user = new UserInfo(fqkkWxParam,fqkkCookie); + if (fqkkWxParam && fqkkCookie) { + user = new UserInfo(fqkkWxParam, fqkkCookie); await deleteV2pValue('fqkkWxParam'); } else { let errorStr = '' - if(!fqkkWxParam) errorStr += 'fqkkWxParam ' - if(!fqkkCookie) errorStr += 'fqkkCookie ' + if (!fqkkWxParam) errorStr += 'fqkkWxParam ' + if (!fqkkCookie) errorStr += 'fqkkCookie ' console.log(`未找到${errorStr}`) return false; } - + return true; } //通知 -async function showmsg() { - if(!notifyStr) return; +async function showmsg () { + if (!notifyStr) return; const notify = $.isNode() ? require('./sendNotify') : ''; - if(!notify) return; + if (!notify) return; notifyBody = jsname + "运行通知\n\n" + notifyStr if (notifyFlag == 1) { $.msg(notifyBody); - if($.isNode()){await notify.sendNotify($.name, notifyBody );} + if ($.isNode()) { await notify.sendNotify($.name, notifyBody); } } else { console.log(notifyBody); } } //pushDear -async function pushDear(str) { - if(!PushDearKey) return; - if(!str) return; - +async function pushDear (str) { + if (!PushDearKey) return; + if (!str) return; + console.log('\n============= PushDear 通知 =============\n') console.log(str) let urlObject = { url: `https://api2.pushdeer.com/message/push?pushkey=${PushDearKey}&text=${encodeURIComponent(str)}`, headers: {}, }; - await httpRequest('get',urlObject) + await httpRequest('get', urlObject) let result = httpResult; - let retStr = result.content.result==false ? '失败' : '成功' + let retStr = result.content.result == false ? '失败' : '成功' console.log(`\n========== PushDear 通知发送${retStr} ==========\n`) } //////////////////////////////////////////////////////////////////// -function populateUrlObject(url,did,body=''){ - let host = url.replace('//','/').split('/')[1] +function populateUrlObject (url, did, body = '') { + let host = url.replace('//', '/').split('/')[1] let urlObject = { url: url, headers: { @@ -486,11 +587,11 @@ function populateUrlObject(url,did,body=''){ "Accept-Encoding": "gzip" }, } - if(body) urlObject.body = body + if (body) urlObject.body = body return urlObject; } -async function httpRequest(method,url) { +async function httpRequest (method, url) { httpResult = null return new Promise((resolve) => { $[method](url, async (err, resp, data) => { @@ -511,7 +612,7 @@ async function httpRequest(method,url) { }); } -function safeGet(data) { +function safeGet (data) { try { if (typeof JSON.parse(data) == "object") { return true; @@ -525,173 +626,174 @@ function safeGet(data) { } } -function getMin(a,b){ - return ((anumStr.length) ? (length-numStr.length) : 0 + let numPad = (length > numStr.length) ? (length - numStr.length) : 0 let retStr = '' - for(let i=0; i>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t="";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9+/=]/g,"");while(f>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/rn/g,"n");var t="";for(var n=0;n127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t="";var n=0;var r=c1=c2=0;while(n191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}} - -function MD5Encrypt(a){function b(a,b){return a<>>32-b}function c(a,b){var c,d,e,f,g;return e=2147483648&a,f=2147483648&b,c=1073741824&a,d=1073741824&b,g=(1073741823&a)+(1073741823&b),c&d?2147483648^g^e^f:c|d?1073741824&g?3221225472^g^e^f:1073741824^g^e^f:g^e^f}function d(a,b,c){return a&b|~a&c}function e(a,b,c){return a&c|b&~c}function f(a,b,c){return a^b^c}function g(a,b,c){return b^(a|~c)}function h(a,e,f,g,h,i,j){return a=c(a,c(c(d(e,f,g),h),j)),c(b(a,i),e)}function i(a,d,f,g,h,i,j){return a=c(a,c(c(e(d,f,g),h),j)),c(b(a,i),d)}function j(a,d,e,g,h,i,j){return a=c(a,c(c(f(d,e,g),h),j)),c(b(a,i),d)}function k(a,d,e,f,h,i,j){return a=c(a,c(c(g(d,e,f),h),j)),c(b(a,i),d)}function l(a){for(var b,c=a.length,d=c+8,e=(d-d%64)/64,f=16*(e+1),g=new Array(f-1),h=0,i=0;c>i;)b=(i-i%4)/4,h=i%4*8,g[b]=g[b]|a.charCodeAt(i)<>>29,g}function m(a){var b,c,d="",e="";for(c=0;3>=c;c++)b=a>>>8*c&255,e="0"+b.toString(16),d+=e.substr(e.length-2,2);return d}function n(a){a=a.replace(/\r\n/g,"\n");for(var b="",c=0;cd?b+=String.fromCharCode(d):d>127&&2048>d?(b+=String.fromCharCode(d>>6|192),b+=String.fromCharCode(63&d|128)):(b+=String.fromCharCode(d>>12|224),b+=String.fromCharCode(d>>6&63|128),b+=String.fromCharCode(63&d|128))}return b}var o,p,q,r,s,t,u,v,w,x=[],y=7,z=12,A=17,B=22,C=5,D=9,E=14,F=20,G=4,H=11,I=16,J=23,K=6,L=10,M=15,N=21;for(a=n(a),x=l(a),t=1732584193,u=4023233417,v=2562383102,w=271733878,o=0;o> 2; o = (n & 3) << 4 | r >> 4; u = (r & 15) << 2 | i >> 6; a = i & 63; if (isNaN(r)) { u = a = 64 } else if (isNaN(i)) { a = 64 } t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a) } return t }, decode: function (e) { var t = ""; var n, r, i; var s, o, u, a; var f = 0; e = e.replace(/[^A-Za-z0-9+/=]/g, ""); while (f < e.length) { s = this._keyStr.indexOf(e.charAt(f++)); o = this._keyStr.indexOf(e.charAt(f++)); u = this._keyStr.indexOf(e.charAt(f++)); a = this._keyStr.indexOf(e.charAt(f++)); n = s << 2 | o >> 4; r = (o & 15) << 4 | u >> 2; i = (u & 3) << 6 | a; t = t + String.fromCharCode(n); if (u != 64) { t = t + String.fromCharCode(r) } if (a != 64) { t = t + String.fromCharCode(i) } } t = Base64._utf8_decode(t); return t }, _utf8_encode: function (e) { e = e.replace(/rn/g, "n"); var t = ""; for (var n = 0; n < e.length; n++) { var r = e.charCodeAt(n); if (r < 128) { t += String.fromCharCode(r) } else if (r > 127 && r < 2048) { t += String.fromCharCode(r >> 6 | 192); t += String.fromCharCode(r & 63 | 128) } else { t += String.fromCharCode(r >> 12 | 224); t += String.fromCharCode(r >> 6 & 63 | 128); t += String.fromCharCode(r & 63 | 128) } } return t }, _utf8_decode: function (e) { var t = ""; var n = 0; var r = c1 = c2 = 0; while (n < e.length) { r = e.charCodeAt(n); if (r < 128) { t += String.fromCharCode(r); n++ } else if (r > 191 && r < 224) { c2 = e.charCodeAt(n + 1); t += String.fromCharCode((r & 31) << 6 | c2 & 63); n += 2 } else { c2 = e.charCodeAt(n + 1); c3 = e.charCodeAt(n + 2); t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63); n += 3 } } return t } } +// prettier-ignore +function MD5Encrypt (a) { function b (a, b) { return a << b | a >>> 32 - b } function c (a, b) { var c, d, e, f, g; return e = 2147483648 & a, f = 2147483648 & b, c = 1073741824 & a, d = 1073741824 & b, g = (1073741823 & a) + (1073741823 & b), c & d ? 2147483648 ^ g ^ e ^ f : c | d ? 1073741824 & g ? 3221225472 ^ g ^ e ^ f : 1073741824 ^ g ^ e ^ f : g ^ e ^ f } function d (a, b, c) { return a & b | ~a & c } function e (a, b, c) { return a & c | b & ~c } function f (a, b, c) { return a ^ b ^ c } function g (a, b, c) { return b ^ (a | ~c) } function h (a, e, f, g, h, i, j) { return a = c(a, c(c(d(e, f, g), h), j)), c(b(a, i), e) } function i (a, d, f, g, h, i, j) { return a = c(a, c(c(e(d, f, g), h), j)), c(b(a, i), d) } function j (a, d, e, g, h, i, j) { return a = c(a, c(c(f(d, e, g), h), j)), c(b(a, i), d) } function k (a, d, e, f, h, i, j) { return a = c(a, c(c(g(d, e, f), h), j)), c(b(a, i), d) } function l (a) { for (var b, c = a.length, d = c + 8, e = (d - d % 64) / 64, f = 16 * (e + 1), g = new Array(f - 1), h = 0, i = 0; c > i;)b = (i - i % 4) / 4, h = i % 4 * 8, g[b] = g[b] | a.charCodeAt(i) << h, i++; return b = (i - i % 4) / 4, h = i % 4 * 8, g[b] = g[b] | 128 << h, g[f - 2] = c << 3, g[f - 1] = c >>> 29, g } function m (a) { var b, c, d = "", e = ""; for (c = 0; 3 >= c; c++)b = a >>> 8 * c & 255, e = "0" + b.toString(16), d += e.substr(e.length - 2, 2); return d } function n (a) { a = a.replace(/\r\n/g, "\n"); for (var b = "", c = 0; c < a.length; c++) { var d = a.charCodeAt(c); 128 > d ? b += String.fromCharCode(d) : d > 127 && 2048 > d ? (b += String.fromCharCode(d >> 6 | 192), b += String.fromCharCode(63 & d | 128)) : (b += String.fromCharCode(d >> 12 | 224), b += String.fromCharCode(d >> 6 & 63 | 128), b += String.fromCharCode(63 & d | 128)) } return b } var o, p, q, r, s, t, u, v, w, x = [], y = 7, z = 12, A = 17, B = 22, C = 5, D = 9, E = 14, F = 20, G = 4, H = 11, I = 16, J = 23, K = 6, L = 10, M = 15, N = 21; for (a = n(a), x = l(a), t = 1732584193, u = 4023233417, v = 2562383102, w = 271733878, o = 0; o < x.length; o += 16)p = t, q = u, r = v, s = w, t = h(t, u, v, w, x[o + 0], y, 3614090360), w = h(w, t, u, v, x[o + 1], z, 3905402710), v = h(v, w, t, u, x[o + 2], A, 606105819), u = h(u, v, w, t, x[o + 3], B, 3250441966), t = h(t, u, v, w, x[o + 4], y, 4118548399), w = h(w, t, u, v, x[o + 5], z, 1200080426), v = h(v, w, t, u, x[o + 6], A, 2821735955), u = h(u, v, w, t, x[o + 7], B, 4249261313), t = h(t, u, v, w, x[o + 8], y, 1770035416), w = h(w, t, u, v, x[o + 9], z, 2336552879), v = h(v, w, t, u, x[o + 10], A, 4294925233), u = h(u, v, w, t, x[o + 11], B, 2304563134), t = h(t, u, v, w, x[o + 12], y, 1804603682), w = h(w, t, u, v, x[o + 13], z, 4254626195), v = h(v, w, t, u, x[o + 14], A, 2792965006), u = h(u, v, w, t, x[o + 15], B, 1236535329), t = i(t, u, v, w, x[o + 1], C, 4129170786), w = i(w, t, u, v, x[o + 6], D, 3225465664), v = i(v, w, t, u, x[o + 11], E, 643717713), u = i(u, v, w, t, x[o + 0], F, 3921069994), t = i(t, u, v, w, x[o + 5], C, 3593408605), w = i(w, t, u, v, x[o + 10], D, 38016083), v = i(v, w, t, u, x[o + 15], E, 3634488961), u = i(u, v, w, t, x[o + 4], F, 3889429448), t = i(t, u, v, w, x[o + 9], C, 568446438), w = i(w, t, u, v, x[o + 14], D, 3275163606), v = i(v, w, t, u, x[o + 3], E, 4107603335), u = i(u, v, w, t, x[o + 8], F, 1163531501), t = i(t, u, v, w, x[o + 13], C, 2850285829), w = i(w, t, u, v, x[o + 2], D, 4243563512), v = i(v, w, t, u, x[o + 7], E, 1735328473), u = i(u, v, w, t, x[o + 12], F, 2368359562), t = j(t, u, v, w, x[o + 5], G, 4294588738), w = j(w, t, u, v, x[o + 8], H, 2272392833), v = j(v, w, t, u, x[o + 11], I, 1839030562), u = j(u, v, w, t, x[o + 14], J, 4259657740), t = j(t, u, v, w, x[o + 1], G, 2763975236), w = j(w, t, u, v, x[o + 4], H, 1272893353), v = j(v, w, t, u, x[o + 7], I, 4139469664), u = j(u, v, w, t, x[o + 10], J, 3200236656), t = j(t, u, v, w, x[o + 13], G, 681279174), w = j(w, t, u, v, x[o + 0], H, 3936430074), v = j(v, w, t, u, x[o + 3], I, 3572445317), u = j(u, v, w, t, x[o + 6], J, 76029189), t = j(t, u, v, w, x[o + 9], G, 3654602809), w = j(w, t, u, v, x[o + 12], H, 3873151461), v = j(v, w, t, u, x[o + 15], I, 530742520), u = j(u, v, w, t, x[o + 2], J, 3299628645), t = k(t, u, v, w, x[o + 0], K, 4096336452), w = k(w, t, u, v, x[o + 7], L, 1126891415), v = k(v, w, t, u, x[o + 14], M, 2878612391), u = k(u, v, w, t, x[o + 5], N, 4237533241), t = k(t, u, v, w, x[o + 12], K, 1700485571), w = k(w, t, u, v, x[o + 3], L, 2399980690), v = k(v, w, t, u, x[o + 10], M, 4293915773), u = k(u, v, w, t, x[o + 1], N, 2240044497), t = k(t, u, v, w, x[o + 8], K, 1873313359), w = k(w, t, u, v, x[o + 15], L, 4264355552), v = k(v, w, t, u, x[o + 6], M, 2734768916), u = k(u, v, w, t, x[o + 13], N, 1309151649), t = k(t, u, v, w, x[o + 4], K, 4149444226), w = k(w, t, u, v, x[o + 11], L, 3174756917), v = k(v, w, t, u, x[o + 2], M, 718787259), u = k(u, v, w, t, x[o + 9], N, 3951481745), t = c(t, p), u = c(u, q), v = c(v, r), w = c(w, s); var O = m(t) + m(u) + m(v) + m(w); return O.toLowerCase() } +// prettier-ignore +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") { + send (t, e = "GET") { t = "string" == typeof t ? { url: t } - : t; + : t; let s = this.get; return "POST" === e && (s = this.post), - "PUT" === e && (s = this.put), - new Promise((e, i) => { - s.call(this, t, (t, s, r) => { - t ? i(t) : e(s) + "PUT" === e && (s = this.put), + new Promise((e, i) => { + s.call(this, t, (t, s, r) => { + t ? i(t) : e(s) + }) }) - }) } - get(t) { + get (t) { return this.send.call(this.env, t) } - post(t) { + post (t) { return this.send.call(this.env, t, "POST") } - put(t) { + put (t) { return this.send.call(this.env, t, "PUT") } } 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("", `\ud83d\udd14${this.name}, \u5f00\u59cb!`) - } - isNode() { + 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("", `\ud83d\udd14${this.name}, \u5f00\u59cb!`) + } + isNode () { return "undefined" != typeof module && !!module.exports } - isQuanX() { + isQuanX () { return "undefined" != typeof $task } - isSurge() { + isSurge () { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } - isLoon() { + isLoon () { return "undefined" != typeof $loon } - toObj(t, e = null) { + toObj (t, e = null) { try { return JSON.parse(t) } catch { return e } } - toStr(t, e = null) { + toStr (t, e = null) { try { return JSON.stringify(t) } catch { return e } } - getjson(t, e) { + getjson (t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) - } catch {} + } catch { } return s } - setjson(t, e) { + setjson (t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } - getScript(t) { + getScript (t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } - runScript(t, e) { + 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("@"), - a = { - url: `http://${h}/v1/scripting/evaluate`, - body: { - script_text: t, - mock_type: "cron", - timeout: r - }, - headers: { - "X-Key": o, - Accept: "*/*" - } - }; + r = e && e.timeout ? e.timeout : r; + const [o, h] = i.split("@"), + a = { + url: `http://${h}/v1/scripting/evaluate`, + body: { + script_text: t, + mock_type: "cron", + timeout: r + }, + headers: { + "X-Key": o, + Accept: "*/*" + } + }; this.post(a, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } - loaddata() { + loaddata () { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), - this.path = this.path ? this.path : require("path"); + 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); + 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; @@ -703,19 +805,19 @@ function Env(t, e) { } } } - writedata() { + writedata () { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), - this.path = this.path ? this.path : require("path"); + 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); + 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) { + lodash_get (t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) @@ -723,14 +825,14 @@ function Env(t, e) { return s; return r } - lodash_set(t, e, s) { + 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) { + getdata (t) { let e = this.getval(t); if (/^@/.test(t)) { - const[, s, i] = /^@(.*?)\.(.*?)$/.exec(t), - r = s ? this.getval(s) : ""; + const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), + r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); @@ -741,77 +843,77 @@ function Env(t, e) { } return e } - setdata(t, 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 || "{}" : "{}"; + 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) + s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), - s = this.setval(JSON.stringify(o), i) + s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } - getval(t) { + 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) { + 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) { + 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)) + 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 = (() => {})) { + get (t, e = (() => { })) { this.initGotEnv(t); + const { + url: s, + ...i + } = t; + this.instance = this.got.extend({ followRedirect: false }); + this.instance.get(s, i).then(t => { const { - url: s, - ...i + statusCode: s, + statusCode: i, + headers: r, + body: o } = t; - this.instance = this.got.extend({followRedirect: false}); - this.instance.get(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) - }) + 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 = (() => {})) { + 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) => { + "X-Surge-Skip-Scripting": !1 + })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), - e(t, s, i) + 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 => { + hints: !1 + })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, @@ -853,18 +955,18 @@ function Env(t, e) { }) } } - put(t, e = (() => {})) { + put (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.put(t, (t, s, i) => { + "X-Surge-Skip-Scripting": !1 + })), $httpClient.put(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), - e(t, s, i) + e(t, s, i) }); else if (this.isQuanX()) t.method = "PUT", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { - hints: !1 - })), $task.fetch(t).then(t => { + hints: !1 + })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, @@ -906,7 +1008,7 @@ function Env(t, e) { }) } } - time(t) { + time (t) { let e = { "M+": (new Date).getMonth() + 1, "d+": (new Date).getDate(), @@ -921,7 +1023,7 @@ function Env(t, e) { new RegExp("(" + s + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? e[s] : ("00" + e[s]).substr(("" + e[s]).length))); return t } - msg(e = t, s = "", i = "", r) { + msg (e = t, s = "", i = "", r) { const o = t => { if (!t) return t; @@ -929,14 +1031,14 @@ function Env(t, e) { return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } - : this.isSurge() ? { - url: t - } - : void 0; + : 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"]; + s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s @@ -944,7 +1046,7 @@ function Env(t, e) { } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, - s = t["media-url"] || t.mediaUrl; + s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s @@ -961,30 +1063,30 @@ function Env(t, e) { this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))); let h = ["", "==============\ud83d\udce3\u7cfb\u7edf\u901a\u77e5\ud83d\udce3=============="]; h.push(e), - s && h.push(s), - i && h.push(i), - console.log(h.join("\n")), - this.logs = this.logs.concat(h) + s && h.push(s), + i && h.push(i), + console.log(h.join("\n")), + this.logs = this.logs.concat(h) } - log(...t) { + log (...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), - console.log(t.join(this.logSeparator)) + console.log(t.join(this.logSeparator)) } - logErr(t, e) { + logErr (t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t.stack) : this.log("", `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t) } - wait(t) { + wait (t) { return new Promise(e => setTimeout(e, t)) } - done(t = {}) { + done (t = {}) { const e = (new Date).getTime(), - s = (e - this.startTime) / 1e3; + s = (e - this.startTime) / 1e3; this.log("", `\ud83d\udd14${this.name}, \u7ed3\u675f! \ud83d\udd5b ${s} \u79d2`), - this.log(), - (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) + this.log(), + (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } } - (t, e) + (t, e) }