feat: year rollover kiss emails
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Build / build (pull_request) Successful in 48s
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Build / build (pull_request) Successful in 48s
				
			This commit is contained in:
		
							parent
							
								
									5a5f6106a3
								
							
						
					
					
						commit
						ef92040f25
					
				
							
								
								
									
										8
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										8
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@ -23,7 +23,7 @@
 | 
			
		||||
        "ncp": "^2.0.0",
 | 
			
		||||
        "typescript": "^5.5",
 | 
			
		||||
        "undici": "^7.10.0",
 | 
			
		||||
        "warframe-public-export-plus": "^0.5.74",
 | 
			
		||||
        "warframe-public-export-plus": "^0.5.76",
 | 
			
		||||
        "warframe-riven-info": "^0.1.2",
 | 
			
		||||
        "winston": "^3.17.0",
 | 
			
		||||
        "winston-daily-rotate-file": "^5.0.0",
 | 
			
		||||
@ -3386,9 +3386,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/warframe-public-export-plus": {
 | 
			
		||||
      "version": "0.5.74",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/warframe-public-export-plus/-/warframe-public-export-plus-0.5.74.tgz",
 | 
			
		||||
      "integrity": "sha512-pA7dxA0lKn9w/2Sc97oxnn+CEzL1SrT9XriNLTDF4Xp+2SBEpGcfbqbdR9ljPQJopIbrc9Zy02R+uBQVomcwyA=="
 | 
			
		||||
      "version": "0.5.76",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/warframe-public-export-plus/-/warframe-public-export-plus-0.5.76.tgz",
 | 
			
		||||
      "integrity": "sha512-0gX3NTWaxFyzUmqBSUHhPY8pMRX92iXQFqoBuMQlMG1+6uC6JMKtwP5t8cuXR3pvV2vkaCi/cDWjP1JUChkZ9g=="
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/warframe-riven-info": {
 | 
			
		||||
      "version": "0.1.2",
 | 
			
		||||
 | 
			
		||||
@ -37,7 +37,7 @@
 | 
			
		||||
    "ncp": "^2.0.0",
 | 
			
		||||
    "typescript": "^5.5",
 | 
			
		||||
    "undici": "^7.10.0",
 | 
			
		||||
    "warframe-public-export-plus": "^0.5.74",
 | 
			
		||||
    "warframe-public-export-plus": "^0.5.76",
 | 
			
		||||
    "warframe-riven-info": "^0.1.2",
 | 
			
		||||
    "winston": "^3.17.0",
 | 
			
		||||
    "winston-daily-rotate-file": "^5.0.0",
 | 
			
		||||
 | 
			
		||||
@ -9,6 +9,7 @@ import { IPolarity, ArtifactPolarity, EquipmentFeatures } from "@/src/types/inve
 | 
			
		||||
import { ExportCustoms, ExportFlavour, ExportResources, ExportVirtuals } from "warframe-public-export-plus";
 | 
			
		||||
import { applyCheatsToInfestedFoundry, handleSubsumeCompletion } from "@/src/services/infestedFoundryService";
 | 
			
		||||
