# Consent-Auto-Blocking für wajos.de

wajos.de: 33 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
- __cf_bm (*.hcaptcha.com): Kategorie externe_medien, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="externe_medien" data-src="https://hcaptcha.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="externe_medien" data-src="https://hcaptcha.com/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.externe_medien equals true.
- Google DoubleClick (*.ad.doubleclick.net): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://ad.doubleclick.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://ad.doubleclick.net/..." src="about:blank" title="Google DoubleClick"></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.
- _shopify_marketing (*.wajos.de): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://wajos.de/..." src="about:blank" title="_shopify_marketing"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- hCaptcha (*.2d5eb85fe397.w.hcaptcha.com): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://2d5eb85fe397.w.hcaptcha.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://2d5eb85fe397.w.hcaptcha.com/..." src="about:blank" title="hCaptcha"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- _shopify_analytics (*.wajos.de): Kategorie statistik, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="statistik" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="statistik" data-src="https://wajos.de/..." src="about:blank" title="_shopify_analytics"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.statistik equals true.
- __cf_bm (*.rdrct.li): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://rdrct.li/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://rdrct.li/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- __kla_id (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="__kla_id"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _gcl_au (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="_gcl_au"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _pandectes_gdpr (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="_pandectes_gdpr"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _shop_app_essential (*.shop.app): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://shop.app/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://shop.app/..." src="about:blank" title="_shop_app_essential"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _shopify_essential (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="_shopify_essential"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _shopify_s (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="_shopify_s"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _shopify_y (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="_shopify_y"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- a.klaviyo.com (*.a.klaviyo.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://a.klaviyo.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://a.klaviyo.com/..." src="about:blank" title="a.klaviyo.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- api.chatarmin.com (*.api.chatarmin.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://api.chatarmin.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://api.chatarmin.com/..." src="about:blank" title="api.chatarmin.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- api.powl.io (*.api.powl.io): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://api.powl.io/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://api.powl.io/..." src="about:blank" title="api.powl.io"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- api.qrserver.com (*.api.qrserver.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://api.qrserver.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://api.qrserver.com/..." src="about:blank" title="api.qrserver.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- armin-files.s3.eu-central-1.amazonaws.com (*.armin-files.s3.eu-central-1.amazonaws.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://armin-files.s3.eu-central-1.amazonaws.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://armin-files.s3.eu-central-1.amazonaws.com/..." src="about:blank" title="armin-files.s3.eu-central-1.amazonaws.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cart_currency (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="cart_currency"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cdn.boostcommerce.io (*.cdn.boostcommerce.io): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn.boostcommerce.io/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn.boostcommerce.io/..." src="about:blank" title="cdn.boostcommerce.io"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cdn.judge.me (*.cdn.judge.me): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn.judge.me/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn.judge.me/..." src="about:blank" title="cdn.judge.me"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cdn.powl.io (*.cdn.powl.io): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn.powl.io/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn.powl.io/..." src="about:blank" title="cdn.powl.io"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cdn.shopify.com (*.cdn.shopify.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn.shopify.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn.shopify.com/..." src="about:blank" title="cdn.shopify.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- customized-whatsapp-widget.chatarmin.com (*.customized-whatsapp-widget.chatarmin.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://customized-whatsapp-widget.chatarmin.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://customized-whatsapp-widget.chatarmin.com/..." src="about:blank" title="customized-whatsapp-widget.chatarmin.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- d2wy8f7a9ursnm.cloudfront.net (*.d2wy8f7a9ursnm.cloudfront.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://d2wy8f7a9ursnm.cloudfront.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://d2wy8f7a9ursnm.cloudfront.net/..." src="about:blank" title="d2wy8f7a9ursnm.cloudfront.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- google.com (*.google.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://google.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://google.com/..." src="about:blank" title="google.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- localization (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="localization"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- otlp-http-production.shopifysvc.com (*.otlp-http-production.shopifysvc.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://otlp-http-production.shopifysvc.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://otlp-http-production.shopifysvc.com/..." src="about:blank" title="otlp-http-production.shopifysvc.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- po_visitor (*.wajos.de): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://wajos.de/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://wajos.de/..." src="about:blank" title="po_visitor"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- static-tracking.klaviyo.com (*.static-tracking.klaviyo.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://static-tracking.klaviyo.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://static-tracking.klaviyo.com/..." src="about:blank" title="static-tracking.klaviyo.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- static.growave.io (*.static.growave.io): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://static.growave.io/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://static.growave.io/..." src="about:blank" title="static.growave.io"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- static.klaviyo.com (*.static.klaviyo.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://static.klaviyo.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://static.klaviyo.com/..." src="about:blank" title="static.klaviyo.com"></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.
