Scan-Fakten als JSON anzeigen
{
"schema": "https://saferpage.de/schemas/public-scan-facts.v1",
"claim_boundary": "Öffentliche Rohdaten enthalten nur Scan-Fakten, Statuswerte, Evidence-Grenzen und feste Detail-/Hintergrund-Links. Betreiber-Hintergrund, Planungen, Checklisten, Code und allgemeine Empfehlungen stehen auf separaten Seiten.",
"current_evidence_policy": {
"schema": "https://saferpage.de/schemas/public-scan-current-evidence-policy.v1",
"status": "current_scan_fields_only",
"summary": "Der Fakten-JSON exportiert nur Felder, die im gespeicherten aktuellen Scan wirklich vorhanden sind. Fehlende neue Evidence wird nicht aus alten Testergebnisformaten nachgebaut.",
"guardrails": [
"Keine synthetischen Boundary-Fallbacks fuer alte Scans",
"Keine Nachbewertung alter Testergebnisse im Fakten-JSON",
"Keine Betreiber-Empfehlung im Report-JSON"
]
},
"host": "lwl-dlbw.de",
"normalized_url": "https://lwl-dlbw.de/",
"score": 55,
"verdict": {
"color": "orange",
"label": "auffällig",
"score": 55
},
"scan_id": "a69d0182-11e1-44d7-8e6b-3256610a7ece",
"created_at": "2026-06-19 18:08:24.13682+02",
"evidence": {
"dns": {
"ok": true,
"addresses": [
"195.202.41.54",
"2001:67c:2e8c:ff02:42:0:103:202"
],
"duration_ms": 34
},
"tls": {
"ok": true,
"cipher": "TLS_AES_256_GCM_SHA384",
"issuer": [
[
[
"countryName",
"US"
]
],
[
[
"organizationName",
"Let's Encrypt"
]
],
[
[
"commonName",
"E7"
]
]
],
"subject": [
[
[
"commonName",
"lwl-dlbw.de"
]
]
],
"version": "TLSv1.3",
"not_after": "Aug 19 11:32:07 2026 GMT",
"hostname_matches": true,
"days_until_expiry": 60,
"subject_alt_names": [
"lwl-dlbw.de",
"www.lwl-dlbw.de"
],
"issuer_common_name": "E7"
},
"http": {
"ok": true,
"status": 200,
"headers": {
"age": "0",
"via": "1.1 f46c7aed6f7e (Varnish/7.4)",
"date": "Fri, 19 Jun 2026 16:07:42 GMT",
"vary": "Cookie,Host,Accept-Encoding",
"server": "Apache",
"expires": "Fri, 19 Jun 2026 16:07:42 GMT",
"x-cache": "MISS",
"x-varnish": "23922338",
"connection": "close",
"set-cookie": "django_language=de; expires=Sat, 19 Jun 2027 16:07:42 GMT; Max-Age=31536000; Path=/",
"content-type": "text/html; charset=utf-8",
"accept-ranges": "bytes",
"cache-control": "max-age=0, no-cache, no-store, must-revalidate, private",
"referrer-policy": "strict-origin-when-cross-origin",
"x-frame-options": "SAMEORIGIN",
"content-language": "de",
"transfer-encoding": "chunked",
"permissions-policy": "camera=(), fullscreen=(self), geolocation=(), microphone=()",
"x-content-type-options": "nosniff",
"content-security-policy": "connect-src 'self' https://pypi.org https://vimeo.com https://recruiting.lwl.org https://www.outdooractive.com *.sibforms.com *.emailsys1a.net https://sketchfab.com https://piwik.lwl.org *.readspeaker.com api.newsletter2go.com piwik.lwl.org https://neurabot.neuraflow.de www.lwl.org api.openrouteservice.org https://neurabot-chat-app-501967154138.europe-west1.run.app https://neurabot-api-501967154138.europe-west3.run.app api.neurabot.de app.fair-text.com *.laizee.ai; img-src 'self' data: https://www.lwl.org/osmlwlde/ https://img.youtube.com https://www.lwl.org/anis/map/ https://bossanova.uk https://piwik.lwl.org https://www.lwl.org https://i.vimeocdn.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com https://static.kulturkurier.de https://static.newsletter2go.com https://my.matterport.com https://mpembed.com https://lwl.gomus.de https://doi.lwl.info files.newsletter2go.com https://res.oastatic.com i.ytimg.com https://i.ytimg.com https://firebasestorage.googleapis.com https://tiles.stadiamaps.com/ app.fair-text.com www.cmsdoku.lwl.org; frame-src 'self' https://www.youtube.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com *.sibforms.com *.emailsys1a.net https://lwl.gomus.de https://www.google.com https://my.matterport.com https://mpembed.com https://nrw.db-schulkinowochen.de https://sibforms.com https://statlas-wl.nrw.de https://wms02.exmap.de statlas.westfalen.org https://static.kulturkurier.de www.statlas-wl.nrw.de *.lwl.org glossar.westfalen-regional.de *.alangu.de app.fair-text.com *.laizee.ai login.stadtradeln.de; frame-ancestors 'self' *.westfalen-regional.de; script-src 'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com https://www.youtube.com/iframe_api https://cdn.ckeditor.com https://piwik.lwl.org https://vimeo.com https://player.vimeo.com https://cdnjs.cloudflare.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com *.sibforms.com *.emailsys1a.net https://lwl.gomus.de https://www.google.com https://static.kulturkurier.de https://my.matterport.com https://static.newsletter2go.com https://mpembed.com https://nrw.db-schulkinowochen.de https://sibforms.com https://statlas-wl.nrw.de https://wms02.exmap.de *.readspeaker.com static.newsletter2go.com https://chat-app.neurabot.de 'unsafe-eval' app.fair-text.com; style-src 'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com *.readspeaker.com sibforms.com https://chat-app.chat-link.de https://chat-app.neurabot.de; media-src 'self' https://intranet.itz.lwl.org https://www.lwl.org; default-src 'none'; font-src 'self' data:",
"strict-transport-security": "max-age=15768000;",
"x-divio-backend-node-name": "lwlzweb27",
"cross-origin-opener-policy": "same-origin"
},
"body_size": 200000,
"final_url": "https://www.lwl-dlbw.de/de/",
"duration_ms": 4172
},
"scanner": {
"bot_url": "https://saferpage.de/bot",
"context": "crawler",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/lwl-dlbw.de\">https://saferpage.de/lwl-dlbw.de</a>)",
"default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
},
"domain_records": {
"mx": true,
"caa": true,
"spf": true,
"dmarc": true,
"dnssec": false,
"records": {
"mx": [
"20 mail12.lwl.org.",
"10 mail11.lwl.org."
],
"ns": [
"ns9.routing.net.",
"ns.routing.net.",
"ns8.routing.net."
],
"caa": [
"0 issue \"letsencrypt.org",
"0 iodef \"mailto:domains@lwl.org"
],
"txt": [
"v=spf1 ip4:195.202.51.19 ip4:89.27.164.139 -all"
],
"cname": [],
"dmarc": [
"v=DMARC1; p=quarantine; rua=mailto:dmarc@lwl.org!500k; ruf=mailto:dmarc@lwl.org!500k; sp=none; rf=afrf; ri=86400; adkim=r; aspf=r; fo=1"
],
"dnskey_present": false
},
"spf_includes": [],
"verifications": []
},
"googlebot_http": {
"ok": true,
"status": 200,
"headers": {
"age": "0",
"via": "1.1 f46c7aed6f7e (Varnish/7.4)",
"date": "Fri, 19 Jun 2026 16:07:42 GMT",
"vary": "Cookie,Host,Accept-Encoding",
"server": "Apache",
"expires": "Fri, 19 Jun 2026 16:07:42 GMT",
"x-cache": "MISS",
"x-varnish": "19600946",
"connection": "close",
"set-cookie": "django_language=de; expires=Sat, 19 Jun 2027 16:07:42 GMT; Max-Age=31536000; Path=/",
"content-type": "text/html; charset=utf-8",
"accept-ranges": "bytes",
"cache-control": "max-age=0, no-cache, no-store, must-revalidate, private",
"referrer-policy": "strict-origin-when-cross-origin",
"x-frame-options": "SAMEORIGIN",
"content-language": "de",
"transfer-encoding": "chunked",
"permissions-policy": "camera=(), fullscreen=(self), geolocation=(), microphone=()",
"x-content-type-options": "nosniff",
"content-security-policy": "frame-ancestors 'self' *.westfalen-regional.de; default-src 'none'; img-src 'self' data: https://www.lwl.org/osmlwlde/ https://img.youtube.com https://www.lwl.org/anis/map/ https://bossanova.uk https://piwik.lwl.org https://www.lwl.org https://i.vimeocdn.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com https://static.kulturkurier.de https://static.newsletter2go.com https://my.matterport.com https://mpembed.com https://lwl.gomus.de https://doi.lwl.info files.newsletter2go.com https://res.oastatic.com i.ytimg.com https://i.ytimg.com https://firebasestorage.googleapis.com https://tiles.stadiamaps.com/ app.fair-text.com www.cmsdoku.lwl.org; font-src 'self' data:; frame-src 'self' https://www.youtube.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com *.sibforms.com *.emailsys1a.net https://lwl.gomus.de https://www.google.com https://my.matterport.com https://mpembed.com https://nrw.db-schulkinowochen.de https://sibforms.com https://statlas-wl.nrw.de https://wms02.exmap.de statlas.westfalen.org https://static.kulturkurier.de www.statlas-wl.nrw.de *.lwl.org glossar.westfalen-regional.de *.alangu.de app.fair-text.com *.laizee.ai login.stadtradeln.de; media-src 'self' https://intranet.itz.lwl.org https://www.lwl.org; script-src 'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com https://www.youtube.com/iframe_api https://cdn.ckeditor.com https://piwik.lwl.org https://vimeo.com https://player.vimeo.com https://cdnjs.cloudflare.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com *.sibforms.com *.emailsys1a.net https://lwl.gomus.de https://www.google.com https://static.kulturkurier.de https://my.matterport.com https://static.newsletter2go.com https://mpembed.com https://nrw.db-schulkinowochen.de https://sibforms.com https://statlas-wl.nrw.de https://wms02.exmap.de *.readspeaker.com static.newsletter2go.com https://chat-app.neurabot.de 'unsafe-eval' app.fair-text.com; style-src 'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com *.readspeaker.com sibforms.com https://chat-app.chat-link.de https://chat-app.neurabot.de; connect-src 'self' https://pypi.org https://vimeo.com https://recruiting.lwl.org https://www.outdooractive.com *.sibforms.com *.emailsys1a.net https://sketchfab.com https://piwik.lwl.org *.readspeaker.com api.newsletter2go.com piwik.lwl.org https://neurabot.neuraflow.de www.lwl.org api.openrouteservice.org https://neurabot-chat-app-501967154138.europe-west1.run.app https://neurabot-api-501967154138.europe-west3.run.app api.neurabot.de app.fair-text.com *.laizee.ai",
"strict-transport-security": "max-age=15768000;",
"x-divio-backend-node-name": "lwlzweb26",
"cross-origin-opener-policy": "same-origin"
},
"body_size": 200000,
"final_url": "https://www.lwl-dlbw.de/de/",
"duration_ms": 4556
},
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.lwl-dlbw.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 155,
"truncated": false,
"body_sha256": "f5cfb551ce32821983f04cfe87bc52935704a5d9aaad7fe0614084738f90e26d",
"duration_ms": 284,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 4,
"wildcard_directives_sample": [
{
"value": "/login",
"directive": "disallow"
},
{
"value": "/*/login",
"directive": "disallow"
},
{
"value": "/admin",
"directive": "disallow"
},
{
"value": "/*/admin",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Disallow: /login",
"Disallow: /*/login",
"Disallow: /admin",
"Disallow: /*/admin",
"Sitemap: https://www.lwl-dlbw.de/sitemap.xml"
]
},
{
"id": "llms_txt",
"url": "https://www.lwl-dlbw.de/llms.txt",
"label": "llms.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1426,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1424,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 2079,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1853,
"http_status": 302,
"relevant_lines": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 5,
"found_file_count": 1,
"policy_file_count": 0,
"explicit_ai_bot_count": 0
},
"summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
"available": true,
"guardrails": [
"Nur feste Same-Origin-Policy-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"known_ai_bots": [
"GPTBot",
"ChatGPT-User",
"Google-Extended",
"ClaudeBot",
"PerplexityBot",
"CCBot"
],
"explicit_ai_bots": [],
"policy_file_count": 0,
"llms_ward_policy_status": "not_publicly_verified",
"robots_ai_policy_status": "generic_robots_policy"
},
"adtech_transparency_evidence": {
"files": [
{
"id": "ads_txt",
"url": "https://www.lwl-dlbw.de/ads.txt",
"label": "ads.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 986,
"http_status": 302,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.lwl-dlbw.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1637,
"http_status": 302,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.lwl-dlbw.de/sellers.json",
"label": "sellers.json",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3120,
"http_status": null,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 3,
"direct_count": 0,
"reseller_count": 0,
"found_file_count": 0,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-AdTech-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
],
"direct_count": 0,
"ads_txt_found": false,
"reseller_count": 0,
"app_ads_txt_found": false,
"sellers_json_found": false,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"sellers_json_parse_ok": false,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"security_trust_policy_evidence": {
"files": [
{
"id": "security_txt",
"url": "https://www.lwl-dlbw.de/.well-known/security.txt",
"label": "security.txt",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3115,
"http_status": null,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.lwl-dlbw.de/security.txt",
"label": "security.txt legacy",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3065,
"http_status": null,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
}
},
"findings": [
{
"id": "pre_consent_nonessential_cookies",
"title": "Möglicherweise nicht notwendige Cookies vor Einwilligung",
"public": true,
"cookies": [
"django_language"
],
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"django_language"
],
"user_importance": 127,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "imprint_missing",
"title": "Kein Impressum-Link erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Geprüft in Startseite, Navigation und Footer: kein Impressum-Link gefunden"
],
"user_importance": 125,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "consent_state_reject_evidence_failed",
"title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Nach 'Ablehnen': 2 neue Cookie(s), 0 neue Tracking-Kontakt(e)"
],
"user_importance": 120,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "post_reject_new_cookies",
"count": 2,
"title": "Neue Cookies nach Ablehnen erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Nach 'Ablehnen' neu gesetzt: 2 Cookie(s)"
],
"user_importance": 119,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"https://piwik.lwl.org/piwik/piwik.php?idsite=53&rec=1",
"lwl-dlbw.de"
],
"user_importance": 119,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"piwik.lwl.org"
],
"user_importance": 118,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "beacon_api_usage",
"count": 2,
"title": "Beacon-/Keepalive-Telemetrie erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Beacon-/Keepalive-Telemetrie im Browser-Lauf erkannt"
],
"user_importance": 116,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "operator_contact_missing",
"title": "Keine klare Kontaktmöglichkeit erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Im geprüften HTML keine Kontaktangabe (E-Mail, Telefon oder Anschrift) erkannt"
],
"user_importance": 116,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "privacy_policy_provider_disclosure_gap",
"title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Erkannte Anbieter sind nicht alle in der Datenschutzerklärung erwähnt"
],
"user_importance": 116,
"importance_label": "Wichtig für Nutzer",
"missing_providers": [
"Matomo"
]
},
{
"id": "browser_keystroke_listener_signals",
"count": 96,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"Tastatur-Eingabe-Listener (Session-Replay-nah) im Browser-Lauf erkannt"
],
"user_importance": 110,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "long_lived_cookie",
"count": 1,
"title": "Langlebige Cookies erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"Cookie mit sehr langer Laufzeit erkannt (Details im Cookie-Inventar)"
],
"user_importance": 104,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "cookie_missing_secure",
"title": "Cookie ohne Secure-Flag",
"public": true,
"cookies": [
"django_language"
],
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"django_language"
],
"user_importance": 102,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "cookie_missing_samesite",
"title": "Cookie ohne SameSite-Attribut",
"public": true,
"cookies": [
"django_language"
],
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"django_language"
],
"user_importance": 98,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "warning",
"user_importance": 96,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "slow_response",
"title": "Langsame Serverantwort",
"public": true,
"audience": "nutzer",
"category": "performance",
"severity": "warning",
"evidence_items": [
"Antwortzeit: 4172 ms"
],
"user_importance": 96,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "warning",
"user_importance": 94,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.sibforms.com",
"*.emailsys1a.net",
"*.readspeaker.com"
],
"audience": "nutzer",
"category": "security_headers",
"severity": "info",
"user_importance": 88,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "important_pages_not_discovered",
"title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
"public": true,
"audience": "nutzer",
"category": "crawl",
"severity": "warning",
"evidence_items": [
"Wichtige Seiten in der Linkstruktur gefunden: keine"
],
"user_importance": 88,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "external_script_without_sri",
"count": 1,
"title": "Externe Skripte ohne Subresource Integrity",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"https://cdn1.readspeaker.com/script/10870/webReader/webReader.js?pids=wr"
],
"user_importance": 84,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "missing_meta_description",
"title": "Meta-Description fehlt",
"public": true,
"audience": "nutzer",
"category": "content",
"severity": "info",
"evidence_items": [
"Im HTML kein <meta name=\"description\"> gefunden"
],
"user_importance": 84,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "image_alt_missing",
"count": 1,
"title": "Bilder ohne Alternativtext",
"public": true,
"audience": "nutzer",
"category": "accessibility",
"severity": "info",
"evidence_items": [
"https://piwik.lwl.org/piwik/piwik.php?idsite=53&rec=1"
],
"user_importance": 82,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_missing_object_src",
"title": "CSP ohne object-src",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"Content-Security-Policy ohne object-src-Direktive"
],
"user_importance": 76,
"importance_label": "Technischer Hinweis"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"Content-Security-Policy ohne base-uri-Direktive"
],
"user_importance": 74,
"importance_label": "Technischer Hinweis"
},
{
"id": "heading_structure_missing",
"title": "Keine Überschriftenstruktur erkannt",
"public": true,
"audience": "betreiber",
"category": "accessibility",
"severity": "info",
"user_importance": 74,
"importance_label": "Technischer Hinweis"
},
{
"id": "too_many_render_blocking_assets",
"title": "Viele potenziell blockierende Assets",
"public": true,
"audience": "betreiber",
"category": "performance",
"severity": "info",
"evidence_items": [
"Viele render-blockierende CSS/JS-Ressourcen im <head> der Startseite"
],
"user_importance": 74,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_embedder_policy",
"title": "Cross-Origin-Embedder-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Embedder-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 68,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_resource_policy",
"title": "Cross-Origin-Resource-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Resource-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 64,
"importance_label": "Technischer Hinweis"
},
{
"id": "crawl_coverage_limited",
"title": "Wenig interne Seiten auf der Startseite gefunden",
"public": true,
"audience": "betreiber",
"category": "crawl",
"severity": "info",
"evidence_items": [
"Nur 0 interne Links auf der Startseite gefunden"
],
"user_importance": 62,
"importance_label": "Technischer Hinweis"
},
{
"id": "consent_banner_dark_pattern_risk",
"count": 1,
"title": "Consent-Banner mit Dark-Pattern-/UX-Risiko",
"public": true,
"audience": "betreiber",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Banner-UX: Akzeptieren 1 vs. Ablehnen 1 – Ablehnen weniger prominent/gleichwertig"
],
"user_importance": 60,
"importance_label": "Technischer Hinweis"
},
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"audience": "betreiber",
"category": "privacy",
"severity": "info",
"evidence_items": [
"Drittanbieter mit unklarer Anbieter-Jurisdiktion / möglichem Drittlandtransfer"
],
"user_importance": 30,
"importance_label": "Technischer Hinweis"
}
],
"audit_modules": [
{
"id": "operator_transparency",
"color": "red",
"score": 25,
"title": "Impressum, Kontakt & Datenschutzerklärung",
"source": "Deutschsprachige Betreiber- und Datenschutzhinweis-Erkennung",
"status": "kritisch",
"evidence": "Impressum: nein, Datenschutz: nein, Kontakt: nein."
},
{
"id": "site_coverage",
"color": "red",
"score": 45,
"title": "Seitenabdeckung & Crawl",
"source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
"status": "kritisch",
"evidence": "0 interne Linkziele erkannt, 0 priorisierte Unterseite(n) abgerufen."
},
{
"id": "security_tls",
"color": "red",
"score": 46,
"title": "Sicherheit, TLS & Header",
"source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
"status": "kritisch",
"evidence": "0 Infrastruktur-Hinweis(e), Security-Header: 7/9 vorhanden, 2 fehlen, externe Skript-Hosts: 1."
},
{
"id": "privacy_consent",
"color": "orange",
"score": 58,
"title": "Datenschutz, Cookies & Consent",
"source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
"status": "auffällig",
"evidence": "0 Tracking-Script(s), 1 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), Ablehnen-Option: nein, Consent-Audit: 58."
},
{
"id": "browser_evidence",
"color": "orange",
"score": 71,
"title": "Browser-Nachweis",
"source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
"status": "auffällig",
"evidence": "53 Request(s), 3 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 1 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 1, Fingerprinting-/Replay-Hinweise: 1."
},
{
"id": "tracking_pixels_beacons",
"color": "orange",
"score": 72,
"title": "Tracking-Pixel & Beacons",
"source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
"status": "auffällig",
"evidence": "1 Pixel-/Bildtracking-Hinweis(e), 2 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
},
{
"id": "performance_mobile",
"color": "yellow",
"score": 82,
"title": "Performance & mobile Nutzbarkeit",
"source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
"status": "prüfen",
"evidence": "Performance-Score 82, Antwortzeit 4172 ms."
},
{
"id": "accessibility_usability",
"color": "yellow",
"score": 88,
"title": "Barrierefreiheit & Usability",
"source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
"status": "prüfen",
"evidence": "1 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 0 Button(s) ohne Namen."
},
{
"id": "referrer_url_leaks",
"color": "yellow",
"score": 88,
"title": "Referrer & URL-Leaks",
"source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
"status": "prüfen",
"evidence": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte."
},
{
"id": "cookie_inventory",
"color": "green",
"score": 92,
"title": "Cookie-Inventar",
"source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
"status": "unauffällig",
"evidence": "1 Cookie(s), 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 1 langlebig, 0 sehr lang."
},
{
"id": "script_supply_chain",
"color": "green",
"score": 96,
"title": "Externe Skripte & SRI",
"source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
"status": "unauffällig",
"evidence": "1 externe Skript(e) von 1 Host(s), 1 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
},
{
"id": "consent_journey",
"color": "green",
"score": 100,
"title": "Consent-Journey-Matrix",
"source": "Chromium-Zustände: Erstaufruf, Reject, Accept und GPC",
"status": "unauffällig",
"evidence": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 2 nach Akzeptieren, 0 im GPC-Aufruf."
},
{
"id": "embedded_content",
"color": "green",
"score": 100,
"title": "Externe Inhalte & Widgets",
"source": "HTML-Embeds und Chromium-Drittanbieter-Requests",
"status": "unauffällig",
"evidence": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen."
},
{
"id": "forms_payments",
"color": "green",
"score": 100,
"title": "Formulare, Login & Zahlung",
"source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
"status": "unauffällig",
"evidence": "Keine Formular- oder Zahlungsabfrage im passiven Startseiten-Sample erkannt."
},
{
"id": "google_third_parties",
"color": "green",
"score": 100,
"title": "Google-Dienste & Drittanbieter",
"source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
"status": "unauffällig",
"evidence": "Keine Google-Domain, keine Google-Tracking-ID und keine datenschutzrelevanten Drittanbieter im passiven Check erkannt."
},
{
"id": "pii_exposure",
"color": "green",
"score": 100,
"title": "PII, URL-Parameter & Datenleck-Schutz",
"source": "URL-Parameter, interne Links, HTML-Formulare, Browser-Drittanbieter und Dateneingabe-Kontext",
"status": "unauffällig",
"evidence": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext."
},
{
"id": "seo_integrity",
"color": "green",
"score": 100,
"title": "SEO-Integrität & Cloaking",
"source": "HTML-Inhalt, strukturierte Daten, Links und Googlebot-Vergleich",
"status": "unauffällig",
"evidence": "0 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e)."
}
],
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.lwl-dlbw.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 155,
"truncated": false,
"body_sha256": "f5cfb551ce32821983f04cfe87bc52935704a5d9aaad7fe0614084738f90e26d",
"duration_ms": 284,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 4,
"wildcard_directives_sample": [
{
"value": "/login",
"directive": "disallow"
},
{
"value": "/*/login",
"directive": "disallow"
},
{
"value": "/admin",
"directive": "disallow"
},
{
"value": "/*/admin",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Disallow: /login",
"Disallow: /*/login",
"Disallow: /admin",
"Disallow: /*/admin",
"Sitemap: https://www.lwl-dlbw.de/sitemap.xml"
]
},
{
"id": "llms_txt",
"url": "https://www.lwl-dlbw.de/llms.txt",
"label": "llms.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1426,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1424,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 2079,
"http_status": 302,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.lwl-dlbw.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1853,
"http_status": 302,
"relevant_lines": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 5,
"found_file_count": 1,
"policy_file_count": 0,
"explicit_ai_bot_count": 0
},
"summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
"available": true,
"guardrails": [
"Nur feste Same-Origin-Policy-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"known_ai_bots": [
"GPTBot",
"ChatGPT-User",
"Google-Extended",
"ClaudeBot",
"PerplexityBot",
"CCBot"
],
"explicit_ai_bots": [],
"policy_file_count": 0,
"llms_ward_policy_status": "not_publicly_verified",
"robots_ai_policy_status": "generic_robots_policy"
},
"adtech_transparency_evidence": {
"files": [
{
"id": "ads_txt",
"url": "https://www.lwl-dlbw.de/ads.txt",
"label": "ads.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 986,
"http_status": 302,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.lwl-dlbw.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "redirect_blocked",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 1637,
"http_status": 302,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.lwl-dlbw.de/sellers.json",
"label": "sellers.json",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3120,
"http_status": null,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 3,
"direct_count": 0,
"reseller_count": 0,
"found_file_count": 0,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-AdTech-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
],
"direct_count": 0,
"ads_txt_found": false,
"reseller_count": 0,
"app_ads_txt_found": false,
"sellers_json_found": false,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"sellers_json_parse_ok": false,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"security_trust_policy_evidence": {
"files": [
{
"id": "security_txt",
"url": "https://www.lwl-dlbw.de/.well-known/security.txt",
"label": "security.txt",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3115,
"http_status": null,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.lwl-dlbw.de/security.txt",
"label": "security.txt legacy",
"reason": "fetch_failed",
"status": "not_available",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 3065,
"http_status": null,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.lwl-dlbw.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
},
"site_coverage_analysis": {
"color": "red",
"pages": [],
"score": 45,
"status": "kritisch",
"summary": "0 interne Linkziele erkannt (0 aus Sitemap), 0 priorisierte Unterseite(n) zusätzlich abgerufen.",
"findings": [
{
"id": "crawl_coverage_limited",
"title": "Wenig interne Seiten auf der Startseite gefunden",
"public": true,
"category": "crawl",
"severity": "info"
},
{
"id": "important_pages_not_discovered",
"title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
"public": true,
"category": "crawl",
"severity": "warning"
},
{
"id": "privacy_policy_provider_disclosure_gap",
"title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
"public": true,
"category": "privacy",
"severity": "warning",
"missing_providers": [
"Matomo"
]
}
],
"robots_ok": true,
"categories": [],
"sample_limit": 4,
"sampled_count": 0,
"sampled_pages": [],
"robots_checked": true,
"sitemap_sources": [],
"sitemap_available": false,
"sitemap_url_count": 0,
"homepage_link_count": 0,
"internal_link_count": 0,
"privacy_policy_audit": [],
"sitemap_source_count": 0,
"provider_disclosure_audit": {
"color": "red",
"found": [],
"score": 0,
"checks": [
{
"id": "analytics_matomo",
"found": false,
"category": "analytics",
"evidence": [
"piwik.lwl.org"
],
"keywords": [
"matomo",
"piwik"
],
"provider": "Matomo",
"category_label": "Sonstige"
}
],
"reason": "no_policy_text",
"status": "kritisch",
"missing": [
"Matomo"
],
"summary": "1 technische Anbieter erkannt, aber keine Datenschutzerklärung im Sample ausgewertet.",
"available": true,
"missing_count": 1,
"detected_count": 1,
"mentioned_count": 0
},
"important_categories_found": [],
"sampled_tracking_page_count": 0,
"sampled_form_privacy_gap_count": 0,
"sitemap_candidate_source_count": 1
},
"page_analysis": {
"h1": [],
"h2": [],
"title": "LWL |\n \n Startseite\n - LWL-Denkmalpflege, Landschafts- und Baukultur in Westfalen",
"keywords": [
[
"fuer",
4
],
[
"angebote",
3
],
[
"menschen",
3
],
[
"startseite",
2
],
[
"lwl-denkmalpflege",
2
],
[
"landschafts-",
2
],
[
"baukultur",
2
],
[
"westfalen",
2
],
[
"g-regel",
2
],
[
"barrierefrei",
2
]
],
"language": "de",
"description": "",
"favicon_url": "https://www.lwl-dlbw.de/static/favicon.dbe22fe628ea.ico",
"link_counts": {
"external": 0,
"internal": 0
},
"preview_image": "/cache/screenshots/lwl-dlbw.de-160x150-19446dbf0cbb0a8fa1.png",
"screenshot_url": "/cache/screenshots/lwl-dlbw.de-160x150-19446dbf0cbb0a8fa1.png",
"external_scripts": [
"https://cdn1.readspeaker.com/script/10870/webReader/webReader.js?pids=wr"
],
"browser_final_url": "https://www.lwl-dlbw.de/de/",
"meta_preview_image": "",
"screenshot_renderer": "playwright-chromium",
"external_link_targets": []
},
"browser_analysis": {
"cookies": {
"items": [
{
"name": "django_language",
"domain": "www.lwl-dlbw.de",
"secure": false,
"expires": 1813421264.680316,
"http_only": false,
"same_site": "Lax"
}
],
"total": 1,
"third_party": 0
},
"storage": {
"total": 1,
"local_storage_keys": [
"lwl-tutorial"
],
"tracking_key_hints": [],
"local_storage_total": 1,
"session_storage_keys": [],
"session_storage_total": 0
},
"findings": [
{
"id": "post_reject_new_cookies",
"count": 2,
"title": "Neue Cookies nach Ablehnen erkannt",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "browser_keystroke_listener_signals",
"count": 96,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "consent_state_reject_evidence_failed",
"title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "beacon_api_usage",
"count": 2,
"title": "Beacon-/Keepalive-Telemetrie erkannt",
"public": true,
"category": "privacy",
"severity": "warning"
}
],
"renderer": "playwright-chromium",
"final_url": "https://www.lwl-dlbw.de/de/",
"consent_ui": {
"accept_controls": [
{
"tag": "button",
"top": 904,
"area": 6526,
"left": 819,
"text": "Alle akzeptieren",
"color": "rgb(40, 40, 40)",
"width": 162,
"height": 40,
"background": "rgb(255, 255, 255)",
"font_weight": "600"
}
],
"accept_max_area": 6526,
"reject_controls": [
{
"tag": "button",
"top": 904,
"area": 5720,
"left": 661,
"text": "Alle ablehnen",
"color": "rgb(40, 40, 40)",
"width": 142,
"height": 40,
"background": "rgb(255, 255, 255)",
"font_weight": "600"
}
],
"reject_max_area": 5720,
"settings_controls": [
{
"tag": "button",
"top": 569,
"area": 7578,
"left": 412,
"text": "Cookie-Einstellungen",
"color": "rgb(255, 255, 255)",
"width": 201,
"height": 38,
"background": "rgb(40, 40, 40)",
"font_weight": "400"
}
],
"first_layer_summary": "Akzeptieren 1 / Ablehnen 1 / Einstellungen 1",
"cookie_context_found": true,
"reject_less_prominent": false,
"visible_control_count": 11,
"reject_prominence_ratio": 0.88
},
"gpc_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 1,
"tracking_key_hints": [],
"local_storage_total": 1,
"session_storage_total": 0
},
"cookie_count": 1,
"request_count": 53,
"sec_gpc_header": true,
"navigator_value": true,
"contacted_domains": [
{
"host": "lwl-dlbw.de",
"count": 46,
"category": "other",
"provider": "lwl-dlbw.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 3,
"image": 28,
"other": 2,
"script": 5,
"document": 1,
"stylesheet": 7
}
},
{
"host": "lwl.org",
"count": 3,
"category": "other",
"provider": "lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"image": 3
}
},
{
"host": "cdn1.readspeaker.com",
"count": 2,
"category": "other",
"provider": "cdn1.readspeaker.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1,
"stylesheet": 1
}
},
{
"host": "piwik.lwl.org",
"count": 2,
"category": "other",
"provider": "piwik.lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"ping": 1,
"script": 1
}
}
],
"contacted_domain_count": 4,
"privacy_relevant_domains": [],
"third_party_cookie_count": 0,
"third_party_domain_count": 3,
"privacy_relevant_domain_count": 0
},
"screenshot": {
"fit": "contain",
"width": 160,
"height": 150,
"source_width": 1024,
"source_height": 960,
"source_capture": "full_page",
"capture_version": "contain-v4-viewport-transparency-160x150"
},
"consent_apis": {
"cmpapi": false,
"tcfapi": false,
"onetrust": false,
"cookiebot": false,
"data_layer": false,
"cmp_detected": false,
"usercentrics": false,
"google_tag_data": false
},
"accept_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 1,
"tracking_key_hints": [],
"local_storage_total": 1,
"session_storage_total": 0
},
"clicked_text": "Alle akzeptieren",
"accept_clicked": true,
"accept_available": true,
"contacted_domains": [
{
"host": "lwl-dlbw.de",
"count": 46,
"category": "other",
"provider": "lwl-dlbw.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 3,
"image": 28,
"other": 2,
"script": 5,
"document": 1,
"stylesheet": 7
}
},
{
"host": "lwl.org",
"count": 3,
"category": "other",
"provider": "lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"image": 3
}
},
{
"host": "cdn1.readspeaker.com",
"count": 2,
"category": "other",
"provider": "cdn1.readspeaker.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1,
"stylesheet": 1
}
},
{
"host": "img.youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"image": 2
}
},
{
"host": "piwik.lwl.org",
"count": 2,
"category": "other",
"provider": "piwik.lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"ping": 1,
"script": 1
}
},
{
"host": "youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"script": 2
}
}
],
"contacted_domain_count": 6,
"new_domains_after_accept": [
{
"host": "img.youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"image": 2
}
},
{
"host": "youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"script": 2
}
}
],
"privacy_relevant_domains": [
{
"host": "img.youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"image": 2
}
},
{
"host": "youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"script": 2
}
}
],
"third_party_domain_count": 5,
"cookie_count_after_accept": 8,
"cookie_count_before_accept": 1,
"request_count_after_accept": 57,
"storage_count_after_accept": 1,
"request_count_before_accept": 53,
"new_cookie_count_after_accept": 7,
"privacy_relevant_domain_count": 2,
"new_request_count_after_accept": 4,
"third_party_cookie_count_after_accept": 5,
"storage_tracking_hint_count_after_accept": 0,
"new_privacy_relevant_domains_after_accept": [
{
"host": "img.youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"image": 2
}
},
{
"host": "youtube.com",
"count": 2,
"category": "video_embed",
"provider": "YouTube",
"third_party": true,
"category_label": "Video",
"resource_types": {
"script": 2
}
}
],
"new_privacy_relevant_domain_count_after_accept": 2
},
"request_count": 53,
"top_providers": [
{
"provider": "lwl.org",
"request_count": 3
},
{
"provider": "cdn1.readspeaker.com",
"request_count": 2
},
{
"provider": "piwik.lwl.org",
"request_count": 2
}
],
"request_samples": [
{
"host": "cdn1.readspeaker.com",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": true,
"path_depth": 4,
"query_keys": [
"pids"
],
"third_party": true,
"resource_type": "script",
"query_key_count": 1,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "lwl.org",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 5,
"query_keys": [],
"third_party": true,
"resource_type": "image",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "lwl.org",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 5,
"query_keys": [],
"third_party": true,
"resource_type": "image",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "lwl.org",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 5,
"query_keys": [],
"third_party": true,
"resource_type": "image",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "cdn1.readspeaker.com",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": true,
"path_depth": 6,
"query_keys": [
"v"
],
"third_party": true,
"resource_type": "stylesheet",
"query_key_count": 1,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "piwik.lwl.org",
"method": "GET",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 2,
"query_keys": [],
"third_party": true,
"resource_type": "script",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "piwik.lwl.org",
"method": "POST",
"referrer": {
"host": "lwl-dlbw.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": true,
"path_depth": 2,
"query_keys": [
"action_name",
"idsite",
"rec",
"r",
"h",
"m",
"s",
"url",
"_id",
"_idn",
"send_image",
"_refts"
],
"third_party": true,
"resource_type": "ping",
"query_key_count": 26,
"url_value_param_count": 1,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 1
}
],
"cmp_consent_state": {
"tcf": {
"api_found": false,
"vendor_li": [],
"cmp_loaded": false,
"cmp_status": "",
"purpose_li": [],
"event_status": "",
"gdpr_applies": null,
"ping_success": false,
"policy_version": "",
"vendor_consents": [],
"vendor_li_count": 0,
"purpose_consents": [],
"purpose_li_count": 0,
"tc_string_length": 0,
"tc_string_present": false,
"vendor_consent_count": 0,
"purpose_consent_count": 0
},
"onetrust": {
"found": false,
"active_groups": [],
"active_group_count": 0
},
"cookiebot": {
"found": false,
"declined": false,
"consented": false,
"has_response": false,
"consent_marketing": null,
"consent_statistics": null,
"consent_preferences": null
},
"usercentrics": {
"found": false,
"has_response": false,
"services_count": 0,
"accepted_services_count": 0
}
},
"contacted_domains": [
{
"host": "lwl-dlbw.de",
"count": 46,
"category": "other",
"provider": "lwl-dlbw.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 3,
"image": 28,
"other": 2,
"script": 5,
"document": 1,
"stylesheet": 7
}
},
{
"host": "lwl.org",
"count": 3,
"category": "other",
"provider": "lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"image": 3
}
},
{
"host": "cdn1.readspeaker.com",
"count": 2,
"category": "other",
"provider": "cdn1.readspeaker.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1,
"stylesheet": 1
}
},
{
"host": "piwik.lwl.org",
"count": 2,
"category": "other",
"provider": "piwik.lwl.org",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"ping": 1,
"script": 1
}
}
],
"privacy_api_metrics": {
"api_calls": {
"beacon_count": 1,
"keyboard_input_listener_count": 96
},
"beacon_count": 1,
"webgl_read_count": 0,
"canvas_read_count": 0,
"audio_context_count": 0,
"canvas_export_count": 0,
"fetch_keepalive_count": 0,
"webgl_parameter_count": 0,
"mutation_observer_count": 0,
"keyboard_input_listener_count": 96
},
"tcf_consent_analysis": {
"color": "green",
"score": 100,
"status": "unauffällig",
"summary": "TCF-Decoder: 0 Zweck(e) mit Consent/LI-Signal, 0 Vendor-Consent(s), 0 Vendor-LI-Signal(e).",
"findings": [],
"api_found": false,
"available": false,
"cmp_loaded": false,
"cmp_status": "",
"event_status": "",
"gdpr_applies": null,
"ping_success": false,
"purpose_rows": [
{
"id": 1,
"label": "Informationen auf einem Gerät speichern und/oder abrufen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 2,
"label": "Einfache Anzeigen auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 3,
"label": "Personalisiertes Anzeigen-Profil erstellen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 4,
"label": "Personalisierte Anzeigen auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 5,
"label": "Personalisiertes Inhalts-Profil erstellen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 6,
"label": "Personalisierte Inhalte auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 7,
"label": "Anzeigen-Leistung messen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 8,
"label": "Inhalte-Leistung messen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 9,
"label": "Marktforschung zur Generierung von Erkenntnissen nutzen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 10,
"label": "Produkte entwickeln und verbessern",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 11,
"label": "Begrenzte Daten zur Anzeigen-Auswahl verwenden",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
}
],
"vendor_li_ids": [],
"policy_version": "",
"vendor_li_count": 0,
"purpose_li_count": 0,
"tc_string_length": 0,
"tc_string_present": false,
"vendor_consent_ids": [],
"granted_purpose_rows": [],
"vendor_consent_count": 0,
"purpose_consent_count": 0,
"high_risk_purpose_count": 0,
"medium_risk_purpose_count": 0
},
"viewport_transparency": {
"samples": [
{
"tag": "button",
"top": 569,
"href": "",
"left": 412,
"text": "Cookie-Einstellungen",
"width": 201,
"height": 38,
"category": "cookie_consent"
},
{
"tag": "a",
"top": 862,
"href": "/datenschutzerklaerung/",
"left": 419,
"text": "Datenschutzerklärung",
"width": 184,
"height": 24,
"category": "privacy_notice"
}
],
"available": true,
"sample_count": 2,
"claim_boundary": "Sichtbarkeits-Evidence aus dem ersten Headless-Chromium-Viewport; keine Aussage ueber Footer nach Scrollen, Loginbereiche oder rechtliche Vollstaendigkeit.",
"viewport_width": 1024,
"category_counts": {
"cookie_consent": 1,
"privacy_notice": 1
},
"contact_visible": false,
"imprint_visible": false,
"viewport_height": 960,
"cookie_consent_visible": true,
"privacy_notice_visible": true
},
"consent_journey_matrix": {
"color": "green",
"items": [
{
"host": "img.youtube.com",
"states": {
"accept_new": 2
},
"category": "video_embed",
"provider": "YouTube",
"category_label": "Video",
"privacy_relevant": true,
"total_request_count": 2
},
{
"host": "youtube.com",
"states": {
"accept_new": 2
},
"category": "video_embed",
"provider": "YouTube",
"category_label": "Video",
"privacy_relevant": true,
"total_request_count": 2
},
{
"host": "lwl.org",
"states": {
"gpc": 3,
"default": 3
},
"category": "other",
"provider": "lwl.org",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 6
},
{
"host": "cdn1.readspeaker.com",
"states": {
"gpc": 2,
"default": 2
},
"category": "other",
"provider": "cdn1.readspeaker.com",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 4
},
{
"host": "piwik.lwl.org",
"states": {
"gpc": 2,
"default": 2
},
"category": "other",
"provider": "piwik.lwl.org",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 4
}
],
"score": 100,
"states": [
{
"id": "default",
"label": "Erstaufruf",
"description": "Kontakte ohne Nutzeraktion",
"domain_count": 3,
"request_count": 7,
"privacy_relevant_domain_count": 0
},
{
"id": "reject_new",
"label": "Nach Ablehnen neu",
"description": "Neue Kontakte nach Ablehnen-Klick",
"domain_count": 0,
"request_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "accept_new",
"label": "Nach Akzeptieren neu",
"description": "Neue Kontakte nach Akzeptieren-Klick",
"domain_count": 2,
"request_count": 4,
"privacy_relevant_domain_count": 2
},
{
"id": "gpc",
"label": "GPC-Aufruf",
"description": "Kontakte bei Global Privacy Control",
"domain_count": 3,
"request_count": 7,
"privacy_relevant_domain_count": 0
}
],
"status": "unauffällig",
"summary": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 2 nach Akzeptieren, 0 im GPC-Aufruf.",
"gpc_privacy_relevant_domain_count": 0,
"accept_privacy_relevant_domain_count": 2,
"reject_privacy_relevant_domain_count": 0
},
"consent_state_evidence": {
"rows": [
{
"id": "default",
"label": "Erstaufruf",
"status": "ohne Nutzeraktion",
"evidence": "Baseline aus erstem Chromium-Aufruf ohne Banner-Interaktion.",
"risk_level": "niedrig",
"cookie_count": 1,
"domain_count": 4,
"request_count": 53,
"storage_total": 1,
"new_cookie_count": 1,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "reject",
"label": "Nach Ablehnen",
"status": "geklickt",
"evidence": "Alle ablehnen",
"risk_level": "hoch",
"cookie_count": 3,
"domain_count": 0,
"request_count": 53,
"storage_total": 1,
"new_cookie_count": 2,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "accept",
"label": "Nach Akzeptieren",
"status": "geklickt",
"evidence": "Alle akzeptieren",
"risk_level": "info",
"cookie_count": 8,
"domain_count": 6,
"request_count": 57,
"storage_total": 1,
"new_cookie_count": 7,
"third_party_cookie_count": 5,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 2
},
{
"id": "gpc",
"label": "GPC-Aufruf",
"status": "aktiv",
"evidence": "Navigator-GPC und Sec-GPC wurden im gesonderten Browserlauf gesetzt.",
"risk_level": "niedrig",
"cookie_count": 1,
"domain_count": 4,
"request_count": 53,
"storage_total": 1,
"new_cookie_count": 0,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
}
],
"color": "yellow",
"score": 78,
"status": "prüfen",
"summary": "Consent-State-Evidence: 4 Zustände verglichen, 1 hoch auffällig, 0 mittel auffällig.",
"findings": [
{
"id": "consent_state_reject_evidence_failed",
"title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
"public": true,
"category": "privacy",
"severity": "warning"
}
],
"available": true,
"high_count": 1,
"medium_count": 0
},
"contacted_domain_count": 4,
"fingerprinting_analysis": {
"color": "yellow",
"score": 88,
"checks": [
{
"id": "canvas",
"ok": true,
"count": 0,
"label": "Canvas-Auslese",
"detail": "0 Pixel-Lesezugriff(e), 0 Export(e)."
},
{
"id": "webgl",
"ok": true,
"count": 0,
"label": "WebGL-Merkmale",
"detail": "0 Parameterzugriff(e), 0 Pixel-Lesezugriff(e)."
},
{
"id": "audio",
"ok": true,
"count": 0,
"label": "AudioContext",
"detail": "0 AudioContext/OfflineAudioContext-Aufruf(e)."
},
{
"id": "session_replay",
"ok": true,
"count": 0,
"label": "Session-Replay-Anbieter",
"detail": "Keine bekannten Anbieter erkannt."
},
{
"id": "input_listeners",
"ok": false,
"count": 96,
"label": "Tastatur-/Eingabe-Listener",
"detail": "96 Tastatur-/Input-Listener, 112 Interaktions-Listener, 0 MutationObserver."
}
],
"status": "prüfen",
"metrics": {
"webgl_read_count": 0,
"canvas_read_count": 0,
"audio_context_count": 0,
"canvas_export_count": 0,
"webgl_parameter_count": 0,
"mutation_observer_count": 0,
"keyboard_input_listener_count": 96
},
"summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
"findings": [
{
"id": "browser_keystroke_listener_signals",
"count": 96,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"finding_count": 1,
"session_replay_domains": []
},
"privacy_relevant_domains": [],
"provider_category_counts": {
"other": 3
},
"provider_category_labels": {
"other": "other"
},
"third_party_domain_count": 3,
"embedded_content_analysis": {
"color": "green",
"items": [],
"score": 100,
"status": "unauffällig",
"summary": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen.",
"findings": [],
"map_count": 0,
"total_count": 0,
"video_count": 0,
"captcha_count": 0,
"category_counts": [],
"social_widget_count": 0,
"loaded_pre_consent_count": 0,
"request_count_by_provider": []
},
"referrer_leakage_analysis": {
"color": "yellow",
"items": [
{
"host": "piwik.lwl.org",
"category": "other",
"provider": "piwik.lwl.org",
"query_keys": [
"action_name",
"idsite",
"rec",
"r",
"h",
"m",
"s",
"url"
],
"risk_reason": "Seiten-URL oder URL-Wert in Drittanbieter-Requestparametern",
"resource_type": "ping",
"category_label": "Sonstige",
"referrer_query_keys": [],
"url_value_param_count": 1,
"target_url_value_param_count": 1
}
],
"score": 88,
"status": "prüfen",
"summary": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte.",
"findings": [
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"category": "privacy",
"severity": "warning"
}
],
"sample_count": 7,
"full_referrer_count": 0,
"page_url_param_count": 1,
"affected_domain_count": 1,
"sensitive_query_count": 0
},
"third_party_contact_matrix": {
"color": "green",
"items": [
{
"host": "lwl.org",
"region": "unbekannt",
"status": "prüfen",
"category": "other",
"provider": "lwl.org",
"risk_level": "niedrig",
"request_count": 3,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"resource_types": [
{
"type": "image",
"count": 3
}
],
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "cdn1.readspeaker.com",
"region": "unbekannt",
"status": "prüfen",
"category": "other",
"provider": "cdn1.readspeaker.com",
"risk_level": "niedrig",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"resource_types": [
{
"type": "script",
"count": 1
},
{
"type": "stylesheet",
"count": 1
}
],
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "piwik.lwl.org",
"region": "unbekannt",
"status": "prüfen",
"category": "other",
"provider": "piwik.lwl.org",
"risk_level": "niedrig",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"resource_types": [
{
"type": "ping",
"count": 1
},
{
"type": "script",
"count": 1
}
],
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
}
],
"score": 95,
"status": "unauffällig",
"summary": "3 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant.",
"category_counts": {
"Sonstige": 3
},
"total_domain_count": 3,
"total_request_count": 7,
"privacy_relevant_count": 0,
"transfer_risk_analysis": {
"color": "yellow",
"items": [
{
"host": "lwl.org",
"region": "unbekannt",
"provider": "lwl.org",
"request_count": 3,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "cdn1.readspeaker.com",
"region": "unbekannt",
"provider": "cdn1.readspeaker.com",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "piwik.lwl.org",
"region": "unbekannt",
"provider": "piwik.lwl.org",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
}
],
"score": 76,
"status": "prüfen",
"summary": "3 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 3 unklar.",
"findings": [
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"unknown_count": 3,
"high_risk_count": 0,
"total_vendor_count": 3,
"third_country_count": 0
}
},
"privacy_relevant_domain_count": 0,
"tracking_pixel_beacon_analysis": {
"color": "orange",
"items": [
{
"url": "https://piwik.lwl.org/piwik/piwik.php?idsite=53&rec=1",
"host": "piwik.lwl.org",
"kind": "tracking_pixel",
"reason": "Tracking-nahe URL",
"source": "html_img",
"category": "other",
"provider": "piwik.lwl.org",
"third_party": true,
"resource_type": "image",
"category_label": "Sonstige"
},
{
"url": "",
"host": "lwl-dlbw.de",
"kind": "beacon_api",
"reason": "sendBeacon API 1 Aufruf(e), 0 Code-Hinweis(e); keepalive 0 Aufruf(e), 0 Code-Hinweis(e).",
"source": "javascript_api",
"category": "telemetry",
"provider": "Beacon-/Keepalive-API",
"third_party": false,
"resource_type": "beacon",
"category_label": "Telemetry"
}
],
"score": 72,
"status": "auffällig",
"summary": "1 Pixel-/Bildtracking-Hinweis(e), 2 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
"findings": [
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "beacon_api_usage",
"count": 2,
"title": "Beacon-/Keepalive-Telemetrie erkannt",
"public": true,
"category": "privacy",
"severity": "warning"
}
],
"pixel_count": 1,
"link_ping_count": 0,
"telemetry_count": 1,
"beacon_api_count": 1,
"third_party_count": 1,
"fetch_keepalive_count": 0,
"privacy_relevant_count": 0,
"beacon_code_reference_count": 0,
"fetch_keepalive_reference_count": 0
}
},
"privacy_analysis": {
"cookies": {
"items": [
{
"name": "django_language",
"secure": false,
"samesite": false,
"tracking": false,
"pre_consent": true,
"likely_essential": false
}
],
"total": 1,
"tracking": [],
"pre_consent": [
"django_language"
],
"missing_secure": [
"django_language"
],
"missing_samesite": [
"django_language"
],
"pre_consent_tracking": [],
"pre_consent_nonessential": [
"django_language"
]
},
"findings": [
{
"id": "pre_consent_nonessential_cookies",
"title": "Möglicherweise nicht notwendige Cookies vor Einwilligung",
"public": true,
"cookies": [
"django_language"
],
"category": "privacy",
"severity": "warning"
},
{
"id": "cookie_missing_secure",
"title": "Cookie ohne Secure-Flag",
"public": true,
"cookies": [
"django_language"
],
"category": "privacy",
"severity": "warning"
},
{
"id": "cookie_missing_samesite",
"title": "Cookie ohne SameSite-Attribut",
"public": true,
"cookies": [
"django_language"
],
"category": "privacy",
"severity": "info"
}
],
"tracking_ids": [],
"tracking_scripts": [],
"consent_hint_found": false,
"privacy_policy_hint_found": false
},
"consent_audit": {
"color": "orange",
"score": 58,
"checks": [
{
"id": "banner_visible",
"ok": false,
"label": "Cookie-/Consent-Hinweis sichtbar",
"detail": "Ein Hinweis mit Cookie-/Einwilligungsbezug wurde im sichtbaren Text erkannt."
},
{
"id": "reject_visible",
"ok": true,
"label": "Ablehnen gleichwertig erreichbar",
"detail": "Ablehnen oder nur notwendige Cookies wurde im Text oder Browser erkannt. Browser-Buttons: 1."
},
{
"id": "settings_visible",
"ok": true,
"label": "Einstellungen oder Auswahl vorhanden",
"detail": "Eine Einstellungs- oder Auswahlmoeglichkeit wurde im Text oder Browser erkannt. Browser-Buttons: 1."
},
{
"id": "browser_reject_visible",
"ok": true,
"label": "Ablehnen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 1, Ablehnen 1, Einstellungen 1."
},
{
"id": "browser_settings_visible",
"ok": true,
"label": "Einstellungen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 1, Ablehnen 1, Einstellungen 1."
},
{
"id": "reject_equally_prominent",
"ok": true,
"label": "Ablehnen nicht deutlich schwaecher dargestellt",
"detail": "Groessen-Verhältnis Ablehnen/Akzeptieren: 0.88."
},
{
"id": "reject_button_clickable",
"ok": true,
"label": "Ablehnen technisch klickbar",
"detail": "Wenn ein Ablehnen-Button sichtbar ist, klickt SaferPage ihn im Chromium-Browser einmal an."
},
{
"id": "no_new_cookies_after_reject",
"ok": false,
"label": "Keine neuen Cookies nach Ablehnen",
"detail": "2 neue Cookie(s) nach dem Ablehnen-Klick."
},
{
"id": "no_tracking_storage_after_reject",
"ok": true,
"label": "Kein Tracking-Storage nach Ablehnen",
"detail": "0 Tracking-Hinweis(e) im Web Storage nach Ablehnen."
},
{
"id": "no_privacy_domains_after_reject",
"ok": true,
"label": "Keine neuen Tracking-Kontakte nach Ablehnen",
"detail": "0 neue datenschutzrelevante Domain(s) nach Ablehnen."
},
{
"id": "gpc_signal_respected",
"ok": true,
"label": "GPC-Signal ohne Tracking-Hinweise",
"detail": "GPC-Aufruf: 0 datenschutzrelevante Domain(s), 0 Drittanbieter-Cookie(s), 0 Storage-Hinweis(e)."
},
{
"id": "no_tracking_cookies_before_consent",
"ok": true,
"label": "Keine Tracking-Cookies vor Einwilligung",
"detail": "0 Tracking-Cookie(s) im Erstaufruf."
},
{
"id": "no_nonessential_cookies_before_consent",
"ok": false,
"label": "Keine nicht notwendigen Cookies vor Einwilligung",
"detail": "1 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
},
{
"id": "third_parties_explained",
"ok": true,
"label": "Drittanbieter begrenzt und erklaerbar",
"detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 3 Drittanbieter insgesamt."
},
{
"id": "storage_without_tracking_hints",
"ok": true,
"label": "Web Storage ohne Tracking-Hinweise",
"detail": "1 Storage-Key(s), 0 Tracking-Hinweis(e)."
},
{
"id": "cmp_api_detected_when_needed",
"ok": true,
"label": "CMP-/TCF-Signal bei Tracking erkennbar",
"detail": "Gängige CMP-/TCF-Indikatoren: __tcfapi, __cmp, Cookiebot, OneTrust oder Usercentrics."
},
{
"id": "accept_click_documented",
"ok": true,
"label": "Akzeptieren-Klick nachvollziehbar",
"detail": "Accept-Test: geklickt, neue Requests 4, neue Cookies 7, neue Datenschutz-Domains 2."
},
{
"id": "cmp_state_readable",
"ok": true,
"label": "CMP-/TCF-Zustand auslesbar",
"detail": "TCF TC-String: nein, Cookiebot: nein, OneTrust: nein, Usercentrics: nein."
},
{
"id": "cmp_default_restrictive",
"ok": true,
"label": "CMP-Default wirkt restriktiv",
"detail": "TCF Purposes erlaubt: 0, TCF Vendors erlaubt: 0, Cookiebot Statistik/Marketing: nein."
}
],
"status": "auffällig",
"summary": "Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.",
"evidence": [
"1 Cookie(s) beim ersten Aufruf aus HTTP-Headern und Chromium",
"0 Tracking-Script(s) im HTML",
"0 datenschutzrelevante Drittanbieter-Domain(s)",
"1 Storage-Key(s), 0 Tracking-Hinweis(e)",
"Consent-Banner-Controls: Akzeptieren 1, Ablehnen 1, Einstellungen 1",
"Ablehnen/Akzeptieren-Prominenz: 0.88",
"Reject-Test: geklickt, neue Cookies 2, Tracking-Storage 0, neue Datenschutz-Domains 0",
"Accept-Test: geklickt, neue Requests 4, neue Cookies 7, neue Datenschutz-Domains 2, Drittanbieter-Cookies 5",
"CMP-State: TCF-String nein, TCF Purposes 0, TCF Vendors 0, Cookiebot nein, OneTrust-Gruppen 0, Usercentrics-Services 0",
"GPC-Test: aktiv, Datenschutz-Domains 0, Drittanbieter-Cookies 0, Storage-Hinweise 0",
"CMP-/TCF-Signal: nein",
"Google Consent Default: nein"
],
"gpc_enabled": true,
"cmp_detected": false,
"blocking_plan": {
"items": [
{
"kind": "cookie",
"level": "mittel",
"source": "lwl-dlbw.de",
"target": "django_language",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Cookiebot"
},
{
"tool": "Usercentrics"
},
{
"tool": "OneTrust"
},
{
"tool": "Developer-Fallback"
}
],
"category": "functional",
"evidence": "vor Consent gesetzt · lwl-dlbw.de · lang (364 Tage)",
"category_label": "Funktional"
},
{
"kind": "storage",
"level": "mittel",
"source": "localStorage",
"target": "lwl-tutorial",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Usercentrics"
},
{
"tool": "Developer-Fallback"
}
],
"category": "unknown",
"evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
"category_label": "Unklar"
}
],
"summary": "2 Blockier-/Consent-Maßnahme(n) abgeleitet: 0 hoch, 2 mittel.",
"available": true,
"high_count": 0,
"total_count": 2,
"type_counts": {
"cookie": 1,
"storage": 1
},
"medium_count": 2
},
"tcf_api_found": false,
"cookiebot_found": false,
"accept_test_enabled": true,
"browser_cookie_count": 1,
"accept_button_clicked": true,
"browser_storage_count": 1,
"reject_button_clicked": true,
"reject_less_prominent": false,
"tcf_tc_string_present": false,
"tracking_script_count": 0,
"accept_button_available": true,
"reject_button_available": true,
"reject_prominence_ratio": 0.88,
"pre_consent_cookie_count": 1,
"pre_consent_cookie_names": [
"django_language"
],
"tcf_vendor_consent_count": 0,
"third_party_domain_count": 3,
"tcf_purpose_consent_count": 0,
"onetrust_active_group_count": 0,
"usercentrics_services_count": 0,
"browser_accept_control_count": 1,
"browser_cookie_context_found": true,
"browser_reject_control_count": 1,
"gpc_third_party_cookie_count": 0,
"post_accept_new_cookie_count": 7,
"post_reject_new_cookie_count": 2,
"post_accept_new_request_count": 4,
"browser_settings_control_count": 1,
"gpc_storage_tracking_hint_count": 0,
"cookiebot_marketing_or_statistics": false,
"gpc_privacy_relevant_domain_count": 0,
"pre_consent_tracking_cookie_count": 0,
"pre_consent_tracking_cookie_names": [],
"privacy_relevant_third_party_count": 0,
"browser_storage_tracking_hint_count": 0,
"post_accept_third_party_cookie_count": 5,
"pre_consent_nonessential_cookie_count": 1,
"pre_consent_nonessential_cookie_names": [
"django_language"
],
"post_accept_storage_tracking_hint_count": 0,
"post_reject_storage_tracking_hint_count": 0,
"post_accept_privacy_relevant_domain_count": 2,
"post_reject_privacy_relevant_domain_count": 0
},
"cookie_inventory": {
"color": "green",
"items": [
{
"name": "django_language",
"domain": "lwl-dlbw.de",
"secure": false,
"sources": [
"http_set_cookie",
"browser_first_load"
],
"category": "functional",
"provider": "lwl-dlbw.de",
"tracking": false,
"http_only": false,
"same_site": "Lax",
"expires_at": "2027-06-19T16:07:44+00:00",
"long_lived": true,
"persistent": true,
"first_party": true,
"origin_host": "lwl-dlbw.de",
"pre_consent": true,
"source_label": "HTTP Set-Cookie, Chromium-Erstaufruf",
"category_label": "Funktional",
"retention_risk": "mittel",
"expires_in_days": 364,
"origin_evidence": "46 Browser-Request(s) · document:1, font:3, image:28, other:2",
"origin_provider": "lwl-dlbw.de",
"retention_class": "long",
"retention_label": "lang (364 Tage)",
"likely_essential": false,
"origin_script_url": "",
"origin_resource_type": ""
}
],
"score": 92,
"total": 1,
"status": "unauffällig",
"summary": "1 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 1 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
"findings": [
{
"id": "long_lived_cookie",
"count": 1,
"title": "Langlebige Cookies erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"categories": {
"functional": 1
},
"tracking_count": 0,
"category_labels": {
"consent": "Consent",
"payment": "Zahlung",
"unknown": "Unklar",
"security": "Sicherheit",
"analytics": "Analytics",
"necessary": "Notwendig",
"functional": "Funktional",
"advertising": "Werbung"
},
"long_lived_count": 1,
"persistent_count": 1,
"first_party_count": 1,
"pre_consent_count": 1,
"retention_classes": {
"long": 1
},
"third_party_count": 0,
"missing_secure_count": 1,
"retention_risk_count": 1,
"retention_risk_items": [
{
"name": "django_language",
"domain": "lwl-dlbw.de",
"secure": false,
"sources": [
"http_set_cookie",
"browser_first_load"
],
"category": "functional",
"provider": "lwl-dlbw.de",
"tracking": false,
"http_only": false,
"same_site": "Lax",
"expires_at": "2027-06-19T16:07:44+00:00",
"long_lived": true,
"persistent": true,
"first_party": true,
"origin_host": "lwl-dlbw.de",
"pre_consent": true,
"source_label": "HTTP Set-Cookie, Chromium-Erstaufruf",
"category_label": "Funktional",
"retention_risk": "mittel",
"expires_in_days": 364,
"origin_evidence": "46 Browser-Request(s) · document:1, font:3, image:28, other:2",
"origin_provider": "lwl-dlbw.de",
"retention_class": "long",
"retention_label": "lang (364 Tage)",
"likely_essential": false,
"origin_script_url": "",
"origin_resource_type": ""
}
],
"very_long_lived_count": 0,
"missing_samesite_count": 0,
"persistent_unknown_count": 0,
"long_lived_tracking_count": 0
},
"security_header_analysis": {
"color": "red",
"score": 46,
"checks": [
{
"ok": true,
"note": "",
"label": "HSTS",
"value": "max-age=15768000;",
"header": "strict-transport-security",
"present": true,
"purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "Content-Security-Policy",
"value": "connect-src 'self' https://pypi.org https://vimeo.com https://recruiting.lwl.org https://www.outdooractive.com *.sibforms.com *.emailsys1a.net https://sketchfab.com https://piwik.lwl.org *.readspeaker.com api.newsletter2",
"header": "content-security-policy",
"present": true,
"purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "X-Frame-Options",
"value": "SAMEORIGIN",
"header": "x-frame-options",
"present": true,
"purpose": "Reduziert Clickjacking-Risiken bei älteren Browsern.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "X-Content-Type-Options",
"value": "nosniff",
"header": "x-content-type-options",
"present": true,
"purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "Referrer-Policy",
"value": "strict-origin-when-cross-origin",
"header": "referrer-policy",
"present": true,
"purpose": "Begrenzt, welche URL-Informationen an Zielseiten weitergegeben werden.",
"severity": "info"
},
{
"ok": true,
"note": "",
"label": "Permissions-Policy",
"value": "camera=(), fullscreen=(self), geolocation=(), microphone=()",
"header": "permissions-policy",
"present": true,
"purpose": "Begrenzt sensible Browser-Funktionen pro Seite.",
"severity": "info"
},
{
"ok": true,
"note": "",
"label": "Cross-Origin-Opener-Policy",
"value": "same-origin",
"header": "cross-origin-opener-policy",
"present": true,
"purpose": "Isoliert Top-Level-Fenster und reduziert Cross-Origin-Seiteneffekte.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Resource-Policy",
"value": "",
"header": "cross-origin-resource-policy",
"present": false,
"purpose": "Begrenzt, welche fremden Seiten Ressourcen einbetten dürfen.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Embedder-Policy",
"value": "",
"header": "cross-origin-embedder-policy",
"present": false,
"purpose": "Erzwingt kontrollierte Cross-Origin-Einbettungen und kann Cross-Origin Isolation ermöglichen.",
"severity": "info"
}
],
"status": "kritisch",
"missing": [
"Cross-Origin-Resource-Policy",
"Cross-Origin-Embedder-Policy"
],
"summary": "7 von 9 wichtigen Security-Headern vorhanden, 7 korrekt bewertet. CSP wirksam mit 9 Direktive(n), 2 Warnung(en), 3 Hinweis(e).",
"findings": [
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.sibforms.com",
"*.emailsys1a.net",
"*.readspeaker.com"
],
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_object_src",
"title": "CSP ohne object-src",
"public": true,
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"category": "security_headers",
"severity": "info"
}
],
"ok_count": 7,
"weak_count": 0,
"csp_analysis": {
"color": "red",
"score": 46,
"status": "kritisch",
"summary": "CSP wirksam mit 9 Direktive(n), 2 Warnung(en), 3 Hinweis(e).",
"enforced": true,
"findings": [
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.sibforms.com",
"*.emailsys1a.net",
"*.readspeaker.com"
],
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_object_src",
"title": "CSP ohne object-src",
"public": true,
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"category": "security_headers",
"severity": "info"
}
],
"available": true,
"directives": [
{
"name": "connect-src",
"value": "'self' https://pypi.org https://vimeo.com https://recruiting.lwl.org https://www.outdooractive.com *.sibforms.com *.emailsys1a.net https://sketchfab.com https://piwik.lwl.org *.readspeaker.com api.newsletter2go.com piwik",
"values": [
"'self'",
"https://pypi.org",
"https://vimeo.com",
"https://recruiting.lwl.org",
"https://www.outdooractive.com",
"*.sibforms.com",
"*.emailsys1a.net",
"https://sketchfab.com",
"https://piwik.lwl.org",
"*.readspeaker.com",
"api.newsletter2go.com",
"piwik.lwl.org",
"https://neurabot.neuraflow.de",
"www.lwl.org",
"api.openrouteservice.org",
"https://neurabot-chat-app-501967154138.europe-west1.run.app"
]
},
{
"name": "default-src",
"value": "'none'",
"values": [
"'none'"
]
},
{
"name": "font-src",
"value": "'self' data:",
"values": [
"'self'",
"data:"
]
},
{
"name": "frame-ancestors",
"value": "'self' *.westfalen-regional.de",
"values": [
"'self'",
"*.westfalen-regional.de"
]
},
{
"name": "frame-src",
"value": "'self' https://www.youtube.com https://recruiting.lwl.org https://www.outdooractive.com https://sketchfab.com *.sibforms.com *.emailsys1a.net https://lwl.gomus.de https://www.google.com https://my.matterport.com https://",
"values": [
"'self'",
"https://www.youtube.com",
"https://recruiting.lwl.org",
"https://www.outdooractive.com",
"https://sketchfab.com",
"*.sibforms.com",
"*.emailsys1a.net",
"https://lwl.gomus.de",
"https://www.google.com",
"https://my.matterport.com",
"https://mpembed.com",
"https://nrw.db-schulkinowochen.de",
"https://sibforms.com",
"https://statlas-wl.nrw.de",
"https://wms02.exmap.de",
"statlas.westfalen.org"
]
},
{
"name": "img-src",
"value": "'self' data: https://www.lwl.org/osmlwlde/ https://img.youtube.com https://www.lwl.org/anis/map/ https://bossanova.uk https://piwik.lwl.org https://www.lwl.org https://i.vimeocdn.com https://recruiting.lwl.org https://ww",
"values": [
"'self'",
"data:",
"https://www.lwl.org/osmlwlde/",
"https://img.youtube.com",
"https://www.lwl.org/anis/map/",
"https://bossanova.uk",
"https://piwik.lwl.org",
"https://www.lwl.org",
"https://i.vimeocdn.com",
"https://recruiting.lwl.org",
"https://www.outdooractive.com",
"https://sketchfab.com",
"https://static.kulturkurier.de",
"https://static.newsletter2go.com",
"https://my.matterport.com",
"https://mpembed.com"
]
},
{
"name": "media-src",
"value": "'self' https://intranet.itz.lwl.org https://www.lwl.org",
"values": [
"'self'",
"https://intranet.itz.lwl.org",
"https://www.lwl.org"
]
},
{
"name": "script-src",
"value": "'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com https://www.youtube.com/iframe_api https://cdn.ckeditor.com https://piwik.lwl.org https://vimeo.com https://player.vimeo.com https://cdnjs.clou",
"values": [
"'self'",
"'unsafe-inline'",
"https://www.lwl.org/anis/map/",
"https://www.youtube.com",
"https://www.youtube.com/iframe_api",
"https://cdn.ckeditor.com",
"https://piwik.lwl.org",
"https://vimeo.com",
"https://player.vimeo.com",
"https://cdnjs.cloudflare.com",
"https://recruiting.lwl.org",
"https://www.outdooractive.com",
"https://sketchfab.com",
"*.sibforms.com",
"*.emailsys1a.net",
"https://lwl.gomus.de"
]
},
{
"name": "style-src",
"value": "'self' 'unsafe-inline' https://www.lwl.org/anis/map/ https://www.youtube.com *.readspeaker.com sibforms.com https://chat-app.chat-link.de https://chat-app.neurabot.de",
"values": [
"'self'",
"'unsafe-inline'",
"https://www.lwl.org/anis/map/",
"https://www.youtube.com",
"*.readspeaker.com",
"sibforms.com",
"https://chat-app.chat-link.de",
"https://chat-app.neurabot.de"
]
}
],
"info_count": 3,
"report_only": false,
"finding_count": 5,
"warning_count": 2
},
"missing_count": 2,
"present_count": 7,
"missing_info_count": 2,
"missing_warning_count": 0
},
"infrastructure_analysis": {
"signals": {
"caa": true,
"dnssec": false,
"final_https": true,
"tls_version": "TLSv1.3",
"hsts_enabled": true,
"address_count": 2,
"ipv6_available": true,
"email_protection": {
"mx": true,
"spf": true,
"dmarc": true
},
"certificate_valid": true,
"certificate_issuer": "E7",
"certificate_alt_names": [
"lwl-dlbw.de",
"www.lwl-dlbw.de"
],
"multiple_ip_addresses": true,
"certificate_expires_at": "Aug 19 11:32:07 2026 GMT",
"certificate_days_remaining": 60,
"certificate_hostname_matches": true
},
"findings": [],
"risk_level": "low",
"positive_signals": [
"Mehrere IP-Adressen gefunden: Hinweis auf redundante Infrastruktur oder CDN.",
"IPv6 ist vorhanden.",
"Moderne TLS-Version aktiv: TLSv1.3.",
"HSTS ist aktiv.",
"DMARC ist für die Domain vorhanden.",
"CAA-Records begrenzen Zertifikatsaussteller."
]
},
"performance_analysis": {
"score": 82,
"signals": {
"compressed": false,
"duration_ms": 4172,
"image_count": 1,
"script_count": 4,
"cache_control": "max-age=0, no-cache, no-store, must-revalidate, private",
"content_length": 0,
"viewport_found": true,
"stylesheet_count": 7
},
"findings": [
{
"id": "slow_response",
"title": "Langsame Serverantwort",
"public": true,
"category": "performance",
"severity": "warning"
},
{
"id": "too_many_render_blocking_assets",
"title": "Viele potenziell blockierende Assets",
"public": true,
"category": "performance",
"severity": "info"
}
],
"risk_level": "medium"
},
"accessibility_analysis": {
"color": "yellow",
"score": 88,
"status": "prüfen",
"signals": {
"h1_count": 0,
"image_count": 1,
"button_count": 0,
"heading_count": 0,
"viewport_found": true,
"html_lang_found": true,
"form_field_count": 0,
"image_missing_alt_count": 1,
"buttons_without_name_count": 0,
"form_fields_without_label_count": 0
},
"summary": "1 Bild(er), 0 Formularfeld(er), 0 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
"findings": [
{
"id": "image_alt_missing",
"count": 1,
"title": "Bilder ohne Alternativtext",
"public": true,
"category": "accessibility",
"severity": "info",
"evidence_items": [
"https://piwik.lwl.org/piwik/piwik.php?idsite=53&rec=1"
]
},
{
"id": "heading_structure_missing",
"title": "Keine Überschriftenstruktur erkannt",
"public": true,
"category": "accessibility",
"severity": "info"
}
],
"wcag_matrix": {
"rows": [
{
"id": "wcag_non_text_content",
"ok": false,
"wcag": "WCAG 1.1.1 Non-text Content",
"title": "Alternativtexte für Bilder",
"impact": "mittel",
"status": "prüfen",
"evidence": "1 von 1 Bild(er) ohne alt-Text im HTML-Sample."
},
{
"id": "wcag_form_labels",
"ok": true,
"wcag": "WCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions",
"title": "Formularfelder beschriften",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 0 Formularfeld(er) ohne erkennbare Beschriftung."
},
{
"id": "wcag_button_names",
"ok": true,
"wcag": "WCAG 4.1.2 Name, Role, Value",
"title": "Buttons mit Namen versehen",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 0 Button(s) ohne erkennbaren Namen."
},
{
"id": "wcag_page_language",
"ok": true,
"wcag": "WCAG 3.1.1 Language of Page",
"title": "Seitensprache auszeichnen",
"impact": "niedrig",
"status": "ok",
"evidence": "HTML-lang-Attribut gefunden."
},
{
"id": "wcag_heading_structure",
"ok": false,
"wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
"title": "Überschriftenstruktur",
"impact": "mittel",
"status": "prüfen",
"evidence": "0 H1 und 0 Überschrift(en) im HTML-Sample."
},
{
"id": "wcag_mobile_reflow",
"ok": true,
"wcag": "WCAG 1.4.10 Reflow",
"title": "Mobile Viewport-Basis",
"impact": "niedrig",
"status": "ok",
"evidence": "Viewport-Meta-Tag gefunden."
}
],
"summary": "2 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 0 mit hoher Auswirkung.",
"standard": "WCAG 2.2 orientierte Basisprüfung",
"available": true,
"issue_count": 2,
"high_impact_count": 0
}
},
"domain_history": {
"status": [
"active"
],
"summary": "RDAP liefert kein klares Registrierungsdatum.",
"age_days": null,
"findings": [],
"available": true,
"registrar": "",
"expires_at": "",
"risk_level": "unknown",
"registered_at": "",
"expires_in_days": null,
"last_changed_at": "2016-06-28T14:42:59+00:00"
},
"data_entry_analysis": {
"forms": [],
"score": 100,
"summary": "Keine Formular- oder Zahlungsabfrage im passiven Startseiten-Sample erkannt.",
"findings": [],
"form_count": 0,
"risk_level": "low",
"field_count": 0,
"asks_for_data": false,
"payment_providers": [],
"detected_data_types": [],
"privacy_context_found": false,
"operator_context_found": false
},
"pii_exposure_analysis": {
"color": "green",
"score": 100,
"checks": [
{
"id": "current_url",
"ok": true,
"count": 0,
"label": "Aktuelle URL",
"detail": "Keine sensiblen Query-Parameter erkannt."
},
{
"id": "link_queries",
"ok": true,
"count": 0,
"label": "Link-Parameter",
"detail": "Keine sensiblen Link-Querys erkannt."
},
{
"id": "get_forms",
"ok": true,
"count": 0,
"label": "GET-Formulare",
"detail": "Keine personenbezogenen GET-Formulare erkannt."
},
{
"id": "external_forms",
"ok": true,
"count": 0,
"label": "Externe Formularziele",
"detail": "Keine externen Formularziele mit personenbezogenen Feldern erkannt."
},
{
"id": "tracking_context",
"ok": true,
"count": 0,
"label": "Tracking neben Dateneingabe",
"detail": "Keine Kombination aus Dateneingabe und datenschutzrelevanten Drittanbietern erkannt."
}
],
"status": "unauffällig",
"summary": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext.",
"findings": [],
"link_hits": [],
"finding_count": 0,
"current_url_hits": [],
"tracking_context": false,
"sensitive_get_forms": []
},
"scan_history_analysis": {
"available": false,
"summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
"total_scan_count": 1,
"previous_scan_count": 0,
"history": [
{
"scan_id": "a69d0182-11e1-44d7-8e6b-3256610a7ece",
"created_at": "2026-06-19 18:08:24.13682+02",
"score": 55,
"verdict": "auffällig",
"finding_count": 30,
"integrity_root_hash": "b7f9d4e5841cf6aacf0d47421c5431165cf6012a69da7c446374dc4859098001",
"integrity_available_hash_count": 9,
"current": true
}
],
"new_findings": [],
"resolved_findings": [],
"technical_changes": {
"available": false,
"summary": "Noch kein früherer Scan für technische Änderungen vorhanden."
}
},
"benchmark_analysis": {
"host": "lwl-dlbw.de",
"rank": 1,
"score": 55,
"status": "im_mittelfeld",
"summary": "lwl-dlbw.de liegt mit 55 Punkten ungefähr im gespeicherten Vergleichsfeld.",
"available": true,
"peer_count": 6575,
"percentile": 0,
"query_mode": "php_ttl_cache_refresh",
"distribution": {
"0_39": 1051,
"40_59": 2688,
"60_79": 2821,
"80_100": 15
},
"median_score": 58,
"average_score": 52.6,
"comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
"same_score_count": 0,
"better_than_count": 0,
"qualified_peer_count": 6336,
"zero_score_count": 239,
"top_quartile_score": 64,
"top_decile_score": 68,
"qualified_average_score": 54.6,
"qualified_median_score": 59,
"qualified_top_quartile_score": 65,
"qualified_top_decile_score": 68,
"thresholds": [
{
"id": "critical",
"label": "Kritisch",
"range": "0-39",
"met": false
},
{
"id": "basic",
"label": "Basis stabilisieren",
"range": "40-59",
"met": true
},
{
"id": "managed",
"label": "Gesteuert",
"range": "60-79",
"met": false
},
{
"id": "strong",
"label": "Stark",
"range": "80-100",
"met": false
}
],
"risk_tier": "basis",
"target_score": 60,
"aspirational_target_score": 68,
"gap_to_target": 5,
"gap_to_top_quartile": 10,
"gap_to_strong": 25,
"cache_ttl_seconds": 300
},
"audit_receipt": {
"url": "https://lwl-dlbw.de/",
"host": "lwl-dlbw.de",
"status": "verfügbar",
"bot_url": "https://saferpage.de/bot",
"summary": "Prüfbeleg für lwl-dlbw.de: kontrollierter HTTP-/Browser-Kurzcheck mit 53 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
"renderer": "playwright-chromium",
"artifacts": [
{
"label": "Öffentlicher Kurzreport",
"detail": "https://saferpage.de/lwl-dlbw.de",
"status": "verfügbar"
},
{
"label": "JSON-Export",
"detail": "Maschinenlesbarer Report mit Modulen, Nachweisen und Tabellen.",
"status": "verfügbar"
},
{
"label": "CSV-Export",
"detail": "Tabellarische Prüfzeilen für Betreiber, Datenschutz und Technik.",
"status": "verfügbar"
},
{
"label": "160x150 Seitenvorschau",
"detail": "/cache/screenshots/lwl-dlbw.de-160x150-19446dbf0cbb0a8fa1.png",
"status": "verfügbar"
},
{
"label": "Cookie-Erklärung",
"detail": "2 Cookie-/Storage-Eintrag/Einträge.",
"status": "unauffällig"
},
{
"label": "Empfänger-/Anbieterinventar",
"detail": "3 Anbieterzeile(n), 3 AVV-/Rollenprüfung(en).",
"status": "prüfen"
},
{
"label": "Barrierefreiheitserklärung-Entwurf",
"detail": "2 bekannte Barrierefreiheits-Punkt(e).",
"status": "Teilweise konform im automatischen Basischeck"
}
],
"available": true,
"final_url": "https://www.lwl-dlbw.de/de/",
"checked_at": "2026-06-19T16:08:23+00:00",
"share_text": "SaferPage Prüfbeleg lwl-dlbw.de: 53 Browser-Request(s), 3 Drittanbieter, 2 Cookie-/Storage-Einträge, geprüft am 2026-06-19T16:08:23.",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/lwl-dlbw.de\">https://saferpage.de/lwl-dlbw.de</a>)",
"limitations": [
"Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
"Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
"Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
],
"scan_context": "crawler",
"coverage_items": [
{
"label": "HTTP/DNS/TLS",
"value": "HTTP 200 · DNS ok · TLS ok"
},
{
"label": "Browserlauf",
"value": "53 Request(s), 3 Drittanbieter-Domain(s), 1 Browser-Cookie(s)."
},
{
"label": "Consent-Zustände",
"value": "4 Zustand/Zustände: Default, Ablehnen, Akzeptieren und GPC soweit verfügbar."
},
{
"label": "Seitenabdeckung",
"value": "0 priorisierte Unterseite(n) im Nachweispack."
},
{
"label": "Drittanbieter-Auszug",
"value": "3 Anbieterzeile(n) im öffentlichen Nachweis."
},
{
"label": "Cookie-Auszug",
"value": "1 Cookie-Zeile(n) im öffentlichen Nachweis."
}
],
"confidence_score": 79,
"browser_final_url": "https://www.lwl-dlbw.de/de/"
},
"evidence_integrity_manifest": {
"host": "lwl-dlbw.de",
"status": "verfügbar",
"summary": "Integritätsmanifest für lwl-dlbw.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
"sections": [
{
"id": "audit_receipt",
"hash": "a3b31b8e3b2f32581a0f8ad4e3bc4a778d05680e7b66036bf1e24a1f685d51d4",
"count": 18,
"label": "Prüfbeleg",
"detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
"status": "verfügbar"
},
{
"id": "protocol",
"hash": "1fa4b838c33494bf551cf025452e06b695c3c903cbd3d96ad1951ef8f684a86c",
"count": 15,
"label": "Scan-Protokoll",
"detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
"status": "verfügbar"
},
{
"id": "checkpoints",
"hash": "fd43d164fd632ccf34a75be776b7e58738b1f1315252cdeff443b9958d178f6f",
"count": 6,
"label": "Prüfschritte",
"detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
"status": "verfügbar"
},
{
"id": "consent_states",
"hash": "2edc68d5a1b2b88c2357e3187c7d380fc0ac5b8719342006b14653087ac3649b",
"count": 4,
"label": "Consent-Zustände",
"detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
"status": "verfügbar"
},
{
"id": "third_party_evidence",
"hash": "f19b273cf10bea3085585e0e9eb54e59ba99349dad5abfc9c9321e62721da1ef",
"count": 3,
"label": "Drittanbieter-Auszug",
"detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
"status": "verfügbar"
},
{
"id": "cookie_evidence",
"hash": "49ab2a9bede0c01c2f89dde2f8ad993d44a0477d986b9be46a3b9fe669c9feb3",
"count": 1,
"label": "Cookie-Auszug",
"detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
"status": "verfügbar"
},
{
"id": "request_samples",
"hash": "1b12a892a8333c0c534685b4d01155296e5deca5316a91e1e6821d8e1c115e0b",
"count": 7,
"label": "Request-Samples",
"detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
"status": "verfügbar"
},
{
"id": "checked_pages",
"hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
"count": 0,
"label": "Geprüfte Unterseiten",
"detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
"status": "leer"
},
{
"id": "screenshot_file",
"hash": "5092b98590f5e86646451149c66ae7b9a55f836476a158377198c08519bba447",
"count": 4520,
"label": "160x150 Seitenvorschau-Datei",
"detail": "/cache/screenshots/lwl-dlbw.de-160x150-19446dbf0cbb0a8fa1.png",
"status": "verfügbar"
}
],
"algorithm": "sha256",
"available": true,
"root_hash": "b7f9d4e5841cf6aacf0d47421c5431165cf6012a69da7c446374dc4859098001",
"checked_at": "2026-06-19T16:08:23+00:00",
"limitations": [
"Das Manifest schützt die im Report veröffentlichten/sanitisierten Nachweise, nicht verdeckte Cookie-Werte oder vollständige Request-URLs.",
"Ohne externe qualifizierte Zeitstempelung beweist der Hash Integrität des exportierten Artefakts, aber keine amtliche Zustellung."
],
"section_count": 9,
"canonicalization": "JSON UTF-8, sort_keys=true, kompakte Separatoren; Screenshot als rohe Datei-Bytes.",
"available_hash_count": 9
},
"audit_evidence_pack": {
"status": "verfügbar",
"summary": "Nachweisprotokoll mit 53 Browser-Request(s), 1 Cookie-Nachweis(en), 3 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
"protocol": {
"host": "lwl-dlbw.de",
"dns_ok": true,
"tls_ok": true,
"bot_url": "https://saferpage.de/bot",
"renderer": "playwright-chromium",
"final_url": "https://www.lwl-dlbw.de/de/",
"input_url": "https://lwl-dlbw.de/",
"checked_at": "2026-06-19T16:08:23+00:00",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/lwl-dlbw.de\">https://saferpage.de/lwl-dlbw.de</a>)",
"http_status": 200,
"scan_context": "crawler",
"screenshot_url": "/cache/screenshots/lwl-dlbw.de-160x150-19446dbf0cbb0a8fa1.png",
"googlebot_status": 200,
"browser_final_url": "https://www.lwl-dlbw.de/de/",
"dns_address_count": 2
},
"checkpoints": [
{
"label": "DNS",
"detail": "2 Adresse(n) aufgelöst.",
"status": "ok"
},
{
"label": "TLS/HTTPS",
"detail": "TLSv1.3",
"status": "ok"
},
{
"label": "HTTP-Abruf",
"detail": "Status 200, Endziel https://www.lwl-dlbw.de/de/.",
"status": "ok"
},
{
"label": "Browserlauf",
"detail": "53 Request(s), 3 Drittanbieter-Domain(s).",
"status": "ok"
},
{
"label": "Consent-Zustände",
"detail": "Default, Ablehnen, Akzeptieren und GPC werden soweit möglich gegenübergestellt.",
"status": "unauffällig"
},
{
"label": "Exports",
"detail": "PDF/Druck, JSON und CSV enthalten die wesentlichen Prüfnachweise.",
"status": "verfügbar"
}
],
"limitations": [
"Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
"Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
"Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
],
"checked_pages": [],
"cookie_evidence": [
{
"name": "django_language",
"domain": "lwl-dlbw.de",
"secure": false,
"category": "Funktional",
"provider": "lwl-dlbw.de",
"tracking": false,
"retention": "lang (364 Tage)",
"same_site": "Lax",
"pre_consent": true
}
],
"browser_evidence": {
"gpc_enabled": true,
"request_count": 53,
"storage_total": 1,
"accept_clicked": true,
"reject_clicked": true,
"browser_cookie_count": 1,
"contacted_domain_count": 4,
"third_party_domain_count": 3,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
"storage_evidence": {
"tracking_key_hints": [],
"local_storage_total": 1,
"session_storage_total": 0
},
"third_party_evidence": [
{
"host": "lwl.org",
"category": "Sonstige",
"provider": "lwl.org",
"transfer": "Jurisdiktion unklar",
"risk_level": "niedrig",
"request_count": 3,
"resource_types": [
"image"
],
"privacy_relevant": false
},
{
"host": "cdn1.readspeaker.com",
"category": "Sonstige",
"provider": "cdn1.readspeaker.com",
"transfer": "Jurisdiktion unklar",
"risk_level": "niedrig",
"request_count": 2,
"resource_types": [
"script",
"stylesheet"
],
"privacy_relevant": false
},
{
"host": "piwik.lwl.org",
"category": "Sonstige",
"provider": "piwik.lwl.org",
"transfer": "Jurisdiktion unklar",
"risk_level": "niedrig",
"request_count": 2,
"resource_types": [
"ping",
"script"
],
"privacy_relevant": false
}
],
"external_script_count": 1,
"consent_state_evidence": [
{
"label": "Erstaufruf",
"cookie_count": 0,
"domain_count": 3,
"request_count": 7,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "Nach Ablehnen neu",
"cookie_count": 0,
"domain_count": 0,
"request_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "Nach Akzeptieren neu",
"cookie_count": 0,
"domain_count": 2,
"request_count": 4,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 2
},
{
"label": "GPC-Aufruf",
"cookie_count": 0,
"domain_count": 3,
"request_count": 7,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
}
],
"request_sample_evidence": [
{
"host": "cdn1.readspeaker.com",
"query_keys": [
"pids"
],
"resource_type": "script",
"query_key_count": 1,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "lwl.org",
"query_keys": [],
"resource_type": "image",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "lwl.org",
"query_keys": [],
"resource_type": "image",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "lwl.org",
"query_keys": [],
"resource_type": "image",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "cdn1.readspeaker.com",
"query_keys": [
"v"
],
"resource_type": "stylesheet",
"query_key_count": 1,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "piwik.lwl.org",
"query_keys": [],
"resource_type": "script",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "piwik.lwl.org",
"query_keys": [
"action_name",
"idsite",
"rec",
"r",
"h",
"m",
"s",
"url"
],
"resource_type": "ping",
"query_key_count": 26,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
}
]
},
"consent_visual_salience_evidence": {
"schema": "https://saferpage.de/schemas/consent-visual-salience-evidence.v1",
"status": "measured_dom_viewport_signal",
"available": true,
"evidence_level": "dom_viewport_signal_only",
"summary": "Der erste Headless-Chromium-Viewport liefert sichtbare Consent-Control-Signale mit Text, Position, Groesse und typografischen Hinweisen.",
"sample_status": "classified_control_samples",
"classified_sample_count": 3,
"accept_control_count": 1,
"reject_control_count": 1,
"settings_control_count": 1,
"visible_control_count": 11,
"accept_max_area": 6526,
"reject_max_area": 5720,
"reject_prominence_ratio": 0.88,
"samples": [
{
"kind": "accept",
"text": "Alle akzeptieren",
"tag": "button",
"width": 162,
"height": 40,
"area": 6526,
"top": 904,
"left": 819,
"font_weight": "600"
},
{
"kind": "reject",
"text": "Alle ablehnen",
"tag": "button",
"width": 142,
"height": 40,
"area": 5720,
"top": 904,
"left": 661,
"font_weight": "600"
},
{
"kind": "settings",
"text": "Cookie-Einstellungen",
"tag": "button",
"width": 201,
"height": 38,
"area": 7578,
"top": 569,
"left": 412,
"font_weight": "400"
}
],
"sample_boundary": "Samples enthalten nur klassifizierte Accept-/Reject-/Settings-Controls. Weitere sichtbare Consent-Controls bleiben als Zaehler erhalten, werden aber ohne Klassifizierung nicht als Ablehnen-, Akzeptieren- oder Einstellungsprobe behauptet.",
"claim_boundary": "Consent-Visual-Salienz ist ein DOM-/Viewport-Signal aus dem ersten Browserlauf. Sie ist keine Rechtsbewertung, kein Dark-Pattern-Endurteil und kein Nachweis fuer spaetere Consent-Zustaende, Scrollbereiche, Loginbereiche oder manuelle Betreiberkontexte."
}
}