From eab9806ee341bf75ba169bd407d57725275b8ff8 Mon Sep 17 00:00:00 2001 From: mike12345567 Date: Thu, 27 Oct 2022 19:14:31 +0100 Subject: [PATCH] Fixing an issue with some browsers sending the gzip type as x-gzip rather than gzip, which caused the processing to fail. --- packages/server/src/sdk/app/backups/imports.ts | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/packages/server/src/sdk/app/backups/imports.ts b/packages/server/src/sdk/app/backups/imports.ts index 5f4b8c7e41..7cc9e0b0e6 100644 --- a/packages/server/src/sdk/app/backups/imports.ts +++ b/packages/server/src/sdk/app/backups/imports.ts @@ -120,6 +120,9 @@ async function updateAutomations(prodAppId: string, db: PouchDB.Database) { * @returns {Object} Returns a fs read stream which can be loaded into the database. */ async function getTemplateStream(template: TemplateType) { + if (template.file && template.file.type !== "text/plain") { + throw new Error("Cannot import a non-text based file.") + } if (template.file) { return fs.createReadStream(template.file.path) } else if (template.key) { @@ -156,7 +159,7 @@ export async function importApp( ) { let prodAppId = dbCore.getProdAppID(appId) let dbStream: any - const isTar = template.file && template.file.type === "application/gzip" + const isTar = template.file && template?.file?.type?.endsWith("gzip") const isDirectory = template.file && fs.lstatSync(template.file.path).isDirectory() if (template.file && (isTar || isDirectory)) {