fix(audit): P93+P95 — Reject-Wording erweitert + Vendor-zentrisches Cookie-Format akzeptiert
CI / detect-changes (push) Successful in 10s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / secret-scan (push) Has been skipped
CI / dep-audit (push) Has been skipped
CI / test-python-backend (push) Successful in 38s
CI / test-python-document-crawler (push) Has been skipped
CI / test-python-dsms-gateway (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / validate-canonical-controls (push) Successful in 16s
CI / loc-budget (push) Failing after 16s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Has been skipped
CI / test-go (push) Has been skipped
CI / iace-gt-coverage (push) Has been skipped
CI / detect-changes (push) Successful in 10s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / secret-scan (push) Has been skipped
CI / dep-audit (push) Has been skipped
CI / test-python-backend (push) Successful in 38s
CI / test-python-document-crawler (push) Has been skipped
CI / test-python-dsms-gateway (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / validate-canonical-controls (push) Successful in 16s
CI / loc-budget (push) Failing after 16s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Has been skipped
CI / test-go (push) Has been skipped
CI / iace-gt-coverage (push) Has been skipped
P93: 'Cookies verbieten', 'Tracking ablehnen', 'verweigern' usw. zaehlen nun als expliziter Reject-Mechanismus. EDPB 5/2020 schreibt kein bestimmtes Wort vor — BMW False-Positive 'Kein Ablehnen-Mechanismus' weg. P95: cookie_table-Check akzeptiert nun zwei gleichwertige Formate: (a) klassische Tabelle, (b) Vendor-Detailseite mit Block pro Anbieter (Name+Anschrift, Zweck, Speicherdauer aggregiert, Cookie-Namen-Liste, Opt-Out-Link). BMW-Stil mit Adform-Block ist DSK-OH 2024 konform. False-Positive 'tabellarisches Cookie-Verzeichnis fehlt' wird seltener. Hinweis-Text in cookie_table umformuliert: nennt beide akzeptablen Formate, weniger normativ. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -276,19 +276,40 @@ COOKIE_CHECKLIST = [
|
||||
},
|
||||
|
||||
# ── Neue L1: Cookie-Tabelle ───────────────────────────────────────
|
||||
# P95: Lockerer Match — Vendor-zentrische Detailseiten (BMW-Stil mit
|
||||
# Adform-Block etc.) werden als gleichwertig akzeptiert. DSK-OH 2024
|
||||
# §3.2 verlangt die Informationen pro Cookie, schreibt aber keine
|
||||
# Tabellenform vor. Ein Vendor-Block der Name+Anbieter+Zweck+Dauer+
|
||||
# Cookie-Namen aggregiert nennt erfuellt das.
|
||||
{
|
||||
"id": "cookie_table",
|
||||
"label": "Strukturierte Cookie-Tabelle/Liste",
|
||||
"label": "Strukturierte Cookie-Informationen (Tabelle oder Vendor-Blöcke)",
|
||||
"level": 1, "parent": None,
|
||||
"patterns": [
|
||||
# Klassische Tabelle
|
||||
r"(?:cookie[\-\s])?(?:tabelle|uebersicht|übersicht|liste|aufstellung)",
|
||||
r"(?:name|bezeichnung)\s*[\|\t]\s*(?:anbieter|zweck|dauer|laufzeit|funktion)",
|
||||
r"(?:first[\-\s]?party|third[\-\s]?party)\s*[\|\t]",
|
||||
r"(?:typ(?:en)?|name|funktion|speicherdauer)\s+(?:typ(?:en)?|name|funktion|speicherdauer)",
|
||||
r"folgende\s+cookies",
|
||||
r"(?:funktionale|session|analyse|tracking)\s+cookies?\s+\w+",
|
||||
# P95: Vendor-zentrische Detail-Bloecke (BMW-Stil) — wenn
|
||||
# mehrere typische Vendor-Block-Marker vorhanden, gilt als
|
||||
# strukturiert. "Gesetzt von:" + "Opt-Out Link:" + "Privacy"
|
||||
# ist ein klares Indiz fuer Vendor-Detailseite.
|
||||
r"gesetzt\s+von\s*[:\|]",
|
||||
r"opt[\-\s]?out[\s\-]?link\s*[:\|]",
|
||||
r"speicherdauer\s*[:\|]\s*\d+\s+(?:tag|monat|jahr|day|month|year)",
|
||||
r"(?:rechtsgrundlage|legal\s+basis)\s*[:\|]",
|
||||
r"(?:diese\s+datenverarbeitung\s+verwendet\s+die\s+folgenden\s+cookies)",
|
||||
],
|
||||
"severity": "LOW",
|
||||
"hint": "Die DSK-Orientierungshilfe empfiehlt eine Tabelle mit 5 Spalten: Name, Anbieter, Zweck, Speicherdauer, Typ (First-/Third-Party). Viele Consent-Tools (Cookiebot, Usercentrics) generieren diese Tabelle automatisch — binden Sie sie ein.",
|
||||
"hint": "DSK-OH Telemedien 2024 §3.2 verlangt Cookie-Informationen pro "
|
||||
"Vendor/Cookie (Name, Anbieter, Zweck, Speicherdauer, Drittlandtransfer). "
|
||||
"Akzeptable Formate: (a) Tabelle mit 5 Spalten oder (b) Vendor-Detailseite "
|
||||
"mit Block pro Anbieter (Anbieter+Anschrift, Zweck, Speicherdauer aggregiert, "
|
||||
"Cookie-Namen-Liste, Opt-Out-Link, Drittlandstatus). BMW-Stil mit Adform-"
|
||||
"Block ist konform. Auch automatisierte CMP-Generierung (Cookiebot, Usercentrics) "
|
||||
"ist OK.",
|
||||
},
|
||||
]
|
||||
|
||||
@@ -159,8 +159,18 @@ async def check_banner_text(page) -> dict:
|
||||
# (e.g. only "Nur technisch Notwendige" — semantically
|
||||
# a reject but EDPB 5/2020 + DSK-OH 2024 prefer explicit
|
||||
# labeling so users recognize it as the reject option)
|
||||
explicit_reject_texts = ["ablehnen", "reject", "alle ablehnen",
|
||||
"decline", "alles ablehnen"]
|
||||
# P93: EDPB 5/2020 schreibt kein bestimmtes Wort vor — Reject-
|
||||
# Mechanismus muss gleichwertig zur Annahme sein. BMW nutzt
|
||||
# "Cookies verbieten", andere Sites "Tracking ablehnen" o.ae. —
|
||||
# alle rechtlich gleichwertig.
|
||||
explicit_reject_texts = [
|
||||
"ablehnen", "reject", "alle ablehnen",
|
||||
"decline", "alles ablehnen",
|
||||
"cookies verbieten", "cookies blockieren",
|
||||
"tracking ablehnen", "tracking verbieten",
|
||||
"zurueckweisen", "block all", "deny all",
|
||||
"alle verweigern", "verweigern",
|
||||
]
|
||||
implicit_reject_texts = ["nur notwendige", "nur technisch", "nur essenzielle",
|
||||
"nur essentielle", "notwendige akzeptieren",
|
||||
"essential only", "only necessary",
|
||||
|
||||
Reference in New Issue
Block a user