Server/project/src/helpers/HttpServerHelper.ts
Refringe 50c7a26a58
ESLint Pass
This is the first pass of ESLint on the codebase.

ESLint formatting is less strict when it comes to line-length and line-breaks then dprint/biome, so if you see formatting that you don't like... fix it! It shouldn't require a configuration change.

- This should merge clean into master (when the time comes).
- This will not merge clean into `3.9.0-DEV`, but the conflicts aren't that bad.
2024-05-07 23:57:08 -04:00

64 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 address
* @returns url
*/
public buildUrl(): string
{
return `${this.httpConfig.backendIp}:${this.httpConfig.backendPort}`;
}
/**
* 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);
}
}