2
0
mirror of https://github.com/ctrlcvs/xiaoyao-cvs-plugin.git synced 2025-01-22 13:51:10 +08:00

修正V3ck查询多号无法识别问题,补充多个stoken添加逻辑具体待测

This commit is contained in:
Ctrlcvs 2022-08-18 23:15:49 +08:00
parent 6981780856
commit 001fccb53b
4 changed files with 82 additions and 56 deletions

View File

@ -122,7 +122,8 @@ export async function mysSign(e) {
}
let iscount = "";
let miHoYoApi = new MihoYoApi(e);
if (Object.keys((await miHoYoApi.getStoken(e.user_id))).length == 0) {
let stokens=await miHoYoApi.getStoken(e.user_id)
if (!stokens) {
e.reply("未读取到stoken请检查cookies是否包含login_ticket、以及云崽是否为最新版本V3、V2兼容")
return true;
}
@ -231,7 +232,8 @@ export async function bbsSeach(e){
return true;
}
let miHoYoApi = new MihoYoApi(e);
if (Object.keys((await miHoYoApi.getStoken(e.user_id))).length == 0) {
let stokens=await miHoYoApi.getStoken(e.user_id)
if (!stokens) {
let cookiesDoc = await getcookiesDoc()
await replyMsg(e, "未读取到stoken请检查cookies是否包含login_ticket请先绑定stoken再查询~\n"+cookiesDoc);
return true;
@ -291,8 +293,8 @@ async function cookie(e) {
e.reply("cookie失效请重新绑定~【教程】\n" + cookiesDoc)
return false;
}
if (Object.keys((await miHoYoApi.getStoken(e.user_id))).length != 0) {
let stokens=miHoYoApi.getStoken(e.user_id)
if (!stokens) {
return true;
}
if (!cookie.includes("login_ticket") && (isV3 && !skuid?.login_ticket)) {
@ -347,8 +349,10 @@ export async function allMysSign() {
let stoken = await gsCfg.getBingStoken();
let isPushSign = await gsCfg.getfileYaml(`${_path}/plugins/xiaoyao-cvs-plugin/config/`, "config").isPushSign
//获取需要签到的用户
for (let data of stoken) {
let user_id = data.qq;
for (let dataUid of stoken) {
for(let uuId in dataUid){
let data=dataUid[uuId]
let user_id = data.userId;
let e = {
user_id,
isTask: true
@ -363,11 +367,12 @@ export async function allMysSign() {
}
if (msg.includes("OK")) { //签到成功并且不是已签到的才推送
// msg = msg.replace("签到成功", "自动签到成功");
utils.relpyPrivate(user_id, msg + "\n自动签到成功");
utils.relpyPrivate(user_id, msg + "uid:"+uuId+"\n自动签到成功");
}
};
await mysSign(e);
await utils.sleepAsync(10000);
}
}
Bot.logger.mark(`米社米币签到任务完成`);
return true

View File

@ -148,9 +148,7 @@ class GsCfg {
const res = await Promise.all(promises)
res.forEach((v,index) => {
let tmp = YAML.parse(v)
tmp["qq"]=files[index].split(".")[0]*1
ck.push(tmp)
})
return ck
}
@ -170,7 +168,11 @@ class GsCfg {
let ck = fs.readFileSync(file, 'utf-8')
ck = YAML.parse(ck)
for(let item in ck){
let login_ticket=ck[item]?.login_ticket
let login_ticket;
if(!ck[item].isMain){
continue;
}
login_ticket=ck[item]?.login_ticket
ck=ck[item].ck
return {ck,item,login_ticket};
}
@ -187,7 +189,18 @@ class GsCfg {
fs.writeFileSync(file, yaml, 'utf8')
}
}
saveBingStoken(userId, data) {
let file = `./plugins/${plugin}/data/yaml/${userId}.yaml`
console.log(data)
console.log(file)
if (lodash.isEmpty(data)) {
fs.existsSync(file) && fs.unlinkSync(file)
} else {
let yaml = YAML.stringify(data)
fs.writeFileSync(file, yaml, 'utf8')
}
}
/**
* 原神角色id转换角色名字
*/

View File

@ -266,11 +266,10 @@ export default class MihoYoApi {
async stoken(cookie, e) {
this.e = e;
let stokens=Object.values(this.getStoken(e.user_id))
if (stokens.length != 0) {
let datalist=this.getStoken(e.user_id)
if (datalist){
return true;
}
let datalist={};
const map = this.getCookieMap(cookie);
let loginTicket = map.get("login_ticket");
const loginUid = map.get("login_uid") ? map.get("login_uid") : map.get("ltuid");
@ -307,18 +306,18 @@ export default class MihoYoApi {
stoken: data.data.list[0].token,
ltoken: data.data.list[1].token,
uid: e.uid,
userId:this.e.user_id,
is_sign:true
}
// gsCfg.saveBingStoken(e.user_id,datalist)
let yamlStr = YAML.stringify(datalist);
fs.writeFileSync(`${YamlDataUrl}/${e.user_id}.yaml`, yamlStr, 'utf8');
gsCfg.saveBingStoken(e.user_id,datalist)
// let yamlStr = YAML.stringify(datalist);
// fs.writeFileSync(`${YamlDataUrl}/${e.user_id}.yaml`, yamlStr, 'utf8');
return true;
});
}
).catch(function(err) {
return false;
});
// console.log(datalist);
return true;
}
/** 米游社 api headers */
@ -415,7 +414,14 @@ export default class MihoYoApi {
try {
let ck = fs.readFileSync(file, 'utf-8')
ck = YAML.parse(ck)
return ck
if(ck?.uid){
let datalist={};
ck.userId=this.e.user_id
datalist[ck.uid]=ck;
ck=datalist
gsCfg.saveBingStoken(this.e.user_id,datalist)
}
return ck[this.e.uid]
} catch (error) {
return {}
}

View File

@ -16,56 +16,57 @@ const RETRY_OPTIONS = {
minTimeout: 5000,
maxTimeout: 10000
};
const nameData=["原神","崩坏3","崩坏2","未定事件簿"];
const nameData = ["原神", "崩坏3", "崩坏2", "未定事件簿"];
/** 配置文件 */
export default class user {
constructor(e) {
this.e=e;
this.stokenPath=`./plugins/${plugin}/data/yaml/`
this.yunPath=`./plugins/${plugin}/data/yunToken/`;
this.e = e;
this.stokenPath = `./plugins/${plugin}/data/yaml/`
this.yunPath = `./plugins/${plugin}/data/yunToken/`;
this.getyunToken(this.e)
}
async getCkData(){
let sumData={};
async getCkData() {
let sumData = {};
await this.cookie(this.e)
this.miHoYoApi = new MihoYoApi(this.e);
if(this.e.yuntoken){
if (this.e.yuntoken) {
let yunres = await this.miHoYoApi.logyunGenshen();
let yundata = yunres.data
if(yunres.retcode===0){
sumData["云原神"]={
"今日可获取":yundata?.coin?.coin_num,
"免费时长":yundata?.free_time?.free_time,
"总时长":yundata.total_time
if (yunres.retcode === 0) {
sumData["云原神"] = {
"今日可获取": yundata?.coin?.coin_num,
"免费时长": yundata?.free_time?.free_time,
"总时长": yundata.total_time
}
}
}
if(this.e.cookies){
if (this.e.cookies) {
let mysres = await this.miHoYoApi.getTasksList();
if(mysres.retcode===0){
sumData["米游社"]={
"米游币任务":mysres.data.can_get_points!=0?"未完成":"已完成",
"米游币余额":mysres.data.total_points,
"今日剩余可获取":mysres.data.can_get_points
if (mysres.retcode === 0) {
sumData["米游社"] = {
"米游币任务": mysres.data.can_get_points != 0 ? "未完成" : "已完成",
"米游币余额": mysres.data.total_points,
"今日剩余可获取": mysres.data.can_get_points
}
}
}
if(this.e.cookie){
for(let name of nameData){
if (this.e.cookie) {
for (let name of nameData) {
let resSign = await this.miHoYoApi.honkai3rdSignTask(name);
if(resSign?.upData){
if (resSign?.upData) {
// console.log(resSign?.upData)
for(let item of resSign?.upData){
let num= lodash.random(0, 9999);
item.upName=item.upName=="原神"?"ys":item.upName=="崩坏3"?"bh3":item.upName=="崩坏2"?"bh2":item.upName=="未定事件簿"?"wdy":""
sumData[item.upName+""+num]={
"uid":item.game_uid,
"游戏昵称":item.nickname,
"等级":item.level,
"今日签到":item.is_sign?"已签到":"未签到",
"累计签到":item.total_sign_day+"天",
"今天奖励":item.awards
for (let item of resSign?.upData) {
let num = lodash.random(0, 9999);
item.upName = item.upName == "原神" ? "ys" : item.upName == "崩坏3" ? "bh3" : item.upName ==
"崩坏2" ? "bh2" : item.upName == "未定事件簿" ? "wdy" : ""
sumData[item.upName + "" + num] = {
"uid": item.game_uid,
"游戏昵称": item.nickname,
"等级": item.level,
"今日签到": item.is_sign ? "已签到" : "未签到",
"累计签到": item.total_sign_day + "天",
"今天奖励": item.awards
}
}
}
@ -99,16 +100,17 @@ export default class user {
async cookie(e) {
let {
cookie,
uid,skuid
uid,
skuid
} = await this.getCookie(e);
let cookiesDoc = await this.getcookiesDoc();
let miHoYoApi = new MihoYoApi(this.e);
let miHoYoApi = new MihoYoApi(this.e);
if (!cookie) {
e.reply("请先#绑定cookie\n发送【体力帮助】查看配置教程")
return false;
}
if (Object.keys((await miHoYoApi.getStoken(e.user_id))).length != 0) {
let stokens = miHoYoApi.getStoken(e.user_id)
if (!stokens) {
return true;
}
if (!cookie.includes("login_ticket") && (isV3 && !skuid?.login_ticket)) {
@ -124,7 +126,7 @@ export default class user {
}
return true;
}
async getcookiesDoc() {
async getcookiesDoc() {
return await gsCfg.getfileYaml(`${_path}/plugins/xiaoyao-cvs-plugin/config/`, "config").cookiesDoc
}
async getCookie(e) {