diff --git a/src/services/missionInventoryUpdateService.ts b/src/services/missionInventoryUpdateService.ts index 6bd6ce58..d96c5979 100644 --- a/src/services/missionInventoryUpdateService.ts +++ b/src/services/missionInventoryUpdateService.ts @@ -1946,6 +1946,28 @@ function getRandomMissionDrops( } } + // Railjack Abandoned Cache Rewards, Rotation A (Mandatory Objectives) + if (region.cacheRewardManifest && RewardInfo.POICompletions) { + const deck = ExportRewards[region.cacheRewardManifest]; + for (let cache = 0; cache != RewardInfo.POICompletions; ++cache) { + const drop = getRandomRewardByChance(deck[0]); + if (drop) { + drops.push({ StoreItem: drop.type, ItemCount: drop.itemCount, FromEnemyCache: true }); + } + } + } + + // Railjack Abandoned Cache Rewards, Rotation B (Optional Objectives) + if (region.cacheRewardManifest && RewardInfo.LootDungeonCompletions) { + const deck = ExportRewards[region.cacheRewardManifest]; + for (let cache = 0; cache != RewardInfo.LootDungeonCompletions; ++cache) { + const drop = getRandomRewardByChance(deck[1]); + if (drop) { + drops.push({ StoreItem: drop.type, ItemCount: drop.itemCount, FromEnemyCache: true }); + } + } + } + if (RewardInfo.nightmareMode) { const deck = ExportRewards["/Lotus/Types/Game/MissionDecks/NightmareModeRewards"]; let rotation = 0; diff --git a/src/types/requestTypes.ts b/src/types/requestTypes.ts index 05adf925..d272f6cf 100644 --- a/src/types/requestTypes.ts +++ b/src/types/requestTypes.ts @@ -187,6 +187,8 @@ export interface IRewardInfo { rewardQualifications?: string; // did a Survival for 5 minutes and this was "1" rewardTierOverrides?: number[]; // Disruption PurgatoryRewardQualifications?: string; + POICompletions?: number; + LootDungeonCompletions?: number; rewardSeed?: number | bigint; periodicMissionTag?: string; T?: number; // Duviri