notebookvb

This commit is contained in:
Vladimir Buzalka
2026-04-21 07:01:02 +02:00
parent c14a4c21b2
commit 9eea870ab6
3 changed files with 107 additions and 50 deletions
@@ -1,7 +1,13 @@
""" """
01 - Přihlášení na VZP Point (Inbox) 01 - Přihlášení na VZP Point (plně automatizované)
Otevře Chrome, přihlásí se certifikátem a naviguje na schránku zpráv.
Okno zůstane otevřené — skript čeká na stisk Enter. Jak to funguje:
1. Nastaví Chrome politiku AutoSelectCertificateForUrls — Chrome vybere
certifikát automaticky bez dialogu (certifikát musí být v Windows store)
2. Otevře Chrome, klikne na 'Certifikát', počká na přesměrování a uloží cookies
Certifikát ve Windows store: MUDr. Michaela Buzalková (I.CA EU Qualified CA2, platný do 16.1.2027)
Použití: python 01_prihlaseni.py Použití: python 01_prihlaseni.py
""" """
@@ -9,16 +15,33 @@ import json
import os import os
import re import re
import sys import sys
import time
import winreg import winreg
INBOX_URL = "https://point.vzp.cz/Inbox/Message" INBOX_URL = "https://point.vzp.cz/Inbox/Message"
CHROME_PROFILE = os.path.abspath(os.path.join(os.path.dirname(__file__), "chrome_profile")) CHROME_PROFILE = os.path.abspath(os.path.join(os.path.dirname(__file__), "chrome_profile"))
COOKIES_FILE = os.path.abspath(os.path.join(os.path.dirname(__file__), "vzp_cookies.json")) COOKIES_FILE = os.path.abspath(os.path.join(os.path.dirname(__file__), "vzp_cookies.json"))
# Issuer CN certifikátu v Windows store (CurrentUser\My)
CERT_ISSUER_CN = "I.CA EU Qualified CA2/RSA 06/2022"
def _set_chrome_cert_policy() -> None:
"""Nastaví Chrome politiku AutoSelectCertificateForUrls pro vzp.cz."""
policy = json.dumps({
"pattern": "https://[*.]vzp.cz",
"filter": {"ISSUER": {"CN": CERT_ISSUER_CN}},
})
key_path = r"SOFTWARE\Policies\Google\Chrome\AutoSelectCertificateForUrls"
try:
key = winreg.CreateKey(winreg.HKEY_CURRENT_USER, key_path)
winreg.SetValueEx(key, "1", 0, winreg.REG_SZ, policy)
winreg.CloseKey(key)
print(f" Chrome politika nastavena (issuer: {CERT_ISSUER_CN})")
except Exception as e:
print(f" Varování: nelze nastavit Chrome politiku: {e}")
def load_cookies(context) -> int: def load_cookies(context) -> int:
"""Načte dříve uložené cookies (včetně session-only) zpět do kontextu."""
if not os.path.exists(COOKIES_FILE): if not os.path.exists(COOKIES_FILE):
return 0 return 0
try: try:
@@ -32,7 +55,6 @@ def load_cookies(context) -> int:
def save_cookies(context) -> int: def save_cookies(context) -> int:
"""Uloží VZP cookies (i session-only) do JSON souboru."""
try: try:
all_cookies = context.cookies() all_cookies = context.cookies()
vzp = [c for c in all_cookies if "vzp.cz" in c.get("domain", "")] vzp = [c for c in all_cookies if "vzp.cz" in c.get("domain", "")]
@@ -44,17 +66,6 @@ def save_cookies(context) -> int:
return 0 return 0
def _delete_chrome_cert_policy() -> None:
"""Smaže AutoSelectCertificateForUrls politiku — Chrome pak zobrazí dialog přirozeně."""
key_path = r"SOFTWARE\Policies\Google\Chrome\AutoSelectCertificateForUrls"
try:
key = winreg.OpenKey(winreg.HKEY_CURRENT_USER, key_path, access=winreg.KEY_SET_VALUE)
winreg.DeleteValue(key, "1")
winreg.CloseKey(key)
except Exception:
pass
def main() -> None: def main() -> None:
try: try:
from playwright.sync_api import sync_playwright from playwright.sync_api import sync_playwright
@@ -62,7 +73,7 @@ def main() -> None:
print("Chybí playwright: pip install playwright && playwright install chrome") print("Chybí playwright: pip install playwright && playwright install chrome")
sys.exit(1) sys.exit(1)
_delete_chrome_cert_policy() _set_chrome_cert_policy()
with sync_playwright() as p: with sync_playwright() as p:
context = p.chromium.launch_persistent_context( context = p.chromium.launch_persistent_context(
@@ -74,15 +85,10 @@ def main() -> None:
args=["--force-renderer-accessibility"], args=["--force-renderer-accessibility"],
) )
try: try:
# Načti dříve uložené cookies (vč. session-only) z JSON
loaded = load_cookies(context) loaded = load_cookies(context)
startup = context.cookies() print(f"Cookies z JSON: {loaded}")
vzp_start = [c for c in startup if "vzp.cz" in c.get("domain", "")]
print(f"Profil: {CHROME_PROFILE}")
print(f"Cookies z JSON: {loaded}, VZP v kontextu: {len(vzp_start)}")
page = context.new_page() page = context.new_page()
print("Naviguji na VZP Point...") print("Naviguji na VZP Point...")
try: try:
page.goto(INBOX_URL, wait_until="domcontentloaded", timeout=30_000) page.goto(INBOX_URL, wait_until="domcontentloaded", timeout=30_000)
@@ -90,39 +96,22 @@ def main() -> None:
print(f"Navigace: {e}") print(f"Navigace: {e}")
if page.url.startswith("https://auth.vzp.cz/signin"): if page.url.startswith("https://auth.vzp.cz/signin"):
print("Přihlašovací stránka — klikám na 'Certifikát'...") print("Přihlašovací stránka — klikám na 'Certifikát' (Chrome auto-vybere)...")
cert_btn = page.locator("a, button").filter(has_text=re.compile(r"certifikát", re.I)).first cert_btn = page.locator("a, button").filter(has_text=re.compile(r"certifikát", re.I)).first
cert_btn.wait_for(state="visible", timeout=10_000) cert_btn.wait_for(state="visible", timeout=10_000)
cert_btn.click(no_wait_after=True) cert_btn.click(no_wait_after=True)
print("Pokud se zobrazí dialog výběru certifikátu, vyberte ho ručně (max 60 s)...") # Chrome auto-vybere certifikát díky politice — čekáme jen na přesměrování
time.sleep(30)
page = context.new_page()
try: try:
page.goto(INBOX_URL, wait_until="domcontentloaded", timeout=30_000) page.wait_for_url("https://point.vzp.cz/**", timeout=30_000)
except Exception as e: except Exception:
print(f"Navigace po auth: {e}") print(f" Timeout čekání na přesměrování. URL: {page.url}")
if not page.url.startswith("https://point.vzp.cz"): if not page.url.startswith("https://point.vzp.cz"):
print(f"Přihlášení selhalo. URL: {page.url}") print(f"Přihlášení selhalo. URL: {page.url}")
return return
print(f"OK — přihlášení úspěšné. URL: {page.url}") print(f"Přihlášení úspěšné. URL: {page.url}")
# Diagnostika: cookies po auth
after = context.cookies()
vzp_after = [c for c in after if "vzp.cz" in c.get("domain", "")]
print(f"Cookies po auth: VZP: {len(vzp_after)}")
for c in vzp_after:
exp = c.get("expires", -1)
persistent = "PERSISTENT" if exp > 0 else "SESSION-ONLY"
# Zkrácený název pro přehlednost
name = c["name"][:60]
print(f" - {name} ({c['domain']}) [{persistent}]")
print("Okno zůstane otevřené. Stiskněte Enter pro zavření...")
input()
finally: finally:
saved = save_cookies(context) saved = save_cookies(context)
@@ -2,9 +2,7 @@
Přihlásí se na VZP Point a stáhne nové zprávy. Přihlásí se na VZP Point a stáhne nové zprávy.
Kombinuje 01_prihlaseni.py + 03_stahuj_nove.py do jednoho spuštění. Kombinuje 01_prihlaseni.py + 03_stahuj_nove.py do jednoho spuštění.
Přihlášení probíhá plně automaticky (Chrome auto-vybere certifikát).
POZNÁMKA: 01_prihlaseni.py čeká na ruční výběr certifikátu a stisk Enter —
počkejte na výzvu, než se spustí stahování.
POUŽITÍ: POUŽITÍ:
python 04_prihlaseni_a_stahuj_nove.py python 04_prihlaseni_a_stahuj_nove.py
@@ -0,0 +1,70 @@
"""
Orchestrační skript — stáhne nové zprávy ze všech pojišťoven po sobě.
Spouští 04_prihlaseni_a_stahuj_nove.py v každém adresáři pojišťovny.
Pokud jedna pojišťovna selže, pokračuje dál na další.
POUŽITÍ:
python stahuj_vse_pojistovny.py
"""
import subprocess
import sys
import os
from datetime import datetime
BASE_DIR = os.path.dirname(os.path.abspath(__file__))
POJISTOVNY = [
("111 VZP", "VZP"),
("205 ČPZP", "ČPZP"),
("207 OZP", "OZP"),
("209 ZPŠ", "ZPŠ"),
("211 ZPMVČR", "ZPMVČR"),
("213 RBP", "RBP"),
]
SKRIPT = "04_prihlaseni_a_stahuj_nove.py"
def main() -> None:
start = datetime.now()
print(f"=== Stahování zpráv ze všech pojišťoven ===")
print(f"Spuštěno: {start.strftime('%Y-%m-%d %H:%M:%S')}\n")
vysledky = []
for adresar, nazev in POJISTOVNY:
skript_path = os.path.join(BASE_DIR, adresar, SKRIPT)
if not os.path.exists(skript_path):
print(f"\n[{nazev}] PŘESKOČENO — skript nenalezen: {skript_path}")
vysledky.append((nazev, "přeskočeno"))
continue
print(f"\n{'='*50}")
print(f" {nazev}")
print(f"{'='*50}")
result = subprocess.run(
[sys.executable, skript_path],
cwd=os.path.join(BASE_DIR, adresar),
check=False,
)
if result.returncode == 0:
print(f"[{nazev}] OK")
vysledky.append((nazev, "OK"))
else:
print(f"[{nazev}] CHYBA (kód {result.returncode})")
vysledky.append((nazev, f"chyba (kód {result.returncode})"))
elapsed = datetime.now() - start
print(f"\n{'='*50}")
print(f"Hotovo za {int(elapsed.total_seconds())} s")
print(f"{'='*50}")
for nazev, stav in vysledky:
print(f" {nazev:<12} {stav}")
if __name__ == "__main__":
main()