2020-11-10 09:29:58 +08:00
/ *
2020-11-10 09:41:37 +08:00
京小超兑换奖品 脚本地址 : https : //raw.githubusercontent.com/lxk0301/jd_scripts/master/jd_blueCoin.js
2020-11-10 09:29:58 +08:00
感谢 @ yangtingxiao提供PR
更新时间 : 2020 - 11 - 05
支持京东多个账号
脚本兼容 : QuantumultX , Surge , Loon , JSBox , Node . js
=== === === === === === === = quantumultx === === === === ===
[ task _local ]
# 京小超兑换奖品
2020-11-10 09:41:37 +08:00
0 0 0 * * * https : //raw.githubusercontent.com/lxk0301/jd_scripts/master/jd_blueCoin.js, tag=京小超兑换奖品, img-url=https://raw.githubusercontent.com/58xinian/icon/master/jxc.png, enabled=true
2020-11-10 09:29:58 +08:00
=== === === === === === == Loon === === === === === ==
[ Script ]
2020-11-10 09:41:37 +08:00
cron "0 0 0 * * *" script - path = https : //raw.githubusercontent.com/lxk0301/jd_scripts/master/jd_blueCoin.js,tag=京小超兑换奖品
2020-11-10 09:29:58 +08:00
=== === === === === === = Surge === === === === === ===
2020-11-10 09:41:37 +08:00
京小超兑换奖品 = type = cron , cronexp = "0 0 0 * * *" , wake - system = 1 , timeout = 20 , script - path = https : //raw.githubusercontent.com/lxk0301/jd_scripts/master/jd_blueCoin.js
2020-11-10 09:29:58 +08:00
* /
const $ = new Env ( '京小超兑换奖品' ) ;
const notify = $ . isNode ( ) ? require ( './sendNotify' ) : '' ;
//Node.js用户请在jdCookie.js处填写京东ck;
const jdCookieNode = $ . isNode ( ) ? require ( './jdCookie.js' ) : '' ;
let coinToBeans = $ . getdata ( 'coinToBeans' ) || 0 ; //兑换多少数量的京豆( 20或者1000) , 0默认兑换不兑换, 如需兑换把0改成20或者1000, 或者'商品名称'(商品名称放到单引号内)即可
let jdNotify = false ; //是否开启静默运行, 默认false关闭(即:奖品兑换成功后会发出通知提示)
//IOS等用户直接用NobyDa的jd cookie
let cookiesArr = [ ] , cookie = '' ;
if ( $ . isNode ( ) ) {
Object . keys ( jdCookieNode ) . forEach ( ( item ) => {
cookiesArr . push ( jdCookieNode [ item ] )
} )
if ( process . env . JD _DEBUG && process . env . JD _DEBUG === 'false' ) console . log = ( ) => { } ;
} else {
cookiesArr . push ( $ . getdata ( 'CookieJD' ) ) ;
cookiesArr . push ( $ . getdata ( 'CookieJD2' ) ) ;
}
const JD _API _HOST = ` https://api.m.jd.com/api?appid=jdsupermarket ` ;
! ( async ( ) => {
if ( ! cookiesArr [ 0 ] ) {
$ . msg ( $ . name , '【提示】请先获取cookie\n直接使用NobyDa的京东签到获取' , 'https://bean.m.jd.com/' , { "open-url" : "https://bean.m.jd.com/" } ) ;
return ;
}
for ( let i = 0 ; i < cookiesArr . length ; i ++ ) {
cookie = cookiesArr [ i ] ;
if ( cookie ) {
$ . UserName = decodeURIComponent ( cookie . match ( /pt_pin=(.+?);/ ) && cookie . match ( /pt_pin=(.+?);/ ) [ 1 ] )
$ . index = i + 1 ;
$ . data = { } ;
$ . coincount = 0 ;
$ . beanscount = 0 ;
$ . blueCost = 0 ;
$ . coinerr = "" ;
$ . beanerr = "" ;
$ . title = '' ;
//console.log($.coincount);
$ . isLogin = true ;
$ . nickName = '' ;
await TotalBean ( ) ;
console . log ( ` \n 开始【京东账号 ${ $ . index } 】 ${ $ . nickName || $ . UserName } \n ` ) ;
if ( ! $ . isLogin ) {
$ . msg ( $ . name , ` 【提示】cookie已失效 ` , ` 京东账号 ${ $ . index } ${ $ . nickName || $ . UserName } \n 请重新登录获取 \n https://bean.m.jd.com/ ` , { "open-url" : "https://bean.m.jd.com/" } ) ;
$ . setdata ( '' , ` CookieJD ${ i ? i + 1 : "" } ` ) ; //cookie失效, 故清空cookie。
if ( $ . isNode ( ) ) await notify . sendNotify ( ` ${ $ . name } cookie已失效 - ${ $ . UserName } ` , ` 京东账号 ${ $ . index } ${ $ . UserName } \n 请重新登录获取cookie ` ) ;
continue
}
//先兑换京豆
if ( $ . isNode ( ) ) {
if ( process . env . MARKET _COIN _TO _BEANS ) {
coinToBeans = process . env . MARKET _COIN _TO _BEANS ;
}
}
if ( ` ${ coinToBeans } ` !== '0' ) {
await smtgHome ( ) ; //查询蓝币数量,是否满足兑换的条件
await smtg _queryPrize ( ) ;
} else {
console . log ( '查询到您设置的是不兑换京豆选项, 现在为您跳过兑换京豆。如需兑换, 请去BoxJs设置或者修改脚本coinToBeans\n' )
}
await msgShow ( ) ;
}
}
} ) ( )
. catch ( ( e ) => $ . logErr ( e ) )
. finally ( ( ) => $ . done ( ) )
//查询任务
function smtg _queryPrize ( timeout = 0 ) {
return new Promise ( ( resolve ) => {
setTimeout ( ( ) => {
let url = {
url : ` ${ JD _API _HOST } &functionId=smtg_queryPrize&clientVersion=8.0.0&client=m&body=%7B%7D&t= ${ Date . now ( ) } ` ,
headers : {
'Origin' : ` https://jdsupermarket.jd.com ` ,
'Cookie' : cookie ,
'Connection' : ` keep-alive ` ,
'Accept' : ` application/json, text/plain, */* ` ,
'Referer' : ` https://jdsupermarket.jd.com/game/?tt=1597540727225 ` ,
'Host' : ` api.m.jd.com ` ,
'Accept-Encoding' : ` gzip, deflate, br ` ,
'Accept-Language' : ` zh-cn `
}
}
$ . post ( url , async ( err , resp , data ) => {
try {
if ( safeGet ( data ) ) {
data = JSON . parse ( data ) ;
$ . queryPrizeData = data ;
if ( data . data . bizCode !== 0 ) {
$ . beanerr = ` ${ data . data . bizMsg } ` ;
return
}
if ( data . data . bizCode === 0 ) {
const { prizeList } = data . data . result ;
if ( ` ${ coinToBeans } ` === '1000' ) {
if ( prizeList [ 1 ] . beanType === 'BeanPackage' ) {
console . log ( ` 查询换 ${ prizeList [ 1 ] . title } ID成功, ID: ${ prizeList [ 1 ] . prizeId } ` )
$ . title = prizeList [ 1 ] . title ;
$ . blueCost = prizeList [ 1 ] . blueCost ;
} else {
console . log ( ` 查询换1000京豆ID失败 ` )
$ . beanerr = ` 东哥今天不给换 ` ;
return ;
}
if ( prizeList [ 1 ] . inStock === 506 ) {
$ . beanerr = ` 失败, 1000京豆领光了, 请明天再来 ` ;
return ;
}
if ( prizeList [ 1 ] . targetNum === prizeList [ 1 ] . finishNum ) {
$ . beanerr = ` ${ prizeList [ 1 ] . subTitle } ` ;
return ;
}
//兑换1000京豆
if ( $ . totalBlue > $ . blueCost ) {
await smtg _obtainPrize ( prizeList [ 1 ] . prizeId ) ;
} else {
console . log ( ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ) ;
$ . beanerr = ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ;
}
} else if ( ` ${ coinToBeans } ` === '20' ) {
if ( prizeList [ 0 ] . beanType === 'Bean' ) {
console . log ( ` 查询换 ${ prizeList [ 0 ] . title } ID成功, ID: ${ prizeList [ 0 ] . prizeId } ` )
$ . title = prizeList [ 0 ] . title ;
$ . blueCost = prizeList [ 0 ] . blueCost ;
} else {
console . log ( ` 查询换万能的京豆ID失败 ` )
$ . beanerr = ` 东哥今天不给换 ` ;
return ;
}
if ( prizeList [ 0 ] . inStock === 506 ) {
console . log ( ` 失败,万能的京豆领光了,请明天再来 ` ) ;
$ . beanerr = ` 失败,万能的京豆领光了,请明天再来 ` ;
return ;
}
if ( prizeList [ 0 ] . targetNum === prizeList [ 0 ] . finishNum ) {
$ . beanerr = ` ${ prizeList [ 0 ] . subTitle } ` ;
return ;
}
//兑换万能的京豆(1-20京豆)
if ( $ . totalBlue > $ . blueCost ) {
await smtg _obtainPrize ( prizeList [ 0 ] . prizeId , 1000 ) ;
} else {
console . log ( ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ) ;
$ . beanerr = ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ;
}
} else {
//自定义输入兑换
let prizeId = '' , i ;
for ( let index = 0 ; index < prizeList . length ; index ++ ) {
if ( prizeList [ index ] . title . indexOf ( coinToBeans ) > - 1 ) {
prizeId = prizeList [ index ] . prizeId ;
i = index ;
$ . title = prizeList [ index ] . title ;
$ . blueCost = prizeList [ index ] . blueCost ;
}
}
if ( prizeId ) {
if ( prizeList [ i ] . inStock === 506 ) {
console . log ( ` 失败,您输入设置的 ${ coinToBeans } 领光了,请明天再来 ` ) ;
$ . beanerr = ` 失败,您输入设置的 ${ coinToBeans } 领光了,请明天再来 ` ;
return ;
}
if ( prizeList [ i ] . targetNum === prizeList [ i ] . finishNum ) {
$ . beanerr = ` ${ prizeList [ 0 ] . subTitle } ` ;
return ;
}
if ( $ . totalBlue > $ . blueCost ) {
await smtg _obtainPrize ( prizeId ) ;
} else {
console . log ( ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ) ;
$ . beanerr = ` 兑换失败,您目前蓝币 ${ $ . totalBlue } 个,不足以兑换 ${ $ . title } 所需的 ${ $ . blueCost } 个 ` ;
}
} else {
console . log ( ` 奖品兑换列表[ ${ coinToBeans } ]已下架, 请检查APP是否存在此商品, 如存在请检查您的输入是否正确 ` ) ;
$ . beanerr = ` 奖品兑换列表[ ${ coinToBeans } ]已下架 ` ;
}
}
}
}
} catch ( e ) {
$ . logErr ( e , resp ) ;
} finally {
resolve ( )
}
} )
} , timeout )
} )
}
//换京豆
function smtg _obtainPrize ( prizeId , timeout = 0 ) {
//1000京豆, prizeId为4401379726
return new Promise ( ( resolve ) => {
setTimeout ( ( ) => {
let url = {
url : ` ${ JD _API _HOST } &functionId=smtg_obtainPrize&clientVersion=8.0.0&client=m&body=%7B%22prizeId%22:%22 ${ prizeId } %22%7D&t= ${ Date . now ( ) } ` ,
headers : {
'Origin' : ` https://jdsupermarket.jd.com ` ,
'Cookie' : cookie ,
'Connection' : ` keep-alive ` ,
'Accept' : ` application/json, text/plain, */* ` ,
'Referer' : ` https://jdsupermarket.jd.com/game/?tt=1597540727225 ` ,
'Host' : ` api.m.jd.com ` ,
'Accept-Encoding' : ` gzip, deflate, br ` ,
'Accept-Language' : ` zh-cn `
}
}
$ . post ( url , async ( err , resp , data ) => {
try {
console . log ( ` 兑换结果: ${ data } ` ) ;
if ( safeGet ( data ) ) {
data = JSON . parse ( data ) ;
$ . data = data ;
if ( $ . data . data . bizCode !== 0 ) {
$ . beanerr = ` ${ $ . data . data . bizMsg } ` ;
//console.log(`【京东账号${$.index}】${$.nickName} 换取京豆失败:${$.data.data.bizMsg}`)
return
}
if ( $ . data . data . bizCode === 0 ) {
if ( ` ${ coinToBeans } ` === '1000' ) {
$ . beanscount ++ ;
console . log ( ` 【京东账号 ${ $ . index } 】 ${ $ . nickName } 第 ${ $ . data . data . result . exchangeNum } 次换 ${ $ . title } 成功 ` )
if ( $ . beanscount === 1 ) return ;
} else if ( ` ${ coinToBeans } ` === '20' ) {
$ . beanscount ++ ;
console . log ( ` 【京东账号 ${ $ . index } 】 ${ $ . nickName } 第 ${ $ . data . data . result . exchangeNum } 次换 ${ $ . title } 成功 ` )
if ( $ . data . data . result . exchangeNum === 20 || $ . beanscount === coinToBeans || $ . data . data . result . blue < 500 ) return ;
} else {
$ . beanscount ++ ;
console . log ( ` 【京东账号 ${ $ . index } 】 ${ $ . nickName } 第 ${ $ . data . data . result . exchangeNum } 次换 ${ $ . title } 成功 ` )
if ( $ . beanscount === 1 ) return ;
}
}
}
await smtg _obtainPrize ( prizeId , 3000 ) ;
} catch ( e ) {
$ . logErr ( e , resp ) ;
} finally {
resolve ( )
}
} )
} , timeout )
} )
}
function smtgHome ( ) {
return new Promise ( ( resolve ) => {
$ . get ( taskUrl ( 'smtg_home' ) , ( err , resp , data ) => {
try {
if ( err ) {
console . log ( '\n京小超兑换奖品: API查询请求失败 ‼️‼️' )
console . log ( JSON . stringify ( err ) ) ;
} else {
if ( safeGet ( data ) ) {
data = JSON . parse ( data ) ;
if ( data . data . bizCode === 0 ) {
const { result } = data . data ;
$ . totalGold = result . totalGold ;
$ . totalBlue = result . totalBlue ;
console . log ( ` 【总金币】 ${ $ . totalGold } 个 \n ` ) ;
console . log ( ` 【总蓝币】 ${ $ . totalBlue } 个 \n ` ) ;
}
}
}
} catch ( e ) {
$ . logErr ( e , resp ) ;
} finally {
resolve ( ) ;
}
} )
} )
}
//通知
async function msgShow ( ) {
// $.msg($.name, ``, `【京东账号${$.index}】${$.nickName}\n【收取蓝币】${$.coincount ? `${$.coincount}个` : $.coinerr }${coinToBeans ? `\n【兑换京豆】${ $.beanscount ? `${$.beanscount}个` : $.beanerr}` : ""}`);
$ . log ( ` \n 【京东账号 ${ $ . index } 】 ${ $ . nickName } \n ${ coinToBeans ? ` 【兑换 ${ $ . title } 】 ${ $ . beanscount ? ` 成功 ` : $ . beanerr } ` : "您设置的是不兑换奖品" } \n ` ) ;
let ctrTemp ;
if ( $ . isNode ( ) && process . env . MARKET _REWARD _NOTIFY ) {
ctrTemp = ` ${ process . env . MARKET _REWARD _NOTIFY } ` === 'false' ;
} else if ( $ . getdata ( 'jdSuperMarketRewardNotify' ) ) {
ctrTemp = $ . getdata ( 'jdSuperMarketRewardNotify' ) === 'false' ;
} else {
ctrTemp = ` ${ jdNotify } ` === 'false' ;
}
//默认只在兑换奖品成功后弹窗提醒。情况情况加,只打印日志,不弹窗
if ( $ . beanscount && ctrTemp ) {
$ . msg ( $ . name , ` ` , ` 【京东账号 ${ $ . index } 】 ${ $ . nickName } \n ${ coinToBeans ? ` 【兑换 ${ $ . title } 】 ${ $ . beanscount ? ` 成功,数量: ${ $ . beanscount } 个 ` : $ . beanerr } ` : "您设置的是不兑换奖品" } ` ) ;
if ( $ . isNode ( ) ) {
await notify . sendNotify ( ` ${ $ . name } - 账号 ${ $ . index } - ${ $ . nickName } ` , ` 【京东账号 ${ $ . index } 】 ${ $ . UserName } \n ${ coinToBeans ? ` 【兑换 ${ $ . title } 】 ${ $ . beanscount ? ` 成功,数量: ${ $ . beanscount } 个 ` : $ . beanerr } ` : "您设置的是不兑换奖品" } ` )
}
}
}
function TotalBean ( ) {
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" : "Mozilla/5.0 (iPhone; CPU iPhone OS 14_0_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0 Mobile/15E148 Safari/604.1"
}
}
$ . post ( options , ( err , resp , data ) => {
try {
if ( err ) {
console . log ( ` ${ JSON . stringify ( err ) } ` )
console . log ( ` ${ $ . name } API请求失败, 请检查网路重试 ` )
} else {
if ( data ) {
data = JSON . parse ( data ) ;
if ( data [ 'retcode' ] === 13 ) {
$ . isLogin = false ; //cookie过期
return
}
$ . nickName = data [ 'base' ] . nickname ;
} else {
console . log ( ` 京东服务器返回空数据 ` )
}
}
} catch ( e ) {
$ . logErr ( e , resp )
} finally {
resolve ( ) ;
}
} )
} )
}
function safeGet ( data ) {
try {
if ( typeof JSON . parse ( data ) == "object" ) {
return true ;
}
} catch ( e ) {
console . log ( e ) ;
console . log ( ` 京东服务器访问数据为空,请检查自身设备网络情况 ` ) ;
return false ;
}
}
function taskUrl ( function _id , body = { } ) {
return {
url : ` ${ JD _API _HOST } &functionId= ${ function _id } &clientVersion=8.0.0&client=m&body= ${ escape ( JSON . stringify ( body ) ) } &t= ${ Date . now ( ) } ` ,
headers : {
'User-Agent' : 'jdapp;iPhone;9.0.8;13.6;Mozilla/5.0 (iPhone; CPU iPhone OS 13_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1' ,
'Host' : 'api.m.jd.com' ,
'Cookie' : cookie ,
'Referer' : 'https://jdsupermarket.jd.com/game' ,
'Origin' : 'https://jdsupermarket.jd.com' ,
}
}
}
function Env ( t , s ) { return new class { constructor ( t , s ) { this . name = t , this . data = null , this . dataFile = "box.dat" , this . logs = [ ] , this . logSeparator = "\n" , this . startTime = ( new Date ) . getTime ( ) , Object . assign ( this , s ) , this . log ( "" , ` \u d83d \u dd14 ${ this . name } , \u 5f00 \u 59cb! ` ) } isNode ( ) { return "undefined" != typeof module && ! ! module . exports } isQuanX ( ) { return "undefined" != typeof $task } isSurge ( ) { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon ( ) { return "undefined" != typeof $loon } getScript ( t ) { return new Promise ( s => { $ . get ( { url : t } , ( t , e , i ) => s ( i ) ) } ) } runScript ( t , s ) { return new Promise ( e => { let i = this . getdata ( "@chavy_boxjs_userCfgs.httpapi" ) ; i = i ? i . replace ( /\n/g , "" ) . trim ( ) : i ; let o = this . getdata ( "@chavy_boxjs_userCfgs.httpapi_timeout" ) ; o = o ? 1 * o : 20 , o = s && s . timeout ? s . timeout : o ; const [ h , a ] = i . split ( "@" ) , r = { url : ` http:// ${ a } /v1/scripting/evaluate ` , body : { script _text : t , mock _type : "cron" , timeout : o } , headers : { "X-Key" : h , Accept : "*/*" } } ; $ . post ( r , ( t , s , i ) => e ( i ) ) } ) . catch ( t => this . logErr ( t ) ) } loaddata ( ) { if ( ! this . isNode ( ) ) return { } ; { this . fs = this . fs ? this . fs : require ( "fs" ) , this . path = this . path ? this . path : require ( "path" ) ; const t = this . path . resolve ( this . dataFile ) , s = this . path . resolve ( process . cwd ( ) , this . dataFile ) , e = this . fs . existsSync ( t ) , i = ! e && this . fs . existsSync ( s ) ; if ( ! e && ! i ) return { } ; { const i = e ? t : s ; try { return JSON . parse ( this . fs . readFileSync ( i ) ) } catch ( t ) { return { } } } } } writedata ( ) { if ( this . isNode ( ) ) { this . fs = this . fs ? this . fs : require ( "fs" ) , this . path = this . path ? this . path : require ( "path" ) ; const t = this . path . resolve ( this . dataFile ) , s = this . path . resolve ( process . cwd ( ) , this . dataFile ) , e = this . fs . existsSync ( t ) , i = ! e && this . fs . existsSync ( s ) , o = JSON . stringify ( this . data ) ; e ? this . fs . writeFileSync ( t , o ) : i ? this . fs . writeFileSync ( s , o ) : this . fs . writeFileSync ( t , o ) } } lodash _get ( t , s , e ) { const i = s . replace ( /\[(\d+)\]/g , ".$1" ) . split ( "." ) ; let o = t ; for ( const t of i ) if ( o = Object ( o ) [ t ] , void 0 === o ) return e ; return o } lodash _set ( t , s , e ) { return Object ( t ) !== t ? t : ( Array . isArray ( s ) || ( s = s . toString ( ) . match ( /[^.[\]]+/g ) || [ ] ) , s . slice ( 0 , - 1 ) . reduce ( ( t , e , i ) => Object ( t [ e ] ) === t [ e ] ? t [ e ] : t [ e ] = Math . abs ( s [ i + 1 ] ) >> 0 == + s [ i + 1 ] ? [ ] : { } , t ) [ s [ s . length - 1 ] ] = e , t ) } getdata ( t ) { let s = this . getval ( t ) ; if ( /^@/ . test ( t ) ) { const [ , e , i ] = /^@(.*?)\.(.*?)$/ . exec ( t ) , o = e ? this . getval ( e ) : "" ; if ( o ) try { const t = JSON . parse ( o ) ; s = t ? this . lodash _get ( t , i , "" ) : s } catch ( t ) { s = "" } } return s } setdata ( t , s ) { let e = ! 1 ; if ( /^@/ . test ( s ) ) { const [ , i , o ] = /^@(.*?)\.(.*?)$/ . exec ( s ) , h = this . getval ( i ) , a = i ? "null" === h ? null : h || "{}" : "{}" ; try { const s = JSON . parse ( a ) ; this . lodash _set ( s , o , t ) , e = this . setval ( JSON . stringify ( s ) , i ) } catch ( s ) { const h = { } ; this . lodash _set ( h , o , t ) , e = this . setval ( JSON . stringify ( h ) , i ) } } else e = $ . setval ( t , s ) ; return e } 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 , s ) { return this . isSurge ( ) || this . isLoon ( ) ? $persistentStore . write ( t , s ) : this . isQuanX ( ) ? $prefs . setValueForKey ( t , s ) : this . isNode ( ) ? ( this . data = this . loaddata ( ) , this . data [ s ] = t , this . writedata ( ) , ! 0 ) : this . data && this . data [ s ] || null } initGotEnv ( t ) { this . got = this . got ? this . got : require ( "got" ) , this . cktough = this . cktough ? this . cktough : require ( "tough-cookie" ) , this . ckjar = this . ckjar ? this . ckjar : new this . cktough . CookieJar , t && ( t . headers = t . headers ? t . headers : { } , void 0 === t . headers . Cookie && void 0 === t . cookieJar && ( t . cookieJar = this . ckjar ) ) } get ( t , s = ( ( ) => { } ) ) { t . headers && ( delete t . headers [ "Content-Type" ] , delete t . headers [ "Content-Length" ] ) , this . isSurge ( ) || this . isLoon ( ) ? $httpClient . get ( t , ( t , e , i ) => { ! t && e && ( e . body = i , e . statusCode = e . status ) , s ( t , e , i ) } ) : this . isQuanX ( ) ? $task . fetch ( t ) . then ( t => { const { statusCode : e , statusCode : i , headers : o , body : h } = t ; s ( null , { status : e , statusCode : i , headers : o , body : h } , h ) } , t => s ( t ) ) : this . isNode ( ) && ( this . initGotEnv ( t ) , this . got ( t ) . on ( "redirect" , ( t , s ) => { try { const e = t . headers [ "set-cookie" ] . map ( this . cktough . Cookie . parse ) . toString ( ) ; this . ckjar . setCookieSync ( e , null ) , s . cookieJar = this . ckjar } catch ( t ) { this . logErr ( t ) } } ) . then ( t => { const { statusCode : e , statusCode : i , headers : o , body : h } = t ; s ( null , { status : e , statusCode : i , headers : o , body : h } , h ) } , t => s ( t ) ) ) } post ( t , s = ( ( ) => { } ) ) { if ( t . body && t . headers && ! t . headers [ "Content-Type" ] && ( t . headers [ "Content-Type" ] = " applicat