Fix being returned to the main menu when inventory full (!251)
- Add a new method of sending errors back but not flagging the response as failed in ItemEventCallback - Don't treat `NOTENOUGHSPACE` errors as critical errors - Return proper `NOTENOUGHSPACE` error code for stash space issues for trader/flea/craft - Add missing error codes to `BackendErrorCodes` Co-authored-by: DrakiaXYZ <565558+TheDgtl@users.noreply.github.com> Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/251 Co-authored-by: DrakiaXYZ <drakiaxyz@noreply.dev.sp-tarkov.com> Co-committed-by: DrakiaXYZ <drakiaxyz@noreply.dev.sp-tarkov.com>
This commit is contained in:
parent
d4ee8f64d4
commit
77bc22f27e
@ -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)
|
||||||
|
@ -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";
|
||||||
@ -949,7 +950,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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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,
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user