3.5 KiB
3.5 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. - Resume Download: Understøtter HTTP
Rangeheaders, så afbrudte downloads af store filer (f.eks. >50GB) genoptages fra det sidste byte i stedet for at starte forfra. - Exponential Backoff: Håndterer automatisk Microsoft Graph throttling (
429 Too Many Requests) og netværksfejl med intelligente genforsøg. - Struktureret Logging: Gemmer detaljerede logs i
sharepoint_download.logsamt en CSV-fejlrapport for hver kørsel. - Paginering: Håndterer automatisk mapper med mere end 200 elementer via
@odata.nextLink. - Smart Skip & Integritet: Skipper filer der allerede findes lokalt med korrekt størrelse, og forbereder til hash-validering (QuickXorHash).
- Entra ID Integration: Benytter MSAL for sikker godkendelse via Client Credentials flow med automatisk token-refresh.
Installation
- Sørg for at have Python 3 installeret.
- Installer de nødvendige biblioteker:
pip install -r requirements.txt
Opsætning i Microsoft Entra ID (Azure AD)
For at scriptet kan få adgang til SharePoint, skal du oprette en App-registrering:
- Log ind på Microsoft Entra admin center.
- Gå til Identity > Applications > App registrations > New registration.
- Giv appen et navn (f.eks. "SharePoint Download Tool") og vælg "Accounts in this organizational directory only". Klik på Register.
- Noter din Application (client) ID og Directory (tenant) ID.
- Gå til API permissions > Add a permission > Microsoft Graph.
- Vælg Application permissions.
- Søg efter og tilføj
Sites.Read.All(ellerSites.ReadWrite.Allhvis du har brug for skriveadgang). - VIGTIGT: Klik på Grant admin consent for [dit domæne] for at godkende rettighederne.
- Gå til Certificates & secrets > New client secret. Tilføj en beskrivelse og vælg udløbsdato.
- VIGTIGT: Kopier værdien under Value med det samme (det er din
CLIENT_SECRET). Du kan ikke se den igen senere.
Anvendelse
Der er to måder at køre værktøjet på:
1. GUI Version (Anbefalet)
For en moderne grafisk brugerflade, kør:
python sharepoint_gui.py
Her kan du nemt indtaste indstillinger, gemme dem, vælge destinationsmappe og starte/stoppe synkroniseringen.
2. CLI Version (Til automatisering)
Hvis du ønsker at køre scriptet direkte fra terminalen:
- Kopier
connection_info.template.txttilconnection_info.txt. - Udfyld dine oplysninger.
- Kør:
python download_sharepoint.py
Logfiler
sharepoint_download.log: Teknisk log over alle handlinger og fejl.download_report_YYYYMMDD_HHMMSS.csv: En hurtig oversigt over filer der fejlede.
Sikkerhed
Husk at .gitignore er sat op til at ignorere connection_info.txt, så dine adgangskoder ikke uploades til Git.