Finalmente pure Iubenda si è adeguata alla gestione di categoria dei Cookie come fanno altri servizi come Cookiebot o OneTrust.
Complice il fatto che è uscita una circolare ufficiale dell’European Data Protection Board che dichiara in modo esplicito e senza alcun dubbio interpretativo che non si è norma GDPR se il consenso NON è granulare e/o se si usa lo scroll come accettazione.
In altre parole da Maggio 2020 è possibile su Iubenda gestire il consenso di categoria in modo granulare. Evviva!
Certo, evviva… ma questo comporta delle leggerissime configurazioni in GTM.
Nella sua gestione standard, Iubenda dispone di 5 categorie:
1
)Finalità incluse:
2
)Finalità incluse:
3
).Finalità incluse:
4
).Finalità incluse:
5
).Finalità incluse:
Oh, che bravi hanno proprio fatto un elenco chiaro e a prova di male interpretazioni. Quindi nel banner apparirà una cosa simile:
Ora che ci è tutto più chiaro iniziamo l’installazione con Google Tag Manager
Ti basta entrare nel profilo e generare lo script attraverso la voce “Cookie Solution“, fare le impostazioni del banner e scrollare più in basso.
Dovresti trovare una text area dove poter copiare il codice proprio come l’immagine qui sotto:
Nel dettaglio il codice sarà una cosa simile a questa
<script type="text/javascript"> var _iub = _iub || []; _iub.csConfiguration = { "consentOnContinuedBrowsing":false, "whitelabel":false, "lang":"it", "siteId":XXXXXXXX, "countryDetection":true, "perPurposeConsent":true, "cookiePolicyId":YYYYYYYYY, "cookiePolicyUrl":"demo.tagmanageitalia.it/esempio/", "banner":{ "acceptButtonDisplay":true, "customizeButtonDisplay":true, "position":"float-top-center", "rejectButtonDisplay":true } }; </script> <script type="text/javascript" src="//cdn.iubenda.com/cs/iubenda_cs.js" charset="UTF-8" async></script>
Ovviamente i parametri in rosso sono dinamici e variano a seconda di come hai configurato la cookie solution su Iubenda e il sito di destinazione (nel mio caso demo.tagmanageritalia.it). Nel mio caso il codice di cookiePolicyId è 20508754 (te lo dico perché lo rivedrai dopo) negli screenshot.
Potresti inoltre avere dei parametri in aggiunta o averne meno. Insomma tutto dipende da quello che configuri.
Ecco un altro esempio:
<script type="text/javascript"> var _iub = _iub || []; _iub.csConfiguration = { "lang": "it", "siteId": XXXXXX, "cookiePolicyId": YYYYYY, "banner": { "position": "float-top-center", "acceptButtonDisplay": true, "customizeButtonDisplay": true }, }; </script> <script type="text/javascript" src="//cdn.iubenda.com/cs/iubenda_cs.js" charset="UTF-8" async></script>
Come vedi i valori in rosso rimangono 🙂
Ora che hai lo script pronto dovrai aggiungere un pezzetto di codice che permetterà di istruire Google Tag Manager quando l’utente accetta o meno una delle cinque categorie. L’istruzione (guarda caso) avverrà attraverso un push nel dataLayer con un evento personalizzato.
La parte in blu è quella da aggiungere al tuo codice. Ci metto pure uno spazio apposta così da non poter sbagliare 🙂
l codice sarà una cosa simile a questa
<script type="text/javascript"> var _iub = _iub || []; _iub.csConfiguration = { "consentOnContinuedBrowsing":false, "whitelabel":false, "lang":"it", "siteId":XXXXXXXX, "countryDetection":true, "perPurposeConsent":true, "cookiePolicyId":YYYYYYYYY, "cookiePolicyUrl":"demo.tagmanageitalia.it/esempio/", "banner":{ "acceptButtonDisplay":true, "customizeButtonDisplay":true, "position":"float-top-center", "rejectButtonDisplay":true }
, callback: { onPreferenceExpressedOrNotNeeded: function(preference) { dataLayer.push({ iubenda_ccpa_opted_out: _iub.cs.api.isCcpaOptedOut() }); if (!preference) { dataLayer.push({ event: "iubenda_preference_not_needed" }); } else { if (preference.consent === true) { dataLayer.push({ event: "iubenda_consent_given" }); } else if (preference.consent === false) { dataLayer.push({ event: "iubenda_consent_rejected" }); } else if (preference.purposes) { for (var purposeId in preference.purposes) { if (preference.purposes[purposeId] && ({{cookie iubenda}} === undefined || {{cookie iubenda}}.indexOf('"' + purposeId + '":true') < 0)){ dataLayer.push({ event: "iubenda_consent_given_purpose_" + purposeId }); } } } } } } }; </script> <script type="text/javascript" src="//cdn.iubenda.com/cs/iubenda_cs.js" charset="UTF-8" async></script>
Ora non ci resta che inserirlo dentro un custom HTML 🙂
Bene ora on ci resta che crearci il nostro bellissimo tag:
Dovresti avere una cosa simile:
Per capire se l’utente ha accettato ile varie categorie di profilazione useremo un #barbatrucco ormai noto. Sappiamo che attraverso un cookie Iubenda si salverà i vari consensi e nei prossimi cambi pagina non farà più apparire la barra della gestione dei cookie.
Con Google Tag Manager è possibile andare a leggere questo cookie. Per semplicità ti dico che il cookie di Iubenda è fatto in questo modo:
_iub_cs-XXX
Dove XXX è il cookiePolicyId di Iubenda, quello dello snippet per capirci. Nel mio caso sarà sempre: 20508754
Quindi non ti resta che creare la Variabile:
Dovresti avere una cosa simile:
Bene, ora se mettiamo in Anteprima di Debug dovrebbe apparirci la barra dei cookie di iubenda. Nel mio esempio ho anche un tag di Google Analytics ancora da bloccare.
Se se accettiamo tutto dovremmo vedere una serie di eventi personalizzati a sinistra e il cookie di iubenda valorizzato,
Nel dettaglio gli eventi si chiamano:
Che originalità 😀
Mentre il cookie avrà un valore del genere:
{"timestamp":"2020-06-11T12:46:23.993Z","version":"1.20.6","purposes":{"1":true,"2":true,"3":true,"4":true,"5":true},"id":20508754}
dunque analizziamo. Per comodità ho già messo in blu le varie tipologie che ci interessano:
Quindi non ci resta che:
Partiamo con la creazione dei 5 attivatori personalizzati.
Sì, lo so… questo è un passaggio semplice ma un po’ monotono (lo dovrai fare 5 volte cambiando il nome).
Il concetto è molto semplice: il numero alla fine identifica la categoria:
Facciamolo per il primo iubenda_consent_given_purpose_1
Dovresti quindi avere una cosa simile:
Ottimo fai la stessa cosa per:
Eccoli tutti assieme
Ottimo, ora creiamo le 5 variabili che ci permetteranno di capire dal Cookie se l’utente ha accettato o no quella specifica categoria. Ci servirà per creare poi gli attivatori negativi universali 🙂
Visto che abbiamo una variabile contenente il Cookie delle preferenze possiamo creare cinque variabili per gestire tutte le categorie di consenso valori. Per farlo useremo un po’ di astuzia e di espressioni regolari 😉
Ecco come dovrebbe essere:
Fai la stessa cosa per gli altri quattro variando il valore dentro il pattern con il numero adatto e ovviamente il nome:
Per il tre
Per il quattro
Per il quinto
Ecco il risultato finale
Uhhh… aspetta, ora te lo dico.
Avremo il valore della preferenza dell’utente ben prima del DOM Ready. In altre parole non ci saranno più problemi nella gestione degli eventi predefiniti di Google Tag Manager (come ad esempio il Page View che dal 10 Giugno 2020 si chiama Container Loaded)
Yuppieeeeeeee!
Ci siamo quasi, ora manca solo la creazione degli attivatori negativi universali e poi la configurazione nei vari tag 🙂
Questo tipo di attivatore ha la particolarità di adattarsi a qualsiasi tipo di evento. Quindi non importa se il tag di Google Analytics o Facebook si dovrà attivare al click, allo scroll e così via. Anche qui ne dovrai creare 5, uno per ogni categoria. La logica dell’attivatore negativo universale è quella di impedire l’accensione grazie agli attivatori in eccezione che è possibile configurare su qualsiasi Tag.
Quindi faremo un attivatore con la logica: se l’utente non ha accettato questa categoria di iubenda.
Difficile? No, ora te lo spiego 🙂
Ottimo ora facciamolo per i restanti 4. Ecco cosa dovresti cambiare
Il secondo:
Il terzo
Il quarto
Il quinto
Yeah! ce l’abbiamo fatta, ora non ci resta che configurare tutti i tag in base alla categoria
Grazie alla combinazione di Attivatori di tipo evento personalizzato e Attivatori negativi universali possiamo gestire tranquillamente qualsiasi tipo di Tag. Ad esempio il classico pageview di Google Analytics potremmo categorizzarlo come Misurazione
Per essere in regola con la GDPR ti basterà semplicemente aggiungere due attivatori:
Ora avvia il debug (ricordati di aggiornare) e BOOM verifica che tutto sia pronto.
Ecco la prova del nove: l’attivatore negativo universale blocca tutto 🙂
Ora, grazie a Google Tag Manager, hai tutte le armi per gestire correttamente il consenso delle categoria con Iubenda nel metodo più ottimizzato possibile 🙂
Cosa ne pensi? Ti è stato utile? Scrivimelo nei commenti!
Buon Tag 😉
Quando qualche anno fa Google Tag Manager lanciò l’Attivatore Visibilità di un Elemento ricordo ancora…
Non credo sia necessario specificare che oggi la maggior parte delle visite e una bella…
Se sei un digital marketer o un digital analyst probabilmente saprai quanto oggi sia importante…
In occasione dell’evento “ECOMMERCE FOOD CONFERENCE” di Bologna, Tag Manager Italia ha condotto una ricerca…
Google Analytics 4 è uno strumento straordinario per raccogliere e analizzare i dati sul comportamento…
Se segui le guide e i webinar di Tag Manager Italia da un po’, probabilmente…
View Comments
Ciao Matteo, ho un dubbio che vedo è stato già espresso tra i commenti. Come dovrei fare con script caricati da plugin? Faccio un esempio banale: l'integrazione di Google Recaptcha V3 di molti plugin per form fa in automatico caricare Roboto da google fonts. Di esempi come questi ce ne sono tanti, possibile non ci sia soluzione?
Sulla tua guida per l'integrazione di Coookiebot un altro utente ha linkato questa pagina di cookiebot (che in realtà ha incontrato subito il tuo scetticismo) dove si parlava di una possibilità di unire i due mondi, quantomeno con cookie bot https://support.cookiebot.com/hc/en-us/articles/360009192739-Google-Tag-Manager-and-Automatic-cookie-blocking
Grazie!
Ciao Manuel, la cosa che puoi fare è inserire dei data attribute nei vari elementi HTML. Il consiglio è chiedere direttamente a chi ha creato i plugin di inserire questa opzione (il data attribute può cambiare da CMP a CMP).
In alternativa puoi valutare di inserire il blocco automatico installando lo script fuori da GTM (occhio che spesso blocca lo stesso GTM).
Fammi sapere se ti ho risposto :)
Ciao, con l'aggiornamento alla versione 1.41.0 mi dà diversi problemi. Non pusha più i dataLayer e i tag con consenso aggiuntivo sembrano scattare da debug ma non creano cookie / beacon / ecc.
Da cosa può essere dovuto?
Ciao, dovresti chiedere all'assistenza di Iubenda e verificare che non ci siano conflitti JavaScript con il sito dove è installato Iubenda.
Fammi sapere
Ciao Matteo, grazie mille per la guida, ma sto riscontrando un piccolo problemino. Voglio inserire un plugin di live chat solo in due pagine (al checkout) e cosi ho messo che il tag si attiva quando Page URL contiene checkout e poi ho messo l'attivatore e l'eccezione come da guida. Con debug funziona tutto correttamente, il problema sorge quando accedo al sito per la prima volta, appare il banner iubenda e clicco su "accetta tutto". Ho notato che il tag viene attivato e la live chat parte, anche se non sono nella pagina checkout. Poi, se ricarico la pagina, il banner non appare e la live chat scompare e appare effettivamente solo sulla pagina di checkout, come dovrebbe essere. Lo stesso succede con tutte le pagine del sito, come se il click sul pulsante "accetta tutto" faccia partire quel tag.
Grazie!
Ciao Marco, ciao verifica il trigger della chat dal debug perché se si attiva il tag significa che il trigger collegato ha tutte le condizioni corrette per essere attivato.
Fammi sapere
Ciao Matteo, ho seguito la guida ma mi sono accorto che in debug la variabile "cookie iubenda" allo step 4 la valorizza sempre come "ubndefined". Come mai? Ti allego un paio di screenshot
il cookie iubenda: https://postimg.cc/PC543Nfz
la debug mode: https://postimg.cc/jCkPxvRN
Grazie mille sempre per le tue guide e il supporto!
Ciao Marco, verifica se effettivamente il cookie di iubenda ha quel codice, lo puoi verificare dal developer tools del browser.
Inoltre finché il cookie non è creato la variabile sarà ovviamente undefined :)
Ciao Matteo ho seguito la tua guida ma i tag mi si attivano 2 volte al containet loaded e all'evento iubenda associato. Non mi sembra di aver saltato passaggi
Ciao è Iubenda che purtroppo lo fa, non è GTM :(
Ciò si verifica quando effettuo una sessione in debug avendo già accettato i cookie. Se invece o cancello i cookie o la effettuo da incognito lì si che mi parte solo 1 volta correttamente
Come già detto è Iubenda che gestisce il nuovo hit :(
Ciao! Ma per la gestione multilingua di iubenda è disponibile un'aggiornamento di questa guida? In particolare per gestire la variabile relativa al cookie proprietario "_iub_cs-XXX" che cambia per ogni lingua (perchè l'id della cookie policy è diverso per ogni lingua). Quindi, per sparare a GA4 gli eventi, mi trovo in difficoltà nel verificare che la variabile contenga ""4":true", dal momento che le variabili sono più di una. Come suggerisci di fare?
Grazie.
Ciao, ma concretamente come va impostata la Lookup table?
Cosa bisogna scrivere nelle righe della tabella?
C'è una guida a riguardo?
Ciao Luca, è molto semplice: dato una variabile di input se il valore matcha con le condizioni riportate nella riga sotto allora restituisci un output.
Trovi diversi esempi in altre guide come questa allo step 3: https://dev.tagmanageritalia.it/guida-avanzata-suddividere-il-traffico-in-analytics-per-ora-locale-con-google-tag-manager/
Ti lascio la guida ufficiale
https://support.google.com/tagmanager/answer/7683362?hl=en#lookup_table
Buon Tag!
Grazie Matteo, sono riuscita, ho usato la variabile Lookup table come hai suggerito :-)
Grande :)
Ciao Sara, puoi gestire l'id con una variabile di tipo Lookup table, così da cambiarla a seconda della lingua del sito :)
Ciao Matteo,
purtroppo sono nella condizione di poter integrare solo Iubenda per decisioni interne, ma grazie alla tua guida tutto funziona regolarmente lato consensi. :)
Facendo un test con Google Consent Mode + Iubenda (al fine di poter gestire il tag di configurazione GA4 con le built-in native), non riesco più a visualizzare nel dL il push relativo allo script da inserire manualmente prima di GTM.
Ovviamente in debug non ho più gli eventi di consenso che tornano visibili solo se implemento tutti gli attivatori, il cookie iubenda di prima parte e il cookie banner con tutte le chiamate callback.
In sostanza, è normale questa non perfetta integrazione della consent mode + Iubenda? Nell'impossibilità di gestione ibrida con consent mode, ma optando per una gestione classica con gli attivatori negativi, il tag di configurazione GA4 va inserito sotto il consenso "Misurazione"?
Grazie
Ciao Massimo, devi verificare se avviene la comunicazione con il consent mode. Lo spiego in questo corso (valuta l'acquisto) con le configurazioni già fatte: https://club.tagmanageritalia.it/corso-clear-consent/
Fammi sapere :)
Ciao Matteo,
ho impostato tutto come da istruzioni, ma credo ci sia un conflitto ad avere sia l'attivatore per tutte le pagine che quello per l'evento di Iubenda,
Iubenda usa solo il loro evento e non quello con tutte le pagine https://www.iubenda.com/it/help/629-google-tag-manager-blocco-cookie.
Usandoli entrambi, al primo accesso tutto a posto dato che ad es. Analytics è spento (cookie = false) e solo all'approvazione triggera.
Facendo un refresh di pagina o accedendo a un'altra pagina ho il caricamento di Analytics subito nel "container loaded" (essendo all pages e consenso = true) e poi Iubenda sembra sempre mandare eventi per le precedenti approvazioni e questo comporta di fatto un nuovo trigger di Analytics.
In GA4 ho infatti 2 pageview.
Va quindi di fatto spenta l'attivazione su tutte le pagine perchè Iubenda manda sempre eventi? E' cambiato qualche cosa da quanto hai scritto la guida? Posso aver impostato qualche cosa in modo errato?
Perdonami ma mi devo rispondere da solo con una bacchettata sulle mani eheh. Ho mischiato i due codici e ho notato solo dopo la modifica nel tuo rispetto all'originale dove si va a verificare l'esistenza del cookie prima di pushare eventi Iubenda.
Modificata quella riga di Js funziona tutto alla perfezione.
Quindi rimane solo da dire un grazie per la guida :)
:D Grazie del feedback Martino ;)
Ciao Matteo,
ma con questo metodo, posso individuare e bloccare anche cookie che vengono installati direttamente da plugin di Wordpress?
Ciao Leila, nope. Puoi gestire tutto quello che è implementato da GTM (cosa che consiglio).
Fammi sapere
Ciao Matteo! Come va? Spero bene. Ho seguito la tua guida e a naso, sembra che sia andato tutto bene (almeno dai primi test, sembra che cookies s'attivino in modo granulare e in base alle scelte degli utenti). L'unica cosa è che non sono riuscito ad inserire la parte di codice in blu ovvero questa:
callback: {
onPreferenceExpressedOrNotNeeded: function(preference) {
dataLayer.push({
iubenda_ccpa_opted_out: _iub.cs.api.isCcpaOptedOut()
});
if (!preference) {
dataLayer.push({
event: "iubenda_preference_not_needed"
});
} else {
if (preference.consent === true) {
dataLayer.push({
event: "iubenda_consent_given"
});
} else if (preference.consent === false) {
dataLayer.push({
event: "iubenda_consent_rejected"
});
} else if (preference.purposes) {
for (var purposeId in preference.purposes) {
if (preference.purposes[purposeId] && ({{cookie iubenda}} === undefined || {{cookie iubenda}}.indexOf('"' + purposeId + '":true') < 0)){
dataLayer.push({
event: "iubenda_consent_given_purpose_" + purposeId
});
}
}
}
}
}
}
Google Tag Manager segnalava degli errori, in particolare in questa riga: onPreferenceExpressedOrNotNeeded: function(preference) {
Come non sono un programmatore, ho fatto a meno di questa cosa e dal momento che ho visto che i cookie scattavano correttamente, ho pensato che forse potevo farne a meno. Secondo, è grave se quelle strisce di codice non ci sono?
Grazie e un saluto!
Ciao Andres,
Lo script aggiuntivo serve a non perdere la prima hit dell'utente quando accetta i cookie che in caso contrario i tag partirebbero solamente al ricaricamento della pagina.
Nello script che hai inserito tu il problema dovrebbero essere le virgolette che sono presenti nello script, assicurati di copiare il codice così com'è e inserirlo nel Tag di GTM e vedrai che funzionerà :)
Fammi sapere!