mirror of
https://github.com/ctrlcvs/xiaoyao-cvs-plugin.git
synced 2025-01-09 07:01:08 +08:00
235 lines
7.8 KiB
JavaScript
235 lines
7.8 KiB
JavaScript
import MihoYoApi from "../model/mys/mihoyo-api.js"
|
||
import utils from '../model/mys/utils.js';
|
||
import promiseRetry from 'promise-retry';
|
||
import {
|
||
Cfg,
|
||
Data
|
||
} from "../components/index.js";
|
||
import moment from 'moment';
|
||
import MysInfo from '../model/mys/mysInfo.js'
|
||
import {
|
||
isV3
|
||
} from '../components/Changelog.js';
|
||
import gsCfg from '../model/gsCfg.js';
|
||
|
||
export const rule = {
|
||
mysSign: {
|
||
reg: "^#*(米游社|mys|社区)(原神|崩坏3|崩坏2|未定事件簿|大别野|崩坏星穹铁道|绝区零|全部)签到$",
|
||
describe: "米游社米游币签到(理论上会签到全部所以区分开了)"
|
||
},
|
||
sign: {
|
||
reg: "^#*(崩坏3|崩坏2|未定事件簿|大别野|崩坏星穹铁道|绝区零)签到$",
|
||
describe: "米社规则签到"
|
||
},
|
||
cookiesDocHelp: {
|
||
reg: "^#*(米游社|cookies|米游币)帮助$",
|
||
describe: "cookies获取帮助"
|
||
}
|
||
};
|
||
|
||
const _path = process.cwd();
|
||
let START = moment().unix();
|
||
const TODAY_DATE = moment().format('YYYY-MM-DD');
|
||
const RETRY_OPTIONS = {
|
||
retries: 3,
|
||
minTimeout: 5000,
|
||
maxTimeout: 10000
|
||
};
|
||
|
||
export async function sign(e) {
|
||
let isck=await cookie(e);
|
||
if (!isck) {
|
||
return true;
|
||
}
|
||
START = moment().unix();
|
||
let miHoYoApi = new MihoYoApi(e);
|
||
let resultMessage="";
|
||
let msg = e.msg.replace(/#|签到|井|米游社|mys|社区/g, "");
|
||
let ForumData = await getDataList(msg);
|
||
e.reply(`开始尝试${msg}签到预计${msg=='全部'?"60":"5-10"}秒~`)
|
||
for (let forum of ForumData) {
|
||
resultMessage += `**${forum.name}**\n`
|
||
try {
|
||
// 1 BBS Sign
|
||
let resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`开始签到: [${forum.name}] 尝试次数: ${number}`);
|
||
return miHoYoApi.honkai3rdSignTask(msg).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 签到失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
Bot.logger.info(`${forum.name} 签到结果: [${resObj.message}]`);
|
||
resultMessage += `签到: [${resObj.message}]\n`;
|
||
} catch (e) {
|
||
Bot.logger.error(`${forum.name} 签到失败 [${e.message}]`);
|
||
resultMessage += `签到失败: [${e.message}]\n`;
|
||
}
|
||
|
||
await utils.randomSleepAsync();
|
||
}
|
||
await replyMsg(e,resultMessage);
|
||
return true
|
||
}
|
||
export async function mysSign(e) {
|
||
let isck=await cookie(e);
|
||
if (!isck) {
|
||
return true;
|
||
}
|
||
let iscount="";
|
||
let miHoYoApi = new MihoYoApi(e);
|
||
if(Object.keys((await miHoYoApi.getStoken(e.user_id))).length == 0){
|
||
e.reply("未读取到stoken请尝试重新登录获取cookies")
|
||
return true;
|
||
}
|
||
|
||
START = moment().unix();
|
||
let resultMessage="";
|
||
// Execute task
|
||
let msg = e.msg.replace(/#|签到|井|米游社|mys|社区/g, "");
|
||
let ForumData = await getDataList(msg);
|
||
e.reply(`开始尝试${msg}社区签到预计${msg=='全部'?"10-20":"1-3"}分钟~`)
|
||
for (let forum of ForumData) {
|
||
resultMessage += `**${forum.name}**\n`
|
||
try {
|
||
// 1 BBS Sign
|
||
let resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`开始签到: [${forum.name}] 尝试次数: ${number}`);
|
||
return miHoYoApi.forumSign(forum.forumId).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 签到失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
Bot.logger.info(`${forum.name} 签到结果: [${resObj.message}]`);
|
||
resultMessage += `签到: [${resObj.message}]\n`;
|
||
} catch (e) {
|
||
Bot.logger.error(`${forum.name} 签到失败 [${e.message}]`);
|
||
resultMessage += `签到失败: [${e.message}]\n`;
|
||
}
|
||
|
||
await utils.randomSleepAsync();
|
||
}
|
||
for (let forum of ForumData) {
|
||
resultMessage += `\n**${forum.name}**\n`
|
||
try {
|
||
// 2 BBS list post
|
||
let resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`读取帖子列表: [${forum.name}] 尝试次数: ${number}`);
|
||
return miHoYoApi.forumPostList(forum.forumId).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 读取帖子列表失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
Bot.logger.info(`${forum.name} 读取列表成功 [${resObj.message}],读取到 [${resObj.data.list.length}] 条记录`);
|
||
|
||
let postList = resObj.data.list;
|
||
for (let post of postList) {
|
||
post = post.post;
|
||
// 2.1 BBS read post
|
||
let resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`读取帖子: [${post.subject}] 尝试次数: ${number}`);
|
||
return miHoYoApi.forumPostDetail(post['post_id']).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 读取帖子失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
Bot.logger.info(`${forum.name} [${post.subject}] 读取成功 [${resObj.message}]`);
|
||
await utils.randomSleepAsync();
|
||
// 2.2 BBS vote post
|
||
resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`点赞帖子: [${post.subject}] 尝试次数: ${number}`);
|
||
return miHoYoApi.forumPostVote(post['post_id']).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 点赞帖子失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
|
||
Bot.logger.info(`${forum.name} [${post.subject}] 点赞成功 [${resObj.message}]`);
|
||
await utils.randomSleepAsync();
|
||
}
|
||
|
||
// 2.3 BBS share post
|
||
let sharePost = postList[0].post;
|
||
resObj = await promiseRetry((retry, number) => {
|
||
Bot.logger.info(`分享帖子: [${sharePost.subject}] 尝试次数: ${number}`);
|
||
return miHoYoApi.forumPostShare(sharePost['post_id']).catch((e) => {
|
||
Bot.logger.error(`${forum.name} 分享帖子失败: [${e.message}] 尝试次数: ${number}`);
|
||
return retry(e);
|
||
});
|
||
}, RETRY_OPTIONS);
|
||
} catch (e) {
|
||
Bot.logger.error(`${forum.name} 读帖点赞分享失败 [${e.message}]`);
|
||
resultMessage += `读帖点赞分享: 失败 [${e.message}]\n`;
|
||
}
|
||
resultMessage += `读帖点赞分享: 成功\n`;
|
||
await utils.randomSleepAsync();
|
||
}
|
||
await replyMsg(e,resultMessage);
|
||
return true
|
||
}
|
||
|
||
async function replyMsg(e,resultMessage){
|
||
const END = moment().unix();
|
||
Bot.logger.info(`运行结束, 用时 ${END - START} 秒`);
|
||
resultMessage += `\n用时 ${END - START} 秒`;
|
||
e.reply(resultMessage);
|
||
}
|
||
|
||
async function getDataList(name){
|
||
let ForumData = Data.readJSON(`${_path}/plugins/xiaoyao-cvs-plugin/defSet/json`, "mys")
|
||
for(let item of ForumData){
|
||
if(item.name==name){ //循环结束未找到的时候返回原数组签到全部
|
||
return [item]
|
||
}
|
||
}
|
||
return ForumData;
|
||
}
|
||
|
||
async function cookie(e) {
|
||
let cookie, uid;
|
||
let miHoYoApi = new MihoYoApi(e);
|
||
let skuid;
|
||
let cookiesDoc=await getcookiesDoc();
|
||
if (isV3) {
|
||
skuid= await gsCfg.getBingCookie(e.user_id);
|
||
cookie = skuid.ck;
|
||
uid = skuid.item;
|
||
} else {
|
||
if (NoteCookie[e.user_id]) {
|
||
cookie = NoteCookie[e.user_id].cookie;
|
||
uid = NoteCookie[e.user_id].uid;
|
||
} else if (BotConfig.dailyNote && BotConfig.dailyNote[e.user_id]) {
|
||
cookie = BotConfig.dailyNote[e.user_id].cookie;
|
||
uid = BotConfig.dailyNote[e.user_id].uid;
|
||
}
|
||
}
|
||
if(!cookie){
|
||
e.reply("cookie失效请重新绑定~【教程】\n"+cookiesDoc)
|
||
return false;
|
||
}
|
||
e.uid = uid;
|
||
e.cookie=cookie;
|
||
if(Object.keys((await miHoYoApi.getStoken(e.user_id))).length != 0){
|
||
return true;
|
||
}
|
||
if (!cookie.includes("login_ticket")&&(isV3&&!skuid?.login_ticket)) {
|
||
e.reply("米游社登录cookie不完整,请前往米游社通行证处重新获取cookie~\ncookies必须包含login_ticket【教程】 "+cookiesDoc)
|
||
return false;
|
||
}
|
||
let flot = (await miHoYoApi.stoken(cookie, e));
|
||
// console.log(flot)
|
||
await utils.sleepAsync(1000); //延迟加载防止文件未生成
|
||
if (!flot) {
|
||
e.reply("登录失效请重新登录获取cookie发送机器人~")
|
||
return false;
|
||
}
|
||
return true;
|
||
}
|
||
export async function cookiesDocHelp(e){
|
||
let cookiesDoc=await getcookiesDoc()
|
||
e.reply("【cookies帮助】"+cookiesDoc+"\ncookies必须包含login_ticket获取后请私发机器人");
|
||
return true
|
||
}
|
||
async function getcookiesDoc(){
|
||
return await gsCfg.getfileYaml(`${_path}/plugins/xiaoyao-cvs-plugin/config/`,"config").cookiesDoc
|
||
}
|