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

caritas.ch: 30 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 (*.fonts.net): Kategorie externe_medien, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="externe_medien" data-src="https://fonts.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="externe_medien" data-src="https://fonts.net/..." src="about:blank" title="__cf_bm"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.externe_medien equals true.
- fast.fonts.net (*.fast.fonts.net): Kategorie externe_medien, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="externe_medien" data-src="https://fast.fonts.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="externe_medien" data-src="https://fast.fonts.net/..." src="about:blank" title="fast.fonts.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.externe_medien 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.
- Meta/Facebook (*.connect.facebook.net): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://connect.facebook.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://connect.facebook.net/..." src="about:blank" title="Meta/Facebook"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- Meta/Facebook (*.facebook.com): Kategorie marketing, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="marketing" data-src="https://facebook.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="marketing" data-src="https://facebook.com/..." src="about:blank" title="Meta/Facebook"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.marketing equals true.
- C (*.adform.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://adform.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://adform.net/..." src="about:blank" title="C"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _fbp (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_fbp"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vis_opt_s (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vis_opt_s"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vis_opt_test_cookie (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vis_opt_test_cookie"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vwo_ds (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vwo_ds"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vwo_sn (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vwo_sn"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vwo_uuid (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vwo_uuid"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- _vwo_uuid_v2 (*.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://caritas.ch/..." src="about:blank" title="_vwo_uuid_v2"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- acdn.adnxs.com (*.acdn.adnxs.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://acdn.adnxs.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://acdn.adnxs.com/..." src="about:blank" title="acdn.adnxs.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- app.usercentrics.eu (*.app.usercentrics.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://app.usercentrics.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://app.usercentrics.eu/..." src="about:blank" title="app.usercentrics.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- assets.caritas.ch (*.assets.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://assets.caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://assets.caritas.ch/..." src="about:blank" title="assets.caritas.ch"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- capi-automation.s3.us-east-2.amazonaws.com (*.capi-automation.s3.us-east-2.amazonaws.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://capi-automation.s3.us-east-2.amazonaws.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://capi-automation.s3.us-east-2.amazonaws.com/..." src="about:blank" title="capi-automation.s3.us-east-2.amazonaws.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cms.caritas.ch (*.cms.caritas.ch): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cms.caritas.ch/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cms.caritas.ch/..." src="about:blank" title="cms.caritas.ch"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- consent-api.service.consent.usercentrics.eu (*.consent-api.service.consent.usercentrics.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://consent-api.service.consent.usercentrics.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://consent-api.service.consent.usercentrics.eu/..." src="about:blank" title="consent-api.service.consent.usercentrics.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- cse.google.com (*.cse.google.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cse.google.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cse.google.com/..." src="about:blank" title="cse.google.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- dev.visualwebsiteoptimizer.com (*.dev.visualwebsiteoptimizer.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://dev.visualwebsiteoptimizer.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://dev.visualwebsiteoptimizer.com/..." src="about:blank" title="dev.visualwebsiteoptimizer.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- diffuser-cdn.app-us1.com (*.diffuser-cdn.app-us1.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://diffuser-cdn.app-us1.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://diffuser-cdn.app-us1.com/..." src="about:blank" title="diffuser-cdn.app-us1.com"></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.
- ib.adnxs.com (*.ib.adnxs.com): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://ib.adnxs.com/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://ib.adnxs.com/..." src="about:blank" title="ib.adnxs.com"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- jsDelivr (*.cdn.jsdelivr.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://cdn.jsdelivr.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://cdn.jsdelivr.net/..." src="about:blank" title="jsDelivr"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- track.adform.net (*.track.adform.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://track.adform.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://track.adform.net/..." src="about:blank" title="track.adform.net"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- uct.service.usercentrics.eu (*.uct.service.usercentrics.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://uct.service.usercentrics.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://uct.service.usercentrics.eu/..." src="about:blank" title="uct.service.usercentrics.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- uid (*.adform.net): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://adform.net/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://adform.net/..." src="about:blank" title="uid"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- v1.api.service.cmp.usercentrics.eu (*.v1.api.service.cmp.usercentrics.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://v1.api.service.cmp.usercentrics.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://v1.api.service.cmp.usercentrics.eu/..." src="about:blank" title="v1.api.service.cmp.usercentrics.eu"></iframe>`
  GTM: Fire only when event equals saferpage_consent_update and consent.unklar equals true.
- web.cmp.usercentrics.eu (*.web.cmp.usercentrics.eu): Kategorie unklar, Default blocked.
  Script: `<script type="text/plain" data-saferpage-category="unklar" data-src="https://web.cmp.usercentrics.eu/..."></script>`
  Iframe: `<iframe data-saferpage-category="unklar" data-src="https://web.cmp.usercentrics.eu/..." src="about:blank" title="web.cmp.usercentrics.eu"></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.
