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' import { fileFrom } from "node-fetch"; export const rule = { mysSign: { reg: "^#*(米游社|mys|社区)(原神|崩坏3|崩坏2|未定事件簿|大别野|崩坏星穹铁道|绝区零|全部)签到$", describe: "米游社米游币签到(理论上会签到全部所以区分开了)" }, sign: { reg: "^#*(原神|崩坏3|崩坏2|未定事件簿|大别野|崩坏星穹铁道|绝区零)签到$", describe: "米社规则签到" } }; 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); if(Object.keys((await miHoYoApi.getStoken(e.user_id))).length == 0){ e.reply("未读取到stoken请尝试重新登录获取cookies") return true; } let resultMessage=""; let msg = e.msg.replace(/#|签到|井|米游社|mys|社区/g, ""); let ForumData = await getDataList(msg); 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(); } 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); 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); if (isV3) { // console.log(e) let 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; } } e.uid = uid; if (!cookie.includes("login_ticket")) { e.reply("米游社登录cookie不完整,请前往米游社通行证处重新获取cookie~\ncookies必须包含login_ticket") 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; }