Rework high flea listing price adjuster to be configurable, more item types can be added (!111)
Co-authored-by: Dev <dev@dev.sp-tarkov.com> Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/111
This commit is contained in:
parent
a962823192
commit
6a864bffa9
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"runIntervalSeconds": 45,
|
"runIntervalSeconds": 45,
|
||||||
"sell": {
|
"sell": {
|
||||||
"simulatedSellHours": 12,
|
"simulatedSellHours": 12,
|
||||||
"fees": true,
|
"fees": true,
|
||||||
"chance": {
|
"chance": {
|
||||||
"base": 50,
|
"base": 50,
|
||||||
@ -31,29 +31,29 @@
|
|||||||
"ragfair": false
|
"ragfair": false
|
||||||
},
|
},
|
||||||
"dynamic": {
|
"dynamic": {
|
||||||
"purchasesAreFoundInRaid": false,
|
"purchasesAreFoundInRaid": false,
|
||||||
"useTraderPriceForOffersIfHigher": true,
|
"useTraderPriceForOffersIfHigher": true,
|
||||||
"barter": {
|
"barter": {
|
||||||
"enable": true,
|
"enable": true,
|
||||||
"chancePercent": 20,
|
"chancePercent": 20,
|
||||||
"itemCountMin": 1,
|
"itemCountMin": 1,
|
||||||
"itemCountMax": 3,
|
"itemCountMax": 3,
|
||||||
"priceRangeVariancePercent": 15,
|
"priceRangeVariancePercent": 15,
|
||||||
"minRoubleCostToBecomeBarter": 20000,
|
"minRoubleCostToBecomeBarter": 20000,
|
||||||
"itemTypeBlacklist": [
|
"itemTypeBlacklist": [
|
||||||
"55802f4a4bdc2ddb688b4569",
|
"55802f4a4bdc2ddb688b4569",
|
||||||
"55802f3e4bdc2de7118b4584",
|
"55802f3e4bdc2de7118b4584",
|
||||||
"543be5cb4bdc2deb348b4568",
|
"543be5cb4bdc2deb348b4568",
|
||||||
"55818ac54bdc2d5b648b456e",
|
"55818ac54bdc2d5b648b456e",
|
||||||
"5a74651486f7744e73386dd1"
|
"5a74651486f7744e73386dd1"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"offerAdjustment":{
|
"offerAdjustment": {
|
||||||
"adjustPriceWhenBelowHandbookPrice": false,
|
"adjustPriceWhenBelowHandbookPrice": false,
|
||||||
"maxPriceDifferenceBelowHandbookPercent": 64,
|
"maxPriceDifferenceBelowHandbookPercent": 64,
|
||||||
"handbookPriceMultipier": 1.1,
|
"handbookPriceMultipier": 1.1,
|
||||||
"priceThreshholdRub": 20000
|
"priceThreshholdRub": 20000
|
||||||
},
|
},
|
||||||
"expiredOfferThreshold": 1500,
|
"expiredOfferThreshold": 1500,
|
||||||
"offerItemCount": {
|
"offerItemCount": {
|
||||||
"min": 7,
|
"min": 7,
|
||||||
@ -67,7 +67,7 @@
|
|||||||
"min": 0.95,
|
"min": 0.95,
|
||||||
"max": 1.05
|
"max": 1.05
|
||||||
},
|
},
|
||||||
"showDefaultPresetsOnly": true,
|
"showDefaultPresetsOnly": true,
|
||||||
"endTimeSeconds": {
|
"endTimeSeconds": {
|
||||||
"min": 360,
|
"min": 360,
|
||||||
"max": 3600
|
"max": 3600
|
||||||
@ -128,7 +128,7 @@
|
|||||||
"min": 0.1,
|
"min": 0.1,
|
||||||
"max": 0.95
|
"max": 0.95
|
||||||
},
|
},
|
||||||
"_currencies": "what percentage of the offers are in each currency",
|
"_currencies": "what percentage of the offers are in each currency",
|
||||||
"currencies": {
|
"currencies": {
|
||||||
"5449016a4bdc2d6f028b456f": 78,
|
"5449016a4bdc2d6f028b456f": 78,
|
||||||
"5696686a4bdc2da3298b456a": 14,
|
"5696686a4bdc2da3298b456a": 14,
|
||||||
@ -141,20 +141,28 @@
|
|||||||
"5448e53e4bdc2d60728b4567",
|
"5448e53e4bdc2d60728b4567",
|
||||||
"5448bf274bdc2dfc2f8b456a",
|
"5448bf274bdc2dfc2f8b456a",
|
||||||
"543be5e94bdc2df1348b4568",
|
"543be5e94bdc2df1348b4568",
|
||||||
"5448f39d4bdc2d0a728b4568"
|
"5448f39d4bdc2d0a728b4568",
|
||||||
|
"62e910aaf957f2915e0a5e36"
|
||||||
],
|
],
|
||||||
"removeSeasonalItemsWhenNotInEvent": true,
|
"removeSeasonalItemsWhenNotInEvent": true,
|
||||||
"blacklist": {
|
"blacklist": {
|
||||||
"damagedAmmoPacks": true,
|
"damagedAmmoPacks": true,
|
||||||
"custom": [],
|
"custom": [],
|
||||||
"enableBsgList": true,
|
"enableBsgList": false,
|
||||||
"enableQuestList": true,
|
"enableQuestList": true,
|
||||||
"traderItems": false
|
"traderItems": false
|
||||||
},
|
},
|
||||||
"unreasonableModPrices": {
|
"unreasonableModPrices": {
|
||||||
"enabled": true,
|
"5448fe124bdc2da5018b4567": {
|
||||||
"handbookPriceOverMultiplier": 9,
|
"enabled": true,
|
||||||
"newPriceHandbookMultiplier": 9
|
"handbookPriceOverMultiplier": 9,
|
||||||
}
|
"newPriceHandbookMultiplier": 9
|
||||||
|
},
|
||||||
|
"57864a66245977548f04a81f": {
|
||||||
|
"enabled": true,
|
||||||
|
"handbookPriceOverMultiplier": 11,
|
||||||
|
"newPriceHandbookMultiplier": 11
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3917,7 +3917,7 @@
|
|||||||
"count": 1,
|
"count": 1,
|
||||||
"endProduct": "62e910aaf957f2915e0a5e36",
|
"endProduct": "62e910aaf957f2915e0a5e36",
|
||||||
"isEncoded": true,
|
"isEncoded": true,
|
||||||
"locked": true,
|
"locked": false,
|
||||||
"needFuelForAllProductionTime": true,
|
"needFuelForAllProductionTime": true,
|
||||||
"productionLimitCount": 0,
|
"productionLimitCount": 0,
|
||||||
"productionTime": 43200,
|
"productionTime": 43200,
|
||||||
@ -3938,10 +3938,6 @@
|
|||||||
"requiredLevel": 2,
|
"requiredLevel": 2,
|
||||||
"type": "Area"
|
"type": "Area"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"questId": "625d700cc48e6c62a440fab5",
|
|
||||||
"type": "QuestComplete"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"templateId": "590c2d8786f774245b1f03f3",
|
"templateId": "590c2d8786f774245b1f03f3",
|
||||||
"type": "Tool"
|
"type": "Tool"
|
||||||
|
@ -85,15 +85,8 @@ export interface Dynamic
|
|||||||
removeSeasonalItemsWhenNotInEvent: boolean
|
removeSeasonalItemsWhenNotInEvent: boolean
|
||||||
/** Flea blacklist settings */
|
/** Flea blacklist settings */
|
||||||
blacklist: Blacklist
|
blacklist: Blacklist
|
||||||
/** Should prices over the multiplier be adjusted */
|
/** Dict of price limits keyed by item type */
|
||||||
unreasonableModPrices: IUnreasonableModPrices
|
unreasonableModPrices: Record<string, IUnreasonableModPrices>
|
||||||
}
|
|
||||||
|
|
||||||
export interface IUnreasonableModPrices
|
|
||||||
{
|
|
||||||
enabled: boolean
|
|
||||||
handbookPriceOverMultiplier: number
|
|
||||||
newPriceHandbookMultiplier: number
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Barter
|
export interface Barter
|
||||||
@ -145,4 +138,11 @@ export interface Blacklist
|
|||||||
/** Should trader items that are blacklisted by bsg */
|
/** Should trader items that are blacklisted by bsg */
|
||||||
traderItems: boolean
|
traderItems: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface IUnreasonableModPrices
|
||||||
|
{
|
||||||
|
enabled: boolean
|
||||||
|
handbookPriceOverMultiplier: number
|
||||||
|
newPriceHandbookMultiplier: number
|
||||||
|
}
|
||||||
|
|
@ -11,7 +11,6 @@ import {
|
|||||||
} from "../models/eft/common/tables/IRepeatableQuests";
|
} from "../models/eft/common/tables/IRepeatableQuests";
|
||||||
import { StageBonus } from "../models/eft/hideout/IHideoutArea";
|
import { StageBonus } from "../models/eft/hideout/IHideoutArea";
|
||||||
import { IAkiProfile } from "../models/eft/profile/IAkiProfile";
|
import { IAkiProfile } from "../models/eft/profile/IAkiProfile";
|
||||||
import { BaseClasses } from "../models/enums/BaseClasses";
|
|
||||||
import { ConfigTypes } from "../models/enums/ConfigTypes";
|
import { ConfigTypes } from "../models/enums/ConfigTypes";
|
||||||
import { HideoutAreas } from "../models/enums/HideoutAreas";
|
import { HideoutAreas } from "../models/enums/HideoutAreas";
|
||||||
import { QuestStatus } from "../models/enums/QuestStatus";
|
import { QuestStatus } from "../models/enums/QuestStatus";
|
||||||
@ -102,7 +101,7 @@ export class ProfileFixerService
|
|||||||
this.updateProfilePocketsToNewId(pmcProfile);
|
this.updateProfilePocketsToNewId(pmcProfile);
|
||||||
this.updateProfileQuestDataValues(pmcProfile);
|
this.updateProfileQuestDataValues(pmcProfile);
|
||||||
|
|
||||||
if (this.ragfairConfig.dynamic.unreasonableModPrices.enabled)
|
if (Object.keys(this.ragfairConfig.dynamic.unreasonableModPrices).length > 0)
|
||||||
{
|
{
|
||||||
this.adjustUnreasonableModFleaPrices();
|
this.adjustUnreasonableModFleaPrices();
|
||||||
}
|
}
|
||||||
@ -113,17 +112,29 @@ export class ProfileFixerService
|
|||||||
const db = this.databaseServer.getTables();
|
const db = this.databaseServer.getTables();
|
||||||
const fleaPrices = db.templates.prices;
|
const fleaPrices = db.templates.prices;
|
||||||
const handbookPrices = db.templates.handbook.Items;
|
const handbookPrices = db.templates.handbook.Items;
|
||||||
for (const itemTpl in fleaPrices)
|
|
||||||
|
for (const itemTypeKey in this.ragfairConfig.dynamic.unreasonableModPrices)
|
||||||
{
|
{
|
||||||
if (this.itemHelper.isOfBaseclass(itemTpl, BaseClasses.MOD))
|
const details = this.ragfairConfig.dynamic.unreasonableModPrices[itemTypeKey];
|
||||||
|
if (!details?.enabled)
|
||||||
{
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const itemTpl in fleaPrices)
|
||||||
|
{
|
||||||
|
if (!this.itemHelper.isOfBaseclass(itemTpl, itemTypeKey))
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
const itemHandbookPrice = handbookPrices.find(x => x.Id === itemTpl);
|
const itemHandbookPrice = handbookPrices.find(x => x.Id === itemTpl);
|
||||||
if (!itemHandbookPrice)
|
if (!itemHandbookPrice)
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fleaPrices[itemTpl] > (itemHandbookPrice.Price * this.ragfairConfig.dynamic.unreasonableModPrices.handbookPriceOverMultiplier))
|
if (fleaPrices[itemTpl] > (itemHandbookPrice.Price * details.handbookPriceOverMultiplier))
|
||||||
{
|
{
|
||||||
if (fleaPrices[itemTpl] <= 1)
|
if (fleaPrices[itemTpl] <= 1)
|
||||||
{
|
{
|
||||||
@ -131,7 +142,7 @@ export class ProfileFixerService
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Price is over limit, adjust
|
// Price is over limit, adjust
|
||||||
fleaPrices[itemTpl] = itemHandbookPrice.Price * this.ragfairConfig.dynamic.unreasonableModPrices.newPriceHandbookMultiplier;
|
fleaPrices[itemTpl] = itemHandbookPrice.Price * details.newPriceHandbookMultiplier;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user