From f74031b4d58866b9db544bfccd5559d791542211 Mon Sep 17 00:00:00 2001 From: chomp Date: Tue, 14 Mar 2023 12:39:36 +0000 Subject: [PATCH] Feature: Ensure chosen extract for repeatable quest always has a chance above 0 (!68) Co-authored-by: Dev Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/68 --- project/src/controllers/RepeatableQuestController.ts | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/project/src/controllers/RepeatableQuestController.ts b/project/src/controllers/RepeatableQuestController.ts index 3af4bd57..f49632b6 100644 --- a/project/src/controllers/RepeatableQuestController.ts +++ b/project/src/controllers/RepeatableQuestController.ts @@ -435,12 +435,13 @@ export class RepeatableQuestController if (Math.random() < repeatableConfig.questConfig.Exploration.specificExits.probability) { - // Filter by whitelist, it's also possible that the field "PassageRequirement" does not exist (e.g. shoreline) + // Filter by whitelist, it's also possible that the field "PassageRequirement" does not exist (e.g. Shoreline) // Scav exits are not listed at all in locations.base currently. If that changes at some point, additional filtering will be required - const possibleExists = (this.databaseServer.getTables().locations[locationKey.toLowerCase()].base as ILocationBase).exits.filter( - x => !("PassageRequirement" in x) - || repeatableConfig.questConfig.Exploration.specificExits.passageRequirementWhitelist.includes(x.PassageRequirement) - || x.Chance > 0 + const mapExits = (this.databaseServer.getTables().locations[locationKey.toLowerCase()].base as ILocationBase).exits; + const possibleExists = mapExits.filter( + x => (!("PassageRequirement" in x) + || repeatableConfig.questConfig.Exploration.specificExits.passageRequirementWhitelist.includes(x.PassageRequirement)) + && x.Chance > 0 ); const exit = this.randomUtil.drawRandomFromList(possibleExists, 1)[0]; const exitCondition = this.generateExplorationExitCondition(exit);