{
    "schema": "https://saferpage.de/schemas/evidence-center.v1",
    "generated_at": "2026-07-03T10:17:29+00:00",
    "domain": "singen.de",
    "available": true,
    "scan": {
        "id": "8ce87c37-e794-4bec-8d95-83ab2e3d16a6",
        "checked_at": "2026-07-03 03:42:22.481466+02"
    },
    "summary": "singen.de: 8 Nachweisartefakte, 52 Request(s), 0 Drittanbieter-Domain(s), Root-Hash 6659df239a43f06a.",
    "metrics": {
        "artifact_count": 8,
        "available_artifact_count": 8,
        "request_count": 52,
        "third_party_count": 0,
        "privacy_relevant_domain_count": 0,
        "cookie_count": 1,
        "storage_tracking_hint_count": 0,
        "consent_score": 58,
        "hash_section_count": 9,
        "history_count": 1
    },
    "protocol": {
        "final_url": "https://www.singen.de/start",
        "checked_at": "2026-07-03T01:41:52+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/singen.de\">https://saferpage.de/singen.de</a>)",
        "renderer": "playwright-chromium",
        "screenshot_url": "/cache/screenshots/singen.de-160x150-09fcc67e8933f1f82f.png",
        "http_status": "200"
    },
    "artifacts": [
        {
            "id": "html_http",
            "label": "HTTP-/HTML-Antwort",
            "status": "verfügbar",
            "detail": "Endziel, Status, Header- und HTML-Signale aus passivem Abruf.",
            "source": "evidence/http",
            "url": ""
        },
        {
            "id": "browser_run",
            "label": "Headless-Browserlauf",
            "status": "verfügbar",
            "detail": "Chromium-/Browser-Signale für Requests, Cookies, Storage und Consent.",
            "source": "browser_analysis",
            "url": ""
        },
        {
            "id": "screenshot",
            "label": "Screenshot",
            "status": "verfügbar",
            "detail": "Kleines Seitenpreview als visueller Kontext.",
            "source": "screenshot",
            "url": "https://saferpage.de/cache/screenshots/singen.de-160x150-09fcc67e8933f1f82f.png"
        },
        {
            "id": "consent_states",
            "label": "Consent-Zustände",
            "status": "verfügbar",
            "detail": "Ablehnen, Akzeptieren, GPC, CMP- und Cookie-/Request-Zustände.",
            "source": "consent_audit",
            "url": "https://saferpage.de/consent/singen.de/nachweise"
        },
        {
            "id": "cookies",
            "label": "Cookie-/Storage-Auszug",
            "status": "verfügbar",
            "detail": "Sanitisierte Cookie-, Storage- und Laufzeit-/Zwecksignale.",
            "source": "cookie_inventory",
            "url": "https://saferpage.de/cookies/singen.de"
        },
        {
            "id": "third_parties",
            "label": "Drittanbieter-/Request-Auszug",
            "status": "verfügbar",
            "detail": "Kontaktierte Domains, Anbieter, Request-Samples und datenschutzrelevante Kontakte.",
            "source": "browser_analysis",
            "url": "https://saferpage.de/anbieter/singen.de"
        },
        {
            "id": "integrity",
            "label": "Integritätsmanifest",
            "status": "verfügbar",
            "detail": "Root-Hash 6659df239a43f06aa1c051a09850365dd9fe09224ed1c578c7a6c16beca53cf8",
            "source": "evidence_integrity_manifest",
            "url": ""
        },
        {
            "id": "zip",
            "label": "ZIP-Nachweispaket",
            "status": "verfügbar",
            "detail": "Getrennte Rohdaten-/Tabellenexporte über die API, soweit im Scan vorhanden.",
            "source": "api_export_zip",
            "url": "https://saferpage.de/api/report/export?id=8ce87c37-e794-4bec-8d95-83ab2e3d16a6&format=zip"
        }
    ],
    "integrity": {
        "algorithm": "sha256",
        "root_hash": "6659df239a43f06aa1c051a09850365dd9fe09224ed1c578c7a6c16beca53cf8",
        "manifest_available": true,
        "derived_root_hash": "71f5fcda3b41252027a7522fc5a8d4199c50bbd1717b1e5d0ec3bbe59c449081",
        "sections": [
            {
                "id": "audit_receipt",
                "hash": "90fb33db092938aabb9a4fe209198692734ed57b7e3533e9a01c6b2191e8f5cd",
                "count": 18,
                "label": "Prüfbeleg",
                "detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
                "status": "verfügbar"
            },
            {
                "id": "protocol",
                "hash": "b92125df284891a3f91828e5023e0e7c93cdcb692e2c0cf35ef3e6c2a90f2590",
                "count": 15,
                "label": "Scan-Protokoll",
                "detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
                "status": "verfügbar"
            },
            {
                "id": "checkpoints",
                "hash": "c8336ef14feb41c0c75eee8589b1936b9cc2347549e76a1191f23f00f8916c0b",
                "count": 6,
                "label": "Prüfschritte",
                "detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
                "status": "verfügbar"
            },
            {
                "id": "consent_states",
                "hash": "4c6fd8288209437d4d29b7db6ad596252434052f1571b72aba7b0bcdb0aed8a7",
                "count": 4,
                "label": "Consent-Zustände",
                "detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
                "status": "verfügbar"
            },
            {
                "id": "third_party_evidence",
                "hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
                "count": 0,
                "label": "Drittanbieter-Auszug",
                "detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
                "status": "leer"
            },
            {
                "id": "cookie_evidence",
                "hash": "19d34a15efbcc0d69bfe2be654a12f810b3ccd09cefde9b04d5e5b465cb13b8a",
                "count": 1,
                "label": "Cookie-Auszug",
                "detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
                "status": "verfügbar"
            },
            {
                "id": "request_samples",
                "hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
                "count": 0,
                "label": "Request-Samples",
                "detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
                "status": "leer"
            },
            {
                "id": "checked_pages",
                "hash": "f2e6accf4e8172758d9b430361b1d6c410243e43ea44f64d7034a045241e78cb",
                "count": 8,
                "label": "Geprüfte Unterseiten",
                "detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
                "status": "verfügbar"
            },
            {
                "id": "screenshot_file",
                "hash": "22c061dd2871221b4f0e4c1caa3e687131d90f8c83190a01d9d3717b9e4f159b",
                "count": 16248,
                "label": "160x150 Seitenvorschau-Datei",
                "detail": "/cache/screenshots/singen.de-160x150-09fcc67e8933f1f82f.png",
                "status": "verfügbar"
            }
        ],
        "verification_steps": [
            "JSON-Export speichern und den jeweiligen Abschnitt kanonisch mit sortierten Schlüsseln serialisieren.",
            "SHA-256 des kanonischen Abschnitts bilden und mit dem Manifest vergleichen.",
            "Screenshot-Datei separat als rohe Datei-Bytes hashen, falls ein Screenshot-Artefakt vorhanden ist.",
            "Bei einem Wiederholungsscan Root-Hash, Zeitstempel und Abschnitts-Hashes getrennt vergleichen."
        ]
    },
    "evidence_samples": {
        "consent_states": [
            {
                "id": "",
                "label": "Erstaufruf",
                "request_count": "0",
                "cookie_count": "0",
                "privacy_relevant_domain_count": "0"
            },
            {
                "id": "",
                "label": "Nach Ablehnen neu",
                "request_count": "0",
                "cookie_count": "0",
                "privacy_relevant_domain_count": "0"
            },
            {
                "id": "",
                "label": "Nach Akzeptieren neu",
                "request_count": "0",
                "cookie_count": "0",
                "privacy_relevant_domain_count": "0"
            },
            {
                "id": "",
                "label": "GPC-Aufruf",
                "request_count": "0",
                "cookie_count": "0",
                "privacy_relevant_domain_count": "0"
            }
        ],
        "third_parties": [
            {
                "host": "singen.de",
                "provider": "",
                "category": "Domainkontakt",
                "request_count": "",
                "privacy_relevant": ""
            }
        ],
        "cookies": [
            {
                "name": "JSESSIONID",
                "domain": "singen.de",
                "category": "Notwendig",
                "retention": "Session",
                "pre_consent": "ja"
            }
        ],
        "requests": []
    },
    "links": {
        "evidence_center": "https://saferpage.de/nachweise/singen.de",
        "json": "https://saferpage.de/nachweise/singen.de/export",
        "csv": "https://saferpage.de/nachweise/singen.de/export-csv",
        "markdown": "https://saferpage.de/nachweise/singen.de/manifest-md",
        "zip": "https://saferpage.de/api/report/export?id=8ce87c37-e794-4bec-8d95-83ab2e3d16a6&format=zip",
        "report": "https://saferpage.de/singen.de",
        "consent_evidence": "https://saferpage.de/consent/singen.de/nachweise",
        "changes": "https://saferpage.de/aenderungen/singen.de",
        "trust": "https://saferpage.de/trust/singen.de"
    },
    "disclaimer": "Nachweise sind öffentliche, sanitisiert dargestellte SaferPage-Artefakte. Sie belegen beobachtete Website-Signale zum Scan-Zeitpunkt, ersetzen aber keine interne Freigabe, keine vollständige Logauswertung und keine Rechtsberatung."
}
