Fonctionnement
Dans cette section, vous trouverez les commandes JavaScript vous permettant d'interagir avec la CMP sur votre site.
Sirdata CMP fournit une liste de commandes standards décrites dans l'IAB Tech Lab CMP JavaScript API.
Toutes les commandes sont exécutées à travers la fonction API __tcfapi.
__tcfapi
1
window.__tcfapi(command, version, callback, parameter);
Copied!
Le paramètre version correspond à la version de la spécification TCF (= 2).
COMMANDE
CALLBACK
PARAMETRE
DESCRIPTION
ping
function(PingReturn, success)
-
Renvoie des informations sur le statut de chargement de la CMP et le mode d'application du RGPD configuré.
getTCData
function(TCData, success)
vendorIds (int array) - optionnel Liste des IDs des partenaires de la Global Vendor List pour lesquels le consentement est demandé. Si elle est renseignée, TCData incluera uniquement les partenaires de cette liste. Sinon, tous les partenaires de la Global Vendor List seront renvoyés.
Renvoie les TC Data de l'utilisateur.
getVendorList
function(GlobalVendorList, success)
vendorListVersion (int) - optionnel Version de la Global Vendor List à récupérer. Si elle n'est pas renseignée, la version utilisée par Sirdata CMP sera renvoyée. Si la valeur est LATEST, la dernière version disponible sera renvoyée. Si la valeur est invalide, GlobalVendorList sera nul et success sera false.
Renvoie la Global Vendor List contenant les finalités et les partenaires participant au Transparency & Consent Framework.
addEventListener
function(TCData, success)
-
Ajoute une fonction JavaScript à appeler avec les TC Data lorsqu'un évènement CMP se produit. Voir la liste des évènements
removeEventListener
function(success)
listenerId (int) ID du listener à supprimer.
Supprime un listener précédemment ajouté avec la commande addEventListener.

PingReturn

1
{
2
gdprApplies: *Boolean*,
3
cmpLoaded: *Boolean*,
4
cmpStatus: *String*,
5
displayStatus: *String*,
6
apiVersion: '2.0',
7
cmpVersion: *Integer*,
8
cmpId: *Integer*,
9
gvlVersion: *Integer*,
10
tcfPolicyVersion: *Integer*
11
}
Copied!

TCData

1
{
2
tcString: [base64url-encoded] *String*,
3
addtlConsent: *String*,
4
tcfPolicyVersion: *Integer*,
5
cmpId: *Integer*,
6
cmpVersion: *Integer*,
7
gdprApplies: *Boolean*,
8
eventStatus: *String*,
9
cmpStatus: *String*,
10
isServiceSpecific: *Boolean*,
11
useNonStandardStacks: *Boolean*,
12
publisherCC: *String*,
13
purposeOneTreatment: *Boolean*,
14
outOfBand: {
15
allowedVendors: {
16
*vendorId*: *Boolean*,
17
?
18
},
19
disclosedVendors: {
20
*vendorId*: *Boolean*,
21
?
22
}
23
},
24
purpose: {
25
consents: {
26
*purposeId*: *Boolean*,
27
?
28
},
29
legitimateInterests: {
30
*purposeId*: *Boolean*,
31
?
32
}
33
},
34
vendor: {
35
consents: {
36
*vendorId* : *Boolean*,
37
?
38
},
39
legitimateInterests: {
40
*vendorId* : *Boolean*,
41
?
42
}
43
},
44
specialFeatureOptins: {
45
*specialFeatureId*: *Boolean*,
46
?
47
},
48
publisher: {
49
consents: {
50
*purposeId*: *Boolean*,
51
?
52
},
53
legitimateInterests: {
54
*purposeId*: *Boolean*,
55
?
56
},
57
customPurpose: {
58
consents: {
59
*customPurposeId*: *Boolean*,
60
?
61
},
62
legitimateInterests: {
63
*customPurposeId*: *Boolean*,
64
?
65
}
66
},
67
restrictions: {
68
*purposeId*: {
69
*vendorId* : *Integer*,
70
?
71
},
72
?
73
}
74
}
75
}
Copied!

GlobalVendorList

1
{
2
gvlSpecificationVersion: *Integer*,
3
vendorListVersion: *Integer*,
4
tcfPolicyVersion: *Integer*,
5
lastUpdated: *String*,
6
purposes: {
7
*purposeId*: {
8
id: *Integer*,
9
name: *String*,
10
description: *String*,
11
descriptionLegal: *String*,
12
},
13
?
14
},
15
specialPurposes: {
16
*specialPurposeId*: {
17
id: *Integer*,
18
name: *String*,
19
description: *String*,
20
descriptionLegal: *String*,
21
},
22
?
23
},
24
features: {
25
*featureId*: {
26
id: *Integer*,
27
name: *String*,
28
description: *String*,
29
descriptionLegal: *String*,
30
},
31
?
32
},
33
specialFeatures: {
34
*specialFeatureId*: {
35
id: *Integer*,
36
name: *String*,
37
description: *String*,
38
descriptionLegal: *String*,
39
},
40
?
41
},
42
stacks: {
43
*stackId*: {
44
id: *Integer*,
45
name: *String*,
46
description: *String*,
47
purposes: [
48
*Integer*,
49
?
50
],
51
specialFeatures: [
52
*Integer*,
53
?
54
],
55
},
56
?
57
},
58
vendors: {
59
*vendorId*: {
60
{
61
id: *Integer*,
62
name: *String*,
63
purposes: [
64
*Integer*,
65
?
66
],
67
legIntPurposes: [
68
*Integer*,
69
?
70
],
71
flexiblePurposes: [
72
*Integer*,
73
?
74
],
75
specialPurposes: [
76
*Integer*,
77
?
78
],
79
features: [
80
*Integer*,
81
?
82
],
83
specialFeatures: [
84
*Integer*,
85
?
86
],
87
policyUrl: *String*,
88
usesCookies: *Boolean*,
89
cookieMaxAgeSeconds: *Integer*,
90
usesNonCookieAccess: *Boolean*,
91
deviceStorageDisclosureUrl: *String*
92
},
93
?
94
}
95
}
Copied!

Evènements

Vous trouverez dans le tableau ci-dessous la liste des évènements qui peuvent être déclenchés par la CMP :
EVENEMENT
DESCRIPTION
tcloaded
Cet évènement se déclenche lorsque la CMP est chargée, qu'une TC String valide est disponible et que l'UI n'est pas affichée.
cmpuishown
Cet évènement se déclenche lorsque l'UI est affichée ou ré-affichée. S'il n'y a pas de TC String existante pour l'utilisateur, la CMP crée une TC String avec tous les signaux d'intérêt légitime définis à true et tous les signaux de consentement définis à false.
useractioncomplete
Cet évènement se déclenche lorsqu'un utilisateur valide ou re-valide ses choix et que la TC String mise à jour est prête à être exposée.
cmpuiclosed
Cet évènement se déclenche lorsqu'un utilisateur ferme l'UI affichée en cliquant sur le bouton fermer (si activé) et donc que la TC String courante est inchangée par la CMP.
Dernière mise à jour 17d ago