Questo documento illustra le autorizzazioni per i modelli personalizzati lato server.
Ogni autorizzazione è:
- Controllate dalle API che le richiedono.
- Rilevato automaticamente in JavaScript con sandbox, in base alle API utilizzate. Questo accade quando vengono apportate modifiche nell'editor dei modelli personalizzati (per un loop di feedback rapido) e quando il codice viene compilato (per verificare che vengano applicate le autorizzazioni corrette).
- Modificabile nell'editor dei modelli personalizzati per rendere l'autorizzazione più specifica.
- Possono essere sottoposti a query in JavaScript in sandbox tramite l'API queryPermission.
access_bigquery
Nome visualizzato: Accedi a BigQuery
Descrizione: consente l'accesso a BigQuery sulla piattaforma Google Cloud.
Configurazione:opzione per consentire l'utilizzo di combinazioni di progetti, set di dati e tabelle specificati con BigQuery. L'impostazione di una configurazione dell'ID progetto su GOOGLE_CLOUD_PROJECT consente di utilizzare la variabile di ambiente GOOGLE_CLOUD_PROJECT come ID progetto quando projectId è escluso da BigQuery API
parameter.
Obbligatorio da: BigQuery
Firma della query:
queryPermission('access_bigquery', <operation>, <options>)
Note: <operation> è una stringa e può avere i seguenti valori:
- write
<options> è un oggetto contenente i seguenti elementi:
{
  'projectId': <project_id>,
  'datasetId': <dataset_id>,
  'tableId': <table_id>
}
Esempio di codice
const BigQuery = require('BigQuery');
const queryPermission = require('queryPermission');
const connectionInfo = {
  'projectId': 'gcp-cloud-project-id',
  'datasetId': 'destination-dataset',
  'tableId': 'destination-table',
};
if (queryPermission('access_bigquery', 'write', connectionInfo)) {
  const rows = [{
    'column1': 'String1',
    'column2': 1234,
  }];
  const options = {
    'ignoreUnknownValues': true,
    'skipInvalidRows': false,
  };
  BigQuery.insert(connectionInfo, rows, options)
      .then(data.gtmOnSuccess, data.gtmOnFailure);
}
access_firestore
Nome visualizzato: accede a Google Firestore
Descrizione: consente l'accesso a Google Firestore.
Configurazione: opzione per consentire l'utilizzo con Firestore di combinazioni di progetti e percorsi specificati (supportata la sintassi dei caratteri jolly). L'impostazione di una configurazione dell'ID progetto di GOOGLE_CLOUD_PROJECT consente di utilizzare la variabile di ambiente GOOGLE_CLOUD_PROJECT come ID progetto quando projectId è escluso da Firestore API parameter.
Obbligatorio da: Firestore
Firma della query:
queryPermission('access_firestore', <operation>, <options>)
Note: <operation> è una stringa e può avere i seguenti valori:
- read: concede l'accesso alle API di lettura e query
- write: concede l'accesso in scrittura all'API
- read_write: concede l'accesso in lettura, scrittura e query alle API
<options> è un oggetto contenente i seguenti elementi:
{
  'projectId': <project_id>,
  'path': <path>
}
Esempio di codice
const Firestore = require('Firestore');
const queryPermission = require('queryPermission');
const options = {
  'projectId': 'gcp-cloud-project-id',
  'path': 'collection/document',
};
if (queryPermission('access_firestore', 'read', options)) {
  Firestore.read('collection/document', {
    projectId: 'gcp-cloud-project-id',
  }).then(data.gtmOnSuccess, data.gtmOnFailure);
}
access_response
Nome visualizzato: Accede alla risposta
Descrizione: accede al corpo, alle intestazioni o allo stato della risposta.
Configurazione:opzione per consentire l'accesso a qualsiasi utente o a utenti specifici, con sottoopzioni per controllare l'accesso a vari componenti secondari.
Obbligatorio per: setPixelResponse, setResponseBody,
setResponseHeader, setResponseStatus
Firma della query:
queryPermission('access_response', 'write', <component>[, <optional component name>])
Note:regola se è possibile accedere al componente della risposta HTTP in uscita.
Esempio di codice
const queryPermission = require('queryPermission');
const setResponseBody = require('setResponseBody');
const setResponseHeader = require('setResponseHeader');
const setResponseStatus = require('setResponseStatus');
if (queryPermission('access_response', 'write', 'header', 'Content-Type')) {
  setResponseHeader('Content-Type', 'text/plain');
}
if (queryPermission('access_response', 'write', 'body')) {
  setResponseBody('Not Found');
}
if (queryPermission('access_response', 'write', 'status')) {
  setResponseStatus(404);
}
access_template_storage
Nome visualizzato: Accede allo spazio di archiviazione del modello
Descrizione: consente l'accesso allo spazio di archiviazione temporaneo per i modelli che possono rimanere invariati per tutta la durata del processo lato server.
Configurazione: nessuna
Obbligatorio da: templateDataStorage
Firma della query: queryPermission('access_template_storage')
Esempio di codice
const queryPermission = require('queryPermission');
const templateDataStorage = require('templateDataStorage');
const key = 'my_key';
if (queryPermission('access_template_storage')) {
  const value = templateDataStorage.getItemCopy(key);
}
get_cookies
Nome visualizzato: legge i valori dei cookie
Descrizione: legge i valori dei cookie con il nome specificato.
Configurazione:elenco dei nomi dei cookie consentiti per la lettura.
Obbligatorio da: getCookieValues
Firma della query: queryPermission('get_cookies', <name>)
Note:regola la possibilità di leggere un cookie, a seconda del nome.
Esempio di codice
const queryPermission = require('queryPermission');
const getCookieValues = require('getCookieValues');
const cookieName = 'info';
let cookieValues;
if (queryPermission('get_cookies', cookieName)) {
  cookieValues = getCookieValues(cookieName);
}
logging
Nome visualizzato: Registra messaggi nella console
Descrizione: registra messaggi nella console sviluppatori e attiva la modalità di anteprima di Tag Manager.
Configurazione:opzione per attivare il logging in produzione. Il valore predefinito è attivare solo il logging in modalità di debug/anteprima. Se l'autorizzazione viene rifiutata, logToConsole non genererà un errore, ma eliminerà il messaggio di log.
Obbligatorio da: logToConsole
Firma della query: queryPermission('logging')
Note:controlla se un modello personalizzato può accedere alla Console dello sviluppatore.
Esempio di codice
const queryPermission = require('queryPermission');
const logToConsole = require('logToConsole');
// Note that it's fine to call log, since the log call will be ignored if
// logging isn't permitted in the current environment.
logToConsole('diagnostic info');
use_message
Nome visualizzato: Utilizza i messaggi
Descrizione: invia o riceve messaggi utilizzando le API addMessageListener o
sendMessage.
Configurazione:opzione per specificare il tipo di messaggio e se il modello può ascoltare, inviare o entrambe le cose.
Obbligatorio per: addMessageListener, sendMessage
Firma della query: queryPermission('use_message', <usage>, <message type>)
Note: il valore di utilizzo può essere listen, send o listen_and_send.
Esempio di codice
const queryPermission = require('queryPermission');
const sendMessage = require('sendMessage');
if (queryPermission('use_message', 'send', 'set_cookie')) {
  sendMessage('set_cookie', {name: 'foo', value: 'bar'});
}
read_container_data
Nome visualizzato: legge i dati del contenitore
Descrizione: legge i dati relativi al contenitore.
Configurazione: nessuna.
Obbligatorio per: getClientName, getContainerVersion
Firma della query: queryPermission('read_container_data')
Note:controlla se un modello personalizzato può leggere i dati del contenitore.
Esempio di codice
const getContainerVersion = require('getContainerVersion');
const queryPermission = require('queryPermission');
if (queryPermission('read_container_data')) {
  return getContainerVersion();
}
read_event_data
Nome visualizzato:legge i dati sugli eventi
Descrizione: legge i dati dall'evento.
Configurazione: opzione per consentire qualsiasi accesso o accesso specifico controllato da un elenco di percorsi delle chiavi consentiti (sintassi di caratteri jolly supportata).
Obbligatorio per: getAllEventData, getEventData
Firma della query: queryPermission('read_event_data'[, <optional key>])
Note:controlla se un modello personalizzato può leggere i dati sugli eventi in un determinato percorso della chiave (o tutti i dati sugli eventi, se non viene specificato alcun percorso della chiave).
Esempio di codice
const getAllEventData = require('getAllEventData');
const queryPermission = require('queryPermission');
if (queryPermission('read_event_data')) {
  return getAllEventData();
}
const getEventData = require('getEventData');
const queryPermission = require('queryPermission');
const keyPath = 'parentField.childField';
if (queryPermission('read_event_data', keyPath)) {
  return getEventData(keyPath);
}
read_event_metadata
Nome visualizzato: legge i metadati degli eventi
Descrizione: legge i metadati degli eventi nei callback eventi
Configurazione: nessuna
Obbligatorio da: addEventCallback
Firma della query: queryPermission('read_event_metadata')
Note:consente di stabilire se un modello personalizzato può leggere i metadati degli eventi nei callback.
Esempio di codice
const queryPermission = require('queryPermission');
const addEventCallback = require('addEventCallback');
if (queryPermission('read_event_metadata')) {
  addEventCallback((containerId, eventMetadata) => {
    // Read event metadata.
  });
}
read_request
Nome visualizzato: legge la richiesta HTTP
Descrizione: legge le intestazioni delle richieste, i parametri di query, il corpo, il percorso o l'indirizzo IP remoto.
Configurazione:opzione per consentire l'accesso a qualsiasi utente o a utenti specifici, con sottoopzioni per controllare l'accesso a vari componenti secondari.
Obbligatorio per: extractEventsFromMpv1, extractEventsFromMpv2,
getRemoteAddress, getRequestBody, getRequestHeader,
getRequestPath, getRequestQueryParameter, getRequestQueryParameters,
getRequestQueryString
Firma della query:
queryPermission('read_request', <component>[, <optional component name>])
Note:regola se è possibile accedere al componente della risposta HTTP in arrivo.
Esempio di codice
const queryPermission = require('queryPermission');
const getRequestBody = require('getRequestBody');
const getRequestHeader = require('getRequestHeader');
let body, contentType;
if (queryPermission('read_request', 'body')) {
  body = getRequestBody();
}
if (queryPermission('read_request', 'header', 'content-type')) {
  contentType = getRequestHeader('content-type');
}
if (body && contentType == 'application/json') { ... }
return_response
Nome visualizzato: restituisce la risposta
Descrizione: restituisce la risposta al chiamante.
Configurazione: nessuna
Obbligatorio da: returnResponse
Firma della query: queryPermission('return_response')
Note: questa autorizzazione non ha campi da restringere e in genere non viene eseguita alcuna query.
run_container
Nome visualizzato: Esegue il contenitore
Descrizione: esegue il contenitore con un evento
Configurazione: nessuna
Obbligatorio da: runContainer
Firma della query: queryPermission('run_container')
Note: questa autorizzazione non ha campi da restringere e in genere non viene eseguita alcuna query.
send_http
Nome visualizzato: invia richieste HTTP
Descrizione: invia una richiesta HTTP a un URL specificato.
Obbligatorio per: getGoogleScript, sendEventToGoogleAnalytics,
sendHttpGet, sendHttpRequest
Firma della query: queryPermission('send_http', <url>)
Note:regola la possibilità di effettuare una richiesta HTTP, a seconda dell'URL. Per garantire una connessione sicura, sono consentiti solo gli URL sicuri (HTTPS).
Esempio di codice
const queryPermission = require('queryPermission');
const sendHttpGet = require('sendHttpGet');
const url = 'https://example.com/search?query=foo&results=10';
if (queryPermission('send_http', url)) {
  sendHttpGet(url);
}
send_pixel_from_browser
Nome visualizzato: Invia pixel dai browser
Descrizione: invia dal browser una richiesta GET a un URL specifico.
Obbligatorio da: sendPixelFromBrowser
Firma della query: queryPermission('send_pixel_from_browser', <url>)
Note:regola se una richiesta può essere inviata dal browser, a seconda dell'URL.
Esempio di codice
const queryPermission = require('queryPermission');
const sendPixelFromBrowser = require('sendPixelFromBrowser');
const url = 'https://example.com/search?query=foo&results=10';
if (queryPermission('send_pixel_from_browser', url)) {
  sendPixelFromBrowser(url);
}
set_cookies
Nome visualizzato:imposta un cookie
Descrizione: imposta un cookie con il nome e i parametri specificati.
Configurazione:una tabella dei nomi dei cookie consentiti, ciascuno con limitazioni facoltative su nome, dominio, percorso, attributo secure e scadenza.
Obbligatorio da: setCookie
Firma della query: queryPermission('set_cookies', <name>, <options>)
Note: regola se è possibile aggiungere un'intestazione "Set-Cookie" alla risposta, a seconda del nome, del dominio, del percorso, dell'attributo secure e della scadenza del cookie.
Esempio di codice
const queryPermission = require('queryPermission');
const setCookie = require('setCookie');
const options = {
  'domain': 'www.example.com',
  'path': '/',
  'max-age': 60*60*24*365,
  'secure': true
};
if (queryPermission('set_cookies', 'info', options)) {
  setCookie('info', 'xyz', options);
}
use_custom_private_keys
Nome visualizzato: utilizza chiavi private personalizzate
Descrizione: utilizza le chiavi private contenute in un file di chiavi JSON per le operazioni crittografiche.
Configurazione:un elenco di ID chiave consentiti. Gli ID devono corrispondere alle chiavi nel
file di chiavi JSON a cui fa riferimento la variabile di ambiente SGTM_CREDENTIALS
sul server.
Obbligatorio da: hmacSha256
Firma della query: queryPermission('use_custom_private_keys', <key id>)
Note:regola l'elenco delle chiavi private consentite.
Esempio di codice
const hmacSha256= require('hmacSha256');
const queryPermission = require('queryPermission');
const keyId = 'key1';
let result;
if (queryPermission('use_custom_private_keys', keyId)) {
  result = hmacSha256('my_data', keyId);
}
use_google_credentials
Nome visualizzato: utilizza le Credenziali predefinite dell'applicazione Google
Descrizione: utilizza le credenziali predefinite di Google per effettuare chiamate alle API di Google.
Configurazione:un elenco di ambiti OAuth 2.0 di Google consentiti.
Obbligatorio da: getGoogleAuth
Firma della query: queryPermission('use_google_credentials', <scopes>)
Note: limita gli ambiti OAuth 2.0 di Google consentiti per l'utilizzo con le API di Google.
Esempio di codice
const getGoogleAuth = require('getGoogleAuth');
const queryPermission = require('queryPermission');
const scopes = [
  'https://www.googleapis.com/auth/datastore'
];
let auth;
if (queryPermission('use_google_credentials', scopes)) {
  auth = getGoogleAuth(scopes);
}