diff options
author | Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> | 2021-08-12 20:16:17 +0200 |
---|---|---|
committer | Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> | 2021-08-12 20:16:17 +0200 |
commit | 87c7cf33d036c9ef1486d5d895f2b9a6b94bf045 (patch) | |
tree | 4bec620a49cd29b10b28f3596176f5f6a344cffd /src/util/FileStorage.ts | |
parent | :sparkles: api (diff) | |
parent | catch for missing config error (diff) | |
download | server-87c7cf33d036c9ef1486d5d895f2b9a6b94bf045.tar.xz |
Merge branch 'cdn'
Diffstat (limited to 'src/util/FileStorage.ts')
-rw-r--r-- | src/util/FileStorage.ts | 40 |
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)); + } +} |