# Consent-Auto-Blocking für gornergrat.ch

gornergrat.ch: 34 Auto-Blocking-Regel(n) für Skripte, Iframes und Tag-Manager-Trigger aus SaferPage-Dienstsignalen.

> Auto-Blocking-Regeln sind Betreiber-Vorlagen. Produktivbetrieb braucht CMP-Freigabe, Tests je Consent-Zustand, CSP-/Tag-Manager-Abgleich und fachliche Freigabe.

## Regeln
- Google AdSense (*.pagead2.googlesyndication.com): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://pagead2.googlesyndication.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://pagead2.googlesyndication.com/..." src="about:blank" title="Google AdSense"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- Google Tag Manager (*.googletagmanager.com): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://googletagmanager.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://googletagmanager.com/..." src="about:blank" title="Google Tag Manager"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- __cf_bm (*.hs-analytics.net): Kategorie statistik, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="statistik" data-src="https://hs-analytics.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="statistik" data-src="https://hs-analytics.net/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.statistik equals true.
- js-eu1.hs-analytics.net (*.js-eu1.hs-analytics.net): Kategorie statistik, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="statistik" data-src="https://js-eu1.hs-analytics.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="statistik" data-src="https://js-eu1.hs-analytics.net/..." src="about:blank" title="js-eu1.hs-analytics.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.statistik equals true.
- __cf_bm (*.hs-banner.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://hs-banner.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://hs-banner.com/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __cf_bm (*.hs-scripts.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://hs-scripts.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://hs-scripts.com/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __cf_bm (*.hsappstatic.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://hsappstatic.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://hsappstatic.net/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __cf_bm (*.hubspot.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://hubspot.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://hubspot.com/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __cf_bm (*.usemessages.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://usemessages.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://usemessages.com/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __hssc (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="__hssc"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __hssrc (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="__hssrc"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __hstc (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="__hstc"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- ab.storage.deviceId.0e5b15ae-87e0-4c1e-87f3-82c2a6ed221d (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="ab.storage.deviceId.0e5b15ae-87e0-4c1e-87f3-82c2a6ed221d"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- api-eu1.hubspot.com (*.api-eu1.hubspot.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://api-eu1.hubspot.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://api-eu1.hubspot.com/..." src="about:blank" title="api-eu1.hubspot.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- app-eu1.hubspot.com (*.app-eu1.hubspot.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://app-eu1.hubspot.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://app-eu1.hubspot.com/..." src="about:blank" title="app-eu1.hubspot.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- assets.contenthub.dev (*.assets.contenthub.dev): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://assets.contenthub.dev/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://assets.contenthub.dev/..." src="about:blank" title="assets.contenthub.dev"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cda.contenthub.dev (*.cda.contenthub.dev): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cda.contenthub.dev/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cda.contenthub.dev/..." src="about:blank" title="cda.contenthub.dev"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cdn1.hubspot.net (*.cdn1.hubspot.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn1.hubspot.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn1.hubspot.net/..." src="about:blank" title="cdn1.hubspot.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- consent.cookiebot.eu (*.consent.cookiebot.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://consent.cookiebot.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://consent.cookiebot.eu/..." src="about:blank" title="consent.cookiebot.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- consentcdn.cookiebot.eu (*.consentcdn.cookiebot.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://consentcdn.cookiebot.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://consentcdn.cookiebot.eu/..." src="about:blank" title="consentcdn.cookiebot.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- exceptions-eu1.hubspot.com (*.exceptions-eu1.hubspot.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://exceptions-eu1.hubspot.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://exceptions-eu1.hubspot.com/..." src="about:blank" title="exceptions-eu1.hubspot.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- forms-eu1.hscollectedforms.net (*.forms-eu1.hscollectedforms.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://forms-eu1.hscollectedforms.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://forms-eu1.hscollectedforms.net/..." src="about:blank" title="forms-eu1.hscollectedforms.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- frontend (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="frontend"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- gql.contenthub.dev (*.gql.contenthub.dev): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gql.contenthub.dev/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gql.contenthub.dev/..." src="about:blank" title="gql.contenthub.dev"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- hubspotutk (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="hubspotutk"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- images.contenthub.dev (*.images.contenthub.dev): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://images.contenthub.dev/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://images.contenthub.dev/..." src="about:blank" title="images.contenthub.dev"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- js-eu1.hs-banner.com (*.js-eu1.hs-banner.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://js-eu1.hs-banner.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://js-eu1.hs-banner.com/..." src="about:blank" title="js-eu1.hs-banner.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- js-eu1.hs-scripts.com (*.js-eu1.hs-scripts.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://js-eu1.hs-scripts.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://js-eu1.hs-scripts.com/..." src="about:blank" title="js-eu1.hs-scripts.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- js-eu1.hscollectedforms.net (*.js-eu1.hscollectedforms.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://js-eu1.hscollectedforms.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://js-eu1.hscollectedforms.net/..." src="about:blank" title="js-eu1.hscollectedforms.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- js-eu1.usemessages.com (*.js-eu1.usemessages.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://js-eu1.usemessages.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://js-eu1.usemessages.com/..." src="about:blank" title="js-eu1.usemessages.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- mgb_magento_cart_count (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="mgb_magento_cart_count"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- mgb_magento_user_name (*.gornergrat.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://gornergrat.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://gornergrat.ch/..." src="about:blank" title="mgb_magento_user_name"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- sdk.fra-01.braze.eu (*.sdk.fra-01.braze.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://sdk.fra-01.braze.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://sdk.fra-01.braze.eu/..." src="about:blank" title="sdk.fra-01.braze.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- static.hsappstatic.net (*.static.hsappstatic.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://static.hsappstatic.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://static.hsappstatic.net/..." src="about:blank" title="static.hsappstatic.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.

## Loader Snippet

```js
window.addEventListener('saferpage-consent-update', function(event) {
  var consent = event.detail || {};
  document.querySelectorAll('script[type="text/plain"][data-saferpage-category][data-src]').forEach(function(node) {
    var category = node.getAttribute('data-saferpage-category');
    if (!consent[category] || node.getAttribute('data-saferpage-loaded') === 'true') return;
    var script = document.createElement('script');
    Array.prototype.slice.call(node.attributes).forEach(function(attr) {
      if (attr.name === 'type' || attr.name === 'data-src' || attr.name === 'data-saferpage-category') return;
      script.setAttribute(attr.name, attr.value);
    });
    script.src = node.getAttribute('data-src');
    script.async = true;
    node.setAttribute('data-saferpage-loaded', 'true');
    node.parentNode.insertBefore(script, node.nextSibling);
  });
  document.querySelectorAll('iframe[data-saferpage-category][data-src]').forEach(function(node) {
    var category = node.getAttribute('data-saferpage-category');
    if (!consent[category] || node.src === node.getAttribute('data-src')) return;
    node.src = node.getAttribute('data-src');
  });
});
```

## GTM Setup
- 1. Consent Initialization: Default Consent Mode vor allen Marketing-/Analytics-Tags auf denied setzen.
- 2. Tag Trigger prüfen: Jeder nicht notwendige Tag braucht Kategoriebedingung aus saferpage_consent_update.
- 3. Unklassifizierte Tags blockieren: Neue oder unbekannte Dienste bleiben aus, bis Kategorie, Zweck und Rechtsgrundlage freigegeben sind.
- 4. Reject/GPC testen: Nach Ablehnen und GPC dürfen keine Marketing-/Analytics-/Embed-Tags nachladen.

## Placeholder
- visual_embeds: Videos, Karten, Captchas und Social Widgets mit Platzhalter anzeigen und erst nach Kategorie-Freigabe laden.
- copy: Dieser externe Inhalt ist blockiert, bis Sie die passende Datenschutz-Kategorie aktivieren.
- preview_limit: Keine externen Preview-Bilder laden, wenn diese bereits Drittanbieter-Kontakte auslösen.
