summary refs log tree commit diff
path: root/cdn/src/util/FileStorage.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-12 20:16:45 +0200
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-12 20:16:45 +0200
commit512375f6ed6f7fe895f0ebbb9494e7d2feb7a525 (patch)
treed2c68ddd310a7b50a46979671566e5ae6c1bf04c /cdn/src/util/FileStorage.ts
parentMerge branch 'cdn' (diff)
downloadserver-512375f6ed6f7fe895f0ebbb9494e7d2feb7a525.tar.xz
:sparkles: cdn
Diffstat (limited to 'cdn/src/util/FileStorage.ts')
-rw-r--r--cdn/src/util/FileStorage.ts40
1 files changed, 40 insertions, 0 deletions
diff --git a/cdn/src/util/FileStorage.ts b/cdn/src/util/FileStorage.ts
new file mode 100644

index 00000000..6e74788f --- /dev/null +++ b/cdn/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)); + } +}