2022-02-11 16:56:14 +08:00
/ *
* @ Author : X1a0He
* @ Contact : https : //t.me/X1a0He
2022-02-11 20:42:38 +08:00
* @ Github : https : //github.com/X1a0He/jd_scripts_fixed
* 清空购物车 , 支持环境变量设置关键字 , 用 @ 分隔 , 使用前请认真看对应注释
* 由于不是用app来进行购物车删除 , 所以可能会出现部分购物车数据无法删除的问题 , 例如预购商品 , 属于正常
2022-02-11 16:56:14 +08:00
* /
const $ = new Env ( '清空购物车' ) ;
//Node.js用户请在jdCookie.js处填写京东ck;
const jdCookieNode = $ . isNode ( ) ? require ( './jdCookie.js' ) : '' ;
const notify = $ . isNode ( ) ? require ( './sendNotify' ) : '' ;
2022-02-11 20:42:38 +08:00
let cookiesArr = [ ] , cookie = '' , postBody = '' , venderCart , error = false ;
let args _xh = {
/ *
* 跳过某个指定账号 , 默认为全部账号清空
* 填写规则 : 例如当前Cookie1为pt _key = key ; pt _pin = pin1 ; 则环境变量填写pin1即可 , 此时pin1的购物车将不会被清空
* 若有更多 , 则按照pin1 @ pin2 @ pin3进行填写
* 环境变量名称 : XH _CLEAN _EXCEPT
* /
except : process . env . XH _CLEAN _EXCEPT && process . env . XH _CLEAN _EXCEPT . split ( '@' ) || [ ] ,
/ *
* 控制脚本是否执行 , 设置为true时才会执行删除购物车
* 环境变量名称 : JD _CART
* /
clean : process . env . JD _CART === 'true' || true ,
/ *
* 控制脚本运行一次取消多少条购物车数据 , 为0则不删除 , 默认为100
* 环境变量名称 : XH _CLEAN _REMOVESIZE
* /
removeSize : process . env . XH _CLEAN _REMOVESIZE * 1 || 100 ,
/ *
* 关键字 / 关键词设置 , 当购物车商品标题包含关键字 / 关键词时 , 跳过该条数据 , 多个则用 @ 分隔 , 例如 旺仔牛奶 @ 红外线 @ 紫光
* 环境变量名称 : XH _CLEAN _KEYWORDS
* /
keywords : process . env . XH _CLEAN _KEYWORDS && process . env . XH _CLEAN _KEYWORDS . split ( '@' ) || [ ] ,
}
console . log ( '使用前请确保你认真看了注释,看完注释有问题就带着你的问题来找我' )
console . log ( 'tg: https://t.me/X1a0He' )
console . log ( '=====环境变量配置如下=====' )
console . log ( ` except: ${ typeof args _xh . except } , ${ args _xh . except } ` )
console . log ( ` clean: ${ typeof args _xh . clean } , ${ args _xh . clean } ` )
console . log ( ` removeSize: ${ typeof args _xh . removeSize } , ${ args _xh . removeSize } ` )
console . log ( ` keywords: ${ typeof args _xh . keywords } , ${ args _xh . keywords } ` )
console . log ( '=======================' )
console . log ( )
if ( $ . isNode ( ) ) {
2022-02-11 16:56:14 +08:00
Object . keys ( jdCookieNode ) . forEach ( ( item ) => {
cookiesArr . push ( jdCookieNode [ item ] )
} )
2022-02-11 20:42:38 +08:00
if ( process . env . JD _DEBUG && process . env . JD _DEBUG === 'false' ) console . log = ( ) => { } ;
} else cookiesArr = [ $ . getdata ( 'CookieJD' ) , $ . getdata ( 'CookieJD2' ) , ... jsonParse ( $ . getdata ( 'CookiesJD' ) || "[]" ) . map ( item => item . cookie ) ] . filter ( item => ! ! item ) ;
! ( async ( ) => {
if ( args _xh . clean ) {
if ( ! cookiesArr [ 0 ] ) {
2022-02-11 16:56:14 +08:00
$ . msg ( '【京东账号一】移除购物车失败' , '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取' , 'https://bean.m.jd.com/bean/signIndex.action' , {
"open-url" : "https://bean.m.jd.com/bean/signIndex.action"
} ) ;
}
2022-02-11 20:42:38 +08:00
for ( let i = 0 ; i < cookiesArr . length ; i ++ ) {
if ( cookiesArr [ i ] ) {
2022-02-11 16:56:14 +08:00
cookie = cookiesArr [ i ] ;
$ . UserName = decodeURIComponent ( cookie . match ( /pt_pin=([^; ]+)(?=;?)/ ) && cookie . match ( /pt_pin=([^; ]+)(?=;?)/ ) [ 1 ] )
$ . index = i + 1 ;
$ . isLogin = true ;
$ . nickName = '' ;
2022-02-11 20:42:38 +08:00
$ . error = false ;
2022-02-11 16:56:14 +08:00
await TotalBean ( ) ;
2022-02-11 20:42:38 +08:00
console . log ( ` ****开始【京东账号 ${ $ . index } 】 ${ $ . nickName || $ . UserName } **** ` ) ;
if ( args _xh . except . includes ( $ . UserName ) ) {
console . log ( ` 跳过账号: ${ $ . nickName || $ . UserName } ` )
continue
}
if ( ! $ . isLogin ) {
2022-02-11 16:56:14 +08:00
$ . msg ( $ . name , ` 【提示】cookie已失效 ` , ` 京东账号 ${ $ . index } ${ $ . nickName || $ . UserName } \n 请重新登录获取 \n https://bean.m.jd.com/bean/signIndex.action ` , {
"open-url" : "https://bean.m.jd.com/bean/signIndex.action"
} ) ;
2022-02-11 20:42:38 +08:00
if ( $ . isNode ( ) ) {
2022-02-11 16:56:14 +08:00
await notify . sendNotify ( ` ${ $ . name } cookie已失效 - ${ $ . UserName } ` , ` 京东账号 ${ $ . index } ${ $ . UserName } \n 请重新登录获取cookie ` ) ;
}
continue
}
2022-02-11 20:42:38 +08:00
if ( args _xh . removeSize === 0 ) continue ;
2022-02-11 16:56:14 +08:00
do {
await getCart _xh ( ) ;
$ . keywordsNum = 0
2022-02-11 20:42:38 +08:00
if ( $ . beforeRemove !== "0" ) {
2022-02-11 16:56:14 +08:00
await cartFilter _xh ( venderCart ) ;
2022-02-11 20:42:38 +08:00
if ( parseInt ( $ . beforeRemove ) !== $ . keywordsNum ) await removeCart ( ) ;
2022-02-11 16:56:14 +08:00
else {
2022-02-11 20:42:38 +08:00
console . log ( '\n由于购物车内的商品均包含关键字, 本次执行将不删除购物车数据' )
2022-02-11 16:56:14 +08:00
break ;
}
} else break ;
2022-02-11 20:42:38 +08:00
} while ( ! $ . error && $ . keywordsNum !== parseInt ( $ . beforeRemove ) )
2022-02-11 16:56:14 +08:00
}
}
} else {
console . log ( "你设置了不删除购物车数据,要删除请设置环境变量 JD_CART 为 true" )
}
} ) ( ) . catch ( ( e ) => {
$ . log ( '' , ` ❌ ${ $ . name } , 失败! 原因: ${ e } ! ` , '' )
} ) . finally ( ( ) => {
$ . done ( ) ;
} )
2022-02-11 20:42:38 +08:00
function getCart _xh ( ) {
2022-02-11 16:56:14 +08:00
console . log ( '正在获取购物车数据...' )
return new Promise ( ( resolve ) => {
const option = {
url : 'https://p.m.jd.com/cart/cart.action?fromnav=1&sceneval=2' ,
headers : {
"Cookie" : cookie ,
"User-Agent" : "jdapp;JD4iPhone/167724 (iPhone; iOS 15.0; Scale/3.00)" ,
} ,
}
2022-02-11 20:42:38 +08:00
$ . get ( option , async ( err , resp , data ) => {
try {
let content = getSubstr ( data , "window.cartData = " , "window._PFM_TIMING" ) . replace ( /\s*/g , "" ) ;
2022-02-11 16:56:14 +08:00
data = JSON . parse ( content ) ;
$ . areaId = data . areaId ; // locationId的传值
$ . traceId = data . traceId ; // traceid的传值
venderCart = data . cart . venderCart ;
postBody = 'pingouchannel=0&commlist=' ;
$ . beforeRemove = data . cartJson . num
console . log ( ` 获取到购物车数据 ${ $ . beforeRemove } 条 ` )
2022-02-11 20:42:38 +08:00
} catch ( e ) {
2022-02-11 16:56:14 +08:00
$ . logErr ( e , resp ) ;
2022-02-11 20:42:38 +08:00
} finally {
2022-02-11 16:56:14 +08:00
resolve ( data ) ;
}
} ) ;
} )
}
2022-02-11 20:42:38 +08:00
function cartFilter _xh ( cartData ) {
2022-02-11 16:56:14 +08:00
console . log ( "正在整理数据..." )
let pid ;
$ . pushed = 0
2022-02-11 20:42:38 +08:00
for ( let cartJson of cartData ) {
if ( $ . pushed === args _xh . removeSize ) break ;
for ( let sortedItem of cartJson . sortedItems ) {
if ( $ . pushed === args _xh . removeSize ) break ;
2022-02-11 16:56:14 +08:00
pid = typeof ( sortedItem . polyItem . promotion ) !== "undefined" ? sortedItem . polyItem . promotion . pid : ""
2022-02-11 20:42:38 +08:00
for ( let product of sortedItem . polyItem . products ) {
if ( $ . pushed === args _xh . removeSize ) break ;
2022-02-11 16:56:14 +08:00
let mainSkuName = product . mainSku . name
$ . isKeyword = false
$ . isPush = true
2022-02-11 20:42:38 +08:00
for ( let keyword of args _xh . keywords ) {
if ( mainSkuName . indexOf ( keyword ) !== - 1 ) {
2022-02-11 16:56:14 +08:00
$ . keywordsNum += 1
$ . isPush = false
$ . keyword = keyword ;
break ;
} else $ . isPush = true
}
2022-02-11 20:42:38 +08:00
if ( $ . isPush ) {
2022-02-11 16:56:14 +08:00
let skuUuid = product . skuUuid ;
let mainSkuId = product . mainSku . id
2022-02-11 20:42:38 +08:00
if ( pid === "" ) postBody += ` ${ mainSkuId } ,,1, ${ mainSkuId } ,1,,0,skuUuid: ${ skuUuid } @@useUuid:0 $ `
2022-02-11 16:56:14 +08:00
else postBody += ` ${ mainSkuId } ,,1, ${ mainSkuId } ,11, ${ pid } ,0,skuUuid: ${ skuUuid } @@useUuid:0 $ `
$ . pushed += 1 ;
} else {
console . log ( ` \n ${ mainSkuName } ` )
console . log ( ` 商品已被过滤,原因:包含关键字 ${ $ . keyword } ` )
$ . isKeyword = true
}
}
}
}
postBody += ` &type=0&checked=0&locationid= ${ $ . areaId } &templete=1®=1&scene=0&version=20190418&traceid= ${ $ . traceId } &tabMenuType=1&sceneval=2 `
}
2022-02-11 20:42:38 +08:00
function removeCart ( ) {
2022-02-11 16:56:14 +08:00
console . log ( '正在删除购物车数据...' )
return new Promise ( ( resolve ) => {
const option = {
url : 'https://wq.jd.com/deal/mshopcart/rmvCmdy?sceneval=2&g_login_type=1&g_ty=ajax' ,
body : postBody ,
headers : {
"Cookie" : cookie ,
"User-Agent" : "jdapp;JD4iPhone/167724 (iPhone; iOS 15.0; Scale/3.00)" ,
"referer" : "https://p.m.jd.com/" ,
"origin" : "https://p.m.jd.com/"
} ,
}
2022-02-11 20:42:38 +08:00
$ . post ( option , async ( err , resp , data ) => {
try {
2022-02-11 16:56:14 +08:00
data = JSON . parse ( data ) ;
$ . afterRemove = data . cartJson . num
2022-02-11 20:42:38 +08:00
if ( $ . afterRemove < $ . beforeRemove ) {
2022-02-11 16:56:14 +08:00
console . log ( ` 删除成功,当前购物车剩余数据 ${ $ . afterRemove } 条 \n ` )
$ . beforeRemove = $ . afterRemove
} else {
console . log ( '删除失败' )
console . log ( data . errMsg )
2022-02-11 20:42:38 +08:00
$ . error = true ;
2022-02-11 16:56:14 +08:00
}
2022-02-11 20:42:38 +08:00
} catch ( e ) {
2022-02-11 16:56:14 +08:00
$ . logErr ( e , resp ) ;
2022-02-11 20:42:38 +08:00
} finally {
2022-02-11 16:56:14 +08:00
resolve ( data ) ;
}
} ) ;
} )
}
2022-02-11 20:42:38 +08:00
function getSubstr ( str , leftStr , rightStr ) {
2022-02-11 16:56:14 +08:00
let left = str . indexOf ( leftStr ) ;
let right = str . indexOf ( rightStr , left ) ;
2022-02-11 20:42:38 +08:00
if ( left < 0 || right < left ) return '' ;
2022-02-11 16:56:14 +08:00
return str . substring ( left + leftStr . length , right ) ;
}
2022-02-11 20:42:38 +08:00
function TotalBean ( ) {
2022-02-11 16:56:14 +08:00
return new Promise ( async resolve => {
const options = {
"url" : ` https://wq.jd.com/user/info/QueryJDUserInfo?sceneval=2 ` ,
"headers" : {
"Accept" : "application/json,text/plain, */*" ,
"Content-Type" : "application/x-www-form-urlencoded" ,
"Accept-Encoding" : "gzip, deflate, br" ,
"Accept-Language" : "zh-cn" ,
"Connection" : "keep-alive" ,
"Cookie" : cookie ,
"Referer" : "https://wqs.jd.com/my/jingdou/my.shtml?sceneval=2" ,
"User-Agent" : $ . isNode ( ) ? ( process . env . JD _USER _AGENT ? process . env . JD _USER _AGENT : ( require ( './USER_AGENTS' ) . USER _AGENT ) ) : ( $ . getdata ( 'JDUA' ) ? $ . getdata ( 'JDUA' ) : "jdapp;iPhone;9.4.4;14.3;network/4g;Mozilla/5.0 (iPhone; CPU iPhone OS 14_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1" )
}
}
$ . post ( options , ( err , resp , data ) => {
2022-02-11 20:42:38 +08:00
try {
if ( err ) {
2022-02-11 16:56:14 +08:00
console . log ( ` ${ JSON . stringify ( err ) } ` )
console . log ( ` ${ $ . name } API请求失败, 请检查网路重试 ` )
} else {
2022-02-11 20:42:38 +08:00
if ( data ) {
2022-02-11 16:56:14 +08:00
data = JSON . parse ( data ) ;
2022-02-11 20:42:38 +08:00
if ( data [ 'retcode' ] === 13 ) {
2022-02-11 16:56:14 +08:00
$ . isLogin = false ; //cookie过期
return
}
2022-02-11 20:42:38 +08:00
if ( data [ 'retcode' ] === 0 ) {
2022-02-11 16:56:14 +08:00
$ . nickName = ( data [ 'base' ] && data [ 'base' ] . nickname ) || $ . UserName ;
} else {
$ . nickName = $ . UserName
}
} else {
console . log ( ` 京东服务器返回空数据 ` )
}
}
2022-02-11 20:42:38 +08:00
} catch ( e ) {
2022-02-11 16:56:14 +08:00
$ . logErr ( e , resp )
2022-02-11 20:42:38 +08:00
} finally {
2022-02-11 16:56:14 +08:00
resolve ( ) ;
}
} )
} )
}
2022-02-11 20:42:38 +08:00
function jsonParse ( str ) {
if ( typeof str == "string" ) {
try {
2022-02-11 16:56:14 +08:00
return JSON . parse ( str ) ;
2022-02-11 20:42:38 +08:00
} catch ( e ) {
2022-02-11 16:56:14 +08:00
console . log ( e ) ;
$ . msg ( $ . name , '' , '请勿随意在BoxJs输入框修改内容\n建议通过脚本去获取cookie' )
return [ ] ;
}
}
}
// prettier-ignore
2022-02-11 20:42:38 +08:00
function Env ( t , e ) {
2022-02-11 16:56:14 +08:00
"undefined" != typeof process && JSON . stringify ( process . env ) . indexOf ( "GITHUB" ) > - 1 && process . exit ( 0 ) ;
2022-02-11 20:42:38 +08:00
class s {
constructor ( t ) {
2022-02-11 16:56:14 +08:00
this . env = t
}
2022-02-11 20:42:38 +08:00
send ( t , e = "GET" ) {
2022-02-11 16:56:14 +08:00
t = "string" == typeof t ? {
url : t
} : t ;
let s = this . get ;
return "POST" === e && ( s = this . post ) , new Promise ( ( e , i ) => {
s . call ( this , t , ( t , s , r ) => {
t ? i ( t ) : e ( s )
} )
} )
}
2022-02-11 20:42:38 +08:00
get ( t ) {
2022-02-11 16:56:14 +08:00
return this . send . call ( this . env , t )
}
2022-02-11 20:42:38 +08:00
post ( t ) {
2022-02-11 16:56:14 +08:00
return this . send . call ( this . env , t , "POST" )
}
}
2022-02-11 20:42:38 +08:00
return new class {
constructor ( t , e ) {
2022-02-11 16:56:14 +08:00
this . name = t , this . http = new s ( this ) , this . data = null , this . dataFile = "box.dat" , this . logs = [ ] , this . isMute = ! 1 , this . isNeedRewrite = ! 1 , this . logSeparator = "\n" , this . startTime = ( new Date ) . getTime ( ) , Object . assign ( this , e ) , this . log ( "" , ` 🔔 ${ this . name } , 开始! ` )
}
2022-02-11 20:42:38 +08:00
isNode ( ) {
2022-02-11 16:56:14 +08:00
return "undefined" != typeof module && ! ! module . exports
}
2022-02-11 20:42:38 +08:00
isQuanX ( ) {
2022-02-11 16:56:14 +08:00
return "undefined" != typeof $task
}
2022-02-11 20:42:38 +08:00
isSurge ( ) {
2022-02-11 16:56:14 +08:00
return "undefined" != typeof $httpClient && "undefined" == typeof $loon
}
2022-02-11 20:42:38 +08:00
isLoon ( ) {
2022-02-11 16:56:14 +08:00
return "undefined" != typeof $loon
}
2022-02-11 20:42:38 +08:00
toObj ( t , e = null ) {
try {
2022-02-11 16:56:14 +08:00
return JSON . parse ( t )
2022-02-11 20:42:38 +08:00
} catch {
2022-02-11 16:56:14 +08:00
return e
}
}
2022-02-11 20:42:38 +08:00
toStr ( t , e = null ) {
try {
2022-02-11 16:56:14 +08:00
return JSON . stringify ( t )
2022-02-11 20:42:38 +08:00
} catch {
2022-02-11 16:56:14 +08:00
return e
}
}
2022-02-11 20:42:38 +08:00
getjson ( t , e ) {
2022-02-11 16:56:14 +08:00
let s = e ;
const i = this . getdata ( t ) ;
2022-02-11 20:42:38 +08:00
if ( i ) try {
2022-02-11 16:56:14 +08:00
s = JSON . parse ( this . getdata ( t ) )
2022-02-11 20:42:38 +08:00
} catch { }
2022-02-11 16:56:14 +08:00
return s
}
2022-02-11 20:42:38 +08:00
setjson ( t , e ) {
try {
2022-02-11 16:56:14 +08:00
return this . setdata ( JSON . stringify ( t ) , e )
2022-02-11 20:42:38 +08:00
} catch {
2022-02-11 16:56:14 +08:00
return ! 1
}
}
2022-02-11 20:42:38 +08:00
getScript ( t ) {
2022-02-11 16:56:14 +08:00
return new Promise ( e => {
this . get ( {
url : t
} , ( t , s , i ) => e ( i ) )
} )
}
2022-02-11 20:42:38 +08:00
runScript ( t , e ) {
2022-02-11 16:56:14 +08:00
return new Promise ( s => {
let i = this . getdata ( "@chavy_boxjs_userCfgs.httpapi" ) ;
i = i ? i . replace ( /\n/g , "" ) . trim ( ) : i ;
let r = this . getdata ( "@chavy_boxjs_userCfgs.httpapi_timeout" ) ;
r = r ? 1 * r : 20 , r = e && e . timeout ? e . timeout : r ;
const [ o , h ] = i . split ( "@" ) , n = {
url : ` http:// ${ h } /v1/scripting/evaluate ` ,
body : {
script _text : t ,
mock _type : "cron" ,
timeout : r
} ,
headers : {
"X-Key" : o ,
Accept : "*/*"
}
} ;
this . post ( n , ( t , e , i ) => s ( i ) )
} ) . catch ( t => this . logErr ( t ) )
}
2022-02-11 20:42:38 +08:00
loaddata ( ) {
if ( ! this . isNode ( ) ) return { } ;
2022-02-11 16:56:14 +08:00
{
this . fs = this . fs ? this . fs : require ( "fs" ) , this . path = this . path ? this . path : require ( "path" ) ;
const t = this . path . resolve ( this . dataFile ) ,
e = this . path . resolve ( process . cwd ( ) , this . dataFile ) ,
s = this . fs . existsSync ( t ) ,
i = ! s && this . fs . existsSync ( e ) ;
2022-02-11 20:42:38 +08:00
if ( ! s && ! i ) return { } ;
2022-02-11 16:56:14 +08:00
{
const i = s ? t : e ;
2022-02-11 20:42:38 +08:00
try {
2022-02-11 16:56:14 +08:00
return JSON . parse ( this . fs . readFileSync ( i ) )
2022-02-11 20:42:38 +08:00
} catch ( t ) {
2022-02-11 16:56:14 +08:00
return { }
}
}
}
}
2022-02-11 20:42:38 +08:00
writedata ( ) {
if ( this . isNode ( ) ) {
2022-02-11 16:56:14 +08:00
this . fs = this . fs ? this . fs : require ( "fs" ) , this . path = this . path ? this . path : require ( "path" ) ;
const t = this . path . resolve ( this . dataFile ) ,
e = this . path . resolve ( process . cwd ( ) , this . dataFile ) ,
s = this . fs . existsSync ( t ) ,
i = ! s && this . fs . existsSync ( e ) ,
r = JSON . stringify ( this . data ) ;
s ? this . fs . writeFileSync ( t , r ) : i ? this . fs . writeFileSync ( e , r ) : this . fs . writeFileSync ( t , r )
}
}
2022-02-11 20:42:38 +08:00
lodash _get ( t , e , s ) {
2022-02-11 16:56:14 +08:00
const i = e . replace ( /\[(\d+)\]/g , ".$1" ) . split ( "." ) ;
let r = t ;
2022-02-11 20:42:38 +08:00
for ( const t of i )
if ( r = Object ( r ) [ t ] , void 0 === r ) return s ;
2022-02-11 16:56:14 +08:00
return r
}
2022-02-11 20:42:38 +08:00
lodash _set ( t , e , s ) {
2022-02-11 16:56:14 +08:00
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 )
}
2022-02-11 20:42:38 +08:00
getdata ( t ) {
2022-02-11 16:56:14 +08:00
let e = this . getval ( t ) ;
2022-02-11 20:42:38 +08:00
if ( /^@/ . test ( t ) ) {
2022-02-11 16:56:14 +08:00
const [ , s , i ] = /^@(.*?)\.(.*?)$/ . exec ( t ) , r = s ? this . getval ( s ) : "" ;
2022-02-11 20:42:38 +08:00
if ( r ) try {
2022-02-11 16:56:14 +08:00
const t = JSON . parse ( r ) ;
e = t ? this . lodash _get ( t , i , "" ) : e
2022-02-11 20:42:38 +08:00
} catch ( t ) {
2022-02-11 16:56:14 +08:00
e = ""
}
}
return e
}
2022-02-11 20:42:38 +08:00
setdata ( t , e ) {
2022-02-11 16:56:14 +08:00
let s = ! 1 ;
2022-02-11 20:42:38 +08:00
if ( /^@/ . test ( e ) ) {
2022-02-11 16:56:14 +08:00
const [ , i , r ] = /^@(.*?)\.(.*?)$/ . exec ( e ) , o = this . getval ( i ) ,
h = i ? "null" === o ? null : o || "{}" : "{}" ;
2022-02-11 20:42:38 +08:00
try {
2022-02-11 16:56:14 +08:00
const e = JSON . parse ( h ) ;
this . lodash _set ( e , r , t ) , s = this . setval ( JSON . stringify ( e ) , i )
2022-02-11 20:42:38 +08:00
} catch ( e ) {
2022-02-11 16:56:14 +08:00
const o = { } ;
this . lodash _set ( o , r , t ) , s = this . setval ( JSON . stringify ( o ) , i )
}
} else s = this . setval ( t , e ) ;
return s
}
2022-02-11 20:42:38 +08:00
getval ( t ) {
2022-02-11 16:56:14 +08:00
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
}
2022-02-11 20:42:38 +08:00
setval ( t , e ) {
2022-02-11 16:56:14 +08:00
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
}
2022-02-11 20:42:38 +08:00
initGotEnv ( t ) {
2022-02-11 16:56:14 +08:00
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 ) )
}
2022-02-11 20:42:38 +08:00
get ( t , e = ( ( ) => { } ) ) {
2022-02-11 16:56:14 +08:00
t . headers && ( delete t . headers [ "Content-Type" ] , delete t . headers [ "Content-Length" ] ) , this . isSurge ( ) || this . isLoon ( ) ? ( this . isSurge ( ) && this . isNeedRewrite && ( t . headers = t . headers || { } , Object . assign ( t . headers , {
"X-Surge-Skip-Scripting" : ! 1
} ) ) , $httpClient . get ( t , ( t , s , i ) => {
! t && s && ( s . body = i , s . statusCode = s . status ) , e ( t , s , i )
} ) ) : this . isQuanX ( ) ? ( this . isNeedRewrite && ( t . opts = t . opts || { } , Object . assign ( t . opts , {
hints : ! 1
} ) ) , $task . fetch ( t ) . then ( t => {
const {
statusCode : s ,
statusCode : i ,
headers : r ,
body : o
} = t ;
e ( null , {
status : s ,
statusCode : i ,
headers : r ,
body : o
} , o )
} , t => e ( t ) ) ) : this . isNode ( ) && ( this . initGotEnv ( t ) , this . got ( t ) . on ( "redirect" , ( t , e ) => {
2022-02-11 20:42:38 +08:00
try {
if ( t . headers [ "set-cookie" ] ) {
2022-02-11 16:56:14 +08:00
const s = t . headers [ "set-cookie" ] . map ( this . cktough . Cookie . parse ) . toString ( ) ;
s && this . ckjar . setCookieSync ( s , null ) , e . cookieJar = this . ckjar
}
2022-02-11 20:42:38 +08:00
} catch ( t ) {
2022-02-11 16:56:14 +08:00
this . logErr ( t )
}
} ) . then ( t => {
const {
statusCode : s ,
statusCode : i ,
headers : r ,
body : o
} = t ;
e ( null , {
status : s ,
statusCode : i ,
headers : r ,
body : o
} , o )
} , t => {
const {
message : s ,
response : i
} = t ;
e ( s , i , i && i . body )
} ) )
}
2022-02-11 20:42:38 +08:00
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 , {
2022-02-11 16:56:14 +08:00
"X-Surge-Skip-Scripting" : ! 1
} ) ) , $httpClient . post ( t , ( t , s , i ) => {
! t && s && ( s . body = i , s . statusCode = s . status ) , e ( t , s , i )
} ) ;
2022-02-11 20:42:38 +08:00
else if ( this . isQuanX ( ) ) t . method = "POST" , this . isNeedRewrite && ( t . opts = t . opts || { } , Object . assign ( t . opts , {
2022-02-11 16:56:14 +08:00
hints : ! 1
} ) ) , $task . fetch ( t ) . then ( t => {
const {
statusCode : s ,
statusCode : i ,
headers : r ,
body : o
} = t ;
e ( null , {
status : s ,
statusCode : i ,
headers : r ,
body : o
} , o )
} , t => e ( t ) ) ;
2022-02-11 20:42:38 +08:00
else if ( this . isNode ( ) ) {
2022-02-11 16:56:14 +08:00
this . initGotEnv ( t ) ;
const {
url : s ,
... i
} = t ;
this . got . post ( s , i ) . then ( t => {
const {
statusCode : s ,
statusCode : i ,
headers : r ,
body : o
} = t ;
e ( null , {
status : s ,
statusCode : i ,
headers : r ,
body : o
} , o )
} , t => {
const {
message : s ,
response : i
} = t ;
e ( s , i , i && i . body )
} )
}
}
2022-02-11 20:42:38 +08:00
time ( t , e = null ) {
2022-02-11 16:56:14 +08:00
const s = e ? new Date ( e ) : new Date ;
let i = {
"M+" : s . getMonth ( ) + 1 ,
"d+" : s . getDate ( ) ,
"H+" : s . getHours ( ) ,
"m+" : s . getMinutes ( ) ,
"s+" : s . getSeconds ( ) ,
"q+" : Math . floor ( ( s . getMonth ( ) + 3 ) / 3 ) ,
S : s . getMilliseconds ( )
} ;
/(y+)/ . test ( t ) && ( t = t . replace ( RegExp . $1 , ( s . getFullYear ( ) + "" ) . substr ( 4 - RegExp . $1 . length ) ) ) ;
2022-02-11 20:42:38 +08:00
for ( let e in i ) new RegExp ( "(" + e + ")" ) . test ( t ) && ( t = t . replace ( RegExp . $1 , 1 == RegExp . $1 . length ? i [ e ] : ( "00" + i [ e ] ) . substr ( ( "" + i [ e ] ) . length ) ) ) ;
2022-02-11 16:56:14 +08:00
return t
}
2022-02-11 20:42:38 +08:00
msg ( e = t , s = "" , i = "" , r ) {
2022-02-11 16:56:14 +08:00
const o = t => {
2022-02-11 20:42:38 +08:00
if ( ! t ) return t ;
if ( "string" == typeof t ) return this . isLoon ( ) ? t : this . isQuanX ( ) ? {
2022-02-11 16:56:14 +08:00
"open-url" : t
} : this . isSurge ( ) ? {
url : t
} : void 0 ;
2022-02-11 20:42:38 +08:00
if ( "object" == typeof t ) {
if ( this . isLoon ( ) ) {
2022-02-11 16:56:14 +08:00
let e = t . openUrl || t . url || t [ "open-url" ] ,
s = t . mediaUrl || t [ "media-url" ] ;
return {
openUrl : e ,
mediaUrl : s
}
}
2022-02-11 20:42:38 +08:00
if ( this . isQuanX ( ) ) {
2022-02-11 16:56:14 +08:00
let e = t [ "open-url" ] || t . url || t . openUrl ,
s = t [ "media-url" ] || t . mediaUrl ;
return {
"open-url" : e ,
"media-url" : s
}
}
2022-02-11 20:42:38 +08:00
if ( this . isSurge ( ) ) {
2022-02-11 16:56:14 +08:00
let e = t . url || t . openUrl || t [ "open-url" ] ;
return {
url : e
}
}
}
} ;
2022-02-11 20:42:38 +08:00
if ( this . isMute || ( this . isSurge ( ) || this . isLoon ( ) ? $notification . post ( e , s , i , o ( r ) ) : this . isQuanX ( ) && $notify ( e , s , i , o ( r ) ) ) , ! this . isMuteLog ) {
2022-02-11 16:56:14 +08:00
let t = [ "" , "==============📣系统通知📣==============" ] ;
t . push ( e ) , s && t . push ( s ) , i && t . push ( i ) , console . log ( t . join ( "\n" ) ) , this . logs = this . logs . concat ( t )
}
}
2022-02-11 20:42:38 +08:00
log ( ... t ) {
2022-02-11 16:56:14 +08:00
t . length > 0 && ( this . logs = [ ... this . logs , ... t ] ) , console . log ( t . join ( this . logSeparator ) )
}
2022-02-11 20:42:38 +08:00
logErr ( t , e ) {
2022-02-11 16:56:14 +08:00
const s = ! this . isSurge ( ) && ! this . isQuanX ( ) && ! this . isLoon ( ) ;
s ? this . log ( "" , ` ❗️ ${ this . name } , 错误! ` , t . stack ) : this . log ( "" , ` ❗️ ${ this . name } , 错误! ` , t )
}
2022-02-11 20:42:38 +08:00
wait ( t ) {
2022-02-11 16:56:14 +08:00
return new Promise ( e => setTimeout ( e , t ) )
}
2022-02-11 20:42:38 +08:00
done ( t = { } ) {
2022-02-11 16:56:14 +08:00
const e = ( new Date ) . getTime ( ) ,
s = ( e - this . startTime ) / 1e3 ;
this . log ( "" , ` 🔔 ${ this . name } , 结束! 🕛 ${ s } 秒 ` ) , this . log ( ) , ( this . isSurge ( ) || this . isQuanX ( ) || this . isLoon ( ) ) && $done ( t )
}
} ( t , e )
}