Fixing an issue with some browsers sending the gzip type as x-gzip rather than gzip, which caused the processing to fail.

This commit is contained in:
mike12345567 2022-10-27 19:14:31 +01:00
parent 3873f0a27f
commit 1c012ee7f7
1 changed files with 4 additions and 1 deletions

View File

@ -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. * @returns {Object} Returns a fs read stream which can be loaded into the database.
*/ */
async function getTemplateStream(template: TemplateType) { 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) { if (template.file) {
return fs.createReadStream(template.file.path) return fs.createReadStream(template.file.path)
} else if (template.key) { } else if (template.key) {
@ -156,7 +159,7 @@ export async function importApp(
) { ) {
let prodAppId = dbCore.getProdAppID(appId) let prodAppId = dbCore.getProdAppID(appId)
let dbStream: any let dbStream: any
const isTar = template.file && template.file.type === "application/gzip" const isTar = template.file && template?.file?.type?.endsWith("gzip")
const isDirectory = const isDirectory =
template.file && fs.lstatSync(template.file.path).isDirectory() template.file && fs.lstatSync(template.file.path).isDirectory()
if (template.file && (isTar || isDirectory)) { if (template.file && (isTar || isDirectory)) {