Files
Sharepoint-Download-Tool/README.md

3.3 KiB

SharePoint Folder Download Tool

Dette script gør det muligt at downloade specifikke mapper fra et SharePoint dokumentbibliotek til din lokale computer ved hjælp af Microsoft Graph API. Scriptet er designet til professionelt brug med fokus på hastighed, stabilitet og dataintegritet.

Funktioner

  • Moderne GUI (UX): Flot mørkt interface med CustomTkinter, der gør det nemt at gemme indstillinger, vælge mapper og se status i realtid.
  • Stop-funktionalitet: Afbryd synkroniseringen midt i processen direkte fra UI.
  • Paralleldownload: Benytter ThreadPoolExecutor (default 5 tråde) for markant højere overførselshastighed.
  • Windows Long Path Support: Håndterer automatisk Windows' begrænsning på 260 tegn i filstier ved brug af \\?\ præfiks, hvilket sikrer stabilitet ved dybe SharePoint-strukturer.
  • Timestamp Synkronisering: Downloader kun filer, hvis kilden på SharePoint er nyere end din lokale fil (lastModifiedDateTime vs. lokal mtime).
  • Integritets-validering: Validerer filernes korrekthed med Microsofts officielle QuickXorHash-algoritme (160-bit circular XOR).
    • Fallback: Har indbygget en præcis 160-bit Python-implementering som standard.
    • Optimering: Understøtter automatisk det lynhurtige quickxorhash C-bibliotek, hvis det er installeret (valgfrit).
    • Smart Grænse: Definer en MB-grænse (standard 30 MB), hvor filer herunder altid hashes, mens større filer (f.eks. 65 GB) kun sammenlignes på størrelse for at spare tid (kan konfigureres).
  • Robust Bibliotekssøgning: Finder automatisk dit bibliotek og har indbygget fallback (f.eks. fra "Delte dokumenter" til "Documents").
  • Resume Download: Understøtter HTTP Range headers for genoptagelse af store filer.
  • Auto-Refresh af Downloads & Tokens: Fornyer automatisk sessioner og links midt i processen uden unødig ventetid (Optimized 401 handling).
  • Intelligent Fejlhåndtering: Inkluderer retry-logik med exponential backoff og specialiseret håndtering af udløbne tokens (safe_graph_get).

Installation

  1. Sørg for at have Python 3 installeret.
  2. Installer de nødvendige biblioteker:
    pip install -r requirements.txt
    

Bemærk: Biblioteket quickxorhash er fjernet fra standard-requirements for at undgå problemer med C++ Build Tools på Windows. Værktøjet fungerer perfekt uden det, da det har en indbygget Python-fallback. Hvis du har brug for lynhurtig hash-validering af meget store filer (GB-klassen), kan du manuelt installere det med pip install quickxorhash.

Anvendelse

1. GUI Version (Anbefalet)

Kør: python sharepoint_gui.py

2. CLI Version (Til automatisering)

Kør: python download_sharepoint.py

Konfiguration (connection_info.txt)

  • ENABLE_HASH_VALIDATION: Sæt til "True" eller "False".
  • HASH_THRESHOLD_MB: Talværdi (f.eks. "30" eller "50").

Status

Vurdering: Produktionsklar (Enterprise-grade)
Dette værktøj er gennemtestet og optimeret til professionel brug. Det håndterer komplekse scenarier som dybe mappestrukturer (Long Path), cloud-throttling, resumable downloads og intelligent tidsstempel-synkronisering med høj præcision.

Sikkerhed

Husk at .gitignore er sat op til at ignorere connection_info.txt, så dine adgangskoder ikke uploades til Git.