feat: handle acquisition of EmailItems (#1064)
Fixes #1063 Reviewed-on: #1064 Co-authored-by: Sainan <sainan@calamity.inc> Co-committed-by: Sainan <sainan@calamity.inc>
This commit is contained in:
parent
70cd088ffa
commit
9158209059
@ -35,7 +35,7 @@ import {
|
|||||||
IUpdateChallengeProgressRequest
|
IUpdateChallengeProgressRequest
|
||||||
} from "../types/requestTypes";
|
} from "../types/requestTypes";
|
||||||
import { logger } from "@/src/utils/logger";
|
import { logger } from "@/src/utils/logger";
|
||||||
import { getExalted, getKeyChainItems } from "@/src/services/itemDataService";
|
import { convertInboxMessage, getExalted, getKeyChainItems } from "@/src/services/itemDataService";
|
||||||
import {
|
import {
|
||||||
EquipmentFeatures,
|
EquipmentFeatures,
|
||||||
IEquipmentClient,
|
IEquipmentClient,
|
||||||
@ -47,6 +47,7 @@ import {
|
|||||||
ExportBundles,
|
ExportBundles,
|
||||||
ExportCustoms,
|
ExportCustoms,
|
||||||
ExportDrones,
|
ExportDrones,
|
||||||
|
ExportEmailItems,
|
||||||
ExportEnemies,
|
ExportEnemies,
|
||||||
ExportFlavour,
|
ExportFlavour,
|
||||||
ExportFusionBundles,
|
ExportFusionBundles,
|
||||||
@ -71,6 +72,7 @@ import { addQuestKey, completeQuest } from "@/src/services/questService";
|
|||||||
import { handleBundleAcqusition } from "./purchaseService";
|
import { handleBundleAcqusition } from "./purchaseService";
|
||||||
import libraryDailyTasks from "@/static/fixed_responses/libraryDailyTasks.json";
|
import libraryDailyTasks from "@/static/fixed_responses/libraryDailyTasks.json";
|
||||||
import { getRandomElement, getRandomInt } from "./rngService";
|
import { getRandomElement, getRandomInt } from "./rngService";
|
||||||
|
import { createMessage } from "./inboxService";
|
||||||
|
|
||||||
export const createInventory = async (
|
export const createInventory = async (
|
||||||
accountOwnerId: Types.ObjectId,
|
accountOwnerId: Types.ObjectId,
|
||||||
@ -425,6 +427,13 @@ export const addItem = async (
|
|||||||
InventoryChanges: inventoryChanges
|
InventoryChanges: inventoryChanges
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
if (typeName in ExportEmailItems) {
|
||||||
|
const emailItem = ExportEmailItems[typeName];
|
||||||
|
await createMessage(inventory.accountOwnerId.toString(), [convertInboxMessage(emailItem.message)]);
|
||||||
|
return {
|
||||||
|
InventoryChanges: {}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
// Path-based duck typing
|
// Path-based duck typing
|
||||||
switch (typeName.substr(1).split("/")[1]) {
|
switch (typeName.substr(1).split("/")[1]) {
|
||||||
|
@ -36,6 +36,7 @@ import {
|
|||||||
TReward
|
TReward
|
||||||
} from "warframe-public-export-plus";
|
} from "warframe-public-export-plus";
|
||||||
import questCompletionItems from "@/static/fixed_responses/questCompletionRewards.json";
|
import questCompletionItems from "@/static/fixed_responses/questCompletionRewards.json";
|
||||||
|
import { IMessage } from "../models/inboxModel";
|
||||||
|
|
||||||
export type WeaponTypeInternal =
|
export type WeaponTypeInternal =
|
||||||
| "LongGuns"
|
| "LongGuns"
|
||||||
@ -207,7 +208,7 @@ export const getQuestCompletionItems = (questKey: string): ITypeCount[] | undefi
|
|||||||
return items;
|
return items;
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getKeyChainMessage = ({ KeyChain, ChainStage }: IKeyChainRequest): IInboxMessage => {
|
export const getKeyChainMessage = ({ KeyChain, ChainStage }: IKeyChainRequest): IMessage => {
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
||||||
const chainStages = ExportKeys[KeyChain]?.chainStages;
|
const chainStages = ExportKeys[KeyChain]?.chainStages;
|
||||||
if (!chainStages) {
|
if (!chainStages) {
|
||||||
@ -227,5 +228,19 @@ export const getKeyChainMessage = ({ KeyChain, ChainStage }: IKeyChainRequest):
|
|||||||
`client requested key chain message in keychain ${KeyChain} at stage ${ChainStage} but they did not exist`
|
`client requested key chain message in keychain ${KeyChain} at stage ${ChainStage} but they did not exist`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
return chainStageMessage;
|
return convertInboxMessage(chainStageMessage);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const convertInboxMessage = (message: IInboxMessage): IMessage => {
|
||||||
|
return {
|
||||||
|
sndr: message.sender,
|
||||||
|
msg: message.body,
|
||||||
|
sub: message.title,
|
||||||
|
att: message.attachments.length > 0 ? message.attachments : undefined,
|
||||||
|
countedAtt: message.countedAttachments.length > 0 ? message.countedAttachments : undefined,
|
||||||
|
icon: message.icon ?? "",
|
||||||
|
transmission: message.transmission ?? "",
|
||||||
|
highPriority: message.highPriority ?? false,
|
||||||
|
r: false
|
||||||
|
} satisfies IMessage;
|
||||||
};
|
};
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { IKeyChainRequest } from "@/src/controllers/api/giveKeyChainTriggeredItemsController";
|
import { IKeyChainRequest } from "@/src/controllers/api/giveKeyChainTriggeredItemsController";
|
||||||
import { isEmptyObject } from "@/src/helpers/general";
|
import { isEmptyObject } from "@/src/helpers/general";
|
||||||
import { IMessage } from "@/src/models/inboxModel";
|
|
||||||
import { TInventoryDatabaseDocument } from "@/src/models/inventoryModels/inventoryModel";
|
import { TInventoryDatabaseDocument } from "@/src/models/inventoryModels/inventoryModel";
|
||||||
import { createMessage } from "@/src/services/inboxService";
|
import { createMessage } from "@/src/services/inboxService";
|
||||||
import { addItem, addKeyChainItems } from "@/src/services/inventoryService";
|
import { addItem, addKeyChainItems } from "@/src/services/inventoryService";
|
||||||
@ -198,19 +197,7 @@ export const giveKeyChainMessage = async (
|
|||||||
): Promise<void> => {
|
): Promise<void> => {
|
||||||
const keyChainMessage = getKeyChainMessage(keyChainInfo);
|
const keyChainMessage = getKeyChainMessage(keyChainInfo);
|
||||||
|
|
||||||
const message = {
|
await createMessage(accountId, [keyChainMessage]);
|
||||||
sndr: keyChainMessage.sender,
|
|
||||||
msg: keyChainMessage.body,
|
|
||||||
sub: keyChainMessage.title,
|
|
||||||
att: keyChainMessage.attachments.length > 0 ? keyChainMessage.attachments : undefined,
|
|
||||||
countedAtt: keyChainMessage.countedAttachments.length > 0 ? keyChainMessage.countedAttachments : undefined,
|
|
||||||
icon: keyChainMessage.icon ?? "",
|
|
||||||
transmission: keyChainMessage.transmission ?? "",
|
|
||||||
highPriority: keyChainMessage.highPriority ?? false,
|
|
||||||
r: false
|
|
||||||
} satisfies IMessage;
|
|
||||||
|
|
||||||
await createMessage(accountId, [message]);
|
|
||||||
|
|
||||||
updateQuestStage(inventory, keyChainInfo, { m: true });
|
updateQuestStage(inventory, keyChainInfo, { m: true });
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user