4ac12ef70a
These are the formatting & linting configuration changes from the `3.8.0` branch and the changes that they make to the overall project. The majority of these changes are from running two commands: `npm run lint:fix` `npm run style:fix` This has already been run on the `3.8.0` branch and this PR should make `master` play nicer when it comes to merges going forward. There are now four VSCode plugins recommended for server development. They've been added to the workspace file and a user should get a UI notification when the workspace is opened if they're not installed. The four plugins are: https://marketplace.visualstudio.com/items?itemName=EditorConfig.EditorConfig https://marketplace.visualstudio.com/items?itemName=dprint.dprint https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint https://marketplace.visualstudio.com/items?itemName=biomejs.biome Once installed they should just work within the workspace. Also, be sure to `npm i` to get the new dprint application. Co-authored-by: Refringe <brownelltyler@gmail.com> Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/168
60 lines
2.1 KiB
TypeScript
60 lines
2.1 KiB
TypeScript
import { inject, injectable } from "tsyringe";
|
|
|
|
import { TraderController } from "@spt-aki/controllers/TraderController";
|
|
import { OnLoad } from "@spt-aki/di/OnLoad";
|
|
import { OnUpdate } from "@spt-aki/di/OnUpdate";
|
|
import { IEmptyRequestData } from "@spt-aki/models/eft/common/IEmptyRequestData";
|
|
import { ITraderAssort, ITraderBase } from "@spt-aki/models/eft/common/tables/ITrader";
|
|
import { IGetBodyResponseData } from "@spt-aki/models/eft/httpResponse/IGetBodyResponseData";
|
|
import { HttpResponseUtil } from "@spt-aki/utils/HttpResponseUtil";
|
|
|
|
@injectable()
|
|
export class TraderCallbacks implements OnLoad, OnUpdate
|
|
{
|
|
constructor(
|
|
@inject("HttpResponseUtil") protected httpResponse: HttpResponseUtil,
|
|
@inject("TraderController") protected traderController: TraderController,
|
|
)
|
|
// TODO: delay required
|
|
{
|
|
}
|
|
public async onLoad(): Promise<void>
|
|
{
|
|
this.traderController.load();
|
|
}
|
|
|
|
public async onUpdate(): Promise<boolean>
|
|
{
|
|
return this.traderController.update();
|
|
}
|
|
|
|
public getRoute(): string
|
|
{
|
|
return "aki-traders";
|
|
}
|
|
|
|
/** Handle client/trading/api/traderSettings */
|
|
public getTraderSettings(
|
|
url: string,
|
|
info: IEmptyRequestData,
|
|
sessionID: string,
|
|
): IGetBodyResponseData<ITraderBase[]>
|
|
{
|
|
return this.httpResponse.getBody(this.traderController.getAllTraders(sessionID));
|
|
}
|
|
|
|
/** Handle client/trading/api/getTrader */
|
|
public getTrader(url: string, info: IEmptyRequestData, sessionID: string): IGetBodyResponseData<ITraderBase>
|
|
{
|
|
const traderID = url.replace("/client/trading/api/getTrader/", "");
|
|
return this.httpResponse.getBody(this.traderController.getTrader(sessionID, traderID));
|
|
}
|
|
|
|
/** Handle client/trading/api/getTraderAssort */
|
|
public getAssort(url: string, info: IEmptyRequestData, sessionID: string): IGetBodyResponseData<ITraderAssort>
|
|
{
|
|
const traderID = url.replace("/client/trading/api/getTraderAssort/", "");
|
|
return this.httpResponse.getBody(this.traderController.getAssort(sessionID, traderID));
|
|
}
|
|
}
|