summary refs log tree commit diff
path: root/cdn/src/util
diff options
context:
space:
mode:
Diffstat (limited to 'cdn/src/util')
-rw-r--r--cdn/src/util/FileStorage.ts51
-rw-r--r--cdn/src/util/S3Storage.ts60
-rw-r--r--cdn/src/util/Storage.ts62
-rw-r--r--cdn/src/util/index.ts3
-rw-r--r--cdn/src/util/multer.ts10
5 files changed, 0 insertions, 186 deletions
diff --git a/cdn/src/util/FileStorage.ts b/cdn/src/util/FileStorage.ts
deleted file mode 100644
index 84ecf556..00000000
--- a/cdn/src/util/FileStorage.ts
+++ /dev/null
@@ -1,51 +0,0 @@
-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");
-
-// TODO: split stored files into separate folders named after cloned route
-
-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> {
-		path = getPath(path);
-		try {
-			return fs.readFileSync(path);
-		} catch (error) {
-			try {
-				const files = fs.readdirSync(path);
-				if (!files.length) return null;
-				return fs.readFileSync(join(path, files[0]));
-			} 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) {
-		//TODO we should delete the parent directory if empty
-		fs.unlinkSync(getPath(path));
-	}
-}
diff --git a/cdn/src/util/S3Storage.ts b/cdn/src/util/S3Storage.ts
deleted file mode 100644
index c4066817..00000000
--- a/cdn/src/util/S3Storage.ts
+++ /dev/null
@@ -1,60 +0,0 @@
-import { S3 } from "@aws-sdk/client-s3";
-import { Readable } from "stream";
-import { Storage } from "./Storage";
-
-const readableToBuffer = (readable: Readable): Promise<Buffer> =>
-	new Promise((resolve, reject) => {
-		const chunks: Buffer[] = [];
-		readable.on("data", (chunk) => chunks.push(chunk));
-		readable.on("error", reject);
-		readable.on("end", () => resolve(Buffer.concat(chunks)));
-	});
-
-export class S3Storage implements Storage {
-	public constructor(
-		private client: S3,
-		private bucket: string,
-		private basePath?: string
-	) {}
-
-	/**
-	 * Always return a string, to ensure consistency.
-	 */
-	get bucketBasePath() {
-		return this.basePath ?? "";
-	}
-
-	async set(path: string, data: Buffer): Promise<void> {
-		await this.client.putObject({
-			Bucket: this.bucket,
-			Key: `${this.bucketBasePath}${path}`,
-			Body: data,
-		});
-	}
-
-	async get(path: string): Promise<Buffer | null> {
-		try {
-			const s3Object = await this.client.getObject({
-				Bucket: this.bucket,
-				Key: `${this.bucketBasePath ?? ""}${path}`,
-			});
-
-			if (!s3Object.Body) return null;
-
-			const body = s3Object.Body;
-
-			return await readableToBuffer(<Readable>body);
-		} catch (err) {
-			console.error(`[CDN] Unable to get S3 object at path ${path}.`);
-			console.error(err);
-			return null;
-		}
-	}
-
-	async delete(path: string): Promise<void> {
-		await this.client.deleteObject({
-			Bucket: this.bucket,
-			Key: `${this.bucketBasePath}${path}`,
-		});
-	}
-}
diff --git a/cdn/src/util/Storage.ts b/cdn/src/util/Storage.ts
deleted file mode 100644
index 89dd5634..00000000
--- a/cdn/src/util/Storage.ts
+++ /dev/null
@@ -1,62 +0,0 @@
-import { FileStorage } from "./FileStorage";
-import path from "path";
-import fse from "fs-extra";
-import { bgCyan, black } from "picocolors";
-import { S3 } from "@aws-sdk/client-s3";
-import { S3Storage } from "./S3Storage";
-process.cwd();
-
-export interface Storage {
-	set(path: string, data: Buffer): Promise<void>;
-	get(path: string): Promise<Buffer | null>;
-	delete(path: string): Promise<void>;
-}
-
-let storage: Storage;
-
-if (process.env.STORAGE_PROVIDER === "file" || !process.env.STORAGE_PROVIDER) {
-	let location = process.env.STORAGE_LOCATION;
-	if (location) {
-		location = path.resolve(location);
-	} else {
-		location = path.join(process.cwd(), "files");
-	}
-	console.log(`[CDN] storage location: ${bgCyan(`${black(location)}`)}`);
-	fse.ensureDirSync(location);
-	process.env.STORAGE_LOCATION = location;
-
-	storage = new FileStorage();
-} else if (process.env.STORAGE_PROVIDER === "s3") {
-	const region = process.env.STORAGE_REGION,
-		bucket = process.env.STORAGE_BUCKET;
-
-	if (!region) {
-		console.error(
-			`[CDN] You must provide a region when using the S3 storage provider.`
-		);
-		process.exit(1);
-	}
-
-	if (!bucket) {
-		console.error(
-			`[CDN] You must provide a bucket when using the S3 storage provider.`
-		);
-		process.exit(1);
-	}
-
-	// in the S3 provider, this should be the root path in the bucket
-	let location = process.env.STORAGE_LOCATION;
-
-	if (!location) {
-		console.warn(
-			`[CDN] STORAGE_LOCATION unconfigured for S3 provider, defaulting to the bucket root...`
-		);
-		location = undefined;
-	}
-
-	const client = new S3({ region });
-
-	storage = new S3Storage(client, bucket, location);
-}
-
-export { storage };
diff --git a/cdn/src/util/index.ts b/cdn/src/util/index.ts
deleted file mode 100644
index 07a5c31a..00000000
--- a/cdn/src/util/index.ts
+++ /dev/null
@@ -1,3 +0,0 @@
-export * from "./FileStorage";
-export * from "./multer";
-export * from "./Storage";
diff --git a/cdn/src/util/multer.ts b/cdn/src/util/multer.ts
deleted file mode 100644
index bfdf6aff..00000000
--- a/cdn/src/util/multer.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import multerConfig from "multer";
-
-export const multer = multerConfig({
-	storage: multerConfig.memoryStorage(),
-	limits: {
-		fields: 10,
-		files: 10,
-		fileSize: 1024 * 1024 * 100, // 100 mb
-	},
-});