diff --git a/rxsq.js b/rxsq.js deleted file mode 100644 index 5db25d1..0000000 --- a/rxsq.js +++ /dev/null @@ -1,564 +0,0 @@ -/* -热项社圈 -扫码注册:https://raw.githubusercontent.com/leafTheFish/DeathNote/main/rxsq.png - -自己捉包把s78.yyyyy.run里面的token值填到变量rxsqCookie里,多账号换行或者@隔开 -每天一次或两次,12点后跑一次收取收益(未测试) -*/ -const jsname = '热项社圈' -const $ = new Env(jsname); - -let envSplitor = ['\n','@'] -let httpResult, httpReq, httpResp - -let userCookie = ($.isNode() ? process.env.rxsqCookie : $.getdata('rxsqCookie')) || ''; -let userList = [] - -let userIdx = 0 -let userCount = 0 - -let SIGN_TIME = 10 -let LINGQU_TIME = 12 -let nowHour = (new Date()).getHours() -/////////////////////////////////////////////////////////////////// -class UserInfo { - constructor(str) { - this.index = ++userIdx - this.name = this.index - this.valid = false - - this.token = str - } - - async getUserName() { - try { - let url = `https://s78.yyyyy.run/api/user/index` - let body = `` - let urlObject = populateUrlObject(url,this.token,body) - await httpRequest('post',urlObject) - let result = httpResult; - if(!result) return - //console.log(result) - if(result.code==1) { - this.valid = true - this.name = result.data.nickname - console.log(`账号[${this.name}]等级${result.data.level},${result.data.levelName},余额${result.data.money}`) - } else { - console.log(`账号[${this.name}]查询账户失败: ${result.msg}`) - } - } catch(e) { - console.log(e) - } finally {} - } - - async userSignData() { - try { - let url = `https://s78.yyyyy.run/api/sign/userSignData` - let body = `` - let urlObject = populateUrlObject(url,this.token,body) - await httpRequest('post',urlObject) - let result = httpResult; - if(!result) return - //console.log(result) - if(result.code==1) { - this.count = result.data.today_count - console.log(`账号[${this.name}]今天已签到${this.count}次,今天签到积分${result.data.today_coin},总积分${result.data.coin}`) - } else { - console.log(`账号[${this.name}]查询签到次数失败: ${result.msg}`) - } - } catch(e) { - console.log(e) - } finally {} - } - - async get_user_signdata() { - try { - let url = `https://s78.yyyyy.run/api/sign/get_user_signdata` - let body = `` - let urlObject = populateUrlObject(url,this.token,body) - await httpRequest('post',urlObject) - } catch(e) { - console.log(e) - } finally {} - } - - async userSignIn() { - try { - let url = `https://s78.yyyyy.run/api/sign/userSignIn` - let body = `` - let urlObject = populateUrlObject(url,this.token,body) - await httpRequest('post',urlObject) - let result = httpResult; - if(!result) return - //console.log(result) - if(result.code==1) { - this.count++ - console.log(`账号[${this.name}]签到成功,已签到${this.count}次`) - } else { - console.log(`账号[${this.name}]签到失败: ${result.msg}`) - } - } catch(e) { - console.log(e) - } finally {} - } - - async lingqu() { - try { - let url = `https://s78.yyyyy.run/api/user/lingqu` - let body = `` - let urlObject = populateUrlObject(url,this.token,body) - await httpRequest('post',urlObject) - let result = httpResult; - if(!result) return - //console.log(result) - if(result.code==1) { - console.log(`账号[${this.name}]: ${result.msg}`) - } else { - console.log(`账号[${this.name}]领取收益失败: ${result.msg}`) - } - } catch(e) { - console.log(e) - } finally {} - } - - async userTask() { - await this.getUserName(); - if(!this.valid) return; - await this.userSignData(); - } -} - -!(async () => { - if (typeof $request !== "undefined") { - await GetRewrite() - }else { - if(!(await checkEnv())) return; - console.log('----------------------------') - - console.log('\n============ 查询状态 ============') - for(let user of userList) { - await user.userTask(); - } - - let validList = userList.filter(x => x.valid); - if(validList.length == 0) return; - - console.log('\n============ 开始签到 ============') - for(let i=0; i x.count < SIGN_TIME) - if(runList.length == 0) break; - if(i > 0) { - console.log('等待一分钟后进行下一次签到...') - await $.wait(61*1000); - } - for(let user of runList) { - await user.get_user_signdata(); - await user.userSignIn(); - } - } - - if(nowHour >= LINGQU_TIME) { - console.log('\n============ 领取收益 ============') - for(let user of validList) { - await user.lingqu(); - } - } - } -})() -.catch((e) => console.log(e)) -.finally(() => $.done()) - -/////////////////////////////////////////////////////////////////// -async function GetRewrite() { - if($request.url.indexOf(`job/listJob.json`) > -1) { - let ck = $request.url.split('sessionId=')[1] - - if(userCookie) { - if(userCookie.indexOf(ck) == -1) { - userCookie = userCookie + '@' + ck - $.setdata(userCookie, 'jjyCookie'); - ckList = userCookie.split('@') - $.msg(jsname+` 获取第${ckList.length}个ck成功: ${ck}`) - } - } else { - $.setdata(ck, 'jjyCookie'); - $.msg(jsname+` 获取第1个ck成功: ${ck}`) - } - } -} - -async function checkEnv() { - if(userCookie) { - let splitor = envSplitor[0]; - for(let sp of envSplitor) { - if(userCookie.indexOf(sp) > -1) { - splitor = sp; - break; - } - } - for(let userCookies of userCookie.split(splitor)) { - if(userCookies) userList.push(new UserInfo(userCookies)) - } - userCount = userList.length - } else { - console.log('未找到CK') - return; - } - - console.log(`共找到${userCount}个账号`) - return true -} - -//////////////////////////////////////////////////////////////////// -function populateUrlObject(url,token,body=''){ - let host = url.replace('//','/').split('/')[1] - let urlObject = { - url: url, - headers: { - 'Host': host, - 'Connection': 'keep-alive', - 'token': token, - 'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.20(0x18001431) NetType/WIFI Language/zh_CN' - }, - timeout: 5000, - } - if(body) { - urlObject.body = body - urlObject.headers['Content-Type'] = 'application/x-www-form-urlencoded' - urlObject.headers['Content-Length'] = urlObject.body ? urlObject.body.length : 0 - } - return urlObject; -} - -async function httpRequest(method,url) { - httpResult = null, httpReq = null, httpResp = null; - return new Promise((resolve) => { - $.send(method, url, async (err, req, resp) => { - try { - httpReq = req; - httpResp = resp; - if (err) { - console.log(`${method}请求失败`); - console.log(JSON.stringify(err)); - } else { - if(resp.body) { - if(typeof resp.body == "object") { - httpResult = resp.body; - } else { - try { - httpResult = JSON.parse(resp.body); - } catch (e) { - httpResult = resp.body; - } - } - } - } - } catch (e) { - console.log(e); - } finally { - resolve(); - } - }); - }); -} - -//////////////////////////////////////////////////////////////////// -//AES/DES加解密,CryptoJS -function EncryptCrypto(method,mode,padding,message,key,iv) { - return CryptoJS[method].encrypt( - CryptoJS.enc.Utf8.parse(message), - CryptoJS.enc.Utf8.parse(key), - {mode:CryptoJS.mode[mode], padding:CryptoJS.pad[padding], iv:CryptoJS.enc.Utf8.parse(iv)} - ).ciphertext.toString(CryptoJS.enc.Base64); -} -function DecryptCrypto(method,mode,padding,message,key,iv) { - return CryptoJS[method].decrypt( - {ciphertext: CryptoJS.enc.Base64.parse(message)}, - CryptoJS.enc.Utf8.parse(key), - {mode:CryptoJS.mode[mode], padding:CryptoJS.pad[padding], iv:CryptoJS.enc.Utf8.parse(iv)} - ).toString(CryptoJS.enc.Utf8); -} -//Base64加解密 -var Base64={_keyStr:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",encode:function(e){var t="";var n,r,i,s,o,u,a;var f=0;e=Base64._utf8_encode(e);while(f>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}} -//MD5 -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=0;j--)str+=sHEXChars.charAt((num>>(j*4))&0x0F);return str;}function AlignSHA1(sIn){var nblk=((sIn.length+8)>>6)+1,blks=new Array(nblk*16);for(var i=0;i>2]|=sIn.charCodeAt(i)<<(24-(i&3)*8);blks[i>>2]|=0x80<<(24-(i&3)*8);blks[nblk*16-1]=sIn.length*8;return blks;}function rol(num,cnt){return(num<>>(32-cnt));}function ft(t,b,c,d){if(t<20)return(b&c)|((~b)&d);if(t<40)return b^c^d;if(t<60)return(b&c)|(b&d)|(c&d);return b^c^d;}function kt(t){return(t<20)?1518500249:(t<40)?1859775393:(t<60)?-1894007588:-899497514;}var x=AlignSHA1(msg);var w=new Array(80);var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;var e=-1009589776;for(var i=0;i -1 && process.exit(0); - return new class { - constructor(name,env) { - this.name = name - this.notifyStr = '' - this.startTime = (new Date).getTime() - Object.assign(this,env) - console.log(`${this.name} 开始运行:\n`) - } - 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 - } - 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) - } - } - elses = 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 - } - send(m, t, e = (() => {})) { - if(m != 'get' && m != 'post' && m != 'put' && m != 'delete') { - console.log(`无效的http方法:${m}`); - return; - } - if(m == 'get' && t.headers) { - delete t.headers["Content-Type"]; - delete t.headers["Content-Length"]; - } else if(t.body && t.headers) { - if(!t.headers["Content-Type"]) t.headers["Content-Type"] = "application/x-www-form-urlencoded"; - } - if(this.isSurge() || this.isLoon()) { - if(this.isSurge() && this.isNeedRewrite) { - t.headers = t.headers || {}; - Object.assign(t.headers, {"X-Surge-Skip-Scripting": !1}); - } - let conf = { - method: m, - url: t.url, - headers: t.headers, - timeout: t.timeout, - data: t.body - }; - if(m == 'get') delete conf.data - $axios(conf).then(t => { - const { - status: i, - request: q, - headers: r, - data: o - } = t; - e(null, q, { - statusCode: i, - headers: r, - body: o - }); - }).catch(err => console.log(err)) - } else if (this.isQuanX()) { - t.method = m.toUpperCase(), this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { - hints: !1 - })), - $task.fetch(t).then(t => { - const { - statusCode: i, - request: q, - headers: r, - body: o - } = t; - e(null, q, { - statusCode: i, - headers: r, - body: o - }) - }, t => e(t)) - } else if (this.isNode()) { - this.got = this.got ? this.got : require("got"); - const { - url: s, - ...i - } = t; - this.instance = this.got.extend({ - followRedirect: false - }); - this.instance[m](s, i).then(t => { - const { - statusCode: i, - request: q, - headers: r, - body: o - } = t; - e(null, q, { - statusCode: i, - headers: r, - body: o - }) - }, t => { - const { - message: s, - response: i - } = t; - e(s, i, i && i.body) - }) - } - } - time(t) { - let e = { - "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 s in 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 - } - async showmsg() { - if(!this.notifyStr) return; - let notifyBody = this.name + " 运行通知\n\n" + this.notifyStr - if($.isNode()){ - var notify = require('./sendNotify'); - console.log('\n============== 推送 ==============') - await notify.sendNotify(this.name, notifyBody); - } else { - this.msg(notifyBody); - } - } - logAndNotify(str) { - console.log(str) - this.notifyStr += str - this.notifyStr += '\n' - } - 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 - } - } - } - }; - this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))); - let h = ["", "============== 系统通知 =============="]; - h.push(e), - s && h.push(s), - i && h.push(i), - console.log(h.join("\n")) - } - getMin(a,b){ - return ((anumStr.length) ? (length-numStr.length) : 0 - let retStr = '' - for(let i=0; i setTimeout(e, t)) - } - done(t = {}) { - const e = (new Date).getTime(), - s = (e - this.startTime) / 1e3; - console.log(`\n${this.name} 运行结束,共运行了 ${s} 秒!`) - if(this.isSurge() || this.isQuanX() || this.isLoon()) $done(t) - } - }(name,env) -} diff --git a/rxsq.png b/rxsq.png deleted file mode 100644 index 265169e..0000000 Binary files a/rxsq.png and /dev/null differ