This commit is contained in:
Dev 2024-03-08 12:05:56 +00:00
commit 5ea7d7b97d
5 changed files with 48 additions and 9 deletions

View File

@ -24,17 +24,38 @@ export class ItemEventCallbacks
): IGetBodyResponseData<IItemEventRouterResponse> ): IGetBodyResponseData<IItemEventRouterResponse>
{ {
const eventResponse = this.itemEventRouter.handleEvents(info, sessionID); const eventResponse = this.itemEventRouter.handleEvents(info, sessionID);
const result = (eventResponse.warnings.length > 0) const result = (this.isCriticalError(eventResponse.warnings))
? this.httpResponse.getBody( ? this.httpResponse.getBody(
eventResponse, eventResponse,
this.getErrorCode(eventResponse.warnings), this.getErrorCode(eventResponse.warnings),
eventResponse.warnings[0].errmsg, eventResponse.warnings[0].errmsg,
) // TODO: map 228 to its enum value )
: this.httpResponse.getBody(eventResponse); : this.httpResponse.getBody(eventResponse);
return result; return result;
} }
/**
* Return true if the passed in list of warnings contains critical issues
* @param warnings The list of warnings to check for critical errors
* @returns
*/
private isCriticalError(warnings: Warning[]): boolean
{
// List of non-critical error codes, we return true if any error NOT included is passed in
const nonCriticalErrorCodes: BackendErrorCodes[] = [BackendErrorCodes.NOTENOUGHSPACE];
for (const warning of warnings)
{
if (!nonCriticalErrorCodes.includes(+warning.code))
{
return true;
}
}
return false;
}
protected getErrorCode(warnings: Warning[]): number protected getErrorCode(warnings: Warning[]): number
{ {
if (warnings[0]?.code) if (warnings[0]?.code)

View File

@ -35,6 +35,7 @@ import { IRecordShootingRangePoints } from "@spt-aki/models/eft/hideout/IRecordS
import { IAddItemDirectRequest } from "@spt-aki/models/eft/inventory/IAddItemDirectRequest"; import { IAddItemDirectRequest } from "@spt-aki/models/eft/inventory/IAddItemDirectRequest";
import { IAddItemsDirectRequest } from "@spt-aki/models/eft/inventory/IAddItemsDirectRequest"; import { IAddItemsDirectRequest } from "@spt-aki/models/eft/inventory/IAddItemsDirectRequest";
import { IItemEventRouterResponse } from "@spt-aki/models/eft/itemEvent/IItemEventRouterResponse"; import { IItemEventRouterResponse } from "@spt-aki/models/eft/itemEvent/IItemEventRouterResponse";
import { BackendErrorCodes } from "@spt-aki/models/enums/BackendErrorCodes";
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes"; import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
import { HideoutAreas } from "@spt-aki/models/enums/HideoutAreas"; import { HideoutAreas } from "@spt-aki/models/enums/HideoutAreas";
import { SkillTypes } from "@spt-aki/models/enums/SkillTypes"; import { SkillTypes } from "@spt-aki/models/enums/SkillTypes";
@ -674,9 +675,11 @@ export class HideoutController
} }
// @Important: Here we need to be very exact: // @Important: Here we need to be very exact:
// - normal recipe: Production time value is stored in attribute "productionType" with small "p" // - normal recipe: Production time value is stored in attribute "productionTime" with small "p"
// - scav case recipe: Production time value is stored in attribute "ProductionType" with capital "P" // - scav case recipe: Production time value is stored in attribute "ProductionTime" with capital "P"
const modifiedScavCaseTime = this.getScavCaseTime(pmcData, recipe.ProductionTime); const adjustedCraftTime = recipe.ProductionTime
- this.hideoutHelper.getCraftingSkillProductionTimeReduction(pmcData, recipe.ProductionTime);
const modifiedScavCaseTime = this.getScavCaseTime(pmcData, adjustedCraftTime);
pmcData.Hideout.Production[body.recipeId] = this.hideoutHelper.initProduction( pmcData.Hideout.Production[body.recipeId] = this.hideoutHelper.initProduction(
body.recipeId, body.recipeId,
@ -949,7 +952,11 @@ export class HideoutController
const totalResultItems = toolsToSendToPlayer.concat(itemAndChildrenToSendToPlayer); const totalResultItems = toolsToSendToPlayer.concat(itemAndChildrenToSendToPlayer);
if (!this.inventoryHelper.canPlaceItemsInInventory(sessionID, totalResultItems)) if (!this.inventoryHelper.canPlaceItemsInInventory(sessionID, totalResultItems))
{ {
this.httpResponse.appendErrorToOutput(output, this.localisationService.getText("inventory-no_stash_space")); this.httpResponse.appendErrorToOutput(
output,
this.localisationService.getText("inventory-no_stash_space"),
BackendErrorCodes.NOTENOUGHSPACE,
);
return; return;
} }

View File

@ -999,7 +999,7 @@ export class HideoutHelper
* @param productionTime Time to complete hideout craft in seconds * @param productionTime Time to complete hideout craft in seconds
* @returns Adjusted craft time in seconds * @returns Adjusted craft time in seconds
*/ */
protected getCraftingSkillProductionTimeReduction(pmcData: IPmcData, productionTime: number): number public getCraftingSkillProductionTimeReduction(pmcData: IPmcData, productionTime: number): number
{ {
const craftingSkill = pmcData.Skills.Common.find((skill) => skill.Id === SkillTypes.CRAFTING); const craftingSkill = pmcData.Skills.Common.find((skill) => skill.Id === SkillTypes.CRAFTING);
if (!craftingSkill) if (!craftingSkill)

View File

@ -20,6 +20,7 @@ import { IInventoryRemoveRequestData } from "@spt-aki/models/eft/inventory/IInve
import { IInventorySplitRequestData } from "@spt-aki/models/eft/inventory/IInventorySplitRequestData"; import { IInventorySplitRequestData } from "@spt-aki/models/eft/inventory/IInventorySplitRequestData";
import { IInventoryTransferRequestData } from "@spt-aki/models/eft/inventory/IInventoryTransferRequestData"; import { IInventoryTransferRequestData } from "@spt-aki/models/eft/inventory/IInventoryTransferRequestData";
import { IItemEventRouterResponse } from "@spt-aki/models/eft/itemEvent/IItemEventRouterResponse"; import { IItemEventRouterResponse } from "@spt-aki/models/eft/itemEvent/IItemEventRouterResponse";
import { BackendErrorCodes } from "@spt-aki/models/enums/BackendErrorCodes";
import { BaseClasses } from "@spt-aki/models/enums/BaseClasses"; import { BaseClasses } from "@spt-aki/models/enums/BaseClasses";
import { BonusType } from "@spt-aki/models/enums/BonusType"; import { BonusType } from "@spt-aki/models/enums/BonusType";
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes"; import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
@ -88,7 +89,11 @@ export class InventoryHelper
if (!this.canPlaceItemsInInventory(sessionId, request.itemsWithModsToAdd)) if (!this.canPlaceItemsInInventory(sessionId, request.itemsWithModsToAdd))
{ {
// No space, exit // No space, exit
this.httpResponse.appendErrorToOutput(output, this.localisationService.getText("inventory-no_stash_space")); this.httpResponse.appendErrorToOutput(
output,
this.localisationService.getText("inventory-no_stash_space"),
BackendErrorCodes.NOTENOUGHSPACE,
);
return; return;
} }
@ -470,7 +475,11 @@ export class InventoryHelper
} }
else else
{ {
this.httpResponse.appendErrorToOutput(output, this.localisationService.getText("inventory-no_stash_space")); this.httpResponse.appendErrorToOutput(
output,
this.localisationService.getText("inventory-no_stash_space"),
BackendErrorCodes.NOTENOUGHSPACE,
);
return; return;
} }

View File

@ -63,6 +63,7 @@ export enum BackendErrorCodes
BANNEDERRORCODE = 1513, BANNEDERRORCODE = 1513,
INSUFFICIENTNUMBERINSTOCK = 1516, INSUFFICIENTNUMBERINSTOCK = 1516,
TOOMANYITEMSTOSELL = 1517, TOOMANYITEMSTOSELL = 1517,
INCORRECTCLIENTPRICE = 1519,
EXAMINATIONFAILED = 22001, EXAMINATIONFAILED = 22001,
ITEMALREADYEXAMINED = 22002, ITEMALREADYEXAMINED = 22002,
UNKNOWNNGINXERROR = 9000, UNKNOWNNGINXERROR = 9000,
@ -83,4 +84,5 @@ export enum BackendErrorCodes
PLAYERALREADYLOOKINGFORGAME = 503001, PLAYERALREADYLOOKINGFORGAME = 503001,
PLAYERINRAID = 503002, PLAYERINRAID = 503002,
LIMITFORPRESETSREACHED = 504001, LIMITFORPRESETSREACHED = 504001,
PLAYERPROFILENOTFOUND = 505001,
} }