Depends on: #7092 | Story: [PAY-768](https://linear.app/n8n/issue/PAY-768) This PR: - Generalizes the `IBinaryDataManager` interface. - Adjusts `Filesystem.ts` to satisfy the interface. - Sets up an S3 client stub to be filled in in the next PR. - Turns `BinaryDataManager` into an injectable service. - Adjusts the config schema and adds new validators. Note that the PR looks large but all the main changes are in `packages/core/src/binaryData`. Out of scope: - `BinaryDataManager` (now `BinaryDataService`) and `Filesystem.ts` (now `fs.client.ts`) were slightly refactored for maintainability, but fully overhauling them is **not** the focus of this PR, which is meant to clear the way for the S3 implementation. Future improvements for these two should include setting up a backwards-compatible dir structure that makes it easier to locate binary data files to delete, removing duplication, simplifying cloning methods, using integers for binary data size instead of `prettyBytes()`, writing tests for existing binary data logic, etc. --------- Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
18 lines
470 B
TypeScript
18 lines
470 B
TypeScript
import type { SchemaObj } from 'convict';
|
|
|
|
class NotStringArrayError extends Error {
|
|
constructor(env: string) {
|
|
super(`${env} is not a string array.`);
|
|
}
|
|
}
|
|
|
|
export const ensureStringArray = (values: string[], { env }: SchemaObj<string>) => {
|
|
if (!env) throw new Error(`Missing env: ${env}`);
|
|
|
|
if (!Array.isArray(values)) throw new NotStringArrayError(env);
|
|
|
|
for (const value of values) {
|
|
if (typeof value !== 'string') throw new NotStringArrayError(env);
|
|
}
|
|
};
|