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
83 lines
3.3 KiB
TypeScript
83 lines
3.3 KiB
TypeScript
import { inject, injectable } from "tsyringe";
|
|
|
|
import { NotifierController } from "@spt-aki/controllers/NotifierController";
|
|
import { HttpServerHelper } from "@spt-aki/helpers/HttpServerHelper";
|
|
import { IEmptyRequestData } from "@spt-aki/models/eft/common/IEmptyRequestData";
|
|
import { IGetBodyResponseData } from "@spt-aki/models/eft/httpResponse/IGetBodyResponseData";
|
|
import { INotifierChannel } from "@spt-aki/models/eft/notifier/INotifier";
|
|
import { ISelectProfileRequestData } from "@spt-aki/models/eft/notifier/ISelectProfileRequestData";
|
|
import { ISelectProfileResponse } from "@spt-aki/models/eft/notifier/ISelectProfileResponse";
|
|
import { HttpResponseUtil } from "@spt-aki/utils/HttpResponseUtil";
|
|
import { JsonUtil } from "@spt-aki/utils/JsonUtil";
|
|
|
|
@injectable()
|
|
export class NotifierCallbacks
|
|
{
|
|
constructor(
|
|
@inject("HttpServerHelper") protected httpServerHelper: HttpServerHelper,
|
|
@inject("HttpResponseUtil") protected httpResponse: HttpResponseUtil,
|
|
@inject("JsonUtil") protected jsonUtil: JsonUtil,
|
|
@inject("NotifierController") protected notifierController: NotifierController,
|
|
)
|
|
{}
|
|
|
|
/**
|
|
* If we don't have anything to send, it's ok to not send anything back
|
|
* because notification requests can be long-polling. In fact, we SHOULD wait
|
|
* until we actually have something to send because otherwise we'd spam the client
|
|
* and the client would abort the connection due to spam.
|
|
*/
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
public sendNotification(sessionID: string, req: any, resp: any, data: any): void
|
|
{
|
|
const splittedUrl = req.url.split("/");
|
|
const tmpSessionID = splittedUrl[splittedUrl.length - 1].split("?last_id")[0];
|
|
|
|
/**
|
|
* Take our array of JSON message objects and cast them to JSON strings, so that they can then
|
|
* be sent to client as NEWLINE separated strings... yup.
|
|
*/
|
|
this.notifierController.notifyAsync(tmpSessionID).then((messages: any) =>
|
|
messages.map((message: any) => this.jsonUtil.serialize(message)).join("\n")
|
|
).then((text) => this.httpServerHelper.sendTextJson(resp, text));
|
|
}
|
|
|
|
/** Handle push/notifier/get */
|
|
/** Handle push/notifier/getwebsocket */
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
public getNotifier(url: string, info: any, sessionID: string): IGetBodyResponseData<any[]>
|
|
{
|
|
return this.httpResponse.emptyArrayResponse();
|
|
}
|
|
|
|
/** Handle client/notifier/channel/create */
|
|
public createNotifierChannel(
|
|
url: string,
|
|
info: IEmptyRequestData,
|
|
sessionID: string,
|
|
): IGetBodyResponseData<INotifierChannel>
|
|
{
|
|
return this.httpResponse.getBody(this.notifierController.getChannel(sessionID));
|
|
}
|
|
|
|
/**
|
|
* Handle client/game/profile/select
|
|
* @returns ISelectProfileResponse
|
|
*/
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
public selectProfile(
|
|
url: string,
|
|
info: ISelectProfileRequestData,
|
|
sessionID: string,
|
|
): IGetBodyResponseData<ISelectProfileResponse>
|
|
{
|
|
return this.httpResponse.getBody({ status: "ok" });
|
|
}
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
public notify(url: string, info: any, sessionID: string): string
|
|
{
|
|
return "NOTIFY";
|
|
}
|
|
}
|