Merge pull request #583 from FanchangWang/master
[京喜农场] fix 助力码变量错误 & add 跳过自己账户的助力码
This commit is contained in:
139
jd_jxnc.js
139
jd_jxnc.js
@@ -32,6 +32,8 @@ cron "0 9,12,18 * * *" script-path=https://raw.githubusercontent.com/lxk0301/jd_
|
|||||||
|
|
||||||
const $ = new Env('京喜农场');
|
const $ = new Env('京喜农场');
|
||||||
let notify = ''; // nodejs 发送通知脚本
|
let notify = ''; // nodejs 发送通知脚本
|
||||||
|
let notifyLevel = process.env.JXNC_NOTIFY_LEVEL || 3; // 通知级别 0=不通知;1=本次获得水滴>0;2=任务执行;3=任务执行+未种植种子;
|
||||||
|
let notifyBool = true; // 代码内部使用,控制是否通知
|
||||||
let cookieArr = []; // 用户 cookie 数组
|
let cookieArr = []; // 用户 cookie 数组
|
||||||
let currentCookie = ''; // 当前用户 cookie
|
let currentCookie = ''; // 当前用户 cookie
|
||||||
let tokenNull = {'farm_jstoken': '', 'phoneid': '', 'timestamp': ''}; // 内置一份空的 token
|
let tokenNull = {'farm_jstoken': '', 'phoneid': '', 'timestamp': ''}; // 内置一份空的 token
|
||||||
@@ -44,19 +46,21 @@ const openUrl = `openjd://virtual?params=${encodeURIComponent('{ "category": "ju
|
|||||||
let subTitle = '', message = '', option = {'open-url': openUrl}; // 消息副标题,消息正文,消息扩展参数
|
let subTitle = '', message = '', option = {'open-url': openUrl}; // 消息副标题,消息正文,消息扩展参数
|
||||||
const JXNC_API_HOST = 'https://wq.jd.com/';
|
const JXNC_API_HOST = 'https://wq.jd.com/';
|
||||||
|
|
||||||
|
$.detail = []; // 今日明细列表
|
||||||
$.helpTask = null;
|
$.helpTask = null;
|
||||||
$.allTask = []; // 任务列表
|
$.allTask = []; // 任务列表
|
||||||
$.info = {}; // 用户信息
|
$.info = {}; // 用户信息
|
||||||
$.answer = 0;
|
$.answer = 0;
|
||||||
$.drip = 0;
|
$.drip = 0;
|
||||||
$.maxHelpNum = shareCode.split('@').length; // 助力 ret 1011 错误最大计数
|
$.maxHelpNum = $.isNode() ? 8 : 3; // 助力 ret 1011 错误最大计数
|
||||||
$.helpNum = 0; // 当前账号 助力 ret 1011 次数
|
$.helpNum = 0; // 当前账号 助力 ret 1011 次数
|
||||||
|
let assistUserShareCode = 0; // 随机助力用户 share code
|
||||||
|
|
||||||
!(async () => {
|
!(async () => {
|
||||||
await requireConfig();
|
await requireConfig();
|
||||||
if (!cookieArr[0]) {
|
if (!cookieArr[0]) {
|
||||||
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/bean/signIndex.action', {"open-url": "https://bean.m.jd.com/bean/signIndex.action"});
|
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/bean/signIndex.action', {"open-url": "https://bean.m.jd.com/bean/signIndex.action"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < cookieArr.length; i++) {
|
for (let i = 0; i < cookieArr.length; i++) {
|
||||||
@@ -99,6 +103,7 @@ function requireConfig() {
|
|||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
$.log('开始获取配置文件\n')
|
$.log('开始获取配置文件\n')
|
||||||
notify = $.isNode() ? require('./sendNotify') : '';
|
notify = $.isNode() ? require('./sendNotify') : '';
|
||||||
|
notifyBool = notifyLevel > 0; // 初始化是否推送
|
||||||
//Node.js用户请在jdCookie.js处填写京东ck;
|
//Node.js用户请在jdCookie.js处填写京东ck;
|
||||||
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
||||||
const jdTokenNode = $.isNode() ? require('./jdJxncTokens.js') : '';
|
const jdTokenNode = $.isNode() ? require('./jdJxncTokens.js') : '';
|
||||||
@@ -120,7 +125,7 @@ function requireConfig() {
|
|||||||
|
|
||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
Object.keys(jdTokenNode).forEach((item) => {
|
Object.keys(jdTokenNode).forEach((item) => {
|
||||||
tokenArr.push(tokenArr[item] ? JSON.parse(jxncShareCodeArr[item]) : tokenNull)
|
tokenArr.push(jdTokenNode[item] ? JSON.parse(jdTokenNode[item]) : tokenNull)
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
tokenArr.push(...[$.getdata('jxnc_token1') || tokenNull, $.getdata('jxnc_token2') || tokenNull]);
|
tokenArr.push(...[$.getdata('jxnc_token1') || tokenNull, $.getdata('jxnc_token2') || tokenNull]);
|
||||||
@@ -218,27 +223,38 @@ async function jdJXNC() {
|
|||||||
subTitle = `【京东账号${$.index}】${$.nickName}`;
|
subTitle = `【京东账号${$.index}】${$.nickName}`;
|
||||||
$.log(`获取用户信息 & 任务列表`);
|
$.log(`获取用户信息 & 任务列表`);
|
||||||
const startInfo = await getTaskList();
|
const startInfo = await getTaskList();
|
||||||
if (!startInfo) { // 未选择种子时,当前账号流程结束
|
if (startInfo.prizename) {
|
||||||
return false;
|
message += `【水果名称】${startInfo.prizename}\n`;
|
||||||
}
|
}
|
||||||
message += `【水果名称】${startInfo.prizename}\n`;
|
if (startInfo) {
|
||||||
$.log(`【京东账号${$.index}(${$.nickName || $.UserName})的${$.name}好友互助码】 ${$.info.smp}`);
|
$.log(`【京东账号${$.index}(${$.nickName || $.UserName})的${$.name}好友互助码】 ${$.info.smp}`);
|
||||||
$.log(`【京东账号${$.index}(${$.nickName || $.UserName})的${$.name}种子active】 ${$.info.active}`);
|
$.log(`【京东账号${$.index}(${$.nickName || $.UserName})的${$.name}种子active】 ${$.info.active}`);
|
||||||
await $.wait(500);
|
|
||||||
const isOk = await browserTask();
|
|
||||||
if (!isOk) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
await $.wait(500);
|
|
||||||
await answerTask();
|
|
||||||
await $.wait(500);
|
|
||||||
const endInfo = await getTaskList();
|
|
||||||
getMessage(endInfo, startInfo);
|
|
||||||
const next = await helpFriends();
|
|
||||||
if (next) {
|
|
||||||
await submitInviteId($.UserName);
|
|
||||||
await $.wait(500);
|
await $.wait(500);
|
||||||
await createAssistUser();
|
const isOk = await browserTask();
|
||||||
|
if (isOk) {
|
||||||
|
await $.wait(500);
|
||||||
|
await answerTask();
|
||||||
|
await $.wait(500);
|
||||||
|
const endInfo = await getTaskList();
|
||||||
|
getMessage(endInfo, startInfo);
|
||||||
|
let next = await helpFriends();
|
||||||
|
if (next) {
|
||||||
|
await submitInviteId($.UserName);
|
||||||
|
await $.wait(500);
|
||||||
|
while (true) {
|
||||||
|
assistUserShareCode = await getAssistUser();
|
||||||
|
if (assistUserShareCode) {
|
||||||
|
await $.wait(300);
|
||||||
|
next = await helpShareCode(assistUserShareCode);
|
||||||
|
if (next) {
|
||||||
|
await $.wait(200);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
await showMsg()
|
await showMsg()
|
||||||
}
|
}
|
||||||
@@ -250,16 +266,15 @@ function getTaskList() {
|
|||||||
try {
|
try {
|
||||||
const res = data.match(/try\{whyour\(([\s\S]*)\)\;\}catch\(e\)\{\}/)[1];
|
const res = data.match(/try\{whyour\(([\s\S]*)\)\;\}catch\(e\)\{\}/)[1];
|
||||||
const {detail, msg, task = [], retmsg, ...other} = JSON.parse(res);
|
const {detail, msg, task = [], retmsg, ...other} = JSON.parse(res);
|
||||||
$.helpTask = task.filter(x => x.tasktype === 2)[0] || { eachtimeget: 0, limit: 0 };
|
$.detail = detail;
|
||||||
|
$.helpTask = task.filter(x => x.tasktype === 2)[0] || {eachtimeget: 0, limit: 0};
|
||||||
$.allTask = task.filter(x => x.tasktype !== 3 && x.tasktype !== 2 && parseInt(x.left) > 0);
|
$.allTask = task.filter(x => x.tasktype !== 3 && x.tasktype !== 2 && parseInt(x.left) > 0);
|
||||||
$.info = other;
|
$.info = other;
|
||||||
$.log(`获取任务列表 ${retmsg} 总共${$.allTask.length}个任务!`);
|
$.log(`获取任务列表 ${retmsg} 总共${$.allTask.length}个任务!`);
|
||||||
if (!$.info.active) {
|
if (!$.info.active) {
|
||||||
$.log('账号未选择种子,请先去京喜农场选择种子,选择 APP 专属种子时,必须提供 token');
|
$.log('账号未选择种子,请先去京喜农场选择种子。\n如果选择 APP 专属种子,必须提供 token。');
|
||||||
$.msg($.name, subTitle, '请先去京喜农场选择种子!\n选择app专属种子时,请参考脚本头部说明获取token,点击通知跳转', option);
|
message += '账号未选择种子,请先去京喜农场选择种子。\n如果选择 APP 专属种子,必须提供 token。\n';
|
||||||
if ($.isNode()) {
|
notifyBool = notifyBool && notifyLevel >= 3;
|
||||||
await notify.sendNotify(`${$.name}`, `京东账号${$.index}[${$.nickName || $.UserName}]请先去京喜农场选择种子!\n选择app专属种子时,请参考脚本头部说明获取token`);
|
|
||||||
}
|
|
||||||
resolve(false);
|
resolve(false);
|
||||||
}
|
}
|
||||||
resolve(other);
|
resolve(other);
|
||||||
@@ -292,10 +307,7 @@ function browserTask() {
|
|||||||
}
|
}
|
||||||
if (status[0] === 1032) {
|
if (status[0] === 1032) {
|
||||||
$.log('任务执行失败,种植的 APP 专属种子,请提供 token 或种植非 APP 种子');
|
$.log('任务执行失败,种植的 APP 专属种子,请提供 token 或种植非 APP 种子');
|
||||||
$.msg($.name, '请参考脚本头部说明获取token', '或者改中非app专属种子,点击通知跳转', option);
|
message += '任务执行失败,种植的 APP 专属种子,请提供 token 或种植非 APP 种子\n';
|
||||||
if ($.isNode()) {
|
|
||||||
await notify.sendNotify(`${$.name}`, `京东账号${$.index}[${$.nickName || $.UserName}]请参考脚本头部说明获取token\n或者改中非app专属种子`);
|
|
||||||
}
|
|
||||||
resolve(false);
|
resolve(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -348,14 +360,28 @@ function answerTask() {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function getMessage(endInfo) {
|
function getMessage(endInfo, startInfo) {
|
||||||
const need = endInfo.target - endInfo.score;
|
const need = endInfo.target - endInfo.score;
|
||||||
const get = $.drip;
|
const get = endInfo.modifyscore; // 本地变更获得水滴
|
||||||
message += `【水滴】获得水滴${get} 还需水滴${need}\n`;
|
const leaveGet = startInfo.modifyscore; // 离开时获得水滴
|
||||||
if (get > 0) {
|
let dayGet = 0; // 今日共获取水滴数
|
||||||
const max = parseInt(need / get);
|
if ($.detail) {
|
||||||
const min = parseInt(need / (get + $.helpTask.limit * $.helpTask.eachtimeget));
|
let dayTime = new Date(new Date().toLocaleDateString()).getTime() / 1000; // 今日 0 点时间戳(10位数)
|
||||||
message += `【预测】还需 ${min} ~ ${max} 天\n`;
|
$.detail.forEach(function (item, index) {
|
||||||
|
if (item.time >= dayTime && item.score) {
|
||||||
|
dayGet += item.score;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
message += `【水滴】本次获得${get} 离线获得${leaveGet} 今日获得${dayGet} 还需水滴${need}\n`;
|
||||||
|
if (get > 0 || leaveGet > 0 || dayGet > 0) {
|
||||||
|
const day = parseInt(need / (dayGet > 0 ? dayGet : (get + leaveGet)));
|
||||||
|
message += `【预测】还需 ${day} 天\n`;
|
||||||
|
}
|
||||||
|
if (get > 0 || leaveGet > 0) { // 本次 或 离线 有水滴
|
||||||
|
notifyBool = notifyBool && notifyLevel >= 1;
|
||||||
|
} else {
|
||||||
|
notifyBool = notifyBool && notifyLevel >= 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -387,26 +413,21 @@ function submitInviteId(userName) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取随机助力码并助力
|
function getAssistUser() {
|
||||||
function createAssistUser() {
|
|
||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
$.get({url: `https://api.ninesix.cc/api/jx-nc?active=${$.info.active}`}, async (err, resp, _data) => {
|
$.get({url: `https://api.ninesix.cc/api/jx-nc?active=${$.info.active}`}, async (err, resp, _data) => {
|
||||||
try {
|
try {
|
||||||
const {code, data = {}} = JSON.parse(_data);
|
const {code, data = {}} = JSON.parse(_data);
|
||||||
$.log(`获取随机助力码 ${code}`);
|
if (data.value) {
|
||||||
if (!data.value) {
|
$.log(`获取随机助力码成功 ${code} ${data.value}`);
|
||||||
$.log('随机助力码不存在,跳过助力');
|
resolve(data.value);
|
||||||
resolve();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const next = await helpShareCode(data.value);
|
|
||||||
if (next) {
|
|
||||||
await createAssistUser();
|
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
$.log(`获取随机助力码失败 ${code}`);
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
$.logErr(e, resp);
|
$.logErr(e, resp);
|
||||||
|
} finally {
|
||||||
|
resolve(false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -429,13 +450,17 @@ async function helpFriends() {
|
|||||||
// 执行助力 return true 继续助力 false 助力结束
|
// 执行助力 return true 继续助力 false 助力结束
|
||||||
function helpShareCode(code) {
|
function helpShareCode(code) {
|
||||||
return new Promise(async resolve => {
|
return new Promise(async resolve => {
|
||||||
|
if (code === $.info.smp) { // 自己的助力码,跳过,继续执行
|
||||||
|
$.log('助力码与当前账号相同,跳过助力。准备进行下一个助力');
|
||||||
|
resolve(true);
|
||||||
|
}
|
||||||
$.get(
|
$.get(
|
||||||
taskUrl('help', `active=${$.info.active}&joinnum=${$.info.joinnum}&smp=${code}`),
|
taskUrl('help', `active=${$.info.active}&joinnum=${$.info.joinnum}&smp=${code}`),
|
||||||
async (err, resp, data) => {
|
async (err, resp, data) => {
|
||||||
try {
|
try {
|
||||||
const res = data.match(/try\{whyour\(([\s\S]*)\)\;\}catch\(e\)\{\}/)[1];
|
const res = data.match(/try\{whyour\(([\s\S]*)\)\;\}catch\(e\)\{\}/)[1];
|
||||||
const {ret, retmsg = ''} = JSON.parse(res);
|
const {ret, retmsg = ''} = JSON.parse(res);
|
||||||
$.log(`助力结果:ret=${ret} retmsg="${retmsg ? retmsg : '助力成功'}"`);
|
$.log(`助力结果:ret=${ret} retmsg="${retmsg ? retmsg : 'OK'}"`);
|
||||||
if (ret === 0 || ret === 1021) { // 0 助力成功 1021 不能助力自己
|
if (ret === 0 || ret === 1021) { // 0 助力成功 1021 不能助力自己
|
||||||
resolve(true);
|
resolve(true);
|
||||||
}
|
}
|
||||||
@@ -504,9 +529,11 @@ function taskUrl(function_path, body) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function showMsg() {
|
async function showMsg() {
|
||||||
$.msg($.name, subTitle, message, option);
|
if (notifyBool) {
|
||||||
if ($.isNode()) {
|
$.msg($.name, subTitle, message, option);
|
||||||
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName}`, `${subTitle}\n${message}`);
|
if ($.isNode()) {
|
||||||
|
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName}`, `${subTitle}\n${message}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user