with temp_file.open("wb") as f: for chunk in r.iter_content(chunk_size=chunk_size): if not chunk: # keep‑alive chunks can be empty continue f.write(chunk) downloaded += len(chunk)
# Optional: if you know the SHA‑256 hash of the original file, # provide it to guard against tampering. # EXPECTED_HASH = "c5a8f2b... (64‑hex chars)" Download Klapr.zip
class ZipDownloadError(RuntimeError): """Base class for errors raised by `download_and_extract`.""" with temp_file
# ------------------------------------------------------------------ # # 5️⃣ Extract safely # ------------------------------------------------------------------ # _safe_extract(temp_file, extract_path) print(f"📂 Extracted to: extract_path") bytes).") def _calc_checksum(file_path: Path
# Optional: give a quick progress report (useful in CLI scripts) if total: percent = downloaded / total * 100 print(f"✅ Download complete (downloaded:, bytes, percent:.1f%).") else: print(f"✅ Download complete (downloaded:, bytes).")
def _calc_checksum(file_path: Path, algo: str = "sha256") -> str: """Calculate a checksum (`algo` can be 'md5', 'sha1', 'sha256', etc.).""" h = hashlib.new(algo) with file_path.open("rb") as f: for chunk in iter(lambda: f.read(8192), b""): h.update(chunk) return h.hexdigest()
except requests.RequestException as e: raise ZipDownloadError(f"Failed to download url!r: e") from e finally: # ------------------------------------------------------------------ # # 6️⃣ Clean up the temporary zip file # ------------------------------------------------------------------ # try: temp_file.unlink(missing_ok=True) except Exception as cleanup_err: print(f"⚠️ Cleanup warning: could not delete temporary file: cleanup_err", file=sys.stderr)