✨ feat(活动): 月基金每月补发
This commit is contained in:
@@ -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);
|
||||
}
|
||||
Reference in New Issue
Block a user