2
0
mirror of https://github.com/ctrlcvs/xiaoyao-cvs-plugin.git synced 2024-12-23 03:20:52 +08:00

修正V3版本兼容导致无法签到社区问题

This commit is contained in:
ctrlcvs 2022-07-29 19:12:49 +08:00 committed by leiyilu
parent 454b18d780
commit 843a3269cf
3 changed files with 30 additions and 14 deletions

View File

@ -166,9 +166,10 @@ async function getDataList(name){
async function cookie(e) {
let cookie, uid;
let miHoYoApi = new MihoYoApi(e);
let skuid;
if (isV3) {
// console.log(e)
let skuid = await gsCfg.getBingCookie(e.user_id);
skuid= await gsCfg.getBingCookie(e.user_id);
cookie = skuid.ck;
uid = skuid.item;
} else {
@ -180,8 +181,12 @@ async function cookie(e) {
uid = BotConfig.dailyNote[e.user_id].uid;
}
}
if(!cookie){
e.reply("cookie失效请重新绑定~")
return false;
}
e.uid = uid;
if (!cookie.includes("login_ticket")) {
if (!cookie.includes("login_ticket")&&(isV3&&!skuid?.login_ticket)) {
e.reply("米游社登录cookie不完整请前往米游社通行证处重新获取cookie~\ncookies必须包含login_ticket")
return false;
}

View File

@ -145,8 +145,9 @@ 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
ck=ck[item].ck
return {ck,item};
return {ck,item,login_ticket};
}
} catch (error) {
return {}

View File

@ -4,7 +4,13 @@ import _ from 'lodash';
import superagent from 'superagent';
import fs from "fs";
import YAML from 'yaml'
import {Data} from "../../components/index.js";
import {
Data
} from "../../components/index.js";
import gsCfg from '../gsCfg.js'
import {
isV3
} from '../../components/Changelog.js';
import fetch from "node-fetch"
const APP_VERSION = "2.2.0";
const DEVICE_ID = utils.randomString(32).toUpperCase();
@ -72,8 +78,11 @@ export default class MihoYoApi {
return true;
}
const map = this.getCookieMap(cookie);
const loginTicket = map.get("login_ticket");
const loginUid = map.get("login_uid");
let loginTicket = map.get("login_ticket");
const loginUid = map.get("login_uid") ? map.get("login_uid") : map.get("ltuid");
if(isV3){
loginTicket=gsCfg.getBingCookie(e.user_id).login_ticket
}
const url = "https://api-takumi.mihoyo.com/auth/api/getMultiTokenByLoginTicket?login_ticket=" +
loginTicket + "&token_types=3&uid=" + loginUid;
fetch(url, {
@ -140,11 +149,12 @@ export default class MihoYoApi {
}
getCookieMap(cookie) {
let cookiePattern = /^(\S+)=(\S+)$/;
let cookieArray = cookie.split("; ");
let cookieArray = cookie.replace(/\s*/g,"").split(";");
let cookieMap = new Map();
for (let item of cookieArray) {
let entry = cookiePattern.exec(item);
cookieMap.set(entry[1], entry[2]);
let entry = item.split("=");
if(!entry[0]) continue;
cookieMap.set(entry[0], entry[1]);
}
return cookieMap;
}