summary refs log tree commit diff
path: root/src/util/FileStorage.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-12 20:16:17 +0200
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-12 20:16:17 +0200
commit87c7cf33d036c9ef1486d5d895f2b9a6b94bf045 (patch)
tree4bec620a49cd29b10b28f3596176f5f6a344cffd /src/util/FileStorage.ts
parent:sparkles: api (diff)
parentcatch for missing config error (diff)
downloadserver-87c7cf33d036c9ef1486d5d895f2b9a6b94bf045.tar.xz
Merge branch 'cdn'
Diffstat (limited to 'src/util/FileStorage.ts')
-rw-r--r--src/util/FileStorage.ts40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/util/FileStorage.ts b/src/util/FileStorage.ts
new file mode 100644
index 00000000..6e74788f
--- /dev/null
+++ b/src/util/FileStorage.ts
@@ -0,0 +1,40 @@
+import { Storage } from "./Storage";
+import fs from "fs";
+import fse from "fs-extra";
+import { join, relative, dirname } from "path";
+import "missing-native-js-functions";
+import { Readable } from "stream";
+import ExifTransformer = require("exif-be-gone");
+
+function getPath(path: string) {
+	// STORAGE_LOCATION has a default value in start.ts
+	const root = process.env.STORAGE_LOCATION || "../";
+	var filename = join(root, path);
+
+	if (path.indexOf("\0") !== -1 || !filename.startsWith(root)) throw new Error("invalid path");
+	return filename;
+}
+
+export class FileStorage implements Storage {
+	async get(path: string): Promise<Buffer | null> {
+		try {
+			return fs.readFileSync(getPath(path));
+		} catch (error) {
+			return null;
+		}
+	}
+
+	async set(path: string, value: any) {
+		path = getPath(path);
+		fse.ensureDirSync(dirname(path));
+
+		value = Readable.from(value);
+		const cleaned_file = fs.createWriteStream(path);
+
+		return value.pipe(new ExifTransformer()).pipe(cleaned_file);
+	}
+
+	async delete(path: string) {
+		fs.unlinkSync(getPath(path));
+	}
+}