From 9385f93879fde6bceced95a0dfe6550b66f31b69 Mon Sep 17 00:00:00 2001 From: Ofri Masad Date: Mon, 26 Feb 2024 12:56:53 +0200 Subject: [PATCH] fix tarfile extraction (#1868) * fix tarfile extraction * fix onnxruntime version --- requirements.txt | 2 +- src/super_gradients/training/utils/utils.py | 17 +++++++++++++++-- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/requirements.txt b/requirements.txt index ef51a97655..cff516f9dd 100755 --- a/requirements.txt +++ b/requirements.txt @@ -15,7 +15,7 @@ sphinx-rtd-theme torchmetrics==0.8 hydra-core>=1.2.0 omegaconf -onnxruntime==1.16.0 +onnxruntime==1.15.0 onnx==1.15.0 pillow>=5.3.0,!=8.3 pip-tools>=6.12.1 diff --git a/src/super_gradients/training/utils/utils.py b/src/super_gradients/training/utils/utils.py index 939c4b8171..27b7d86099 100755 --- a/src/super_gradients/training/utils/utils.py +++ b/src/super_gradients/training/utils/utils.py @@ -509,6 +509,20 @@ def download_one(url, dir): download_one(u, dir) +def safe_untar(tar_file, extract_path): + """ + Protect against Tar Slip vulnerability. + Calling extractall to extract all files from a tar file without sanitization + may result files outside destination directory to be overwritten, resulting in an arbitrary file write. + CVE-2007-4559 https://nvd.nist.gov/vuln/detail/CVE-2007-4559 + """ + with tarfile.TarFile(tar_file, "r") as tf: + for member in tf: + file_path = os.path.realpath(os.path.join(extract_path, member.name)) + if file_path.startswith(os.path.realpath(extract_path)): + tf.extract(member, extract_path) + + def download_and_untar_from_url(urls: List[str], dir: Union[str, Path] = "."): """ Download a file from url and untar. @@ -533,8 +547,7 @@ def download_and_untar_from_url(urls: List[str], dir: Union[str, Path] = "."): assert filepath.suffix in modes.keys(), f"{filepath} has {filepath.suffix} suffix which is not supported" logger.info(f"Extracting to {dir}...") - with tarfile.open(filepath, mode=modes[filepath.suffix]) as f: - f.extractall(dir) + safe_untar(filepath, dir) filepath.unlink()