import {
 | 
			
		||||
    addEmailItem,
 | 
			
		||||
    addMiscItems,
 | 
			
		||||
    allDailyAffiliationKeys,
 | 
			
		||||
    cleanupInventory,
 | 
			
		||||
@ -110,7 +111,69 @@ export const inventoryController: RequestHandler = async (request, response) =>
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (inventory.CalendarProgress) {
 | 
			
		||||
            const previousYearIteration = inventory.CalendarProgress.Iteration;
 | 
			
		||||
            getCalendarProgress(inventory); // handle year rollover; the client expects to receive an inventory with an up-to-date CalendarProgress
 | 
			
		||||
 | 
			
		||||
            // also handle sending of kiss cinematic at year rollover
 | 
			
		||||
            if (
 | 
			
		||||
                inventory.CalendarProgress.Iteration != previousYearIteration &&
 | 
			
		||||
                inventory.DialogueHistory &&
 | 
			
		||||
                inventory.DialogueHistory.Dialogues
 | 
			
		||||
            ) {
 | 
			
		||||
                let kalymos = false;
 | 
			
		||||
                for (const { dialogue, kissEmail } of [
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/ArthurDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/ArthurKissEmailItem"
 | 
			
		||||
                    },
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/EleanorDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/EleanorKissEmailItem"
 | 
			
		||||
                    },
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/LettieDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/LettieKissEmailItem"
 | 
			
		||||
                    },
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/JabirDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/AmirKissEmailItem"
 | 
			
		||||
                    },
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/AoiDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/AoiKissEmailItem"
 | 
			
		||||
                    },
 | 
			
		||||
                    {
 | 
			
		||||
                        dialogue: inventory.DialogueHistory.Dialogues.find(
 | 
			
		||||
                            x => x.DialogueName == "/Lotus/Types/Gameplay/1999Wf/Dialogue/QuincyDialogue_rom.dialogue"
 | 
			
		||||
                        ),
 | 
			
		||||
                        kissEmail: "/Lotus/Types/Items/EmailItems/QuincyKissEmailItem"
 | 
			
		||||
                    }
 | 
			
		||||
                ]) {
 | 
			
		||||
                    if (dialogue) {
 | 
			
		||||
                        if (dialogue.Rank == 7) {
 | 
			
		||||
                            await addEmailItem(inventory, kissEmail);
 | 
			
		||||
                            kalymos = false;
 | 
			
		||||
                            break;
 | 
			
		||||
                        }
 | 
			
		||||
                        if (dialogue.Rank == 6) {
 | 
			
		||||
                            kalymos = true;
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
                if (kalymos) {
 | 
			
		||||
                    await addEmailItem(inventory, "/Lotus/Types/Items/EmailItems/KalymosKissEmailItem");
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        cleanupInventory(inventory);
 | 
			
		||||
 | 
			
		||||
@ -23,7 +23,9 @@ export interface IMessageDatabase extends IMessage {
 | 
			
		||||
export interface IMessage {
 | 
			
		||||
    sndr: string;
 | 
			
		||||
    msg: string;
 | 
			
		||||
    cinematic?: string;
 | 
			
		||||
    sub: string;
 | 
			
		||||
    customData?: string;
 | 
			
		||||
    icon?: string;
 | 
			
		||||
    highPriority?: boolean;
 | 
			
		||||
    lowPrioNewPlayers?: boolean;
 | 
			
		||||
@ -102,7 +104,9 @@ const messageSchema = new Schema<IMessageDatabase>(
 | 
			
		||||
        ownerId: Schema.Types.ObjectId,
 | 
			
		||||
        sndr: String,
 | 
			
		||||
        msg: String,
 | 
			
		||||
        cinematic: String,
 | 
			
		||||
        sub: String,
 | 
			
		||||
        customData: String,
 | 
			
		||||
        icon: String,
 | 
			
		||||
        highPriority: Boolean,
 | 
			
		||||
        lowPrioNewPlayers: Boolean,
 | 
			
		||||
 | 
			
		||||
@ -83,7 +83,7 @@ import { addQuestKey, completeQuest } from "@/src/services/questService";
 | 
			
		||||
import { handleBundleAcqusition } from "./purchaseService";
 | 
			
		||||
import libraryDailyTasks from "@/static/fixed_responses/libraryDailyTasks.json";
 | 
			
		||||
import { getRandomElement, getRandomInt, getRandomWeightedReward, SRng } from "./rngService";
 | 
			
		||||
import { createMessage } from "./inboxService";
 | 
			
		||||
import { createMessage, IMessageCreationTemplate } from "./inboxService";
 | 
			
		||||
import { getMaxStanding, getMinStanding } from "@/src/helpers/syndicateStandingHelper";
 | 
			
		||||
import { getNightwaveSyndicateTag, getWorldState } from "./worldStateService";
 | 
			
		||||
import { ICalendarSeason } from "@/src/types/worldStateTypes";
 | 
			
		||||
@ -1563,7 +1563,22 @@ export const addEmailItem = async (
 | 
			
		||||
    const meta = ExportEmailItems[typeName];
 | 
			
		||||
    const emailItem = inventory.EmailItems.find(x => x.ItemType == typeName);
 | 
			
		||||
    if (!emailItem || !meta.sendOnlyOnce) {
 | 
			
		||||
        await createMessage(inventory.accountOwnerId, [convertInboxMessage(meta.message)]);
 | 
			
		||||
        const msg: IMessageCreationTemplate = convertInboxMessage(meta.message);
 | 
			
		||||
        if (msg.cinematic == "/Lotus/Levels/1999/PlayerHomeBalconyCinematics.level") {
 | 
			
		||||
            msg.customData = JSON.stringify({
 | 
			
		||||
                Tag: msg.customData + "KissCin",
 | 
			
		||||
                CinLoadout: {
 | 
			
		||||
                    Skins: inventory.AdultOperatorLoadOuts[0].Skins,
 | 
			
		||||
                    Upgrades: inventory.AdultOperatorLoadOuts[0].Upgrades,
 | 
			
		||||
                    attcol: inventory.AdultOperatorLoadOuts[0].attcol,
 | 
			
		||||
                    cloth: inventory.AdultOperatorLoadOuts[0].cloth,
 | 
			
		||||
                    eyecol: inventory.AdultOperatorLoadOuts[0].eyecol,
 | 
			
		||||
                    pricol: inventory.AdultOperatorLoadOuts[0].pricol,
 | 
			
		||||
                    syancol: inventory.AdultOperatorLoadOuts[0].syancol
 | 
			
		||||
                }
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
        await createMessage(inventory.accountOwnerId, [msg]);
 | 
			
		||||
 | 
			
		||||
        if (emailItem) {
 | 
			
		||||
            emailItem.ItemCount += 1;
 | 
			
		||||
 | 
			
		||||
@ -251,7 +251,9 @@ export const convertInboxMessage = (message: IInboxMessage): IMessage => {
 | 
			
		||||
    return {
 | 
			
		||||
        sndr: message.sender,
 | 
			
		||||
        msg: message.body,
 | 
			
		||||
        cinematic: message.cinematic,
 | 
			
		||||
        sub: message.title,
 | 
			
		||||
        customData: message.customData,
 | 
			
		||||
        att: message.attachments.length > 0 ? message.attachments : undefined,
 | 
			
		||||
        countedAtt: message.countedAttachments.length > 0 ? message.countedAttachments : undefined,
 | 
			
		||||
        icon: message.icon ?? "",
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user