From 953d6014a323a1c54e6f3652cdff1898c3c69478 Mon Sep 17 00:00:00 2001 From: Flavio F Lima Date: Thu, 9 Nov 2023 11:59:30 +0000 Subject: [PATCH 1/3] fix: use native methods unless its snap --- src/backend/utils.ts | 58 ++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 53 insertions(+), 5 deletions(-) diff --git a/src/backend/utils.ts b/src/backend/utils.ts index d78d0b29e8..e9a796b1e0 100644 --- a/src/backend/utils.ts +++ b/src/backend/utils.ts @@ -34,7 +34,8 @@ import { GITHUB_API, isMac, configStore, - isLinux + isLinux, + isSnap } from './constants' import { logError, @@ -1348,10 +1349,57 @@ interface ExtractOptions { } async function extractFiles({ path, destination, strip = 0 }: ExtractOptions) { - return decompress(path, destination, { - plugins: [decompressTargz(), decompressTarxz()], - strip - }) + if (!isSnap && (path.endsWith('.tar.xz') || path.endsWith('.tar.gz'))) { + try { + await extractNative(path, destination, strip) + } catch (error) { + logError(`Error: ${error}`, LogPrefix.Backend) + } + } else { + try { + await extractDecompress(path, destination, strip) + } catch (error) { + logError(`Error: ${error}`, LogPrefix.Backend) + } + } +} + +async function extractNative(path: string, destination: string, strip: number) { + logInfo( + `Extracting ${path} to ${destination} using native tar`, + LogPrefix.Backend + ) + const { code, stderr } = await spawnAsync('tar', [ + '-xf', + path, + '-C', + destination, + `--strip-components=${strip}` + ]) + if (code !== 0) { + logError(`Extracting Error: ${stderr}`, LogPrefix.Backend) + return { status: 'error', error: stderr } + } + return { status: 'done', installPath: destination } +} + +async function extractDecompress( + path: string, + destination: string, + strip: number +) { + logInfo( + `Extracting ${path} to ${destination} using decompress`, + LogPrefix.Backend + ) + try { + await decompress(path, destination, { + plugins: [decompressTargz(), decompressTarxz()], + strip + }) + } catch (error) { + logError(`Error: ${error}`, LogPrefix.Backend) + } } export { From 73acce8f56f429acba0bdf18e7cc38c5c6f83279 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fl=C3=A1vio=20Fearn?= <26871415+flavioislima@users.noreply.github.com> Date: Tue, 21 Nov 2023 19:49:02 +0000 Subject: [PATCH 2/3] Update src/backend/utils.ts MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Mathis Dröge --- src/backend/utils.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/backend/utils.ts b/src/backend/utils.ts index e9a796b1e0..7ae230761b 100644 --- a/src/backend/utils.ts +++ b/src/backend/utils.ts @@ -1353,7 +1353,7 @@ async function extractFiles({ path, destination, strip = 0 }: ExtractOptions) { try { await extractNative(path, destination, strip) } catch (error) { - logError(`Error: ${error}`, LogPrefix.Backend) + logError(['Error:', error], LogPrefix.Backend) } } else { try { From 7fd9addbe3352170a8e5212843534d76be39c032 Mon Sep 17 00:00:00 2001 From: Flavio F Lima Date: Tue, 21 Nov 2023 19:54:09 +0000 Subject: [PATCH 3/3] chore: pr comments --- src/backend/utils.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/backend/utils.ts b/src/backend/utils.ts index e9a796b1e0..ae64a96e02 100644 --- a/src/backend/utils.ts +++ b/src/backend/utils.ts @@ -1353,13 +1353,13 @@ async function extractFiles({ path, destination, strip = 0 }: ExtractOptions) { try { await extractNative(path, destination, strip) } catch (error) { - logError(`Error: ${error}`, LogPrefix.Backend) + logError(['Error:', error], LogPrefix.Backend) } } else { try { await extractDecompress(path, destination, strip) } catch (error) { - logError(`Error: ${error}`, LogPrefix.Backend) + logError(['Error:', error], LogPrefix.Backend) } } } @@ -1398,7 +1398,7 @@ async function extractDecompress( strip }) } catch (error) { - logError(`Error: ${error}`, LogPrefix.Backend) + logError(['Error:', error], LogPrefix.Backend) } }