2020-05-12 15:44:25 +08:00
|
|
|
|
/*
|
|
|
|
|
爱奇艺会员签到脚本
|
|
|
|
|
|
2024-05-15 00:07:36 +08:00
|
|
|
|
更新时间: 2024/05/15
|
2020-07-29 16:33:12 +08:00
|
|
|
|
脚本兼容: QuantumultX, Surge4, Loon, JsBox, Node.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
电报频道: @NobyDa
|
|
|
|
|
问题反馈: @NobyDa_bot
|
|
|
|
|
|
|
|
|
|
获取Cookie说明:
|
2022-01-27 02:11:09 +08:00
|
|
|
|
Safari浏览器打开 https://m.iqiyi.com/user.html 使用密码登录, 如通知成功获取cookie则可使用该脚本.
|
2020-05-12 15:44:25 +08:00
|
|
|
|
获取Cookie后, 请将Cookie脚本禁用并移除主机名,以免产生不必要的MITM.
|
|
|
|
|
脚本将在每天上午9:00执行, 您可以修改执行时间。
|
|
|
|
|
|
2020-07-29 16:33:12 +08:00
|
|
|
|
如果使用Node.js, 需自行安装'request'模块. 例: npm install request -g
|
|
|
|
|
|
2022-01-28 18:00:19 +08:00
|
|
|
|
Node.js环境变量相关:
|
|
|
|
|
Cookie:IQIYI_COOKIE
|
|
|
|
|
Debug调试:IQIYI_DEBUG
|
|
|
|
|
Bark通知推送Key:BARK_PUSH
|
|
|
|
|
Bark服务端(默认官方):BARK_SERVER
|
2022-01-28 00:57:49 +08:00
|
|
|
|
|
2022-01-26 22:18:59 +08:00
|
|
|
|
JsBox, Node.js用户获取Cookie说明:
|
2022-01-28 00:57:49 +08:00
|
|
|
|
方法一手机:开启抓包, 网页登录 https://m.iqiyi.com/user.html 返回抓包APP搜索URL关键字 apis/user/info.action 复制请求头中的Cookie字段填入以下脚本变量或环境变量中即可
|
2022-01-26 22:18:59 +08:00
|
|
|
|
|
2022-01-28 00:57:49 +08:00
|
|
|
|
方法二PC:网页登录 https://www.iqiyi.com 按F12控制台执行 console.log(document.cookie) 复制打印的Cookie填入以下脚本变量或环境变量中即可
|
2020-07-29 16:33:12 +08:00
|
|
|
|
*/
|
|
|
|
|
|
2022-01-26 22:18:59 +08:00
|
|
|
|
var cookie = ''; //单引号内填入手动获取的Cookie
|
2020-07-29 16:33:12 +08:00
|
|
|
|
|
2021-09-22 23:55:44 +08:00
|
|
|
|
var barkKey = ''; //Bark APP 通知推送Key
|
|
|
|
|
|
2022-01-28 18:00:19 +08:00
|
|
|
|
var barkServer = ''; //Bark APP 通知服务端地址(默认官方)
|
2022-01-28 10:51:27 +08:00
|
|
|
|
|
2020-07-29 16:33:12 +08:00
|
|
|
|
/*********************
|
2021-12-04 07:33:12 +08:00
|
|
|
|
QuantumultX 远程脚本配置:
|
|
|
|
|
**********************
|
|
|
|
|
[task_local]
|
|
|
|
|
# 爱奇艺会员签到
|
|
|
|
|
0 9 * * * https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
[rewrite_local]
|
|
|
|
|
# 获取Cookie
|
2022-06-18 21:15:41 +08:00
|
|
|
|
^https:\/\/passport\.iqiyi\.com\/apis\/user\/ url script-request-header https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
[mitm]
|
2022-01-26 22:18:59 +08:00
|
|
|
|
hostname= passport.iqiyi.com
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
**********************
|
|
|
|
|
Surge 4.2.0+ 脚本配置:
|
|
|
|
|
**********************
|
|
|
|
|
[Script]
|
2022-01-26 22:18:59 +08:00
|
|
|
|
爱奇艺签到 = type=cron,cronexp=0 9 * * *,timeout=120,script-path=https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2022-06-18 21:15:41 +08:00
|
|
|
|
爱奇艺获取Cookie = type=http-request,pattern=^https:\/\/passport\.iqiyi\.com\/apis\/user\/,script-path=https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
[MITM]
|
2022-01-26 22:18:59 +08:00
|
|
|
|
hostname= passport.iqiyi.com
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
************************
|
|
|
|
|
Loon 2.1.0+ 脚本配置:
|
|
|
|
|
************************
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
[Script]
|
|
|
|
|
# 爱奇艺签到
|
|
|
|
|
cron "0 9 * * *" script-path=https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
# 获取Cookie
|
2022-06-18 21:15:41 +08:00
|
|
|
|
http-request ^https:\/\/passport\.iqiyi\.com\/apis\/user\/ script-path=https://raw.githubusercontent.com/NobyDa/Script/master/iQIYI-DailyBonus/iQIYI.js
|
2020-05-12 15:44:25 +08:00
|
|
|
|
|
2021-12-04 07:33:12 +08:00
|
|
|
|
[Mitm]
|
2022-01-26 22:18:59 +08:00
|
|
|
|
hostname= passport.iqiyi.com
|
2021-12-04 07:33:12 +08:00
|
|
|
|
|
|
|
|
|
*/
|
2020-07-29 16:33:12 +08:00
|
|
|
|
|
|
|
|
|
var LogDetails = false; // 响应日志
|
|
|
|
|
|
2022-01-26 22:18:59 +08:00
|
|
|
|
var pushMsg = [];
|
|
|
|
|
|
2024-05-15 00:07:36 +08:00
|
|
|
|
let P00001, P00003, DFP
|
2020-07-29 16:33:12 +08:00
|
|
|
|
|
2020-05-12 15:44:25 +08:00
|
|
|
|
var $nobyda = nobyda();
|
|
|
|
|
|
2020-08-05 17:01:03 +08:00
|
|
|
|
(async () => {
|
2020-07-29 16:33:12 +08:00
|
|
|
|
cookie = cookie || $nobyda.read("CookieQY")
|
|
|
|
|
LogDetails = $nobyda.read("iQIYI_LogDetails") === "true" ? true : LogDetails
|
2023-02-26 23:31:35 +08:00
|
|
|
|
if (typeof process !== 'undefined' && typeof process.env !== 'undefined') {
|
|
|
|
|
cookie = cookie || process.env.IQIYI_COOKIE;
|
|
|
|
|
LogDetails = LogDetails || process.env.IQIYI_DEBUG;
|
|
|
|
|
barkKey = barkKey || process.env.BARK_PUSH;
|
|
|
|
|
barkServer = barkServer || process.env.BARK_SERVER;
|
|
|
|
|
}
|
2020-07-29 16:33:12 +08:00
|
|
|
|
if ($nobyda.isRequest) {
|
|
|
|
|
GetCookie()
|
|
|
|
|
} else if (cookie) {
|
2024-05-15 00:07:36 +08:00
|
|
|
|
if (cookie.includes("P00001") && cookie.includes("P00003") && cookie.includes("__dfp=")) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
P00001 = cookie.match(/P00001=(.*?);/)[1];
|
|
|
|
|
P00003 = cookie.match(/P00003=(.*?);/)[1];
|
2024-05-15 00:07:36 +08:00
|
|
|
|
DFP = cookie.match(/__dfp=(\w+)/)[1];
|
2023-02-26 23:31:35 +08:00
|
|
|
|
await login();
|
|
|
|
|
await Checkin();
|
|
|
|
|
for (let i = 0; i < 3; i++) {
|
|
|
|
|
const run = await Lottery(i);
|
|
|
|
|
if (run) {
|
|
|
|
|
await new Promise(r => setTimeout(r, 1000));
|
|
|
|
|
} else {
|
|
|
|
|
break
|
2022-01-26 22:18:59 +08:00
|
|
|
|
}
|
2023-02-26 23:31:35 +08:00
|
|
|
|
}
|
|
|
|
|
const tasks = await getTaskList();
|
|
|
|
|
for (let i = 0; i < tasks.length; i++) {
|
|
|
|
|
if (![1, 4].includes(tasks[i].status)) { //0:待领取 1:已完成 2:未开始 4:进行中
|
|
|
|
|
await joinTask(tasks[i]);
|
|
|
|
|
await notifyTask(tasks[i]);
|
|
|
|
|
await new Promise(r => setTimeout(r, 1000));
|
|
|
|
|
await getTaskRewards(tasks[i]);
|
|
|
|
|
console.log(`--------------------`)
|
2022-01-26 22:18:59 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-02-26 23:31:35 +08:00
|
|
|
|
const expires = $nobyda.expire ? $nobyda.expire.replace(/\u5230\u671f/, "") : "获取失败 ⚠️"
|
|
|
|
|
if (!$nobyda.isNode) $nobyda.notify("爱奇艺", "到期时间: " + expires, pushMsg.join('\n'));
|
|
|
|
|
if (barkKey) await BarkNotify($nobyda, barkKey, '爱奇艺', `到期时间: ${expires}\n${pushMsg.join('\n')}`, barkServer);
|
|
|
|
|
await $nobyda.time();
|
|
|
|
|
} else {
|
|
|
|
|
console.log(`Cookie缺少关键值,需重新获取`)
|
|
|
|
|
}
|
2022-01-26 22:18:59 +08:00
|
|
|
|
} else {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.notify("爱奇艺会员", "", "签到终止, 未获取Cookie");
|
2022-01-26 00:49:56 +08:00
|
|
|
|
}
|
2020-08-05 17:01:03 +08:00
|
|
|
|
})().finally(() => {
|
|
|
|
|
$nobyda.done();
|
|
|
|
|
})
|
2020-07-29 16:33:12 +08:00
|
|
|
|
|
|
|
|
|
function login() {
|
|
|
|
|
return new Promise(resolve => {
|
|
|
|
|
var URL = {
|
2022-01-26 22:18:59 +08:00
|
|
|
|
url: 'https://cards.iqiyi.com/views_category/3.0/vip_home?secure_p=iPhone&scrn_scale=0&dev_os=0&ouid=0&layout_v=6&psp_cki=' + P00001 + '&page_st=suggest&app_k=8e48946f144759d86a50075555fd5862&dev_ua=iPhone8%2C2&net_sts=1&cupid_uid=0&xas=1&init_type=6&app_v=11.4.5&idfa=0&app_t=0&platform_id=0&layout_name=0&req_sn=0&api_v=0&psp_status=0&psp_uid=451953037415627&qyid=0&secure_v=0&req_times=0',
|
2020-07-29 16:33:12 +08:00
|
|
|
|
headers: {
|
|
|
|
|
sign: '7fd8aadd90f4cfc99a858a4b087bcc3a',
|
|
|
|
|
t: '479112291'
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.get(URL, function (error, response, data) {
|
2020-07-29 16:33:12 +08:00
|
|
|
|
const Details = LogDetails ? data ? `response:\n${data}` : '' : ''
|
|
|
|
|
if (!error && data.match(/\"text\":\"\d.+?\u5230\u671f\"/)) {
|
|
|
|
|
$nobyda.expire = data.match(/\"text\":\"(\d.+?\u5230\u671f)\"/)[1]
|
|
|
|
|
console.log(`爱奇艺-查询成功: ${$nobyda.expire} ${Details}`)
|
|
|
|
|
} else {
|
|
|
|
|
console.log(`爱奇艺-查询失败${error || ': 无到期数据 ⚠️'} ${Details}`)
|
|
|
|
|
}
|
|
|
|
|
resolve()
|
|
|
|
|
})
|
2020-05-12 15:44:25 +08:00
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function Checkin() {
|
2022-01-24 15:56:04 +08:00
|
|
|
|
const timestamp = new Date().getTime();
|
2022-01-26 22:18:59 +08:00
|
|
|
|
const stringRandom = (length) => {
|
|
|
|
|
var rdm62, ret = '';
|
|
|
|
|
while (length--) {
|
|
|
|
|
rdm62 = 0 | Math.random() * 62;
|
|
|
|
|
ret += String.fromCharCode(rdm62 + (rdm62 < 10 ? 48 : rdm62 < 36 ? 55 : 61))
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
};
|
2020-05-12 15:44:25 +08:00
|
|
|
|
return new Promise(resolve => {
|
2022-01-24 15:56:04 +08:00
|
|
|
|
const sign_date = {
|
2024-05-15 00:07:36 +08:00
|
|
|
|
task_code: 'natural_month_sign',
|
2022-01-24 15:56:04 +08:00
|
|
|
|
timestamp: timestamp,
|
2024-05-15 00:07:36 +08:00
|
|
|
|
appKey: 'lequ_rn',
|
2022-01-24 15:56:04 +08:00
|
|
|
|
userId: P00003,
|
2024-05-15 00:07:36 +08:00
|
|
|
|
authCookie: P00001,
|
|
|
|
|
agenttype: 20,
|
|
|
|
|
agentversion: '15.4.6',
|
|
|
|
|
srcplatform: 20,
|
|
|
|
|
appver: '15.4.6',
|
|
|
|
|
qyid: md5(stringRandom(16))
|
2022-01-24 15:56:04 +08:00
|
|
|
|
};
|
2024-05-15 00:07:36 +08:00
|
|
|
|
|
2022-01-24 15:56:04 +08:00
|
|
|
|
const post_date = {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
"natural_month_sign": {
|
2024-05-15 00:07:36 +08:00
|
|
|
|
"verticalCode": "iQIYI",
|
|
|
|
|
"agentVersion": "15.4.6",
|
2023-02-26 23:31:35 +08:00
|
|
|
|
"authCookie": P00001,
|
|
|
|
|
"taskCode": "iQIYI_mofhr",
|
2024-05-15 00:07:36 +08:00
|
|
|
|
"dfp": DFP,
|
|
|
|
|
"qyid": md5(stringRandom(16)),
|
|
|
|
|
"agentType": 20,
|
|
|
|
|
"signFrom": 1
|
2022-01-24 15:56:04 +08:00
|
|
|
|
}
|
|
|
|
|
};
|
2024-05-15 00:07:36 +08:00
|
|
|
|
const sign = k("cRcFakm9KSPSjFEufg3W", sign_date, {
|
2022-01-24 15:56:04 +08:00
|
|
|
|
split: "|",
|
|
|
|
|
sort: !0,
|
|
|
|
|
splitSecretKey: !0
|
|
|
|
|
});
|
2020-05-12 15:44:25 +08:00
|
|
|
|
var URL = {
|
2022-01-24 15:56:04 +08:00
|
|
|
|
url: 'https://community.iqiyi.com/openApi/task/execute?' + w(sign_date) + "&sign=" + sign,
|
|
|
|
|
headers: {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
'Content-Type': 'application/json'
|
2022-01-24 15:56:04 +08:00
|
|
|
|
},
|
|
|
|
|
body: JSON.stringify(post_date)
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.post(URL, function (error, response, data) {
|
2022-02-07 00:40:25 +08:00
|
|
|
|
let CheckinMsg, rewards = [];
|
2023-02-26 23:31:35 +08:00
|
|
|
|
const Details = LogDetails ? `msg:\n${data || error}` : '';
|
2022-01-28 00:57:49 +08:00
|
|
|
|
try {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
if (error) throw new Error(`接口请求出错 ‼️`);
|
2020-07-29 16:33:12 +08:00
|
|
|
|
const obj = JSON.parse(data)
|
2022-01-24 15:56:04 +08:00
|
|
|
|
if (obj.code === "A00000") {
|
|
|
|
|
if (obj.data.code === "A0000") {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
for (let i = 0; i < obj.data.data.rewards.length; i++) {
|
|
|
|
|
if (obj.data.data.rewards[i].rewardType == 1) {
|
|
|
|
|
rewards.push(`成长值+${obj.data.data.rewards[i].rewardCount}`)
|
|
|
|
|
} else if (obj.data.data.rewards[i].rewardType == 2) {
|
|
|
|
|
rewards.push(`VIP天+${obj.data.data.rewards[i].rewardCount}`)
|
|
|
|
|
} else if (obj.data.data.rewards[i].rewardType == 3) {
|
|
|
|
|
rewards.push(`积分+${obj.data.data.rewards[i].rewardCount}`)
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-01-24 15:56:04 +08:00
|
|
|
|
var continued = obj.data.data.signDays;
|
2023-02-26 23:31:35 +08:00
|
|
|
|
CheckinMsg = `应用签到: ${rewards.length ? `${rewards.join(", ")}${rewards.length < 3 ? `, 累计签到${continued}天` : ``}` : '无奖励'} 🎉`;
|
2020-05-12 15:44:25 +08:00
|
|
|
|
} else {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
CheckinMsg = `应用签到: ${obj.data.msg} ⚠️`;
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
} else {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
CheckinMsg = `应用签到: Cookie无效 ⚠️`;
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
2022-01-28 00:57:49 +08:00
|
|
|
|
} catch (e) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
CheckinMsg = `应用签到: ${e.message || e}`;
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
2022-01-26 22:18:59 +08:00
|
|
|
|
pushMsg.push(CheckinMsg);
|
|
|
|
|
console.log(`爱奇艺-${CheckinMsg} ${Details}`);
|
2020-05-12 15:44:25 +08:00
|
|
|
|
resolve()
|
|
|
|
|
})
|
2020-07-29 16:33:12 +08:00
|
|
|
|
})
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
2020-08-05 17:01:03 +08:00
|
|
|
|
function Lottery(s) {
|
2020-05-12 15:44:25 +08:00
|
|
|
|
return new Promise(resolve => {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
const URL = {
|
|
|
|
|
url: 'https://iface2.iqiyi.com/aggregate/3.0/lottery_activity?app_k=0&app_v=0&platform_id=0&dev_os=0&dev_ua=0&net_sts=0&qyid=0&psp_uid=0&psp_cki=' + P00001 + '&psp_status=0&secure_p=0&secure_v=0&req_sn=0'
|
|
|
|
|
}
|
|
|
|
|
$nobyda.get(URL, async function (error, response, data) {
|
|
|
|
|
const Details = LogDetails ? `msg:\n${data || error}` : ''
|
|
|
|
|
let LotteryMsg;
|
|
|
|
|
try {
|
|
|
|
|
if (error) throw new Error("接口请求出错 ‼️");
|
|
|
|
|
const obj = JSON.parse(data);
|
|
|
|
|
if (obj.title) {
|
|
|
|
|
LotteryMsg = `应用抽奖: ${obj.title != '影片推荐' && obj.awardName || '未中奖'} 🎉`;
|
|
|
|
|
LotteryMsg = obj.kv.code == 'Q00702' && `应用抽奖: 您的抽奖次数已经用完 ⚠️` || LotteryMsg;
|
|
|
|
|
$nobyda.stop = obj.kv.code == 'Q00702';
|
|
|
|
|
} else if (obj.kv.code == 'Q00304') {
|
|
|
|
|
LotteryMsg = `应用抽奖: Cookie无效 ⚠️`;
|
|
|
|
|
$nobyda.stop = 1;
|
|
|
|
|
} else {
|
|
|
|
|
LotteryMsg = `应用抽奖: 未知错误 ⚠️`
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
2023-02-26 23:31:35 +08:00
|
|
|
|
} catch (e) {
|
|
|
|
|
LotteryMsg = `应用抽奖: ${e.message || e}`;
|
|
|
|
|
}
|
|
|
|
|
console.log(`爱奇艺-${LotteryMsg} (${s + 1}) ${Details}`)
|
|
|
|
|
pushMsg.push(LotteryMsg)
|
|
|
|
|
resolve(!$nobyda.stop)
|
|
|
|
|
})
|
2020-07-29 16:33:12 +08:00
|
|
|
|
})
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
2022-01-26 22:18:59 +08:00
|
|
|
|
|
2022-01-28 00:57:49 +08:00
|
|
|
|
function getTaskList(task) {
|
|
|
|
|
return new Promise(resolve => {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.get(`https://tc.vip.iqiyi.com/taskCenter/task/queryUserTask?P00001=${P00001}`, function (error, response, data) {
|
|
|
|
|
let taskListMsg, taskList = [];
|
|
|
|
|
const Details = LogDetails ? `msg:\n${data || error}` : '';
|
2022-01-28 00:57:49 +08:00
|
|
|
|
try {
|
|
|
|
|
if (error) throw new Error(`请求失败`);
|
|
|
|
|
const obj = JSON.parse(data);
|
|
|
|
|
if (obj.code == 'A00000' && obj.data && obj.data.tasks) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
Object.keys(obj.data.tasks).map((group) => {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
(obj.data.tasks[group] || []).map((item) => {
|
|
|
|
|
taskList.push({
|
|
|
|
|
name: item.taskTitle,
|
|
|
|
|
taskCode: item.taskCode,
|
|
|
|
|
status: item.status
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
taskListMsg = `获取成功!`;
|
|
|
|
|
} else {
|
|
|
|
|
taskListMsg = `获取失败!`;
|
|
|
|
|
}
|
|
|
|
|
} catch (e) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
taskListMsg = `${e.message || e} ‼️`;
|
2022-01-28 00:57:49 +08:00
|
|
|
|
}
|
|
|
|
|
console.log(`爱奇艺-任务列表: ${taskListMsg} ${Details}`)
|
|
|
|
|
resolve(taskList)
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2021-12-02 21:34:40 +08:00
|
|
|
|
function joinTask(task) {
|
|
|
|
|
return new Promise(resolve => {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
$nobyda.get('https://tc.vip.iqiyi.com/taskCenter/task/joinTask?taskCode=' + task.taskCode + '&lang=zh_CN&platform=0000000000000000&P00001=' + P00001, function (error, response, data) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
let joinTaskMsg, Details = LogDetails ? `msg:\n${data || error}` : '';
|
|
|
|
|
try {
|
|
|
|
|
if (error) throw new Error(`请求失败`);
|
|
|
|
|
const obj = JSON.parse(data);
|
|
|
|
|
joinTaskMsg = obj.code || '领取失败';
|
|
|
|
|
} catch (e) {
|
|
|
|
|
joinTaskMsg = `错误 ${e.message || e}`;
|
|
|
|
|
}
|
|
|
|
|
console.log(`爱奇艺-领取任务: ${task.name} => ${joinTaskMsg} ${Details}`)
|
|
|
|
|
resolve()
|
2022-01-28 00:57:49 +08:00
|
|
|
|
})
|
2021-12-02 21:34:40 +08:00
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function notifyTask(task) {
|
|
|
|
|
return new Promise(resolve => {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
$nobyda.get('https://tc.vip.iqiyi.com/taskCenter/task/notify?taskCode=' + task.taskCode + '&lang=zh_CN&platform=0000000000000000&P00001=' + P00001, function (error, response, data) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
let notifyTaskMsg, Details = LogDetails ? `msg:\n${data || error}` : '';
|
|
|
|
|
try {
|
|
|
|
|
if (error) throw new Error(`请求失败`);
|
|
|
|
|
const obj = JSON.parse(data);
|
|
|
|
|
notifyTaskMsg = obj.code || '失败';
|
|
|
|
|
} catch (e) {
|
|
|
|
|
notifyTaskMsg = e.message || e;
|
|
|
|
|
}
|
|
|
|
|
console.log(`爱奇艺-开始任务: ${task.name} => ${notifyTaskMsg} ${Details}`)
|
|
|
|
|
resolve()
|
2022-01-28 00:57:49 +08:00
|
|
|
|
})
|
2021-12-02 21:34:40 +08:00
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getTaskRewards(task) {
|
|
|
|
|
return new Promise(resolve => {
|
2022-01-28 00:57:49 +08:00
|
|
|
|
$nobyda.get('https://tc.vip.iqiyi.com/taskCenter/task/getTaskRewards?taskCode=' + task.taskCode + '&lang=zh_CN&platform=0000000000000000&P00001=' + P00001, function (error, response, data) {
|
|
|
|
|
let RewardsMsg;
|
2023-02-26 23:31:35 +08:00
|
|
|
|
const Details = LogDetails ? `msg:\n${data || error}` : ''
|
2022-01-28 00:57:49 +08:00
|
|
|
|
try {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
if (error) throw new Error(`接口请求出错 ‼️`);
|
2022-01-28 00:57:49 +08:00
|
|
|
|
const obj = JSON.parse(data)
|
|
|
|
|
if (obj.msg === "成功" && obj.code === "A00000" && obj.dataNew[0] !== undefined) {
|
|
|
|
|
RewardsMsg = `任务奖励: ${task.name} => ${obj.dataNew[0].name + obj.dataNew[0].value} 🎉`
|
|
|
|
|
} else {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
RewardsMsg = `任务奖励: ${task.name} => ${obj.msg !== `成功` && obj.msg || `未完成`} ⚠️`
|
2022-01-28 00:57:49 +08:00
|
|
|
|
}
|
|
|
|
|
} catch (e) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
RewardsMsg = `任务奖励: ${e.message || e}`;
|
2021-12-02 21:34:40 +08:00
|
|
|
|
}
|
2022-01-28 00:57:49 +08:00
|
|
|
|
pushMsg.push(RewardsMsg)
|
|
|
|
|
console.log(`爱奇艺-${RewardsMsg} ${Details}`)
|
|
|
|
|
resolve()
|
2021-12-02 21:34:40 +08:00
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-12 15:44:25 +08:00
|
|
|
|
function GetCookie() {
|
2022-06-18 21:15:41 +08:00
|
|
|
|
if (!$request.url.includes("iqiyi.com")) {
|
2022-01-26 22:18:59 +08:00
|
|
|
|
$nobyda.notify(`写入爱奇艺Cookie失败`, "", "请更新脚本配置(URL正则/MITM)");
|
|
|
|
|
return
|
|
|
|
|
}
|
2022-06-18 18:39:54 +08:00
|
|
|
|
var CKA = $request.headers['Cookie'] || $request.headers['cookie'];;
|
2024-05-15 00:07:36 +08:00
|
|
|
|
var iQIYI = CKA && CKA.includes("P00001=") && CKA.includes("P00003=") && CKA.includes("__dfp=") && CKA;
|
2020-09-01 19:58:06 +08:00
|
|
|
|
var RA = $nobyda.read("CookieQY")
|
2022-01-26 22:18:59 +08:00
|
|
|
|
if (CKA && iQIYI) {
|
|
|
|
|
if (RA != iQIYI) {
|
2020-09-01 19:58:06 +08:00
|
|
|
|
var OldTime = $nobyda.read("CookieQYTime")
|
2022-01-26 22:18:59 +08:00
|
|
|
|
if (!$nobyda.write(iQIYI, "CookieQY")) {
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.notify(`${RA ? `更新` : `首次写入`}爱奇艺签到Cookie失败‼️`, "", "")
|
2020-09-01 19:58:06 +08:00
|
|
|
|
} else {
|
|
|
|
|
if (!OldTime || OldTime && (Date.now() - OldTime) / 1000 >= 21600) {
|
|
|
|
|
$nobyda.write(JSON.stringify(Date.now()), "CookieQYTime")
|
2023-02-26 23:31:35 +08:00
|
|
|
|
$nobyda.notify(`${RA ? `更新` : `首次写入`}爱奇艺签到Cookie成功 🎉`, "", "")
|
2020-07-29 16:33:12 +08:00
|
|
|
|
} else {
|
2020-09-01 19:58:06 +08:00
|
|
|
|
console.log(`\n更新爱奇艺Cookie成功! 🎉\n检测到频繁通知, 已转为输出日志`)
|
2020-07-29 16:33:12 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2020-09-01 19:58:06 +08:00
|
|
|
|
console.log("\n爱奇艺-与本机储存Cookie相同, 跳过写入 ⚠️")
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
} else {
|
2022-01-26 22:18:59 +08:00
|
|
|
|
$nobyda.notify(`爱奇艺`, "", "写入Cookie失败,关键值缺失 ⚠️")
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-26 23:31:35 +08:00
|
|
|
|
async function BarkNotify(c, k, t, b, p) { for (let i = 0; i < 3; i++) { console.log(`🔷Bark notify >> Start push (${i + 1})`); const s = await new Promise((n) => { c.post({ url: p || 'https://api.day.app/push', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ title: t, body: b, device_key: k, ext_params: { group: t } }) }, (e, r, d) => r && r.status == 200 ? n(1) : n(d || e)) }); if (s === 1) { console.log('✅Push success!'); break } else { console.log(`❌Push failed! >> ${s.message || s}`) } } }
|
2021-09-22 23:55:44 +08:00
|
|
|
|
|
2020-05-12 15:44:25 +08:00
|
|
|
|
function nobyda() {
|
2020-07-29 16:33:12 +08:00
|
|
|
|
const times = 0
|
|
|
|
|
const start = Date.now()
|
2020-05-12 15:44:25 +08:00
|
|
|
|
const isRequest = typeof $request != "undefined"
|
|
|
|
|
const isSurge = typeof $httpClient != "undefined"
|
|
|
|
|
const isQuanX = typeof $task != "undefined"
|
2020-07-29 16:33:12 +08:00
|
|
|
|
const isLoon = typeof $loon != "undefined"
|
|
|
|
|
const isJSBox = typeof $app != "undefined" && typeof $http != "undefined"
|
|
|
|
|
const isNode = typeof require == "function" && !isJSBox;
|
|
|
|
|
const node = (() => {
|
|
|
|
|
if (isNode) {
|
|
|
|
|
const request = require('request');
|
|
|
|
|
return ({
|
|
|
|
|
request
|
|
|
|
|
})
|
|
|
|
|
} else {
|
|
|
|
|
return (null)
|
|
|
|
|
}
|
|
|
|
|
})()
|
2020-05-12 15:44:25 +08:00
|
|
|
|
const notify = (title, subtitle, message) => {
|
|
|
|
|
if (isQuanX) $notify(title, subtitle, message)
|
|
|
|
|
if (isSurge) $notification.post(title, subtitle, message)
|
2020-07-29 16:33:12 +08:00
|
|
|
|
if (isNode) log('\n' + title + '\n' + subtitle + '\n' + message)
|
|
|
|
|
if (isJSBox) $push.schedule({
|
|
|
|
|
title: title,
|
|
|
|
|
body: subtitle ? subtitle + "\n" + message : message
|
|
|
|
|
})
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
const write = (value, key) => {
|
|
|
|
|
if (isQuanX) return $prefs.setValueForKey(value, key)
|
|
|
|
|
if (isSurge) return $persistentStore.write(value, key)
|
|
|
|
|
}
|
|
|
|
|
const read = (key) => {
|
|
|
|
|
if (isQuanX) return $prefs.valueForKey(key)
|
|
|
|
|
if (isSurge) return $persistentStore.read(key)
|
|
|
|
|
}
|
|
|
|
|
const adapterStatus = (response) => {
|
|
|
|
|
if (response) {
|
|
|
|
|
if (response.status) {
|
|
|
|
|
response["statusCode"] = response.status
|
|
|
|
|
} else if (response.statusCode) {
|
|
|
|
|
response["status"] = response.statusCode
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return response
|
|
|
|
|
}
|
|
|
|
|
const get = (options, callback) => {
|
|
|
|
|
if (isQuanX) {
|
|
|
|
|
if (typeof options == "string") options = {
|
|
|
|
|
url: options
|
|
|
|
|
}
|
|
|
|
|
options["method"] = "GET"
|
|
|
|
|
$task.fetch(options).then(response => {
|
|
|
|
|
callback(null, adapterStatus(response), response.body)
|
|
|
|
|
}, reason => callback(reason.error, null, null))
|
|
|
|
|
}
|
|
|
|
|
if (isSurge) $httpClient.get(options, (error, response, body) => {
|
|
|
|
|
callback(error, adapterStatus(response), body)
|
|
|
|
|
})
|
2020-07-29 16:33:12 +08:00
|
|
|
|
if (isNode) {
|
|
|
|
|
node.request(options, (error, response, body) => {
|
|
|
|
|
callback(error, adapterStatus(response), body)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
if (isJSBox) {
|
|
|
|
|
if (typeof options == "string") options = {
|
|
|
|
|
url: options
|
|
|
|
|
}
|
|
|
|
|
options["header"] = options["headers"]
|
2023-02-26 23:31:35 +08:00
|
|
|
|
options["handler"] = function (resp) {
|
2020-07-29 16:33:12 +08:00
|
|
|
|
let error = resp.error;
|
|
|
|
|
if (error) error = JSON.stringify(resp.error)
|
|
|
|
|
let body = resp.data;
|
|
|
|
|
if (typeof body == "object") body = JSON.stringify(resp.data);
|
|
|
|
|
callback(error, adapterStatus(resp.response), body)
|
|
|
|
|
};
|
|
|
|
|
$http.get(options);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-09-22 23:55:44 +08:00
|
|
|
|
const post = (options, callback) => {
|
|
|
|
|
if (isQuanX) {
|
|
|
|
|
if (typeof options == "string") options = {
|
|
|
|
|
url: options
|
|
|
|
|
}
|
|
|
|
|
options["method"] = "POST"
|
|
|
|
|
$task.fetch(options).then(response => {
|
|
|
|
|
callback(null, adapterStatus(response), response.body)
|
|
|
|
|
}, reason => callback(reason.error, null, null))
|
|
|
|
|
}
|
|
|
|
|
if (isSurge) {
|
|
|
|
|
options.headers['X-Surge-Skip-Scripting'] = false
|
|
|
|
|
$httpClient.post(options, (error, response, body) => {
|
|
|
|
|
callback(error, adapterStatus(response), body)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
if (isNode) {
|
|
|
|
|
node.request.post(options, (error, response, body) => {
|
|
|
|
|
callback(error, adapterStatus(response), body)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
if (isJSBox) {
|
|
|
|
|
if (typeof options == "string") options = {
|
|
|
|
|
url: options
|
|
|
|
|
}
|
|
|
|
|
options["header"] = options["headers"]
|
2023-02-26 23:31:35 +08:00
|
|
|
|
options["handler"] = function (resp) {
|
2021-09-22 23:55:44 +08:00
|
|
|
|
let error = resp.error;
|
|
|
|
|
if (error) error = JSON.stringify(resp.error)
|
|
|
|
|
let body = resp.data;
|
|
|
|
|
if (typeof body == "object") body = JSON.stringify(resp.data)
|
|
|
|
|
callback(error, adapterStatus(resp.response), body)
|
|
|
|
|
}
|
|
|
|
|
$http.post(options);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-29 16:33:12 +08:00
|
|
|
|
|
|
|
|
|
const log = (message) => console.log(message)
|
|
|
|
|
const time = () => {
|
|
|
|
|
const end = ((Date.now() - start) / 1000).toFixed(2)
|
|
|
|
|
return console.log('\n签到用时: ' + end + ' 秒')
|
2020-05-12 15:44:25 +08:00
|
|
|
|
}
|
|
|
|
|
const done = (value = {}) => {
|
2020-08-21 22:19:48 +08:00
|
|
|
|
if (isQuanX) return $done(value)
|
2020-05-12 15:44:25 +08:00
|
|
|
|
if (isSurge) isRequest ? $done(value) : $done()
|
|
|
|
|
}
|
|
|
|
|
return {
|
|
|
|
|
isRequest,
|
2020-07-29 16:33:12 +08:00
|
|
|
|
isNode,
|
2020-05-12 15:44:25 +08:00
|
|
|
|
notify,
|
|
|
|
|
write,
|
|
|
|
|
read,
|
|
|
|
|
get,
|
2021-09-22 23:55:44 +08:00
|
|
|
|
post,
|
2020-07-29 16:33:12 +08:00
|
|
|
|
log,
|
|
|
|
|
time,
|
|
|
|
|
times,
|
2020-05-12 15:44:25 +08:00
|
|
|
|
done
|
|
|
|
|
}
|
2022-01-24 15:56:04 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function k(e, t) {
|
|
|
|
|
var a = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : {}
|
|
|
|
|
, n = a.split
|
|
|
|
|
, c = void 0 === n ? "|" : n
|
|
|
|
|
, r = a.sort
|
|
|
|
|
, s = void 0 === r || r
|
|
|
|
|
, o = a.splitSecretKey
|
|
|
|
|
, i = void 0 !== o && o
|
|
|
|
|
, l = s ? Object.keys(t).sort() : Object.keys(t)
|
|
|
|
|
, u = l.map((function (e) {
|
|
|
|
|
return "".concat(e, "=").concat(t[e])
|
|
|
|
|
}
|
|
|
|
|
)).join(c) + (i ? c : "") + e;
|
|
|
|
|
return md5(u)
|
|
|
|
|
}
|
2022-01-26 22:18:59 +08:00
|
|
|
|
|
|
|
|
|
// Modified from https://github.com/blueimp/JavaScript-MD5
|
2023-02-26 23:31:35 +08:00
|
|
|
|
function md5(string) { function RotateLeft(lValue, iShiftBits) { return (lValue << iShiftBits) | (lValue >>> (32 - iShiftBits)) } function AddUnsigned(lX, lY) { var lX4, lY4, lX8, lY8, lResult; lX8 = (lX & 0x80000000); lY8 = (lY & 0x80000000); lX4 = (lX & 0x40000000); lY4 = (lY & 0x40000000); lResult = (lX & 0x3FFFFFFF) + (lY & 0x3FFFFFFF); if (lX4 & lY4) { return (lResult ^ 0x80000000 ^ lX8 ^ lY8) } if (lX4 | lY4) { if (lResult & 0x40000000) { return (lResult ^ 0xC0000000 ^ lX8 ^ lY8) } else { return (lResult ^ 0x40000000 ^ lX8 ^ lY8) } } else { return (lResult ^ lX8 ^ lY8) } } function F(x, y, z) { return (x & y) | ((~x) & z) } function G(x, y, z) { return (x & z) | (y & (~z)) } function H(x, y, z) { return (x ^ y ^ z) } function I(x, y, z) { return (y ^ (x | (~z))) } function FF(a, b, c, d, x, s, ac) { a = AddUnsigned(a, AddUnsigned(AddUnsigned(F(b, c, d), x), ac)); return AddUnsigned(RotateLeft(a, s), b) }; function GG(a, b, c, d, x, s, ac) { a = AddUnsigned(a, AddUnsigned(AddUnsigned(G(b, c, d), x), ac)); return AddUnsigned(RotateLeft(a, s), b) }; function HH(a, b, c, d, x, s, ac) { a = AddUnsigned(a, AddUnsigned(AddUnsigned(H(b, c, d), x), ac)); return AddUnsigned(RotateLeft(a, s), b) }; function II(a, b, c, d, x, s, ac) { a = AddUnsigned(a, AddUnsigned(AddUnsigned(I(b, c, d), x), ac)); return AddUnsigned(RotateLeft(a, s), b) }; function ConvertToWordArray(string) { var lWordCount; var lMessageLength = string.length; var lNumberOfWords_temp1 = lMessageLength + 8; var lNumberOfWords_temp2 = (lNumberOfWords_temp1 - (lNumberOfWords_temp1 % 64)) / 64; var lNumberOfWords = (lNumberOfWords_temp2 + 1) * 16; var lWordArray = Array(lNumberOfWords - 1); var lBytePosition = 0; var lByteCount = 0; while (lByteCount < lMessageLength) { lWordCount = (lByteCount - (lByteCount % 4)) / 4; lBytePosition = (lByteCount % 4) * 8; lWordArray[lWordCount] = (lWordArray[lWordCount] | (string.charCodeAt(lByteCount) << lBytePosition)); lByteCount++ } lWordCount = (lByteCount - (lByteCount % 4)) / 4; lBytePosition = (lByteCount % 4) * 8; lWordArray[lWordCount] = lWordArray[lWordCount] | (0x80 << lBytePosition); lWordArray[lNumberOfWords - 2] = lMessageLength << 3; lWordArray[lNumberOfWords - 1] = lMessageLength >>> 29; return lWordArray }; function WordToHex(lValue) { var WordToHexValue = "", WordToHexValue_temp = "", lByte, lCount; for (lCount = 0; lCount <= 3; lCount++) { lByte = (lValue >>> (lCount * 8)) & 255; WordToHexValue_temp = "0" + lByte.toString(16); WordToHexValue = WordToHexValue + WordToHexValue_temp.substr(WordToHexValue_temp.length - 2, 2) } return WordToHexValue }; function Utf8Encode(string) { string = string.replace(/\r\n/g, "\n"); var utftext = ""; for (var n = 0; n < string.length; n++) { var c = string.charCodeAt(n); if (c < 128) { utftext += String.fromCharCode(c) } else if ((c > 127) && (c < 2048)) { utftext += String.fromCharCode((c >> 6) | 192); utftext += String.fromCharCode((c & 63) | 128) } else { utftext += String.fromCharCode((c >> 12) | 224); utftext += String.fromCharCode(((c >> 6) & 63) | 128); utftext += String.fromCharCode((c & 63) | 128) } } return utftext }; var x = Array(); var k, AA, BB, CC, DD, a, b, c, d; var S11 = 7, S12 = 12, S13 = 17, S14 = 22; var S21 = 5, S22 = 9, S23 = 14, S24 = 20; var S31 = 4, S32 = 11, S33 = 16, S34 = 23; var S41 = 6, S42 = 10, S43 = 15, S44 = 21; string = Utf8Encode(string); x = ConvertToWordArray(string); a = 0x67452301; b = 0xEFCDAB89; c = 0x98BADCFE; d = 0x10325476; for (k = 0; k < x.length; k += 16) { AA = a; BB = b; CC = c; DD = d; a = FF(a, b, c, d, x[k + 0], S11, 0xD76AA478); d = FF(d, a, b, c, x[k + 1], S12, 0xE8C7B756); c = FF(c, d, a, b, x[k + 2], S13, 0x242070DB); b = FF(b, c, d, a, x[k + 3], S14, 0xC1BDCEEE); a = FF(a, b, c, d, x[k + 4], S11, 0xF57C0FAF); d = FF(d, a, b, c, x[k + 5], S12, 0x4787C62A); c = FF(c, d, a, b, x[k + 6], S13, 0xA8304613); b = FF(b, c, d, a, x[k + 7], S14, 0xFD469501); a = FF(a, b, c, d, x[k + 8], S11, 0x698098D8); d = FF(d, a, b, c, x[k + 9], S12, 0x8B44F7AF); c = FF(c, d, a, b, x[k + 10], S13, 0xFFFF5BB1); b = FF(b, c, d, a, x[k + 11],
|
2022-01-26 22:18:59 +08:00
|
|
|
|
|
2023-02-26 23:31:35 +08:00
|
|
|
|
function w() {
|
2022-01-24 15:56:04 +08:00
|
|
|
|
var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {}
|
|
|
|
|
, t = [];
|
|
|
|
|
return Object.keys(e).forEach((function (a) {
|
|
|
|
|
t.push("".concat(a, "=").concat(e[a]))
|
|
|
|
|
}
|
|
|
|
|
)),
|
|
|
|
|
t.join("&")
|
|
|
|
|
}
|