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(/积分:(.*?)</)[1])
-                this.money = Math.floor(this.gold)/100
+                this.money = Math.floor(this.gold) / 100
                 console.log(`账户余额:${this.gold} ≈ ${this.money}元`)
-                if(this.gold >= 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 class="userinfo-name">(.*)<\/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 ((a<b) ? a : b)
+function getMin (a, b) {
+    return ((a < b) ? a : b)
 }
 
-function getMax(a,b){
-    return ((a<b) ? b : a)
+function getMax (a, b) {
+    return ((a < b) ? b : a)
 }
 
-function padStr(num,length,padding='0') {
+function padStr (num, length, padding = '0') {
     let numStr = String(num)
-    let numPad = (length>numStr.length) ? (length-numStr.length) : 0
+    let numPad = (length > numStr.length) ? (length - numStr.length) : 0
     let retStr = ''
-    for(let i=0; i<numPad; i++) {
+    for (let i = 0; i < numPad; i++) {
         retStr += padding
     }
     retStr += numStr
     return retStr;
 }
 
-function randomString(len=32) {
+function randomString (len = 32) {
     let chars = 'abcdef0123456789';
     let maxLen = chars.length;
     let str = '';
     for (i = 0; i < len; i++) {
-        str += chars.charAt(Math.floor(Math.random()*maxLen));
+        str += chars.charAt(Math.floor(Math.random() * maxLen));
     }
     return str;
 }
 
-function req2json(str) {
+function req2json (str) {
     let ret = {}
-    for(let items of str.split('&')) {
+    for (let items of str.split('&')) {
         let kv = items.split('=')
         ret[kv[0]] = kv[1]
     }
     return ret
 }
 
-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<e.length){n=e.charCodeAt(f++);r=e.charCodeAt(f++);i=e.charCodeAt(f++);s=n>>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}}
-
-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()}
-
-function Env(t, e) {
+// prettier-ignore
+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 < e.length) { n = e.charCodeAt(f++); r = e.charCodeAt(f++); i = e.charCodeAt(f++); s = n >> 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)
 }