From 9707595792329fefc6d12b7db9730ac76076550c Mon Sep 17 00:00:00 2001
From: Faker <Faker@apple.com>
Date: Mon, 17 Oct 2022 17:22:53 +0800
Subject: [PATCH] update

---
 USER_AGENTS.js    |    2 +-
 jd_bean_change.js |   27 +-
 jd_beauty.js      | 1408 +++++++++++++++++++++++----------------------
 3 files changed, 732 insertions(+), 705 deletions(-)

diff --git a/USER_AGENTS.js b/USER_AGENTS.js
index b9b2e6d..6c5ecde 100644
--- a/USER_AGENTS.js
+++ b/USER_AGENTS.js
@@ -89,4 +89,4 @@ function UARAM (){
 module.exports = {
   USER_AGENT,
   UARAM
-}
\ No newline at end of file
+}
diff --git a/jd_bean_change.js b/jd_bean_change.js
index c012784..248672d 100644
--- a/jd_bean_change.js
+++ b/jd_bean_change.js
@@ -427,11 +427,16 @@ if(DisableIndex!=-1){
 			TempBaipiao = "";
 			strGuoqi="";
 			console.log(`******开始查询【京东账号${$.index}】${$.nickName || $.UserName}*********`);
-		
 			await TotalBean();			
 		    //await TotalBean2();
-			
 			if ($.beanCount == 0) {
+				console.log("数据获取失败,等待30秒后重试....")
+				await $.wait(30*1000);
+				await TotalBean();		
+			}
+			if ($.beanCount == 0) {
+				console.log("疑似获取失败,等待10秒后用第二个接口试试....")
+				await $.wait(10*1000);
 			    var userdata = await getuserinfo();
 			    if (userdata.code == 1) {
 			        $.beanCount = userdata.content.jdBean;
@@ -497,7 +502,7 @@ if(DisableIndex!=-1){
 			    TodayCache.push(tempAddCache);
 			}
 						
-			await getjdfruitinfo() //东东农场
+			await getjdfruitinfo(); //东东农场
 			await $.wait(1000);
 			
 			await Promise.all([
@@ -2030,9 +2035,14 @@ function jdfruitRequest(function_id, body = {}, timeout = 1000) {
 						console.log(`function_id:${function_id}`)
 						$.logErr(err);
 					} else {
-						if (safeGet(data)) {
+						if (safeGet(data)) {							
 							data = JSON.parse(data);
-							$.JDwaterEveryDayT = data.totalWaterTaskInit.totalWaterTaskTimes;
+							if (data.code=="400"){
+								console.log('东东农场: '+data.message);
+								llgeterror = true;
+							}
+							else
+								$.JDwaterEveryDayT = data.totalWaterTaskInit.totalWaterTaskTimes;
 						}
 					}
 				} catch (e) {
@@ -2055,7 +2065,10 @@ async function getjdfruitinfo() {
             "channel": 1,
             "babelChannel": "120"
         });
-
+		
+		if (llgeterror)
+			return
+		
         await getjdfruit();
         if (llgeterror) {
             console.log(`东东农场API查询失败,等待10秒后再次尝试...`)
@@ -3053,7 +3066,7 @@ async function queryScores() {
 }
 
 async function getuserinfo() {
-	var body={"pin": "$cooMrdGatewayUid$"};
+	var body=[{"pin": "$cooMrdGatewayUid$"}];
 	var ua = `jdapp;iPhone;${random(["11.1.0", "10.5.0", "10.3.6"])};${random(["13.5", "14.0", "15.0"])};${uuidRandom()};network/wifi;supportApplePay/0;hasUPPay/0;hasOCPay/0;model/iPhone11,6;addressid/7565095847;supportBestPay/0;appBuild/167541;jdSupportDarkMode/0;Mozilla/5.0 (iPhone; CPU iPhone OS 13_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1`;
 
     let config = {
diff --git a/jd_beauty.js b/jd_beauty.js
index 13f99e6..922a28f 100644
--- a/jd_beauty.js
+++ b/jd_beauty.js
@@ -1,768 +1,782 @@
 /*
 美丽研究院
 修复+尽量优化为同步执行,减少并发,说不定就减小黑号概率了呢?
+https://raw.githubusercontent.com/aTenb/jdOpenSharePicker/master/jd_beautyStudy.js
 更新时间:2021-12-03
-来源 Dylan
-定时自定义,集中访问可能炸
 活动入口:京东app首页-美妆馆-底部中间按钮
-#随机定时运行一次
+定时自定义,集中访问可能炸
  */
 const $ = new Env('美丽研究院');
 const notify = $.isNode() ? require('./sendNotify') : '';
+console.log('连接服务器不稳定,能不能用随缘!!!')
 const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
-
-
 const WebSocket = require('ws');
 const UA = process.env.JD_USER_AGENT ? process.env.JD_USER_AGENT : (require('./USER_AGENTS').USER_AGENT)
-const JD_API_HOST = 'https://api.m.jd.com/client.action';
 $.accountCheck = true;
 $.init = false;
 let cookiesArr = [], cookie = '', message;
-
 function oc(fn, defaultVal) {
-  try {
-    return fn()
-  } catch (e) {
-    return undefined
-  }
-}
-
-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 = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item);
-}
-
-!(async () => {
-  if (!cookiesArr[0]) {
-    $.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/', {"open-url": "https://bean.m.jd.com/"});
-    return;
-  }
-  if (!$.isNode()) {
-    $.msg($.name, 'iOS端不支持websocket,暂不能使用此脚本', '');
-    return
-  }
-  helpInfo = []
-  for (let i = 0; i < cookiesArr.length; i++) {
-    if (cookiesArr[i]) {
-      cookie = cookiesArr[i];
-      $.UserName = decodeURIComponent(cookie.match(/pt_pin=([^; ]+)(?=;?)/) && cookie.match(/pt_pin=([^; ]+)(?=;?)/)[1])
-      $.index = i + 1;
-      $.isLogin = true;
-      $.nickName = '';
-      message = '';
-      $.token = '';
-      //await TotalBean();
-      console.log(`\n******开始【京东账号${$.index}】${$.nickName || $.UserName}*********\n`);
-      if (!$.isLogin) {
-        $.msg($.name, `【提示】cookie已失效`, `京东账号${$.index} ${$.nickName || $.UserName}\n请重新登录获取\nhttps://bean.m.jd.com/`, {"open-url": "https://bean.m.jd.com/"});
-
-        if ($.isNode()) {
-          await notify.sendNotify(`${$.name}cookie已失效 - ${$.UserName}`, `京东账号${$.index} ${$.UserName}\n请重新登录获取cookie`);
-        }
-        continue
-      }
-      await accountCheck();
-      await $.wait(10000)
-      if ($.accountCheck) {
-        await jdBeauty();
-      }
-      if ($.accountCheck) {
-        helpInfo = $.helpInfo;
-      }
+    try {
+        return fn()
+    } catch (e) {
+        return undefined
+    }
+}
+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 = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item);
+}
+const JD_API_HOST = 'https://api.m.jd.com/client.action';
+!(async () => {
+    if (!cookiesArr[0]) {
+        $.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/', { "open-url": "https://bean.m.jd.com/" });
+        return;
+    }
+    if (!$.isNode()) {
+        $.msg($.name, 'iOS端不支持websocket,暂不能使用此脚本', '');
+        return
+    }
+    helpInfo = []
+    for (let i = 0; i < cookiesArr.length; i++) {
+        if (cookiesArr[i]) {
+            cookie = cookiesArr[i];
+            $.UserName = decodeURIComponent(cookie.match(/pt_pin=([^; ]+)(?=;?)/) && cookie.match(/pt_pin=([^; ]+)(?=;?)/)[1])
+            $.index = i + 1;
+            $.isLogin = true;
+            $.nickName = '';
+            message = '';
+            $.token = '';
+            await TotalBean();
+            console.log(`\n******开始【京东账号${$.index}】${$.nickName || $.UserName}*********\n`);
+            if (!$.isLogin) {
+                $.msg($.name, `【提示】cookie已失效`, `京东账号${$.index} ${$.nickName || $.UserName}\n请重新登录获取\nhttps://bean.m.jd.com/`, { "open-url": "https://bean.m.jd.com/" });
+
+                if ($.isNode()) {
+                    await notify.sendNotify(`${$.name}cookie已失效 - ${$.UserName}`, `京东账号${$.index} ${$.UserName}\n请重新登录获取cookie`);
+                }
+                continue
+            }
+            await accountCheck();
+            while (!$.hasDone) {
+                await $.wait(3000)
+            }
+            if ($.accountCheck) {
+                await jdBeauty();
+            }
+            if ($.accountCheck) {
+                helpInfo = $.helpInfo;
+            }
+        }
     }
-  }
 })()
     .catch((e) => {
-      $.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '')
+        $.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '')
     })
     .finally(() => {
-      $.done();
+        $.done();
     })
 
 async function accountCheck() {
-  $.hasDone = false;
-  console.log(`***检测账号是否黑号***`);
-  await getIsvToken()
-  await $.wait(10000)
-  await getIsvToken2()
-  await $.wait(10000)
-  await getAuth()
-  await $.wait(10000)
-  if (!$.token) {
-    console.log(`\n\n提示:请尝试换服务器ip或者设置"xinruimz-isv.isvjcloud.com"域名直连,或者自定义UA再次尝试(环境变量JD_USER_AGENT)\n\n`)
-    $.accountCheck = false;
-    return
-  }
-  let client = new WebSocket(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`, null, {
-    headers: {
-      'user-agent': UA,
+    $.hasDone = false;
+    console.log(`***检测账号是否黑号***`);
+    await getIsvToken()
+    await $.wait(10000)
+    await getIsvToken2()
+    await $.wait(10000)
+    await getToken()
+    await $.wait(10000)
+    if (!$.token || !$.token2) {
+        console.log(`\n\n提示:请尝试换服务器ip或者设置"xinruimz-isv.isvjcloud.com"域名直连,或者自定义UA再次尝试(环境变量JD_USER_AGENT)\n\n`)
+        $.accountCheck = false;
+        return
     }
-  });
-  client.onopen = async () => {
-    console.log(`美容研究院服务器连接成功`);
-    client.send('{"msg":{"type":"action","args":{"source":1},"action":"_init_"}}');
-    await $.wait(20000);
-    client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_user"}}`);
-    await $.wait(20000);
-  };
-  client.onmessage = async function (e) {
-    if (e.data !== 'pong' && e.data && safeGet(e.data)) {
-      let vo = JSON.parse(e.data);
-      if (vo.action === "_init_") {
-        let vo = JSON.parse(e.data);
-        if (vo.msg === "风险用户") {
-          $.accountCheck = false;
-          // $.init=true;
-          client.close();
-          console.log(`${vo.msg},跳过此账号`)
+    let client = new WebSocket(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`, null, {
+        headers: {
+            'user-agent': UA,
         }
-      } else if (vo.action === "get_user") {
-        // $.init=true;
-        $.accountCheck = true;
-        client.close();
-        console.log(`${vo.msg},账号正常`);
-      }
-    }
-    client.onclose = (e) => {
-      $.hasDone = true;
-      console.log('服务器连接关闭\n');
+    });
+    client.onopen = async () => {
+        console.log(`美容研究院服务器连接成功`);
+        client.send('{"msg":{"type":"action","args":{"source":1},"action":"_init_"}}');
+        await $.wait(10000);
+        client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_user"}}`);
+        await $.wait(10000);
     };
-  }
+    client.onmessage = async function (e) {
+        if (e.data !== 'pong' && e.data && safeGet(e.data)) {
+            let vo = JSON.parse(e.data);
+            if (vo.action === "_init_") {
+                let vo = JSON.parse(e.data);
+                if (vo.msg === "风险用户") {
+                    $.accountCheck = false;
+                    // $.init=true;
+                    client.close();
+                    console.log(`${vo.msg},跳过此账号`)
+                }
+            } else if (vo.action === "get_user") {
+                // $.init=true;
+                $.accountCheck = true;
+                client.close();
+                console.log(`${vo.msg},账号正常`);
+            }
+        }
+        client.onclose = (e) => {
+            $.hasDone = true;
+            console.log('服务器连接关闭\n');
+        };
+    }
 }
 
 async function jdBeauty() {
-  $.hasDone = false
-  await mr()
-  while (!$.hasDone) {
-    await $.wait(10000)
-  }
-  await showMsg();
+    $.hasDone = false
+    await mr()
+    while (!$.hasDone) {
+        await $.wait(10000)
+    }
+    await showMsg();
 }
 
 async function mr() {
-  $.coins = 0
-  let positionList = ['b1', 'h1', 's1', 'b2', 'h2', 's2']
-  $.tokens = []
-  $.pos = []
-  $.helpInfo = []
-  $.needs = []
-  let client = new WebSocket(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`,null,{
-    headers:{
-      'user-agent': UA,
-    }
-  })
-  console.log(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`)
-  client.onopen = async () => {
-    console.log(`美容研究院服务器连接成功`);
-    client.send('{"msg":{"type":"action","args":{"source":1},"action":"_init_"}}');
-    await $.wait(10000);
-    client.send(`{"msg":{"type":"action","args":{"source":"meizhuangguandibudaohang"},"action":"stats"}}`)
-    await $.wait(10000);
-    while (!$.init) {
-      client.send(`ping`)
-      await $.wait(10000);
-    }
-    console.log(`\n========生产任务相关========\n`)
-    client.send(`{"msg":{"type":"action","args":{},"action":"get_produce_material"}}`)
-    await $.wait(20000);
-    // 获得正在生产的商品信息
-    client.send('{"msg":{"type":"action","args":{},"action":"product_producing"}}')
-    await $.wait(20000);
-    // 获得可生成的商品列表
-    client.send(`{"msg":{"type":"action","args":{"page":1,"num":10},"action":"product_lists"}}`)
-    await $.wait(20000);
-    // 获得原料生产列表
-    for (let pos of positionList) {
-      client.send(`{"msg":{"type":"action","args":{"position":"${pos}"},"action":"produce_position_info_v2"}}`)
-      await $.wait(20000);
-    }
-    console.log(`\n========日常任务相关========`)
-    client.send(`{"msg":{"type":"action","args":{},"action":"check_up"}}`)
-    await $.wait(20000);
-    if($.check_up){
-      //收集
-      client.send(`{"msg":{"type":"action","args":{},"action":"collect_coins"}}`);
-      await $.wait(20000);
-      //兑换
-      client.send(`{"msg":{"type":"action","args":{},"action":"get_benefit"}}`)
-      await $.wait(50000);
-      //最后做时间最久的日常任务
-      client.send(`{"msg":{"type":"action","args":{},"action":"shop_products"}}`)
-      await $.wait(20000);
-    }
-  };
-  client.onclose = () => {
-    console.log(`本次运行获得美妆币${$.coins}`)
-    console.log('服务器连接关闭');
-    $.init = true;
-    $.hasDone = true;
-    for (let i = 0; i < $.pos.length && i < $.tokens.length; ++i) {
-      $.helpInfo.push(`{"msg":{"type":"action","args":{"inviter_id":"${$.userInfo.id}","position":"${$.pos[i]}","token":"${$.tokens[i]}"},"action":"employee"}}`)
-    }
-  };
-  client.onmessage = async function (e) {
-    if (e.data !== 'pong' && e.data && safeGet(e.data)) {
-      let vo = JSON.parse(e.data);
-      await $.wait(Math.random()*2000+500);
-      console.log(`\n开始任务:"${JSON.stringify(vo.action)}`);
-      switch (vo.action) {
-        case "get_ad":
-          console.log(`当期活动:${vo.data.screen.name}`)
-          if (vo.data.check_sign_in === 1) {
-            // 去签到
-            console.log(`去做签到任务`)
-            client.send(`{"msg":{"type":"action","args":{},"action":"sign_in"}}`)
+    $.coins = 0
+    let positionList = ['b1', 'h1', 's1', 'b2', 'h2', 's2']
+    let positionList2 = ['b2', 'h2', 's2']
+    $.tokens = []
+    $.pos = []
+    $.helpInfo = []
+    $.needs = []
+    let client = new WebSocket(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`, null, {
+        headers: {
+            'user-agent': UA,
+        }
+    })
+    console.log(`wss://xinruimz-isv.isvjcloud.com/wss/?token=${$.token}`)
+    client.onopen = async () => {
+        console.log(`美容研究院服务器连接成功`);
+        client.send('{"msg":{"type":"action","args":{"source":1},"action":"_init_"}}');
+        await $.wait(10000);
+        client.send(`{"msg":{"type":"action","args":{"source":"meizhuangguandibudaohang"},"action":"stats"}}`)
+        await $.wait(10000);
+        while (!$.init) {
+            client.send(`ping`)
+            await $.wait(10000);
+        }
+        console.log(`\n========生产任务相关========\n`)
+        for (let help of helpInfo) {
+            client.send(help);
+        }
+        await $.wait(3000)
+        client.send(`{"msg":{"type":"action","args":{},"action":"get_produce_material"}}`)
+        await $.wait(10000);
+        // 获得正在生产的商品信息
+        client.send('{"msg":{"type":"action","args":{},"action":"product_producing"}}')
+        await $.wait(10000);
+        // 获得库存
+        client.send(`{"msg":{"type":"action","args":{},"action":"get_package"}}`)
+        // 获得可生成的商品列表
+        client.send(`{"msg":{"type":"action","args":{"page":1,"num":10},"action":"product_lists"}}`)
+        await $.wait(10000);
+        // 获得原料生产列表
+        for (let pos of positionList) {
+            client.send(`{"msg":{"type":"action","args":{"position":"${pos}"},"action":"produce_position_info_v2"}}`)
+            await $.wait(10000);
+        }
+        console.log(`\n========日常任务相关========`)
+        client.send(`{"msg":{"type":"action","args":{},"action":"check_up"}}`)
+        await $.wait(20000);
+        if ($.check_up) {
+            //收集
+            client.send(`{"msg":{"type":"action","args":{},"action":"collect_coins"}}`);
             await $.wait(20000);
-            client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":1,"channel":2,"source_app":2}}}`)
-            await $.wait(20000);
-          }
-          break
-        case "get_user":
-          $.userInfo = vo.data
-          $.total = vo.data.coins
-          if ($.userInfo.newcomer === 0) {
-            console.log(`去做新手任务`)
-            for (let i = $.userInfo.step; i < 15; ++i) {
-              client.send(`{"msg":{"type":"action","args":{},"action":"newcomer_update"}}`)
-              await $.wait(20000);
-            }
-          } else
-            $.init = true;
-          $.level = $.userInfo.level;
-          console.log(`当前美妆币${$.total},用户等级${$.level}`);
-          break;
-        case "check_up":
-          //获得当前任务状态
-          $.taskState = vo.data
-          console.log($.taskState)
-          $.check_up = true
-          // 6-9点签到
-          //for (let check_up of vo.data.check_up) {
-          // if (check_up['receive_status'] !== 1) {
-          //   console.log(`去领取第${check_up.times}次签到奖励`)
-          //   client.send(`{"msg":{"type":"action","args":{"check_up_id":${check_up.id}},"action":"check_up_receive"}}`)
-          // } else {
-          //   console.log(`第${check_up.times}次签到奖励已领取`)
-          // }
-          // }
-          break
-        case "shop_products":
-          let count = $.taskState.shop_view.length;
-          if (count < $.taskState.daily_shop_follow_times) console.log(`\n去做关注店铺任务\n`);
-          for (let i = 0; i < vo.data.shops.length && count < $.taskState.daily_shop_follow_times; ++i) {
-            const shop = vo.data.shops[i];
-            if (!$.taskState.shop_view.includes(shop.id)) {
-              count++;
-              console.log(`\n去做关注店铺【${shop.name}】`);
-              client.send(`{"msg":{"type":"action","args":{"shop_id":${shop.id}},"action":"shop_view"}}`);
-              await $.wait(5000);
-              client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":6,"channel":2,"source_app":2,"vender":"${shop.vender_id}"}}}`);
-              await $.wait(5000);
-            }
+            //兑换
+            client.send(`{"msg":{"type":"action","args":{},"action":"get_benefit"}}`)
+            await $.wait(50000);
+            //最后做时间最久的日常任务
+            client.send(`{"msg":{"type":"action","args":{},"action":"shop_products"}}`)
             await $.wait(10000);
-          }
-          count = $.taskState.product_adds.length;
-          if (count < $.taskState.daily_product_add_times && process.env.FS_LEVEL) console.log(`\n去做浏览并加购任务\n`)
-          for (let i = 0; i < vo.data.products.length && count < $.taskState.daily_product_add_times && process.env.FS_LEVEL; ++i) {
-            const product = vo.data.products[i];
-            if (!$.taskState.product_adds.includes(product.id)) {
-              count++;
-              console.log(`\n去加购商品【${product.name}】`);
-              client.send(`{"msg":{"type":"action","args":{"add_product_id":${product.id}},"action":"add_product_view"}}`);
-              await $.wait(5000);
-              client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":9,"channel":2,"source_app":2,"vender":"${product.id}"}}}`);
-              await $.wait(5000);
-              client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":5,"channel":2,"source_app":2,"vender":"${product.id}"}}}`);
-              await $.wait(5000);
+        }
+    };
+    client.onclose = () => {
+        console.log(`本次运行获得美妆币${$.coins}`)
+        console.log('服务器连接关闭');
+        $.init = true;
+        $.hasDone = true;
+        for (let i = 0; i < $.pos.length && i < $.tokens.length; ++i) {
+            client.send(`{"msg":{"type":"action","args":{"inviter_id":"${$.userInfo.id}"},"action":"employee_get_user"}}`);
+            $.helpInfo.push(`{"msg":{"type":"action","args":{"inviter_id":"${$.userInfo.id}","position":"${$.pos[i]}","token":"${$.tokens[i]}"},"action":"employee_v2"}}`)
+            client.send(`{"msg":{"type":"action","args":{"inviter_id":"${$.userInfo.id}","position":"${$.pos[i]}"},"action":"employee_speed_v2"}}`);
+            client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":3,"channel":2,"source_app":2}}}`);
+        }
+    };
+    client.onmessage = async function (e) {
+        if (e.data !== 'pong' && e.data && safeGet(e.data)) {
+            let vo = JSON.parse(e.data);
+            await $.wait(Math.random() * 2000 + 500);
+            console.log(`\n开始任务:"${JSON.stringify(vo.action)}`);
+            switch (vo.action) {
+                case "get_ad":
+                    console.log(`当期活动:${vo.data.screen.name}`)
+                    if (vo.data.check_sign_in === 1) {
+                        // 去签到
+                        console.log(`去做签到任务`)
+                        client.send(`{"msg":{"type":"action","args":{},"action":"sign_in"}}`)
+                        await $.wait(10000);
+                        client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":1,"channel":2,"source_app":2}}}`)
+                        await $.wait(10000);
+                    }
+                    break
+                case "get_user":
+                    $.userInfo = vo.data
+                    $.total = vo.data.coins
+                    if ($.userInfo.newcomer === 0) {
+                        console.log(`去做新手任务`)
+                        for (let i = $.userInfo.step; i < 15; ++i) {
+                            client.send(`{"msg":{"type":"action","args":{},"action":"newcomer_update"}}`)
+                            await $.wait(10000);
+                        }
+                    } else
+                        $.init = true;
+                    $.level = $.userInfo.level;
+                    console.log(`当前美妆币${$.total},用户等级${$.level}`);
+                    break;
+                case "check_up":
+                    //获得当前任务状态
+                    $.taskState = vo.data
+                    console.log($.taskState)
+                    $.check_up = true
+                    // 6-9点签到
+                    //for (let check_up of vo.data.check_up) {
+                    // if (check_up['receive_status'] !== 1) {
+                    //   console.log(`去领取第${check_up.times}次签到奖励`)
+                    //   client.send(`{"msg":{"type":"action","args":{"check_up_id":${check_up.id}},"action":"check_up_receive"}}`)
+                    // } else {
+                    //   console.log(`第${check_up.times}次签到奖励已领取`)
+                    // }
+                    // }
+                    break
+                case "shop_products":
+                    let count = $.taskState.shop_view.length;
+                    if (count < $.taskState.daily_shop_follow_times) console.log(`\n去做关注店铺任务\n`);
+                    for (let i = 0; i < vo.data.shops.length && count < $.taskState.daily_shop_follow_times; ++i) {
+                        const shop = vo.data.shops[i];
+                        if (!$.taskState.shop_view.includes(shop.id)) {
+                            count++;
+                            console.log(`\n去做关注店铺【${shop.name}】`);
+                            client.send(`{"msg":{"type":"action","args":{"shop_id":${shop.id}},"action":"shop_view"}}`);
+                            await $.wait(5000);
+                            client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":6,"channel":2,"source_app":2,"vender":"${shop.vender_id}"}}}`);
+                            await $.wait(5000);
+                        }
+                        await $.wait(10000);
+                    }
+                    count = $.taskState.product_adds.length;
+                    if (count < $.taskState.daily_product_add_times && process.env.FS_LEVEL) console.log(`\n去做浏览并加购任务\n`)
+                    for (let i = 0; i < vo.data.products.length && count < $.taskState.daily_product_add_times && process.env.FS_LEVEL; ++i) {
+                        const product = vo.data.products[i];
+                        if (!$.taskState.product_adds.includes(product.id)) {
+                            count++;
+                            console.log(`\n去加购商品【${product.name}】`);
+                            client.send(`{"msg":{"type":"action","args":{"add_product_id":${product.id}},"action":"add_product_view"}}`);
+                            await $.wait(5000);
+                            client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":9,"channel":2,"source_app":2,"vender":"${product.id}"}}}`);
+                            await $.wait(5000);
+                            client.send(`{"msg":{"action":"write","type":"action","args":{"action_type":5,"channel":2,"source_app":2,"vender":"${product.id}"}}}`);
+                            await $.wait(5000);
+                        }
+                        await $.wait(10000);
+                    }
+                    if ($.taskState.meetingplace_view.length <= vo.data.meetingplaces.length) {
+                        for (let vc of vo.data.meetingplaces) {
+                            console.log(`去做第${vc.name}浏览会场任务`)
+                            client.send(`{"msg":{"type":"action","args":{"source":1,"meetingplace_id":${vc.id}},"action":"meetingplace_view"}}`)
+                            await $.wait(2500)
+                        }
+                    }
+                    if ($.taskState.today_answered === 0) {
+                        console.log(`去做每日问答任务`)
+                        client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_question"}}`)
+                        await $.wait(10000);
+                    }
+                    break
+                case 'newcomer_update':
+                    if (vo.code === '200' || vo.code === 200) {
+                        console.log(`第${vo.data.step}步新手任务完成成功,获得${vo.data.coins}美妆币`)
+                        if (vo.data.step === 15) $.init = true
+                        if (vo.data.coins) $.coins += vo.data.coins
+                    } else {
+                        console.log(`新手任务完成失败,错误信息:${JSON.stringify(vo)}`)
+                    }
+                    break
+                case 'get_question':
+                    const questions = vo.data
+                    let commit = {}
+                    for (let i = 0; i < questions.length; ++i) {
+                        const ques = questions[i]
+                        commit[`${ques.id}`] = parseInt(ques.answers)
+                    }
+                    client.send(`{"msg":{"type":"action","args":{"commit":${JSON.stringify(commit)},"correct":${questions.length}},"action":"submit_answer"}}`)
+                    await $.wait(10000);
+                    break
+                case 'complete_task':
+                case 'action':
+                case 'submit_answer':
+                case "check_up_receive":
+                case "shop_view":
+                case "add_product_view":
+                case "meetingplace_view":
+                    if (vo.code === '200' || vo.code === 200) {
+                        console.log(`任务完成成功,获得${vo.data.coins}美妆币`)
+                        if (vo.data.coins) $.coins += vo.data.coins
+                        $.total = vo.data.user_coins
+                    } else {
+                        console.log(`任务完成失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "produce_position_info_v2":
+                    // console.log(`${Boolean(oc(() => vo.data))};${oc(() => vo.data.material_name) !== ''}`);
+                    if (vo.data && vo.data.material_name !== '') {
+                        console.log(`【${oc(() => vo.data.position)}】上正在生产【${oc(() => vo.data.material_name)}】,可收取 ${vo.data.produce_num} 份`)
+                        if (new Date().getTime() > vo.data.procedure.end_at) {
+                            console.log(`去收取${oc(() => vo.data.material_name)}`)
+                            client.send(`{"msg":{"type":"action","args":{"position":"${oc(() => vo.data.position)}","replace_material":false},"action":"material_fetch_v2"}}`)
+                            await $.wait(5000);
+                            client.send(`{"msg":{"type":"action","args":{},"action":"to_employee"}}`)
+                            await $.wait(5000);
+                            $.pos.push(oc(() => vo.data.position))
+                        }
+                    } else {
+                        if (oc(() => vo.data) && vo.data.valid_electric > 0) {
+                            console.log(`【${vo.data.position}】上尚未开始生产`)
+                            let ma
+                            console.log(`$.needs:${JSON.stringify($.needs)}`);
+                            if ($.needs.length) {
+                                ma = $.needs.pop()
+                                console.log(`ma:${JSON.stringify(ma)}`);
+                            } else {
+                                ma = $.material.base[0]['items'][positionList.indexOf(vo.data.position)];
+                                console.log(`elsema:${JSON.stringify(ma)}`);
+                            }
+                            console.log(`ma booleam${Boolean(ma)}`);
+                            if (ma) {
+                                console.log(`去生产${ma.name}`)
+                                client.send(`{"msg":{"type":"action","args":{"position":"${vo.data.position}","material_id":${ma.id}},"action":"material_produce_v2"}}`)
+                                await $.wait(5000);
+                            } else {
+                                ma = $.material.base[1]['items'][positionList2.indexOf(vo.data.position)]
+                                if (ma) {
+                                    console.log(`else去生产${ma.name}`)
+                                    client.send(`{"msg":{"type":"action","args":{"position":"${vo.data.position}","material_id":${ma.id}},"action":"material_produce_v2"}}`)
+                                    await $.wait(5000);
+                                }
+                            }
+                        }
+                        else {
+                            console.log(`【${vo.data.position}】电力不足`)
+                        }
+                    }
+                    break
+                case "material_produce_v2":
+                    console.log(`【${oc(() => vo.data.position)}】上开始生产${oc(() => vo.data.material_name)}`)
+                    client.send(`{"msg":{"type":"action","args":{},"action":"to_employee"}}`)
+                    await $.wait(5000);
+                    if (oc(() => vo.data.position)) {
+                        $.pos.push(vo.data.position)
+                    } else {
+                        console.log(`not exist:${oc(() => vo.data)}`)
+                    }
+                    break
+                case "material_fetch_v2":
+                    if (vo.code === '200' || vo.code === 200) {
+                        console.log(`【${vo.data.position}】收取成功,获得${vo.data.procedure.produce_num}份${vo.data.material_name}\n`);
+                    } else {
+                        console.log(`任务完成失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "get_package":
+                    if (vo.code === '200' || vo.code === 200) {
+                        // $.products = vo.data.product
+                        $.materials = vo.data.material
+                        let msg = `仓库信息:`
+                        for (let material of $.materials) {
+                            msg += `【${material.material.name}】${material.num}份 `
+                        }
+                        console.log(msg)
+                    } else {
+                        console.log(`仓库信息获取失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "product_lists":
+                    let need_material = []
+                    if (vo.code === '200' || vo.code === 200) {
+                        $.products = vo.data.filter(vo => vo.level === $.level - 1)
+                        console.log(`========可生产商品信息========`)
+                        for (let product of $.products) {
+                            let num = Infinity
+                            let msg = ''
+                            msg += `生产【${product.name}】`
+                            for (let material of product.product_materials) {
+                                msg += `需要原料“${material.material.name}${material.num} 份” ` //material.num 需要材料数量
+                                const ma = $.materials.filter(vo => vo.item_id === material.material_id)[0] //仓库里对应的材料信息
+                                // console.log(`ma:${JSON.stringify(ma)}`);
+                                if (ma) {
+                                    msg += `(库存 ${ma.num} 份)`;
+                                    num = Math.min(num, Math.trunc(ma.num / material.num));//Math.trunc 取整数部分
+                                    if (material.num > ma.num) { need_material.push(material.material) };
+                                    // console.log(`num:${JSON.stringify(num)}`);
+                                } else {
+                                    if (need_material.findIndex(vo => vo.id === material.material.id) === -1)
+                                        need_material.push(material.material)
+                                    //console.log(`need_material:${JSON.stringify(need_material)}`);
+                                    msg += `(没有库存)`
+                                    num = -1000
+                                }
+                            }
+                            if (num !== Infinity && num > 0) {
+                                msg += `,可生产 ${num}份`
+                                console.log(msg)
+                                console.log(`【${product.name}】可生产份数大于0,去生产`)
+                                //product_produce 产品研发里的生产
+                                client.send(`{"msg":{"type":"action","args":{"product_id":${product.id},"amount":${num}},"action":"product_produce"}}`)
+                                client.send(`{"msg":{"type":"action","args":{"product_id":${product.id},"amount":${num}},"action":"once_completion"}}`)
+                                await $.wait(10000);
+                            } else {
+                                console.log(msg)
+                                console.log(`【${product.name}】原料不足,无法生产`)
+                            }
+                        }
+                        $.needs = need_material
+                        // console.log(`product_lists $.needs:${JSON.stringify($.needs)}`);
+                        console.log(`=======================`)
+                    } else {
+                        console.log(`生产信息获取失败,错误信息:${vo.msg}`)
+                    }
+                    // await $.wait(5000);
+                    // client.close();
+                    break
+                case "product_produce":
+                    if (vo.code === '200' || vo.code === 200) {
+                        // console.log(`product_produce:${JSON.stringify(vo)}`)
+                        console.log(`生产成功`)
+                    } else {
+                        console.log(`生产信息获取失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "collect_coins":
+                    if (vo.code === '200' || vo.code === 200) {
+                        // console.log(`product_produce:${JSON.stringify(vo)}`)
+                        console.log(`收取成功,获得${vo['data']['coins']}美妆币,当前总美妆币:${vo['data']['user_coins']}\n`)
+                    } else {
+                        console.log(`收取美妆币失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "product_producing":
+                    if (vo.code === '200' || vo.code === 200) {
+                        for (let product of vo.data) {
+                            if (product.num === product.produce_num) {
+                                client.send(`{"msg":{"type":"action","args":{"log_id":${product.id}},"action":"new_product_fetch"}}`)
+                                await $.wait(5000);
+                            } else {
+                                console.log(`产品【${product.product.id}】未生产完成,无法收取`)
+                            }
+                        }
+                    } else {
+                        console.log(`生产商品信息获取失败,错误信息${vo.msg}`)
+                    }
+                    break
+                case "new_product_fetch":
+                    if (vo.code === '200' || vo.code === 200) {
+                        console.log(`收取产品【${vo.data.product.name}】${vo.data.num}份`)
+                    } else {
+                        console.log(`收取产品失败,错误信息${vo.msg}`)
+                    }
+                    break
+                // case "get_task":
+                //   console.log(`当前任务【${vo.data.describe}】,需要【${vo.data.product.name}】${vo.data.package_stock}/${vo.data.num}份`)
+                //   if (vo.data.package_stock >= vo.data.num) {
+                //     console.log(`满足任务要求,去完成任务`)
+                //     client.send(`{"msg":{"type":"action","args":{"task_id":${vo.data.id}},"action":"complete_task"}}`)
+                //   }
+                //   break
+                case 'get_benefit':
+                    for (let benefit of vo.data) {
+                        if (benefit.type === 1) { //type 1 是京豆
+                            //console.log(`benefit:${JSON.stringify(benefit)}`);
+                            if (benefit.description === "1 京豆" && parseInt(benefit.day_exchange_count) < 5 && $.total > benefit.coins) {
+                                $timenum = parseInt($.total / benefit.coins);
+                                if ($timenum > 5) $timenum = 5;
+                                console.log(`\n可兑换${$timenum}次京豆:`)
+                                for (let i = 0; i < $timenum; i++) {
+                                    client.send(`{"msg":{"type":"action","args":{"benefit_id":${benefit.id}},"action":"to_exchange"}}`);
+                                    await $.wait(5000)
+                                    client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_user"}}`)
+                                    await $.wait(5000);
+                                }
+                            }
+                            // console.log(`物品【${benefit.description}】需要${benefit.coins}美妆币,库存${benefit.stock}份`)
+                            // if (parseInt(benefit.setting.beans_count) === bean && //兑换多少豆 bean500就500豆
+                            //   $.total > benefit.coins &&
+                            //   parseInt(benefit.day_exchange_count) < benefit.day_limit) {
+                            //   console.log(`满足条件,去兑换`)
+                            //   client.send(`{"msg":{"type":"action","args":{"benefit_id":${benefit.id}},"action":"to_exchange"}}`)
+                            //   await $.wait(10000)
+                            // }
+                        }
+                    }
+                    break
+                case "to_exchange":
+                    if (oc(() => vo.data.coins)) {
+                        console.log(`兑换${vo.data.coins / -10000}京豆成功`)
+                    } else {
+                        console.log(`兑换京豆失败`)
+                    }
+                    break
+                case "get_produce_material":
+                    $.material = vo.data
+                    break
+                //case "to_employee":
+                // console.log(`雇佣助力码【${oc(() => vo.data.token)}】`)
+                // if(oc(() => vo.data.token)){
+                //   $.tokens.push(vo.data.token)
+                // }else{
+                //   console.log(`not exist:${oc(() => vo.data)}`)
+                // }
+                // break
+                case "employee_v2":
+                    console.log(`${vo.msg}`)
+                    break
             }
-            await $.wait(10000);
-          }
-          for (let i = $.taskState.meetingplace_view; i < $.taskState.mettingplace_count; ++i) {
-            console.log(`去做第${i + 1}次浏览会场任务`)
-            client.send(`{"msg":{"type":"action","args":{"source":1},"action":"meetingplace_view"}}`)
-            await $.wait(10000);
-          }
-          if ($.taskState.today_answered === 0) {
-            console.log(`去做每日问答任务`)
-            client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_question"}}`)
-            await $.wait(10000);
-          }
-          break
-        case 'newcomer_update':
-          if (vo.code === '200' || vo.code === 200) {
-            console.log(`第${vo.data.step}步新手任务完成成功,获得${vo.data.coins}美妆币`)
-            if (vo.data.step === 15) $.init = true
-            if (vo.data.coins) $.coins += vo.data.coins
-          } else {
-            console.log(`新手任务完成失败,错误信息:${JSON.stringify(vo)}`)
-          }
-          break
-        case 'get_question':
-          const questions = vo.data
-          let commit = {}
-          for (let i = 0; i < questions.length; ++i) {
-            const ques = questions[i]
-            commit[`${ques.id}`] = parseInt(ques.answers)
-          }
-          client.send(`{"msg":{"type":"action","args":{"commit":${JSON.stringify(commit)},"correct":${questions.length}},"action":"submit_answer"}}`)
-          await $.wait(10000);
-          break
-        case 'complete_task':
-        case 'action':
-        case 'submit_answer':
-        case "check_up_receive":
-        case "shop_view":
-        case "add_product_view":
-        case "meetingplace_view":
-          if (vo.code === '200' || vo.code === 200) {
-            console.log(`任务完成成功,获得${vo.data.coins}美妆币`)
-            if (vo.data.coins) $.coins += vo.data.coins
-            $.total = vo.data.user_coins
-          } else {
-            console.log(`任务完成失败,错误信息${vo.msg}`)
-          }
-          break
-        case "produce_position_info_v2":
-          // console.log(`${Boolean(oc(() => vo.data))};${oc(() => vo.data.material_name) !== ''}`);
-          if (vo.data && vo.data.material_name !== '') {
-            console.log(`【${oc(() => vo.data.position)}】上正在生产【${oc(() => vo.data.material_name)}】,可收取 ${vo.data.produce_num} 份`)
-            if (new Date().getTime() > vo.data.procedure.end_at) {
-              console.log(`去收取${oc(() => vo.data.material_name)}`)
-              client.send(`{"msg":{"type":"action","args":{"position":"${oc(() => vo.data.position)}","replace_material":false},"action":"material_fetch_v2"}}`)
-              await $.wait(5000);
-              client.send(`{"msg":{"type":"action","args":{},"action":"to_employee"}}`)
-              await $.wait(5000);
-              $.pos.push(oc(() => vo.data.position))
-            }
-          } else {
-            if (oc(() => vo.data) && vo.data.valid_electric > 0) {
-              console.log(`【${vo.data.position}】上尚未开始生产`)
-              let ma
-              console.log(`$.needs:${JSON.stringify($.needs)}`);
-              if($.needs.length){
-                ma = $.needs.pop()
-                console.log(`ma:${JSON.stringify(ma)}`);
-              } else {
-                ma = $.material.base[0]['items'][positionList.indexOf(vo.data.position)];
-                console.log(`elsema:${JSON.stringify(ma)}`);
-              }
-              console.log(`ma booleam${Boolean(ma)}`);
-              if (ma) {
-                console.log(`去生产${ma.name}`)
-                client.send(`{"msg":{"type":"action","args":{"position":"${vo.data.position}","material_id":${ma.id}},"action":"material_produce_v2"}}`)
-                await $.wait(5000);
-              } else {
-                ma = $.material.base[1]['items'][positionList.indexOf(vo.data.position)]
-                if (ma) {
-                  console.log(`else去生产${ma.name}`)
-                  client.send(`{"msg":{"type":"action","args":{"position":"${vo.data.position}","material_id":${ma.id}},"action":"material_produce_v2"}}`)
-                  await $.wait(5000);
-                }
-              }
-            }
-            else{
-              console.log(`【${vo.data.position}】电力不足`)
-            }
-          }
-          break
-        case "material_produce_v2":
-          console.log(`【${oc(() => vo.data.position)}】上开始生产${oc(() => vo.data.material_name)}`)
-          client.send(`{"msg":{"type":"action","args":{},"action":"to_employee"}}`)
-          await $.wait(5000);
-          if(oc(() => vo.data.position)){
-            $.pos.push(vo.data.position)
-          }else{
-            console.log(`not exist:${oc(() => vo.data)}`)
-          }
-          break
-        case "material_fetch_v2":
-          if (vo.code === '200' || vo.code === 200) {
-            console.log(`【${vo.data.position}】收取成功,获得${vo.data.procedure.produce_num}份${vo.data.material_name}\n`);
-          } else {
-            console.log(`任务完成失败,错误信息${vo.msg}`)
-          }
-          break
-        case "get_package":
-          if (vo.code === '200' || vo.code === 200) {
-            // $.products = vo.data.product
-            $.materials = vo.data.material
-            let msg = `仓库信息:`
-            for (let material of $.materials) {
-              msg += `【${material.material.name}】${material.num}份 `
-            }
-            console.log(msg)
-          } else {
-            console.log(`仓库信息获取失败,错误信息${vo.msg}`)
-          }
-          break
-        case "product_lists":
-          let need_material = []
-          if (vo.code === '200' || vo.code === 200) {
-            $.products = vo.data.filter(vo=>vo.level===$.level)
-            console.log(`========可生产商品信息========`)
-            for (let product of $.products) {
-              let num = Infinity
-              let msg = ''
-              msg += `生产【${product.name}】`
-              for (let material of product.product_materials) {
-                msg += `需要原料“${material.material.name}${material.num} 份” ` //material.num 需要材料数量
-                const ma = $.materials.filter(vo => vo.item_id === material.material_id)[0] //仓库里对应的材料信息
-                // console.log(`ma:${JSON.stringify(ma)}`);
-                if (ma) {
-                  msg += `(库存 ${ma.num} 份)`;
-                  num = Math.min(num, Math.trunc(ma.num / material.num)) ;//Math.trunc 取整数部分
-                  if(material.num > ma.num){need_material.push(material.material)};
-                  // console.log(`num:${JSON.stringify(num)}`);
-                } else {
-                  if(need_material.findIndex(vo=>vo.id===material.material.id)===-1)
-                    need_material.push(material.material)
-                  //console.log(`need_material:${JSON.stringify(need_material)}`);
-                  msg += `(没有库存)`
-                  num = -1000
-                }
-              }
-              if (num !== Infinity && num > 0) {
-                msg += `,可生产 ${num}份`
-                console.log(msg)
-                console.log(`【${product.name}】可生产份数大于0,去生产`)
-                //product_produce 产品研发里的生产
-                client.send(`{"msg":{"type":"action","args":{"product_id":${product.id},"amount":${num}},"action":"product_produce"}}`)
-                await $.wait(10000);
-              } else {
-                console.log(msg)
-                console.log(`【${product.name}】原料不足,无法生产`)
-              }
-            }
-            $.needs = need_material
-            // console.log(`product_lists $.needs:${JSON.stringify($.needs)}`);
-            console.log(`=======================`)
-          } else {
-            console.log(`生产信息获取失败,错误信息:${vo.msg}`)
-          }
-          // await $.wait(5000);
-          // client.close();
-          break
-        case "product_produce":
-          if (vo.code === '200' || vo.code === 200) {
-            // console.log(`product_produce:${JSON.stringify(vo)}`)
-            console.log(`生产成功`)
-          } else {
-            console.log(`生产信息获取失败,错误信息${vo.msg}`)
-          }
-          break
-        case "collect_coins":
-          if (vo.code === '200' || vo.code === 200) {
-            // console.log(`product_produce:${JSON.stringify(vo)}`)
-            console.log(`收取成功,获得${vo['data']['coins']}美妆币,当前总美妆币:${vo['data']['user_coins']}\n`)
-          } else {
-            console.log(`收取美妆币失败,错误信息${vo.msg}`)
-          }
-          break
-        case "product_producing":
-          if (vo.code === '200' || vo.code === 200) {
-            for (let product of vo.data) {
-              if (product.num === product.produce_num) {
-                client.send(`{"msg":{"type":"action","args":{"log_id":${product.id}},"action":"new_product_fetch"}}`)
-                await $.wait(5000);
-              } else {
-                console.log(`产品【${product.product.id}】未生产完成,无法收取`)
-              }
-            }
-          } else {
-            console.log(`生产商品信息获取失败,错误信息${vo.msg}`)
-          }
-          break
-        case "new_product_fetch":
-          if (vo.code === '200' || vo.code === 200) {
-            console.log(`收取产品【${vo.data.product.name}】${vo.data.num}份`)
-          } else {
-            console.log(`收取产品失败,错误信息${vo.msg}`)
-          }
-          break
-          // case "get_task":
-          //   console.log(`当前任务【${vo.data.describe}】,需要【${vo.data.product.name}】${vo.data.package_stock}/${vo.data.num}份`)
-          //   if (vo.data.package_stock >= vo.data.num) {
-          //     console.log(`满足任务要求,去完成任务`)
-          //     client.send(`{"msg":{"type":"action","args":{"task_id":${vo.data.id}},"action":"complete_task"}}`)
-          //   }
-          //   break
-        case 'get_benefit':
-          for (let benefit of vo.data) {
-            if (benefit.type === 1) { //type 1 是京豆
-              //console.log(`benefit:${JSON.stringify(benefit)}`);
-              if(benefit.description === "1 京豆" && parseInt(benefit.day_exchange_count) < 10 && $.total > benefit.coins){
-                $timenum = parseInt($.total / benefit.coins);
-                if ($timenum > 10) $timenum = 10;
-                console.log(`\n可兑换${$timenum}次京豆:`)
-                for (let i = 0; i < $timenum; i++){
-                  client.send(`{"msg":{"type":"action","args":{"benefit_id":${benefit.id}},"action":"to_exchange"}}`);
-                  await $.wait(5000)
-                  client.send(`{"msg":{"type":"action","args":{"source":1},"action":"get_user"}}`)
-                  await $.wait(5000);
-                }
-              }
-              // console.log(`物品【${benefit.description}】需要${benefit.coins}美妆币,库存${benefit.stock}份`)
-              // if (parseInt(benefit.setting.beans_count) === bean && //兑换多少豆 bean500就500豆
-              //   $.total > benefit.coins &&
-              //   parseInt(benefit.day_exchange_count) < benefit.day_limit) {
-              //   console.log(`满足条件,去兑换`)
-              //   client.send(`{"msg":{"type":"action","args":{"benefit_id":${benefit.id}},"action":"to_exchange"}}`)
-              //   await $.wait(10000)
-              // }
-            }
-          }
-          break
-        case "to_exchange":
-          if(oc(() => vo.data.coins)){
-            console.log(`兑换${vo.data.coins/-1000}京豆成功`)
-          }else{
-            console.log(`兑换京豆失败`)
-          }
-          break
-        case "get_produce_material":
-          $.material = vo.data
-          break
-        case "to_employee":
-          console.log(`雇佣助力码【${oc(() => vo.data.token)}】`)
-          if(oc(() => vo.data.token)){
-            $.tokens.push(vo.data.token)
-          }else{
-            console.log(`not exist:${oc(() => vo.data)}`)
-          }
-          break
-        case "employee":
-          console.log(`${vo.msg}`)
-          break
-      }
-    }
-  };
+        }
+    };
 }
 
 function getIsvToken() {
-  let config = {
-    url: 'https://api.m.jd.com/client.action?functionId=genToken',
-    body: 'body=%7B%22to%22%3A%22https%3A%5C/%5C/xinruimz-isv.isvjcloud.com%5C/?channel%3Dmeizhuangguandibudaohang%26collectionId%3D96%26tttparams%3DYEyYQjMIeyJnTG5nIjoiMTE4Ljc2MjQyMSIsImdMYXQiOiIzMi4yNDE4ODIifQ8%253D%253D%26un_area%3D12_904_908_57903%26lng%3D118.7159742308471%26lat%3D32.2010317443041%22%2C%22action%22%3A%22to%22%7D&build=167490&client=apple&clientVersion=9.3.2&openudid=53f4d9c70c1c81f1c8769d2fe2fef0190a3f60d2&osVersion=14.2&partner=apple&rfs=0000&scope=01&sign=b0aac3dd04b1c6d68cee3d425e27f480&st=1610161913667&sv=111',
-    headers: {
-      'Host': 'api.m.jd.com',
-      'accept': '*/*',
-      'user-agent': UA,
-      'content-type': 'application/x-www-form-urlencoded',
-      'Cookie': cookie
-    }
-  }
-  return new Promise(resolve => {
-    $.post(config, async (err, resp, data) => {
-      try {
-        if (err) {
-          console.log(`${$.name} API请求失败,请检查网路重试`);
-          console.log(`${JSON.stringify(err)}`)
-        } else {
-          if (safeGet(data)) {
-            data = JSON.parse(data);
-            $.isvToken = data['tokenKey'];
-            console.log(`isvToken:${$.isvToken}`);
-          }
+    let config = {
+        url: 'https://api.m.jd.com/client.action?functionId=genToken',
+        body: 'body=%7B%22to%22%3A%22https%3A%5C/%5C/xinruimz-isv.isvjcloud.com%5C/?channel%3Dmeizhuangguandibudaohang%26collectionId%3D96%26tttparams%3DYEyYQjMIeyJnTG5nIjoiMTE4Ljc2MjQyMSIsImdMYXQiOiIzMi4yNDE4ODIifQ8%253D%253D%26un_area%3D12_904_908_57903%26lng%3D118.7159742308471%26lat%3D32.2010317443041%22%2C%22action%22%3A%22to%22%7D&build=167490&client=apple&clientVersion=9.3.2&openudid=53f4d9c70c1c81f1c8769d2fe2fef0190a3f60d2&osVersion=14.2&partner=apple&rfs=0000&scope=01&sign=b0aac3dd04b1c6d68cee3d425e27f480&st=1610161913667&sv=111',
+        headers: {
+            'Host': 'api.m.jd.com',
+            'accept': '*/*',
+            'user-agent': UA,
+            'content-type': 'application/x-www-form-urlencoded',
+            'Cookie': cookie
         }
-      } catch (e) {
-        $.logErr(e, resp)
-      } finally {
-        resolve(data);
-      }
+    }
+    return new Promise(resolve => {
+        $.post(config, async (err, resp, data) => {
+            try {
+                if (err) {
+                    console.log(`${$.name} API请求失败,请检查网路重试`);
+                    console.log(`${JSON.stringify(err)}`)
+                } else {
+                    if (safeGet(data)) {
+                        data = JSON.parse(data);
+                        $.isvToken = data['tokenKey'];
+                        //console.log(`isvToken:${$.isvToken}`);
+                    }
+                }
+            } catch (e) {
+                $.logErr(e, resp)
+            } finally {
+                resolve(data);
+            }
+        })
     })
-  })
 }
 
 async function getIsvToken2() {
-  let config = {
-    url: 'https://api.m.jd.com/client.action?functionId=isvObfuscator',
-    body: await getSignfromDY('isvObfuscator',{"id":"","url":"https://xinruimz-isv.isvjcloud.com"}),
-    headers: {
-      'Host': 'api.m.jd.com',
-      'accept': '*/*',
-      'user-agent': UA,
-      'accept-language': 'zh-Hans-JP;q=1, en-JP;q=0.9, zh-Hant-TW;q=0.8, ja-JP;q=0.7, en-US;q=0.6',
-      'content-type': 'application/x-www-form-urlencoded',
-      'Cookie': cookie
+    for (let i = 0; i < 3; i++) {
+        var body = await getSignfromDY('isvObfuscator', { "id": "", "url": "https://xinruimz-isv.isvjcloud.com" })
+        if (body) break;
+        await $.wait(5000)
     }
-  }
-  return new Promise(resolve => {
-    $.post(config, async (err, resp, data) => {
-      try {
-        if (err) {
-          console.log(`${JSON.stringify(err)}`)
-          console.log(`${$.name} API请求失败,请检查网路重试`)
-        } else {
-          if (safeGet(data)) {
-            data = JSON.parse(data);
-            $.token2 = data['token']
-            console.log(`token2:${$.token2}`);
-          }
+    let config = {
+        url: 'https://api.m.jd.com/client.action?functionId=isvObfuscator',
+        body: body,
+        headers: {
+            'Host': 'api.m.jd.com',
+            'accept': '*/*',
+            'user-agent': UA,
+            //'accept-language': 'zh-Hans-JP;q=1, en-JP;q=0.9, zh-Hant-TW;q=0.8, ja-JP;q=0.7, en-US;q=0.6',
+            //'content-type': 'application/x-www-form-urlencoded',
+            'Cookie': cookie
         }
-      } catch (e) {
-        $.logErr(e, resp)
-      } finally {
-        resolve(data);
-      }
+    }
+
+    return new Promise(resolve => {
+        $.post(config, async (err, resp, data) => {
+            try {
+                if (err) {
+                    console.log(`${JSON.stringify(err)}`)
+                    console.log(`${$.name} API请求失败,请检查网路重试`)
+                } else {
+                    if (safeGet(data)) {
+                        data = JSON.parse(data);
+                        $.token2 = data['token']
+                        //console.log(`token2:${$.token2}`);
+                    }
+                }
+            } catch (e) {
+                $.logErr(e, resp)
+            } finally {
+                resolve(data);
+            }
+        })
     })
-  })
 }
 function getSignfromDY(functionId, body) {
-  var strsign = '';
-  let data = `functionId=${functionId}&body=${encodeURIComponent(JSON.stringify(body))}`
-  return new Promise((resolve) => {
-    let opt = {
-      url: "https://jd.nbplay.xyz/dylan/getsign",
-      body: data,
-      headers: {
-        'Content-Type': 'application/x-www-form-urlencoded',
-      }
-      ,timeout: 30000
-    }
-    $.post(opt, async(err, resp, data) => {
-      try {
-        if (data){
-          data = JSON.parse(data);
-          if (data && data.code == 0) {
-            console.log("连接DY服务成功" );
-            if (data.data){
-              strsign = data.data || '';
+    var strsign = '';
+    let data = { 'fn': functionId, 'body': JSON.stringify(body) };
+    return new Promise((resolve) => {
+        let opt = {
+            url: "https://api.nolanstore.top/sign",
+            body: JSON.stringify(data),
+            headers: {
+                'Content-Type': 'application/json',
             }
-            if (strsign != ''){
-              resolve(strsign);
-            }
-            else
-              console.log("签名获取失败,换个时间再试.");
-          } else {
-            console.log(data.msg);
-          }
-        }else{console.log('连接连接DY服务失败,重试。。。')}
-      }catch (e) {
-        $.logErr(e, resp);
-      }finally {
-        resolve(strsign);
-      }
-    })
-  })
-}
-function getAuth() {
-  let config = {
-    url: 'https://xinruimz-isv.isvjcloud.com/api/auth',
-    body: JSON.stringify({"token":$.token2,"source":"01"}),
-    headers: {
-      'Host': 'xinruimz-isv.isvjcloud.com',
-      'Accept': 'application/x.jd-school-island.v1+json',
-      'Source': '02',
-      'Accept-Language': 'zh-cn',
-      'Content-Type': 'application/json;charset=utf-8',
-      'Origin': 'https://xinruimz-isv.isvjcloud.com',
-      'user-agent': UA,
-      'Referer': 'https://xinruimz-isv.isvjcloud.com/logined_jd/',
-      'Authorization': 'Bearer undefined',
-      'Cookie': `IsvToken=${$.isvToken};`
-    }
-  }
-  return new Promise(resolve => {
-    $.post(config, async (err, resp, data) => {
-      try {
-        if (err) {
-          console.log(`${JSON.stringify(err)}`)
-          console.log(`${$.name} API请求失败,请检查网路重试`)
-        } else {
-          if (safeGet(data)) {
-            data = JSON.parse(data);
-            $.token = data.access_token
-            console.log(`$.token ${$.token}`)
-          }
+            , timeout: 30000
         }
-      } catch (e) {
-        $.logErr(e, resp)
-      } finally {
-        resolve(data);
-      }
+        $.post(opt, async (err, resp, data) => {
+            try {
+                if (data) {
+                    data = JSON.parse(data);
+                    if (data && data.body) {
+                        console.log("连接Nolan服务成功");
+                            strsign = data.body || '';
+                        if (strsign != '') {
+                            resolve(strsign);
+                        }
+                        else
+                            console.log("签名获取失败,换个时间再试.");
+                    } else {
+                        console.log(data.msg);
+                    }
+                } else { console.log('连接服务失败,重试。。。') }
+            } catch (e) {
+                $.logErr(e, resp);
+            } finally {
+                resolve(strsign);
+            }
+        })
+    })
+}
+function getToken() {
+    let config = {
+        url: 'https://xinruimz-isv.isvjcloud.com/api/auth',
+        body: JSON.stringify({ "token": $.token2, "source": "01", "channel": "meizhuangguandibudaohang" }),
+        headers: {
+            'Host': 'xinruimz-isv.isvjcloud.com',
+            'Accept': 'application/x.jd-school-island.v1+json',
+            'Source': '02',
+            'Accept-Language': 'zh-cn',
+            'Content-Type': 'application/json;charset=utf-8',
+            'Origin': 'https://xinruimz-isv.isvjcloud.com',
+            'user-agent': UA,
+            'Referer': 'https://xinruimz-isv.isvjcloud.com/logined_jd/',
+            'Authorization': 'Bearer undefined',
+            'Cookie': `IsvToken=${$.token2};`
+        }
+    }
+    return new Promise(resolve => {
+        $.post(config, async (err, resp, data) => {
+            try {
+                if (err) {
+                    console.log(`${JSON.stringify(err)}`)
+                    console.log(`${$.name} API请求失败,请检查网路重试`)
+                } else {
+                    if (safeGet(data)) {
+                        data = JSON.parse(data);
+                        $.token = data.access_token
+                        console.log(`$.token ${$.token}`)
+                    }
+                }
+            } catch (e) {
+                $.logErr(e, resp)
+            } finally {
+                resolve(data);
+            }
+        })
     })
-  })
 }
 
 function showMsg() {
-  return new Promise(resolve => {
-    message += `本次运行获得美妆币${$.coins}枚\n当前美妆币${$.total}`;
-    $.msg($.name, '', `京东账号${$.index}${$.nickName}\n${message}`);
-    resolve()
-  })
+    return new Promise(resolve => {
+        message += `本次运行获得美妆币${$.coins}枚\n当前美妆币${$.total}`;
+        $.msg($.name, '', `京东账号${$.index}${$.nickName}\n${message}`);
+        resolve()
+    })
 }
 
 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': UA,
-      }
-    }
-    $.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
+    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': UA,
             }
-            if (data['retcode'] === 0) {
-              $.nickName = (data['base'] && data['base'].nickname) || $.UserName;
-            } else {
-              $.nickName = $.UserName
-            }
-          } else {
-            console.log(`京东服务器返回空数据`)
-          }
         }
-      } catch (e) {
-        $.logErr(e, resp)
-      } finally {
-        resolve();
-      }
+        $.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
+                        }
+                        if (data['retcode'] === 0) {
+                            $.nickName = (data['base'] && data['base'].nickname) || $.UserName;
+                        } else {
+                            $.nickName = $.UserName
+                        }
+                    } else {
+                        console.log(`京东服务器返回空数据`)
+                    }
+                }
+            } catch (e) {
+                $.logErr(e, resp)
+            } finally {
+                resolve();
+            }
+        })
     })
-  })
 }
 
 function safeGet(data) {
-  try {
-    if (typeof JSON.parse(data) == "object") {
-      return true;
+    try {
+        if (typeof JSON.parse(data) == "object") {
+            return true;
+        }
+    } catch (e) {
+        console.log(e);
+        console.log(`京东服务器访问数据为空,请检查自身设备网络情况`);
+        return false;
     }
-  } catch (e) {
-    console.log(e);
-    console.log(`京东服务器访问数据为空,请检查自身设备网络情况`);
-    return false;
-  }
 }
 
 function jsonParse(str) {
-  if (typeof str == "string") {
-    try {
-      return JSON.parse(str);
-    } catch (e) {
-      console.log(e);
-      $.msg($.name, '', '不要在BoxJS手动复制粘贴修改cookie')
-      return [];
+    if (typeof str == "string") {
+        try {
+            return JSON.parse(str);
+        } catch (e) {
+            console.log(e);
+            $.msg($.name, '', '不要在BoxJS手动复制粘贴修改cookie')
+            return [];
+        }
     }
-  }
 }
 
 // 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"){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)})})}get(t){return this.send.call(this.env,t)}post(t){return this.send.call(this.env,t,"POST")}}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("",`🔔${this.name}, 开始!`)}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}toObj(t,e=null){try{return JSON.parse(t)}catch{return e}}toStr(t,e=null){try{return JSON.stringify(t)}catch{return e}}getjson(t,e){let s=e;const i=this.getdata(t);if(i)try{s=JSON.parse(this.getdata(t))}catch{}return s}setjson(t,e){try{return this.setdata(JSON.stringify(t),e)}catch{return!1}}getScript(t){return new Promise(e=>{this.get({url:t},(t,s,i)=>e(i))})}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("@"),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))}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),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;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),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){const i=e.replace(/\[(\d+)\]/g,".$1").split(".");let r=t;for(const t of i)if(r=Object(r)[t],void 0===r)return s;return r}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){let e=this.getval(t);if(/^@/.test(t)){const[,s,i]=/^@(.*?)\.(.*?)$/.exec(t),r=s?this.getval(s):"";if(r)try{const t=JSON.parse(r);e=t?this.lodash_get(t,i,""):e}catch(t){e=""}}return e}setdata(t,e){let s=!1;if(/^@/.test(e)){const[,i,r]=/^@(.*?)\.(.*?)$/.exec(e),o=this.getval(i),h=i?"null"===o?null:o||"{}":"{}";try{const e=JSON.parse(h);this.lodash_set(e,r,t),s=this.setval(JSON.stringify(e),i)}catch(e){const o={};this.lodash_set(o,r,t),s=this.setval(JSON.stringify(o),i)}}else s=this.setval(t,e);return s}getval(t){return this.isSurge()||this.isLoon()?$persistentStore.read(t):this.isQuanX()?$prefs.valueForKey(t):this.isNode()?(this.data=this.loaddata(),this.data[t]):this.data&&this.data[t]||null}setval(t,e){return this.isSurge()||this.isLoon()?$persistentStore.write(t,e):this.isQuanX()?$prefs.setValueForKey(t,e):this.isNode()?(this.data=this.loaddata(),this.data[e]=t,this.writedata(),!0):this.data&&this.data[e]||null}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,e=(()=>{})){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)=>{try{if(t.headers["set-cookie"]){const s=t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString();s&&this.ckjar.setCookieSync(s,null),e.cookieJar=this.ckjar}}catch(t){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)}))}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)=>{!t&&s&&(s.body=i,s.statusCode=s.status),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=>{const{statusCode:s,statusCode:i,headers:r,body:o}=t;e(null,{status:s,statusCode:i,headers:r,body:o},o)},t=>e(t));else if(this.isNode()){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)})}}time(t,e=null){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)));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)));return t}msg(e=t,s="",i="",r){const o=t=>{if(!t)return t;if("string"==typeof t)return this.isLoon()?t:this.isQuanX()?{"open-url":t}:this.isSurge()?{url:t}:void 0;if("object"==typeof t){if(this.isLoon()){let e=t.openUrl||t.url||t["open-url"],s=t.mediaUrl||t["media-url"];return{openUrl:e,mediaUrl:s}}if(this.isQuanX()){let e=t["open-url"]||t.url||t.openUrl,s=t["media-url"]||t.mediaUrl;return{"open-url":e,"media-url":s}}if(this.isSurge()){let e=t.url||t.openUrl||t["open-url"];return{url:e}}}};if(this.isMute||(this.isSurge()||this.isLoon()?$notification.post(e,s,i,o(r)):this.isQuanX()&&$notify(e,s,i,o(r))),!this.isMuteLog){let t=["","==============📣系统通知📣=============="];t.push(e),s&&t.push(s),i&&t.push(i),console.log(t.join("\n")),this.logs=this.logs.concat(t)}}log(...t){t.length>0&&(this.logs=[...this.logs,...t]),console.log(t.join(this.logSeparator))}logErr(t,e){const s=!this.isSurge()&&!this.isQuanX()&&!this.isLoon();s?this.log("",`❗️${this.name}, 错误!`,t.stack):this.log("",`❗️${this.name}, 错误!`,t)}wait(t){return new Promise(e=>setTimeout(e,t))}done(t={}){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)}
\ No newline at end of file
+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") { 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) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } 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("", `🔔${this.name}, 开始!`) } 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 } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } 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("@"), 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)) } 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), 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; 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), 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) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } 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) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } 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, e = (() => { })) { 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) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { 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) })) } 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) => { !t && s && (s.body = i, s.statusCode = s.status), 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 => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { 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) }) } } time(t, e = null) { 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))); 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))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { 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) }
\ No newline at end of file