Merge branch 'bugfix' into dev
This commit is contained in:
commit
73ccfd4921
@ -24,7 +24,10 @@ export default async function (call: ApiCall<ReqOpen, ResOpen>) {
|
||||
await PayFun.delPayLog(
|
||||
call.uid, { payId: G.gc.zhanling.payId, val: [] }
|
||||
);
|
||||
|
||||
// 战令重置的时候需要删除所有的任务进度,但是每天的任务进度不做处理,因为每天会自然重置,怕玩家会刷
|
||||
// ZhanLingTasks.clearLog(call.uid, 'day');
|
||||
ZhanLingTasks.clearLog(call.uid, 'week');
|
||||
ZhanLingTasks.clearLog(call.uid, 'round');
|
||||
data = (await G.mongodb.cEvent('zhanling').findOneAndUpdate({
|
||||
uid: call.uid,
|
||||
type: 'zhanling'
|
||||
|
119
src/fix_patch/patch_20240109-1.ts
Normal file
119
src/fix_patch/patch_20240109-1.ts
Normal file
@ -0,0 +1,119 @@
|
||||
import { patchFun, patchInit } from "../patch";
|
||||
import { PublicShared } from "../shared/public/public";
|
||||
import { JJCFun } from "../public/jjc";
|
||||
|
||||
function getRankPrize(rank: number, conf?: typeof G.gc.jjc_ph['']) {
|
||||
if (!conf) {
|
||||
conf = Object.values(G.gc.jjc_ph).filter(v => rank >= v.ph[0] && rank <= v.ph[1])[0];
|
||||
}
|
||||
if (conf) {
|
||||
return [...conf.prize, { a: 'item', t: '11', n: typeof conf.rongyuprize == 'number' ? conf.rongyuprize : PublicShared.eval(conf.rongyuprize, { a: rank }) }];
|
||||
} else {
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
class Path {
|
||||
|
||||
async addEmail(email, isCross = false) {
|
||||
let { prize, uid, ...e } = email;
|
||||
let lng = await G.redis.rawGet(`user:lng:${uid}`);
|
||||
let sendEmail = {
|
||||
_id: null,
|
||||
uid: uid,
|
||||
type: e.type,
|
||||
title: e.lngTitle ? (e.lngTitle[lng] || e.lngTitle['ja']) : e.title,
|
||||
content: e.lngContent ? (e.lngContent[lng] || e.lngContent['ja']) : e.content,
|
||||
createTime: e.createTime || G.time,
|
||||
contentInsertArr: e.contentInsertArr || []
|
||||
} as any;
|
||||
|
||||
/**跨服邮件给sid标识*/
|
||||
// if (isCross) {
|
||||
// sendEmail.sid = uid.split('_')[0];
|
||||
// }
|
||||
if ((prize === null || prize === void 0 ? void 0 : prize.length) > 0) {
|
||||
sendEmail.prizeData = {
|
||||
prize: email.prize,
|
||||
isGet: false
|
||||
};
|
||||
}
|
||||
if (email.g123log && Object.keys(email.g123log).length > 0)
|
||||
sendEmail.g123log = email.g123log;
|
||||
|
||||
if (email.lngTitle) {
|
||||
sendEmail.lngTitle = email.lngTitle;
|
||||
sendEmail.lngContent = email.lngContent;
|
||||
}
|
||||
//太亏了!换其他清理机制,getAllEmail是性能消耗大户
|
||||
//todo.. 换其他清理机制
|
||||
// if (!isCross) {
|
||||
// let emailList = await this.getAllEmail(uid);
|
||||
// if (emailList.length >= 50) {
|
||||
// emailList.sort((a, b) => {
|
||||
// let noPrizeA = a.prizeData == undefined ? 0 : 1;
|
||||
// let noPrizeB = b.prizeData == undefined ? 0 : 1;
|
||||
// let getA = a.prizeData?.isGet == true ? 0 : 1;
|
||||
// let getB = b.prizeData?.isGet == true ? 0 : 1;
|
||||
// if (noPrizeA != noPrizeB) {
|
||||
// return noPrizeA - noPrizeB;
|
||||
// } else if (getA != getB) {
|
||||
// return getA - getB;
|
||||
// }
|
||||
// return a.createTime - b.createTime;
|
||||
// });
|
||||
// this.removeEmail(uid, emailList[0]._id);
|
||||
// G.server.sendMsgByUid(uid, 'msg_s2c/EmailDel', emailList[0]._id);
|
||||
// }
|
||||
// }
|
||||
//@ts-ignore
|
||||
await G.mongodb.collection('email').insertOne({
|
||||
ttl: new Date(), ...G.mongodb.conversionIdObj(sendEmail)
|
||||
})
|
||||
}
|
||||
|
||||
async sendEmail(uid: string, rank: number, prize: atn[]) {
|
||||
|
||||
if (uid.indexOf('npc_') != -1) return;
|
||||
|
||||
await this.addEmail({
|
||||
uid: uid,
|
||||
type: 'system',
|
||||
title: G.gc.jjc_com.email.titel,
|
||||
content: G.gc.jjc_com.email.content,
|
||||
prize: prize,
|
||||
contentInsertArr: [rank]
|
||||
});
|
||||
}
|
||||
async fun1(a: any) {
|
||||
for (let conf of Object.values(G.gc.jjc_ph)) {
|
||||
let players = await JJCFun.getRankListUid(conf.ph[0] - 1, conf.ph[1]);
|
||||
|
||||
for (let index = 0; index < players.length; index++) {
|
||||
let uid = players[index];
|
||||
await this.sendEmail(uid, conf.ph[0] + index, getRankPrize(conf.ph[0] + index, conf));
|
||||
console.log("sendEmail", uid, conf.ph[0] + index)
|
||||
}
|
||||
}
|
||||
|
||||
return "sucess!!!"
|
||||
}
|
||||
|
||||
|
||||
|
||||
async run() {
|
||||
await this.fun1(1);
|
||||
}
|
||||
}
|
||||
|
||||
async function main() {
|
||||
await patchInit()
|
||||
let patch = new Path();
|
||||
await patch.run();
|
||||
console.log("逻辑执行完成,等待退出");
|
||||
setTimeout(function () {
|
||||
console.log('结束程序');
|
||||
process.exit();
|
||||
}, 3000);
|
||||
}
|
||||
main();
|
684
src/fix_patch/patch_20240109.ts
Normal file
684
src/fix_patch/patch_20240109.ts
Normal file
@ -0,0 +1,684 @@
|
||||
import { patchFun, patchInit } from "../patch";
|
||||
|
||||
class Path {
|
||||
|
||||
async fun1(a: any) {
|
||||
const con = {
|
||||
"16_6575db20f6ef8b7da5c8f1fd": {
|
||||
"item": {
|
||||
"1": 55400000,
|
||||
"12": 10600,
|
||||
"2": 223000,
|
||||
"6": 690
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 30500,
|
||||
"jinbi": 2850000000
|
||||
}
|
||||
},
|
||||
"15_6575a14b2f930bd5e51ccde9": {
|
||||
"item": {
|
||||
"1": 137200000,
|
||||
"12": 16600,
|
||||
"2": 273700,
|
||||
"6": 1735
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 35200,
|
||||
"jinbi": 3420000000
|
||||
}
|
||||
},
|
||||
"10_6573c51480a92f081d78e1d9": {
|
||||
"item": {
|
||||
"1": 35600000,
|
||||
"12": 13000,
|
||||
"2": 67800,
|
||||
"6": 1180
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 12400,
|
||||
"jinbi": 630000000
|
||||
}
|
||||
},
|
||||
"10_6573ecd9a884822d24482a1a": {
|
||||
"item": {
|
||||
"1": 103200000,
|
||||
"18": 9490,
|
||||
"12": 28000,
|
||||
"2": 421600,
|
||||
"6": 1300
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 53400,
|
||||
"jinbi": 5210000000
|
||||
}
|
||||
},
|
||||
"11_657412487fe3541fe7241a60": {
|
||||
"item": {
|
||||
"1": 35000000,
|
||||
"12": 99300,
|
||||
"2": 110900,
|
||||
"6": 460
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 19200,
|
||||
"jinbi": 1830000000
|
||||
}
|
||||
},
|
||||
"11_657436eb3bc021c4e335f356": {
|
||||
"item": {
|
||||
"1": 197200000,
|
||||
"12": 243700,
|
||||
"2": 597200,
|
||||
"6": 2475
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 97400,
|
||||
"jinbi": 9930000000
|
||||
}
|
||||
},
|
||||
"11_657428e87fe3541fe7245b75": {
|
||||
"item": {
|
||||
"1": 71200000,
|
||||
"12": 64300,
|
||||
"2": 219300,
|
||||
"6": 910
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 37300,
|
||||
"jinbi": 3630000000
|
||||
}
|
||||
},
|
||||
"10_6573aeb2602e0a72e8279b54": {
|
||||
"item": {
|
||||
"1": 17800000,
|
||||
"12": 22300,
|
||||
"2": 58100,
|
||||
"6": 240
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 10500,
|
||||
"jinbi": 940000000
|
||||
}
|
||||
},
|
||||
"11_657447453bc021c4e3362403": {
|
||||
"item": {
|
||||
"1": 322000000,
|
||||
"18": 31290,
|
||||
"12": 134800,
|
||||
"2": 1297200,
|
||||
"6": 4035
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 162900,
|
||||
"jinbi": 16160000000
|
||||
}
|
||||
},
|
||||
"11_657405957b27be6c2f4cac11": {
|
||||
"item": {
|
||||
"1": 18600000,
|
||||
"18": 1050,
|
||||
"12": 74500,
|
||||
"2": 79900,
|
||||
"6": 245
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 12000,
|
||||
"jinbi": 980000000
|
||||
}
|
||||
},
|
||||
"14_6575004f7aecd430eb86fbb5": {
|
||||
"item": {
|
||||
"1": 44000000,
|
||||
"18": 3440,
|
||||
"12": 104800,
|
||||
"2": 182600,
|
||||
"6": 545
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 25300,
|
||||
"jinbi": 2270000000
|
||||
}
|
||||
},
|
||||
"16_6575d6ac2e4ba33a00a04cbc": {
|
||||
"item": {
|
||||
"1": 36600000,
|
||||
"12": 13000,
|
||||
"2": 108200,
|
||||
"6": 470
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 19100,
|
||||
"jinbi": 1870000000
|
||||
}
|
||||
},
|
||||
"12_6574823b27bd4264da470583": {
|
||||
"item": {
|
||||
"1": 8800000,
|
||||
"12": 123000,
|
||||
"2": 37500,
|
||||
"6": 115
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 7300,
|
||||
"jinbi": 530000000
|
||||
}
|
||||
},
|
||||
"16_6575b61caff1b610d8bc6c96": {
|
||||
"item": {
|
||||
"24": 6,
|
||||
"10": 200,
|
||||
"12": 55000,
|
||||
"600": 20,
|
||||
"18": 1400,
|
||||
"1": 16200000,
|
||||
"2": 64900,
|
||||
"6": 180,
|
||||
"9": 3500
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 14400,
|
||||
"jinbi": 840000000
|
||||
}
|
||||
},
|
||||
"14_6574f2e66c7af0fe3713b718": {
|
||||
"item": {
|
||||
"1": 48800000,
|
||||
"12": 12700,
|
||||
"2": 90900,
|
||||
"6": 655
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 12400,
|
||||
"jinbi": 1100000000
|
||||
}
|
||||
},
|
||||
"11_65740da4deb68620911e96ef": {
|
||||
"item": {
|
||||
"1": 64200000,
|
||||
"18": 5580,
|
||||
"12": 28300,
|
||||
"2": 265400,
|
||||
"6": 820
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 33800,
|
||||
"jinbi": 3270000000
|
||||
}
|
||||
},
|
||||
"15_657594c3a7981612a8ea7e0e": {
|
||||
"item": {
|
||||
"1": 96800000,
|
||||
"18": 8870,
|
||||
"12": 3700,
|
||||
"2": 397200,
|
||||
"6": 1230
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 50400,
|
||||
"jinbi": 4920000000
|
||||
}
|
||||
},
|
||||
"11_657434f8290f4393568f16fe": {
|
||||
"item": {
|
||||
"1": 129000000,
|
||||
"12": 198300,
|
||||
"2": 392100,
|
||||
"6": 1630
|
||||
},
|
||||
"attr": {
|
||||
"jinbi": 6500000000
|
||||
}
|
||||
},
|
||||
"14_657512ee7aecd430eb872b5d": {
|
||||
"item": {
|
||||
"1": 121800000,
|
||||
"12": 36400,
|
||||
"2": 363400,
|
||||
"6": 1530
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 31500,
|
||||
"jinbi": 6150000000
|
||||
}
|
||||
},
|
||||
"11_657454089beef4c060edab88": {
|
||||
"item": {
|
||||
"1": 96600000,
|
||||
"18": 8660,
|
||||
"12": 149200,
|
||||
"2": 392900,
|
||||
"6": 1215
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 49800,
|
||||
"jinbi": 4890000000
|
||||
}
|
||||
},
|
||||
"10_6573e8aa80a92f081d7930b4": {
|
||||
"item": {
|
||||
"1": 242400000,
|
||||
"18": 16210,
|
||||
"12": 84100,
|
||||
"2": 978800,
|
||||
"6": 3040
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 123100,
|
||||
"jinbi": 12180000000
|
||||
}
|
||||
},
|
||||
"11_6573fd7a08e89e5a6859446e": {
|
||||
"item": {
|
||||
"1": 178200000,
|
||||
"18": 16230,
|
||||
"12": 10900,
|
||||
"2": 717000,
|
||||
"6": 2225
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 92000,
|
||||
"jinbi": 8990000000
|
||||
}
|
||||
},
|
||||
"11_65744fe2d0256beb85eed193": {
|
||||
"item": {
|
||||
"1": 262800000,
|
||||
"18": 25540,
|
||||
"12": 55800,
|
||||
"2": 1057600,
|
||||
"6": 3275
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 134000,
|
||||
"jinbi": 13190000000
|
||||
}
|
||||
},
|
||||
"11_657440e7ee44bd9935bbbd7c": {
|
||||
"item": {
|
||||
"1": 83000000,
|
||||
"18": 7160,
|
||||
"12": 250900,
|
||||
"2": 341800,
|
||||
"6": 1055
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 43300,
|
||||
"jinbi": 4220000000
|
||||
}
|
||||
},
|
||||
"11_657420932dd070117eb15e92": {
|
||||
"item": {
|
||||
"1": 307400000,
|
||||
"18": 29210,
|
||||
"12": 50200,
|
||||
"2": 1239200,
|
||||
"6": 3880
|
||||
},
|
||||
"attr": {
|
||||
"jinbi": 15470000000
|
||||
}
|
||||
},
|
||||
"14_65750da36439ef15582d6e6d": {
|
||||
"item": {
|
||||
"1": 105000000,
|
||||
"12": 93900,
|
||||
"2": 361000,
|
||||
"6": 1335
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 54100,
|
||||
"jinbi": 5310000000
|
||||
}
|
||||
},
|
||||
"12_6574762427bd4264da46ce63": {
|
||||
"item": {
|
||||
"1": 44400000,
|
||||
"18": 3390,
|
||||
"12": 15900,
|
||||
"2": 185000,
|
||||
"6": 555
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 25000,
|
||||
"jinbi": 2290000000
|
||||
}
|
||||
},
|
||||
"16_6575e1625685671e63fe001f": {
|
||||
"item": {
|
||||
"1": 12600000,
|
||||
"2": 51400,
|
||||
"6": 155
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 9200,
|
||||
"jinbi": 710000000
|
||||
}
|
||||
},
|
||||
"10_6573e236a884822d244816a0": {
|
||||
"item": {
|
||||
"1": 76200000,
|
||||
"18": 6760,
|
||||
"12": 79600,
|
||||
"2": 310200,
|
||||
"6": 945
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 40700,
|
||||
"jinbi": 3870000000
|
||||
}
|
||||
},
|
||||
"10_6573a17268053554fe606611": {
|
||||
"item": {
|
||||
"1": 109200000,
|
||||
"18": 9410,
|
||||
"12": 58000,
|
||||
"2": 428000,
|
||||
"6": 2365
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 55000,
|
||||
"jinbi": 5240000000
|
||||
}
|
||||
},
|
||||
"15_657595a3a7981612a8ea8009": {
|
||||
"item": {
|
||||
"1": 19200000,
|
||||
"18": 830,
|
||||
"12": 74800,
|
||||
"2": 84100,
|
||||
"6": 1115
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 11300,
|
||||
"jinbi": 990000000
|
||||
}
|
||||
},
|
||||
"11_657438a83bc021c4e335f86e": {
|
||||
"item": {
|
||||
"1": 71200000,
|
||||
"18": 6300,
|
||||
"12": 55600,
|
||||
"2": 292500,
|
||||
"6": 905
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 37200,
|
||||
"jinbi": 3600000000
|
||||
}
|
||||
},
|
||||
"10_6573e0395fe4caaf29a9b83c": {
|
||||
"item": {
|
||||
"1": 9000000,
|
||||
"12": 184000,
|
||||
"2": 45800,
|
||||
"6": 135
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 6400,
|
||||
"jinbi": 530000000
|
||||
}
|
||||
},
|
||||
"10_6573e596dc05fa03150d7db1": {
|
||||
"item": {
|
||||
"1": 12800000,
|
||||
"18": 410,
|
||||
"12": 15400,
|
||||
"2": 60000,
|
||||
"6": 175
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 8200,
|
||||
"jinbi": 690000000
|
||||
}
|
||||
},
|
||||
"14_65752c79c85dd4cf1a874893": {
|
||||
"item": {
|
||||
"1": 14200000,
|
||||
"12": 33700,
|
||||
"2": 64500,
|
||||
"6": 185
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 8900,
|
||||
"jinbi": 790000000
|
||||
}
|
||||
},
|
||||
"12_657455ed6b804f4a6d4b53a2": {
|
||||
"item": {
|
||||
"1": 160800000,
|
||||
"18": 14900,
|
||||
"12": 4800,
|
||||
"2": 650900,
|
||||
"6": 2025
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 82000,
|
||||
"jinbi": 8080000000
|
||||
}
|
||||
},
|
||||
"12_657481316ad7b8861da8a914": {
|
||||
"item": {
|
||||
"1": 5600000,
|
||||
"18": 450,
|
||||
"12": 34600,
|
||||
"2": 25500,
|
||||
"6": 65
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 7800,
|
||||
"jinbi": 300000000
|
||||
}
|
||||
},
|
||||
"4_6571c11bb0b5337a4d3a63a0": {
|
||||
"item": {
|
||||
"24": 7,
|
||||
"10": 400,
|
||||
"12": 15600,
|
||||
"600": 50,
|
||||
"18": 190,
|
||||
"1": 5200000,
|
||||
"2": 16300,
|
||||
"6": 10,
|
||||
"9": 8500
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 8800,
|
||||
"jinbi": 310000000
|
||||
}
|
||||
},
|
||||
"10_6573714bc7069a58e96ba077": {
|
||||
"item": {
|
||||
"1": 14400000,
|
||||
"18": 610,
|
||||
"12": 11800,
|
||||
"2": 66400,
|
||||
"6": 190
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 9000,
|
||||
"jinbi": 770000000
|
||||
}
|
||||
},
|
||||
"11_65744ba29beef4c060ed803c": {
|
||||
"item": {
|
||||
"1": 331800000,
|
||||
"12": 14800,
|
||||
"2": 1001400,
|
||||
"6": 4155
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 167500,
|
||||
"jinbi": 16670000000
|
||||
}
|
||||
},
|
||||
"16_6575d57c5685671e63fdb6ee": {
|
||||
"item": {
|
||||
"1": 13600000,
|
||||
"12": 42700,
|
||||
"2": 44500,
|
||||
"6": 420
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 7000,
|
||||
"jinbi": 430000000
|
||||
}
|
||||
},
|
||||
"11_65743bb09beef4c060ed46e7": {
|
||||
"item": {
|
||||
"10": 300,
|
||||
"12": 8100,
|
||||
"600": 30,
|
||||
"18": 920,
|
||||
"1": 18400000,
|
||||
"2": 69600,
|
||||
"6": 170,
|
||||
"9": 4500
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 13700,
|
||||
"jinbi": 950000000
|
||||
}
|
||||
},
|
||||
"10_6573bb4b68053554fe60940c": {
|
||||
"item": {
|
||||
"1": 19400000,
|
||||
"18": 1080,
|
||||
"12": 63000,
|
||||
"2": 83100,
|
||||
"6": 235
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 12300,
|
||||
"jinbi": 1010000000
|
||||
}
|
||||
},
|
||||
"16_6575d97df2211cd2ff29ba12": {
|
||||
"item": {
|
||||
"1": 3400000,
|
||||
"12": 11100,
|
||||
"2": 16700,
|
||||
"6": 50
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 5000,
|
||||
"jinbi": 250000000
|
||||
}
|
||||
},
|
||||
"11_657434c6d0256beb85ee6fae": {
|
||||
"item": {
|
||||
"1": 80600000,
|
||||
"18": 7360,
|
||||
"12": 232000,
|
||||
"2": 332200,
|
||||
"6": 1025
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 42100,
|
||||
"jinbi": 4090000000
|
||||
}
|
||||
},
|
||||
"16_6575b6d0f6ef8b7da5c84bf0": {
|
||||
"item": {
|
||||
"1": 70600000,
|
||||
"12": 29700,
|
||||
"2": 218200,
|
||||
"6": 900
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 36000,
|
||||
"jinbi": 3610000000
|
||||
}
|
||||
},
|
||||
"10_6587fbf00c11d852663c5bbb": {
|
||||
"item": {
|
||||
"1": 26800000,
|
||||
"18": 1940,
|
||||
"12": 168000,
|
||||
"2": 118300,
|
||||
"6": 350
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 15300,
|
||||
"jinbi": 1410000000
|
||||
}
|
||||
},
|
||||
"10_657397c2f31ed0c046ef3730": {
|
||||
"item": {
|
||||
"1": 220800000,
|
||||
"18": 1900,
|
||||
"12": 8800,
|
||||
"2": 701400,
|
||||
"6": 2780
|
||||
},
|
||||
"attr": {
|
||||
"rmbmoney": 112100,
|
||||
"jinbi": 11100000000
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const uids = Object.keys(con);
|
||||
let _users = await G.mongodb.find('user', { uid: { $in: uids } })
|
||||
for (let i = 0; i < _users.length; i++) {
|
||||
let user = _users[i]
|
||||
const uid = user.uid
|
||||
const _delattr = con[uid]["attr"]
|
||||
const _delitem = con[uid]["item"]
|
||||
let _setUserData = {}
|
||||
let _dellog = { "attr": {}, "item": {} }
|
||||
for (let t in _delattr) {
|
||||
if (t == "rmbmoney") {
|
||||
let v = user.rmbmoney - _delattr[t]
|
||||
if (v < 0) { v = 0 }
|
||||
_setUserData[t] = v
|
||||
_dellog["attr"][t] = { "old": user.rmbmoney, "new": v }
|
||||
}
|
||||
else if (t == "jinbi") {
|
||||
let v = user.jinbi - _delattr[t]
|
||||
if (v < 0) { v = 0 }
|
||||
_setUserData[t] = v
|
||||
_dellog["attr"][t] = { "old": user.jinbi, "new": v }
|
||||
}
|
||||
}
|
||||
|
||||
const itemIds = Object.keys(_delitem);
|
||||
// 删除item
|
||||
let _itemlist = await G.mongodb.collection('item').find({ "uid": uid, "itemId": { "$in": itemIds } }).toArray();
|
||||
for (let i = 0; i < _itemlist.length; i++) {
|
||||
const _item = _itemlist[i]
|
||||
const _itemid = _item.itemId
|
||||
const del = _delitem[_itemid] || 0
|
||||
let v = _item.num - del
|
||||
if (v < 0) { v = 0 }
|
||||
let _setItemData = {}
|
||||
_setItemData["num"] = v
|
||||
_dellog["item"][_itemid] = { "old": _item.num, "new": v }
|
||||
await G.mongodb.collection('item').updateOne({ "uid": uid, "itemId": _itemid }, { "$set": _setItemData });
|
||||
}
|
||||
await G.mongodb.collection('user').updateOne({ "uid": uid }, { "$set": _setUserData });
|
||||
// 输出日志
|
||||
console.log(uid, ":", _dellog);
|
||||
}
|
||||
|
||||
return "sucess!!!"
|
||||
}
|
||||
|
||||
|
||||
|
||||
async run() {
|
||||
await this.fun1(1);
|
||||
}
|
||||
}
|
||||
|
||||
async function main() {
|
||||
await patchInit()
|
||||
let patch = new Path();
|
||||
await patch.run();
|
||||
console.log("逻辑执行完成,等待退出");
|
||||
setTimeout(function () {
|
||||
console.log('结束程序');
|
||||
process.exit();
|
||||
}, 3000);
|
||||
}
|
||||
main();
|
@ -87,9 +87,13 @@ export class FightFun {
|
||||
|
||||
/**挑战竞技场 */
|
||||
static async fightJJc(call: ApiCall, rankInfo: rankInfo) {
|
||||
if (rankInfo.player.uid.indexOf('npc_') != -1) return await this.fightNpc(call, G.gc.jjc_npc[rankInfo.player.uid].npcId, 'jjc', await this.getPlayerFightData(call.conn.uid));
|
||||
let result;
|
||||
|
||||
let result = this.fight([await this.getPlayerFightData(call.conn.uid), await this.getPlayerFightData(rankInfo.player.uid)]);
|
||||
if (rankInfo.player.uid.indexOf('npc_') != -1) {
|
||||
result = await this.fightNpc(call, G.gc.jjc_npc[rankInfo.player.uid].npcId, 'jjc', await this.getPlayerFightData(call.conn.uid));
|
||||
} else {
|
||||
result = this.fight([await this.getPlayerFightData(call.conn.uid), await this.getPlayerFightData(rankInfo.player.uid)]);
|
||||
}
|
||||
|
||||
// 竞技场 战败触发推送礼包
|
||||
if (result.winSide != 0) {
|
||||
@ -137,7 +141,7 @@ export class FightFun {
|
||||
* @param result
|
||||
*/
|
||||
static async saveLog(uid: string, type: string, result: fightResult) {
|
||||
let writeList = ['ganhai', 'jjc', 'hbzbJfs', 'hbzbZbs', 'slzd', 'clsl']
|
||||
let writeList = ['ganhai', 'jjc', 'hbzbJfs', 'hbzbZbs', 'slzd', 'clsl']
|
||||
if (uid.indexOf('npc') != -1 || !writeList.includes(type)) return;
|
||||
|
||||
G.mongodb.collection('fightLog').insertOne({ uid, type, ...result })
|
||||
@ -145,6 +149,6 @@ export class FightFun {
|
||||
}
|
||||
|
||||
static async readLog(uid: string, type: string, len = 20) {
|
||||
return await G.mongodb.collection('fightLog').find({ uid, type }).limit(len).toArray() || []
|
||||
return await G.mongodb.collection('fightLog').find({ uid, type }).limit(len).sort({ _id: -1 }).toArray() || []
|
||||
}
|
||||
}
|
@ -1,5 +1,5 @@
|
||||
import {PublicShared} from '../../shared/public/public';
|
||||
import {Scheduler, schedulerType} from './scheduler';
|
||||
import { PublicShared } from '../../shared/public/public';
|
||||
import { Scheduler, schedulerType } from './scheduler';
|
||||
|
||||
|
||||
export class SchedulerZhanLing extends Scheduler {
|
||||
@ -12,12 +12,12 @@ export class SchedulerZhanLing extends Scheduler {
|
||||
this.isReady = false;
|
||||
return
|
||||
}
|
||||
let data = await this.db.findOne({type: this.id});
|
||||
let data = await this.db.findOne({ type: this.id });
|
||||
if (!data) {
|
||||
// 开服时间整除战令周期
|
||||
let round = Math.floor(PublicShared.getOpenServerDay() / G.gc.zhanling.eventOpen.day)
|
||||
let round = Math.floor((PublicShared.getOpenServerDay() - 1) / G.gc.zhanling.eventOpen.day)
|
||||
let prev_run_time = PublicShared.getToDayZeroTime(G.openTime) + round * G.gc.zhanling.eventOpen.day * 86400
|
||||
this.db.updateOne({type: this.id}, {$set: {lastRunTime: prev_run_time, round: round}}, {upsert: true});
|
||||
this.db.updateOne({ type: this.id }, { $set: { lastRunTime: prev_run_time, round: round } }, { upsert: true });
|
||||
}
|
||||
|
||||
if (!data || G.time > PublicShared.getToDayZeroTime(data.lastRunTime) + 24 * 3600 * G.gc.zhanling.eventOpen.day) {
|
||||
@ -33,11 +33,11 @@ export class SchedulerZhanLing extends Scheduler {
|
||||
// 开服时间整除战令周期
|
||||
let round = Math.floor(PublicShared.getOpenServerDay() / G.gc.zhanling.eventOpen.day)
|
||||
// lastRunTime仅储存最大值,问题记录: 本地多人启动服务时,有调用此定时器的情况下,时间会混乱。
|
||||
await this.db.updateOne({type: this.id}, {$set: {round: round}, $max: {lastRunTime: G.time}}, {upsert: true});
|
||||
await this.db.updateOne({ type: this.id }, { $set: { round: round }, $max: { lastRunTime: G.time } }, { upsert: true });
|
||||
|
||||
this.startTime = PublicShared.getToDayZeroTime() + 24 * 3600 * G.gc.zhanling.eventOpen.day;
|
||||
this.isStart = false;
|
||||
|
||||
G.mongodb.collection('zhanling').updateMany({type: 'round'}, {$set: {data: {}}});
|
||||
G.mongodb.collection('zhanling').updateMany({ type: 'round' }, { $set: { data: {} } });
|
||||
}
|
||||
}
|
@ -1,9 +1,10 @@
|
||||
import {ApiCall, ApiReturn} from "tsrpc";
|
||||
import {HongDianChange} from "../api_s2c/hongdian/fun";
|
||||
import {taskType} from "../shared/protocols/task/type";
|
||||
import {PublicShared} from "../shared/public/public";
|
||||
import {PeijianFun} from "./peijian";
|
||||
import {manager} from "./taskclass";
|
||||
import { ApiCall, ApiReturn } from "tsrpc";
|
||||
import { HongDianChange } from "../api_s2c/hongdian/fun";
|
||||
import { taskType } from "../shared/protocols/task/type";
|
||||
import { PublicShared } from "../shared/public/public";
|
||||
import { PeijianFun } from "./peijian";
|
||||
import { manager } from "./taskclass";
|
||||
import ApiRecTask from "../api_s2c/event/zhanling/ApiRecTask";
|
||||
|
||||
let taskDict = {};
|
||||
const SHUJUKU = "task";
|
||||
@ -114,7 +115,7 @@ export class TaskFun {
|
||||
let _taskCon = await this.getTaskConByType(_task["type"], _task["taskid"]);
|
||||
if (!_taskCon || Object.keys(_taskCon).length == 0) {
|
||||
// 策划改了任务 找不到 自动删除任务
|
||||
await G.mongodb.collection(SHUJUKU).deleteMany({uid: call.uid, taskid: _task["taskid"]});
|
||||
await G.mongodb.collection(SHUJUKU).deleteMany({ uid: call.uid, taskid: _task["taskid"] });
|
||||
continue
|
||||
}
|
||||
|
||||
@ -142,12 +143,12 @@ export class TaskFun {
|
||||
// 任务值上限检测
|
||||
_resVal = _resVal > _pval ? _pval : _resVal;
|
||||
// 设置任务
|
||||
let _setData = {nval: _resVal};
|
||||
let _where = {taskid: _task["taskid"]};
|
||||
let _setData = { nval: _resVal };
|
||||
let _where = { taskid: _task["taskid"] };
|
||||
await this.setTask(uid, _where, _setData);
|
||||
|
||||
if (_resVal == _pval) {
|
||||
G.server.sendMsgByUid(call.uid, 'msg_s2c/TaskChange', {..._task, nval: _resVal})
|
||||
G.server.sendMsgByUid(call.uid, 'msg_s2c/TaskChange', { ..._task, nval: _resVal })
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -187,7 +188,7 @@ export class TaskFun {
|
||||
// 重置每日任务
|
||||
if (ttype == 1 || ttype == 4) {
|
||||
let _zero = PublicShared.getToDayZeroTime(G.time);
|
||||
let _where = {retime: {$gte: _zero, $lte: _zero + 24 * 60 * 60 - 1}, type: ttype};
|
||||
let _where = { retime: { $gte: _zero, $lte: _zero + 24 * 60 * 60 - 1 }, type: ttype };
|
||||
let _tmp = await this.getUserTaksList(call.uid, _where);
|
||||
if (_tmp.length == 0) await this.resetDailyTask(call, ttype);
|
||||
}
|
||||
@ -197,7 +198,7 @@ export class TaskFun {
|
||||
* 重置每日任务
|
||||
*/
|
||||
static async resetDailyTask(call: ApiCall, type: number = 1) {
|
||||
await this.delTasks(call.uid, {type: type});
|
||||
await this.delTasks(call.uid, { type: type });
|
||||
// 该限制改到红点检测判断,避免此处注释后,红点检测与账号创建初始化任务并发。
|
||||
// if (PublicShared.chkSameDate(call.conn.gud.cTime, G.time)) return;
|
||||
let _taskCons = await this.getTaskConsByType(type);
|
||||
@ -236,7 +237,7 @@ export class TaskFun {
|
||||
static async getFinishByStype(call: ApiCall, stype: number, where: {}) {
|
||||
// 任务刷新
|
||||
await this.refreshTask(call);
|
||||
Object.assign(where, {stype: stype});
|
||||
Object.assign(where, { stype: stype });
|
||||
let _r = await this.getUserTaksList(call.uid, where);
|
||||
return _r;
|
||||
}
|
||||
@ -255,11 +256,33 @@ export class TaskFun {
|
||||
// Object.assign(where, { type: { $in: ttype } })
|
||||
for (let index = 0; index < ttype.length; index++) {
|
||||
const _type = ttype[index];
|
||||
Object.assign(_w, {type: _type, ...where});
|
||||
Object.assign(_w, { type: _type, ...where });
|
||||
if (_finishType.indexOf(_type) != -1) {
|
||||
delete _w["finish"];
|
||||
}
|
||||
let _tmp = await this.getUserTaksList(call.uid, _w);
|
||||
// 没有未完成任务
|
||||
// 检测是否有新加任务
|
||||
if (_tmp.length == 0) {
|
||||
let rectask = (await G.mongodb.collection('task').find(
|
||||
{ uid: call.uid, type: _type }, { projection: { taskid: 1, _id: 0 } }
|
||||
).toArray()).map(e => e.taskid);
|
||||
|
||||
for (let taskid of rectask) {
|
||||
let conf = G.gc.task[_type][taskid];
|
||||
// 配置不存在
|
||||
// 没有后续任务
|
||||
// 后续任务已完成
|
||||
if (!conf || !conf.followtask || rectask.includes(conf.followtask)) {
|
||||
continue
|
||||
}
|
||||
|
||||
// 生成后续任务
|
||||
await this.setTaskInfo(call, conf.followtask, { type: _type });
|
||||
break;
|
||||
}
|
||||
_tmp = await this.getUserTaksList(call.uid, _w);
|
||||
}
|
||||
_r[_type] = _tmp;
|
||||
}
|
||||
return _r;
|
||||
@ -313,7 +336,7 @@ export class TaskFun {
|
||||
* @param call
|
||||
*/
|
||||
static async updateMainTask(call: ApiCall) {
|
||||
let data = await G.mongodb.collection(SHUJUKU).findOne({uid: call.uid, type: 2, finish: 0});
|
||||
let data = await G.mongodb.collection(SHUJUKU).findOne({ uid: call.uid, type: 2, finish: 0 });
|
||||
|
||||
let _ftaskCon = await TaskFun.getTaskConByType(2, data.taskid);
|
||||
// @ts-ignore
|
||||
@ -324,14 +347,14 @@ export class TaskFun {
|
||||
type: 2,
|
||||
finish: 0,
|
||||
taskid: data.taskid
|
||||
}, {$set: {...newTask, nval: data.nval || newTask.nval, retime: data.retime,}}, {upsert: true})
|
||||
}, { $set: { ...newTask, nval: data.nval || newTask.nval, retime: data.retime, } }, { upsert: true })
|
||||
}
|
||||
|
||||
/**
|
||||
* 生成所有任务
|
||||
*/
|
||||
static async generateAllTask(call: ApiCall) {
|
||||
let _r = await G.mongodb.collection(SHUJUKU).count({uid: call.uid});
|
||||
let _r = await G.mongodb.collection(SHUJUKU).count({ uid: call.uid });
|
||||
if (_r > 0) return;
|
||||
let _taskInfo = [];
|
||||
let _con = G.gc.task;
|
||||
@ -352,7 +375,7 @@ export class TaskFun {
|
||||
/**生成指定类型任务-初始化 */
|
||||
static async reInitTask(call: ApiCall, type: string) {
|
||||
// 查询类型任务是否存在
|
||||
let _r = await G.mongodb.collection(SHUJUKU).count({uid: call.uid, type: ~~type});
|
||||
let _r = await G.mongodb.collection(SHUJUKU).count({ uid: call.uid, type: ~~type });
|
||||
let _taskInfo = [];
|
||||
if (_r == 0) {
|
||||
let _con = G.gc.task;
|
||||
@ -374,7 +397,7 @@ export class TaskFun {
|
||||
*/
|
||||
static async getUserTaksList(uid: string, where: {}) {
|
||||
// type : 1 主线 2 成就 3 每日
|
||||
Object.assign(where, {uid: uid});
|
||||
Object.assign(where, { uid: uid });
|
||||
let _taskInfo = await G.mongodb.collection(SHUJUKU).find(where).toArray();
|
||||
_taskInfo.forEach(e => {
|
||||
if (e._id) delete e._id;
|
||||
@ -386,7 +409,7 @@ export class TaskFun {
|
||||
* 删除相关任务
|
||||
*/
|
||||
static async delTasks(uid: string, where: { type: number; }) {
|
||||
Object.assign(where, {uid: uid});
|
||||
Object.assign(where, { uid: uid });
|
||||
await G.mongodb.collection(SHUJUKU).deleteMany(where);
|
||||
}
|
||||
|
||||
@ -420,8 +443,8 @@ export class TaskFun {
|
||||
if (Object.keys(setData).length == 0) {
|
||||
return;
|
||||
}
|
||||
Object.assign(where, {uid});
|
||||
setData = {$set: setData};
|
||||
Object.assign(where, { uid });
|
||||
setData = { $set: setData };
|
||||
await G.mongodb.collection(SHUJUKU).updateOne(where, setData);
|
||||
}
|
||||
|
||||
@ -445,7 +468,7 @@ export class TaskFun {
|
||||
if ((element == "1" || element == "3") && call.conn.gud.lv < 7) continue;
|
||||
let _values: number[] = _ttype[element];
|
||||
let _where: {} = {
|
||||
uid: call.uid, type: {$in: _values}, finish: 0, '$expr': {
|
||||
uid: call.uid, type: { $in: _values }, finish: 0, '$expr': {
|
||||
$lte: ["$pval", "$nval"]
|
||||
}
|
||||
};
|
||||
@ -534,10 +557,10 @@ export class TaskAllEmitFun {
|
||||
});
|
||||
if (_val > (usertasklog?.maxherolv | 0)) {
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{$set: {maxherolv: _val}});
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{ $set: { maxherolv: _val } });
|
||||
}
|
||||
// 干部等级达到 n 级
|
||||
G.emit("Class_task_106", 'Class_task_106', node.call, _val, 0);
|
||||
@ -580,10 +603,10 @@ export class TaskAllEmitFun {
|
||||
});
|
||||
if (_val > (usertasklog?.maxequiplv | 0)) {
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{$set: {maxequiplv: _val}});
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{ $set: { maxequiplv: _val } });
|
||||
}
|
||||
G.emit("Class_task_112", 'Class_task_112', node.call, _val, 0);
|
||||
// 有 n 件强化 配置 等级装备 后面复写正确值
|
||||
@ -604,10 +627,10 @@ export class TaskAllEmitFun {
|
||||
});
|
||||
if (_val > (usertasklog?.maxequiplv | 0)) {
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{$set: {maxequiplv: _val}});
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{ $set: { maxequiplv: _val } });
|
||||
}
|
||||
// 有 n 件强化 配置 等级装备 后面复写正确值
|
||||
G.emit("Class_task_113", 'Class_task_113', node.call, 0, 0);
|
||||
@ -622,10 +645,10 @@ export class TaskAllEmitFun {
|
||||
let _color = G.gc.hero[element.heroId].colour;
|
||||
G.emit("Class_task_114", 'Class_task_114', node.call, 1, _color);
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{$inc: G.mongodb.createTreeObj({key: `herocolor.${_color}`, val: 1})});
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{ $inc: G.mongodb.createTreeObj({ key: `herocolor.${_color}`, val: 1 }) });
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -651,7 +674,7 @@ export class TaskAllEmitFun {
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.uid,
|
||||
type: 'usertasklog'
|
||||
}, {$set: {equipcolor: usertasklog.equipcolor}})
|
||||
}, { $set: { equipcolor: usertasklog.equipcolor } })
|
||||
}
|
||||
// if (node.call.service.name == 'chongzhi/Open' && node.return.isSucc) {
|
||||
// // 累计充值 n 钻石 数量后面复写
|
||||
@ -690,10 +713,10 @@ export class TaskAllEmitFun {
|
||||
}
|
||||
_val = _val + usertasklog.friendAsk + usertasklog.sendGift
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{$set: {friendAsk: _val}});
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
{ $set: { friendAsk: _val } });
|
||||
G.emit("Class_task_144", 'Class_task_144', node.call, 1, 0);
|
||||
}
|
||||
if (node.call.service.name == 'tanxian/FastGuaJi' && node.return.isSucc) {
|
||||
@ -852,7 +875,7 @@ export class TaskAllEmitFun {
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
});
|
||||
let _setData = {$set: {}}; // 更新配件记录
|
||||
let _setData = { $set: {} }; // 更新配件记录
|
||||
|
||||
let peijianCon = G.gc.peijian;
|
||||
let _lv = 0;
|
||||
@ -881,9 +904,9 @@ export class TaskAllEmitFun {
|
||||
// 配件升级到 xx 级
|
||||
if (_setData["$set"]["maxpeijianlv"]) G.emit("Class_task_139", 'Class_task_139', node.call, _lv, 0);
|
||||
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
uid: node.call.conn.uid,
|
||||
type: 'usertasklog'
|
||||
},
|
||||
_setData);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user