Martin Tranberg df55660291 fix: task 7 — production hardening quick fixes
- Replace 4 bare `except:` with `except Exception:` (load_settings,
  get_txt, get_icon_idx_for_file, process_file cleanup block) so
  SystemExit and KeyboardInterrupt are no longer swallowed
- Replace 2 print() calls with logger.error() (__init__ MSAL init,
  ensure_valid_token) so errors appear in the configurable log output
- Sanitize item['name'] with os.path.basename() in on_download_clicked
  and _download_folder_recursive_sync to prevent path traversal from
  server-controlled filenames
- Add 8 new unit tests covering all Task 7 changes

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-12 10:22:54 +02:00

SharePoint Browser

En moderne Python-baseret fil-browser til Microsoft SharePoint, specielt designet til at omgå Windows' MAX_PATH (260 karakterer) begrænsning. Det opnås ved at integrere direkte med Microsoft Graph API ved hjælp af unikke ID'er og downloade/udtjekke filer til redigering via korte, midlertidige stier lokalt.

🚀 Funktioner

  • Ingen Sti-begrænsning (MAX_PATH): Problemfri og pålidelig redigering uanset mappedybde i SharePoint.
  • Sikker Redigering & Kollision-beskyttelse: Automatisk Check-out/Check-in og intelligent overvågning af fil-låse lokalt.
  • Professionel Brugerflade: Bygget med wxPython (Native Windows UI) inklusiv indfødte OS-ikoner, data-drevet brødkrummesti (breadcrumbs) og lazy-loading af hierarkisk træstruktur for markant hurtigere navigation.
  • Paginering & Stor-tenant understøttelse: Alle Graph API-kald følger @odata.nextLink automatisk, så mapper og sites med hundredvis af elementer indlæses korrekt uden tab.
  • Statuslinje med fremgangsmåler: En integreret statusmåler (gauge) i statuslinjen giver visuelt feedback under alle netværksoperationer.
  • First-Run Setup Wizard: Automatisk konfigurationsguide ved første opstart, der opsamler Client ID og Tenant ID (kræver ingen forudgående manuel settings.json).
  • Avanceret Søgning: Hurtig global søgefunktion der bygger på et lokalt, trinvist opdateret indeks, samt understøttelse af "OG"-logik (AND logic).
  • Fuld Fil- og Mappestyring: Understøtter upload, sletning og omdøbning, samt visning af udvidet fil-metadata (filstørrelse, redigeringsdato).
  • Multisprog: Indbygget og brugerstyret understøttelse af både Dansk og Engelsk-grænseflade.
  • Multi-File Editing: Robust understøttelse for lokalt at redigere flere forskellige filer uafhængigt af hinanden i baggrunden uden at interface fryser.

⚙️ Indstillinger

Indstillingsdialogen er organiseret i faner:

Fane Indhold
Konto Azure Client ID og Tenant ID
Stier Midlertidig downloadmappe og app-placering
Licens Licensnøgle og aktiveringsstatus
System Sprog og log-output til fejlfinding
Om Versionsinformation og kontaktoplysninger

🛠️ Teknologier

  • Sprog: Python 3.x
  • GUI Framework: wxPython
  • Godkendelse: MSAL (Microsoft Authentication Library)
  • API Integration: Microsoft Graph API via requests
  • Fil-overvågning: Polling via låse på lokalt filsystem

📦 Installation & Opstart

Forudsætninger

Sørg for, at du har Python installeret sammen med afhængighederne. Det anbefales at have en Microsoft 365-licens klar.

pip install wxPython msal requests

Kør applikationen

Start op med:

python sharepoint_browser.py

Ved første kørsel uden en konfiguration vil applikationen præsentere en Setup Wizard, hvor man nemt kan indtaste Microsoft-loginoplysningerne. Indtastningerne gemmes i en lokal settings.json fil.

🏗️ Byg til EXE (Valgfrit)

For at pakke programmet til en uafhængig, kørbar .exe fil til Windows bruges den medfølgende PyInstaller spec-fil:

pip install pyinstaller
python -m PyInstaller "SharePoint Explorer.spec" --noconfirm

Den færdige fil placeres i dist/SharePoint Explorer.exe med ikon indlejret.

🧩 Arkitektur & Workflow

  1. Godkendelse: Autentificerer brugeren via MSAL & MS Graph API.
  2. Navigation: Data hentes asynkront (lazy-loading) og chunked — de første resultater vises straks mens resten streames ind. Alt håndteres med ID'er i stedet for filstier, hvilket sikrer MAX_PATH-modstandsdygtighed.
  3. Navigationskontekst: Brødkrummestien er data-drevet; hvert segment gemmer det fulde navigationsobjekt, så klik på en forælder altid navigerer korrekt uden at gennemsøge træet.
  4. Stale-result beskyttelse: En navigations-tæller (_nav_gen) sikrer, at svar fra afbrudte netværkskald aldrig overskriver den aktive mappevisning.
  5. Baggrundshåndtering af redigering:
    • Filer tjekkes ud (Checkout) direkte i SharePoint.
    • Hentes ned til det lokale drev under korte stier, eks. C:\Temp_SP\[MD5-Hash].[ext].
    • Et baggrunds-thread overvåger det lokale program (fx Word) kontinuerligt via os.rename() tricket.
    • Når filen lukkes, uploades ændringerne til SharePoint og modtager et Checkin.

🧪 Tests

En unit-test suite dækker de kritiske logik-komponenter:

python -m unittest tests.test_review_fixes -v

Testene kører uden skærm/display og dækker: navigations-tæller, oversættelses-nøgler, URL-initialisering og signaturer.

💡 Backlog / Kommende muligheder

  1. Integration for håndtering af flere tenants (lejemål)
  2. Et yderligere detaljeret log-system specielt til debugging af baggrundstråden.
  3. Udvidet aktivitetslog til sporing af handlinger for de seneste 14 dage.
  4. Styring af licenser til specifikke kunders varigheder (fx 1 år, 3 år, Lifetime).
Description
No description provided
Readme 1.2 MiB
2026-04-12 08:46:16 +00:00
Languages
Python 100%