feat(活动): 月基金每月补发

This commit is contained in:
luying
2023-03-24 19:13:34 +08:00
parent 6ca399c2e8
commit 47a896c0ba
8 changed files with 93 additions and 5 deletions

View File

@@ -5,10 +5,10 @@ import { nowSeconds, getTimeFun, getSeconds } from '../pubUtils/timeUtil';
import { getTodayGuildActivity, gameData } from '../pubUtils/data';
import { pvpSeasonEnd } from './pvpService';
import { getAllOnlineRoles, getAllServers, delGuildActivityRank, getServerCreateTime } from './redisService';
import { GUILD_ACTIVITY_TYPE, REFRESH_TIME, COUNTER, AUCTION_TIME, GM_MAIL_TYPE, SERVER_TIMER, ACTIVITY_TYPE, PUSH_ROUTE, STATUS, LADDER_STATUS, LADDER_SERVER_GAP_TIME, GVG_PERIOD, SDK_PUSH_MSG_TYPE } from '../consts';
import { GUILD_ACTIVITY_TYPE, REFRESH_TIME, COUNTER, AUCTION_TIME, GM_MAIL_TYPE, SERVER_TIMER, ACTIVITY_TYPE, PUSH_ROUTE, STATUS, LADDER_STATUS, LADDER_SERVER_GAP_TIME, GVG_PERIOD, SDK_PUSH_MSG_TYPE, MAIL_TYPE } from '../consts';
import { pinus } from 'pinus';
import { settleGuildWeekly } from './guildService';
import { SendMailFun, sendMailsByGmMail, } from './mailService';
import { sendMailByContent, SendMailFun, sendMailsByGmMail, } from './mailService';
import { sendEndMsgToAllServer, sendGuildActivityStatus, setPreDayActiveData, incCurGuildActivityIndex } from './guildActivity/guildActivityService';
import { sendUngotDividendJob, startGuildAuction, startWorldAuction, stopAuction } from './auctionService';
import { DicGuildActivity } from '../pubUtils/dictionary/DicGuildActivity';
@@ -46,6 +46,11 @@ import { GVGConfigModel } from '../db/GVGConfig';
import { createNewGVGConfig, initLeaguePrepare } from './gvg/gvgService';
import { getFightTimeByPeriod, saveVestigeRankSchedule, gvgBattlePeriodSchedule } from './gvg/gvgFightService';
import { gvgBattleEnd } from './gvg/gvgBattleService';
import { ActivityMonthlyFundModel } from '../db/ActivityMonthlyFund';
import { getActivityById } from './activity/activityService';
import { MonthlyFundData } from "../domain/activityField/monthlyFundField";
import { RewardInter } from '../pubUtils/interface';
import { stringToRewardInter } from './activity/giftPackageService';
const PER_SECOND = 1 * 1000;
const PER_DAY = 24 * 60 * 60;
@@ -116,6 +121,9 @@ export async function init() {
// 定时推送消息
initPushMsgSchedule();
// 月基金每月未领取
initMonthlyFundSchedule();
}
// 每日刷新
@@ -1011,4 +1019,38 @@ async function initPushMsgSchedule() {
scheduleJob('sendAfkPlayers', '0 0 12 * * ?', async () => {
pushClientMsg(SDK_PUSH_MSG_TYPE.AP_LUNCH);
});
}
// 月基金未领取的发送到邮件,每月发送
async function initMonthlyFundSchedule() {
scheduleJob('initMonthlyFundSchedule', '0 0 5 1 * ?', async () => {
let roundIndex = parseInt(moment().add(-1, 'M').format('YYYYMM'));
await monthlyFundSchedule(roundIndex);
});
}
export async function monthlyFundSchedule(roundIndex: number) {
let activityMap = new Map<number, ActivityModelType>();
let playerDatas = await ActivityMonthlyFundModel.findNotReceivedReward(roundIndex);
let _ids: string[] = [];
for(let playerData of playerDatas) {
if(!activityMap.has(playerData.activityId)) {
let activity = await getActivityById(playerData.activityId);
activityMap.set(playerData.activityId, activity);
}
let activityData = activityMap.get(playerData.activityId);
if(!activityData) continue;
let data = new MonthlyFundData(activityData, 0, 0);
let page = data.findPage(playerData.pageIndex);
page.setPlayerRecord(playerData);
let rewards: RewardInter[] = [];
for(let { reward, hasReceived } of page.rewards) {
if(!hasReceived) rewards.push(...stringToRewardInter(reward));
}
if(rewards.length > 0) {
await sendMailByContent(MAIL_TYPE.MONTHLY_FUND, playerData.roleId, { goods: rewards });
}
_ids.push(playerData._id);
}
await ActivityMonthlyFundModel.updateHasReceivedAll(_ids);
}