mirror of
https://github.com/sp-tarkov/server.git
synced 2025-02-13 09:50:43 -05:00
Initially this was going to be an update to dependencies but it seems i got a little carried away! Anyways this PR removes 2 unused dependencies (`jshint` and `utf-8-validate`), and 2 other, `del` and `fs-extra` that were replaced by the built-in `fs/promises`. It also renames all `tsconfig` and `Dockerfile` files, in a way that when viewed in a file tree sorted alphabetically they will be next to each other. It also updates the typescript target to `ES2022`, and changes moduleResolution from `Node` to `Node10` (this isn't an update, they are the same thing but `Node` is now deprecated). It also adds the `node:` discriminator to every import from built-in modules. It also has major changes to the build script, `del` and `fs-extra` were only being used in the build script, it's now using `fs/promises` instead, cleaned up the code from some functions, adds better documentation to a few functions, and renames some gulp tasks and npm scripts to better represent what they actually do. And finally it updates dependencies, except for `atomically` which can't be updated unless the project switches to ESM. Reviewed-on: SPT-AKI/Server#150 Co-authored-by: TheSparta <thesparta@noreply.dev.sp-tarkov.com> Co-committed-by: TheSparta <thesparta@noreply.dev.sp-tarkov.com>
27 lines
808 B
TypeScript
27 lines
808 B
TypeScript
import fs from "node:fs";
|
|
import { ServerResponse } from "node:http";
|
|
import { inject, injectable } from "tsyringe";
|
|
import { HttpServerHelper } from "../helpers/HttpServerHelper";
|
|
|
|
@injectable()
|
|
export class HttpFileUtil
|
|
{
|
|
constructor(
|
|
@inject("HttpServerHelper") protected httpServerHelper: HttpServerHelper
|
|
)
|
|
{
|
|
}
|
|
|
|
public sendFile(resp: ServerResponse, file: any): void
|
|
{
|
|
const pathSlic = file.split("/");
|
|
const type = this.httpServerHelper.getMimeText(pathSlic[pathSlic.length - 1].split(".").at(-1)) || this.httpServerHelper.getMimeText("txt");
|
|
const fileStream = fs.createReadStream(file);
|
|
|
|
fileStream.on("open", function ()
|
|
{
|
|
resp.setHeader("Content-Type", type);
|
|
fileStream.pipe(resp);
|
|
});
|
|
}
|
|
} |