Server/project/src/helpers/HttpServerHelper.ts
Refringe 4ac12ef70a Formatting/Linting Changes (!168)
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
2023-11-16 21:42:06 +00:00

65 lines
1.6 KiB
TypeScript

import { inject, injectable } from "tsyringe";
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
import { IHttpConfig } from "@spt-aki/models/spt/config/IHttpConfig";
import { ConfigServer } from "@spt-aki/servers/ConfigServer";
@injectable()
export class HttpServerHelper
{
protected httpConfig: IHttpConfig;
protected mime = {
css: "text/css",
bin: "application/octet-stream",
html: "text/html",
jpg: "image/jpeg",
js: "text/javascript",
json: "application/json",
png: "image/png",
svg: "image/svg+xml",
txt: "text/plain",
};
constructor(@inject("ConfigServer") protected configServer: ConfigServer)
{
this.httpConfig = this.configServer.getConfig(ConfigTypes.HTTP);
}
public getMimeText(key: string): string
{
return this.mime[key];
}
/**
* Combine ip and port into url
* @returns url
*/
public buildUrl(): string
{
return `${this.httpConfig.ip}:${this.httpConfig.port}`;
}
/**
* Prepend http to the url:port
* @returns URI
*/
public getBackendUrl(): string
{
return `http://${this.buildUrl()}`;
}
/** Get websocket url + port */
public getWebsocketUrl(): string
{
return `ws://${this.buildUrl()}`;
}
public sendTextJson(resp: any, output: any): void
{
// eslint-disable-next-line @typescript-eslint/naming-convention
resp.writeHead(200, "OK", { "Content-Type": this.mime.json });
resp.end(output);
}
}