В этом документе описаны API для серверной разметки.
addEventCallback
Регистрирует функцию обратного вызова, которая будет вызвана по завершении события. Функция обратного вызова будет вызвана после выполнения всех тегов события. В функцию обратного вызова передаются два значения: идентификатор контейнера, вызывающего функцию, и объект, содержащий информацию о событии.
При использовании этого API в теге он связывается с текущим событием. При использовании этого API в клиенте его необходимо привязать к конкретному событию с помощью функции bindToEvent API runContainer . Дополнительные сведения см. в примере .
Синтаксис
const addEventCallback = require('addEventCallback');
addEventCallback((containerId, eventData) => {
// Take some action based on the event data.
});
Параметры
| Параметр | Тип | Описание |
|---|---|---|
callback | функция | Функция, которая будет вызвана в конце события. |
Объект eventData содержит следующие данные:
| Имя ключа | Тип | Описание |
|---|---|---|
tags | Множество | Массив объектов данных тегов. Каждый тег, сработавший во время события, будет иметь запись в этом массиве. Объект данных тега содержит идентификатор тега ( id ), статус выполнения ( status ) и время выполнения ( executionTime ). Данные тега также будут включать дополнительные метаданные тега, настроенные для тега. |
У клиента:
const addEventCallback = require('addEventCallback');
const claimRequest = require('claimRequest');
const extractEventsFromMpv1 = require('extractEventsFromMpv1');
const logToConsole = require('logToConsole');
const returnResponse = require('returnResponse');
const runContainer = require('runContainer');
claimRequest();
const events = extractEventsFromMpv1();
let eventsCompleted = 0;
events.forEach((evt, i) => {
runContainer(evt, /* onComplete= */ (bindToEvent) => {
bindToEvent(addEventCallback)((containerId, eventData) => {
logToConsole('Event Number: ' + i);
eventData.tags.forEach((tag) => {
logToConsole('Tag ID: ' + tag.id);
logToConsole('Tag Status: ' + tag.status);
logToConsole('Tag Execution Time: ' + tag.executionTime);
});
});
if (events.length === ++eventsCompleted) {
returnResponse();
}
});
});
В теге:
const addEventCallback = require('addEventCallback');
addEventCallback((containerId, eventData) => {
// This will be called at the end of the current event.
});
Соответствующие разрешения
callLater
Планирует асинхронный вызов функции. Функция будет вызвана после возврата из текущего кода. Это эквивалентно вызову setTimeout(<function>, 0) .
Пример
const callLater = require('callLater');
const logToConsole = require('logToConsole');
callLater(() => {
logToConsole('Logged asynchronously');
});
Синтаксис
callLater(function)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
function | функция | Функция, которую нужно вызвать. |
Соответствующие разрешения
Никто.
claimRequest
Используйте этот API в клиенте для подтверждения запроса. После подтверждения запроса контейнер не сможет запускать дополнительные клиенты.
Этот API генерирует исключение, если вызывается внутри тега или переменной. Этот API генерирует исключение, если вызывается после возврата клиента (например, если вызывается в асинхронном коллбэке, таком как callLater или функция onComplete runContainer ).
Перед вызовом API runContainer клиент должен подтвердить запрос, используя этот API.
Пример
const claimRequest = require('claimRequest');
claimRequest();
Синтаксис
claimRequest();
Соответствующие разрешения
Никто.
computeEffectiveTldPlusOne
Возвращает эффективный домен верхнего уровня + 1 (eTLD+1) заданного домена или URL. eTLD+1 вычисляется путем сравнения домена с правилами публичного списка суффиксов . eTLD+1 обычно представляет собой домен самого высокого уровня, для которого можно установить cookie.
Если аргумент равен null или undefined, то значение аргумента возвращается без изменений. В противном случае аргумент преобразуется в строку. Если аргумент не является допустимым доменом или URL-адресом, то возвращается пустая строка. Если сервер не может получить список общедоступных суффиксов, то значение аргумента возвращается без изменений.
Пример
const computeEffectiveTldPlusOne = require('computeEffectiveTldPlusOne');
// Returns 'example.co.uk'
computeEffectiveTldPlusOne('analytics.example.co.uk');
// Returns 'example.co.uk'
computeEffectiveTldPlusOne('https://analytics.example.co.uk/path');
Синтаксис
computeEffectiveTldPlusOne(domainOrUrl);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
domainOrUrl | нить | Домен или URL-адрес, для которого вычисляется eTLD+1. |
Соответствующие разрешения
Никто.
createRegex
Создает новый экземпляр регулярного выражения и возвращает его, обернутый в объект. Вы не можете получить доступ к регулярному выражению напрямую. Однако вы можете передать его в API testRegex , а также в методы String.replace() , String.match() и String.search() .
Возвращает null если регулярное выражение недействительно или Re2 недоступен на сервере.
Этот API использует реализацию Re2 . Образ Docker сервера должен быть версии 2.0.0 или более поздней.
Пример
const createRegex = require('createRegex');
const domainRegex = createRegex('\\w+\\.com', 'i');
// Returns '/foobar'
'example.com/foobar'.replace(domainRegex, '');
Синтаксис
createRegex(pattern, flags);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
pattern | нить | Текст регулярного выражения. |
flags | нить | Необязательная строка, содержащая флаги для создаваемого регулярного выражения. Поддерживаются `g` (глобальный) и `i` (игнорировать регистр). Все остальные символы игнорируются без уведомления. |
Соответствующие разрешения
Никто.
Минимальная версия изображения
decodeUri
Декодирует все закодированные символы в предоставленном URI. Возвращает строку , представляющую декодированный URI. Возвращает undefined если предоставлен недопустимый ввод.
Пример
const decodeUri = require('decodeUri');
const decodedUrl = decodeUri(data.encodedUrl);
if (decodedUrl) {
// ...
}
Синтаксис
decodeUri(encoded_uri);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
encoded_uri | нить | URI, закодированный с помощью encodeUri() или иным способом. |
Соответствующие разрешения
Никто.
decodeUriComponent
Декодирует все закодированные символы в предоставленном компоненте URI. Возвращает строку , представляющую декодированный компонент URI. Возвращает undefined при получении недопустимых входных данных.
Пример
const decodeUriComponent = require('decodeUriComponent');
const decodedQuery = decodeUriComponent(data.query);
if (decodedQuery) {
// ...
}
Синтаксис
decodeUriComponent(encoded_uri_component);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
encoded_uri_component | нить | Компонент URI, закодированный с помощью encodeUriComponent() или иным способом. |
Соответствующие разрешения
Никто.
encodeUri
Возвращает закодированный унифицированный идентификатор ресурса (URI) путем экранирования специальных символов. Возвращает строку , представляющую предоставленную строку, закодированную как URI.
Пример
const encodeUri = require('encodeUri');
const sendHttpGet = require('sendHttpGet');
sendHttpGet('https://www.example.com/' + encodeUri(pathInput));
Синтаксис
encodeUri(uri);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
uri | нить | Полный URI. |
Соответствующие разрешения
Никто.
encodeUriComponent
Возвращает закодированный унифицированный идентификатор ресурса (URI) путем экранирования специальных символов. Возвращает строку , представляющую предоставленную строку, закодированную как URI.
Пример
const encodeUriComponent = require('encodeUriComponent');
const sendHttpGet = require('sendHttpGet');
sendHttpGet('https://www.example.com/?' + encodeUriComponent(queryInput));
Синтаксис
encodeUriComponent(str);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
str | нить | Компонент URI. |
Соответствующие разрешения
Никто.
extractEventsFromMpv1
Преобразует входящий запрос протокола Measurement Protocol V1 в список событий в формате Unified Schema. Возвращает список извлеченных событий. Генерирует ошибку, если запрос имеет неправильный формат.
Пример
const extractEventsFromMpv1 = require('extractEventsFromMpv1');
const isRequestMpv1 = require('isRequestMpv1');
if (isRequestMpv1()) {
const events = extractEventsFromMpv1();
for (let i = 0; i < events.length; ++i) {
const event = events[i];
// Process event.
}
}
Синтаксис
extractEventsFromMpv1();
Соответствующие разрешения
Требуется разрешение read_request ). Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
body -
query parameters
extractEventsFromMpv2
Преобразует входящий запрос протокола Measurement Protocol V2 в список событий в формате Unified Schema. Возвращает список извлеченных событий. Генерирует ошибку, если запрос имеет неправильный формат.
Пример
const extractEventsFromMpv2 = require('extractEventsFromMpv2');
const isRequestMpv2 = require('isRequestMpv2');
if (isRequestMpv2()) {
const events = extractEventsFromMpv2();
for (let i = 0; i < events.length; ++i) {
const event = events[i];
// Process event.
}
}
Синтаксис
extractEventsFromMpv2();
Соответствующие разрешения
Требуется разрешение read_request ). Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
body -
query parameters
fromBase64
Декодирует строку, закодированную в формате Base64. Возвращает undefined если входные данные недействительны.
Синтаксис
fromBase64(base64EncodedString);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
base64EncodedString | нить | Строка, закодированная в Base64. |
Пример
const fromBase64 = require('fromBase64');
const greeting = fromBase64('aGVsbG8=');
if (greeting === 'hello') {
// ...
}
Соответствующие разрешения
Никто.
generateRandom
Возвращает случайное число (целое число) в заданном диапазоне.
Пример
const generateRandom = require('generateRandom');
const randomValue = generateRandom(0, 10000000);
Синтаксис
generateRandom(min, max);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
min | число | Минимальное потенциальное значение возвращаемого целого числа (включительно). |
max | число | Максимально возможное значение возвращаемого целого числа (включительно). |
Соответствующие разрешения
Никто.
getAllEventData
Возвращает копию данных события.
Синтаксис
getAllEventData();
Соответствующие разрешения
getClientName
Возвращает строку , содержащую имя текущего клиента.
Синтаксис
getClientName();
Соответствующие разрешения
getContainerVersion
Возвращает объект , содержащий данные о текущем контейнере. Возвращаемый объект будет иметь следующие поля:
{
containerId: string,
debugMode: boolean,
environmentName: string,
environmentMode: boolean,
previewMode: boolean,
version: string,
}
Пример
const getContainerVersion = require('getContainerVersion');
const containerVersion = getContainerVersion();
const containerId = containerVersion['containerId'];
const isDebug = containerVersion['debugMode'];
Синтаксис
getContainerVersion();
Соответствующие разрешения
getCookieValues
Возвращает массив, содержащий значения всех файлов cookie с заданным именем.
Пример
const getCookieValues = require('getCookieValues');
const lastVisit = getCookieValues('lastVisit')[0];
if (lastVisit) {
// ...
}
Синтаксис
getCookieValues(name[, noDecode]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
name | нить | Название файла cookie. |
noDecode | логический | Если true , значения cookie не будут декодированы перед возвратом. По умолчанию — false . |
Соответствующие разрешения
getEventData
Возвращает копию значения по указанному пути в данных события. Возвращает undefined если данные события отсутствуют или если значение по указанному пути отсутствует.
Пример
const getEventData = require('getEventData');
const campaignId = getEventData('campaign.id');
const itemId = getEventData('items.0.id');
const referrer = getEventData('page_referrer');
Параметры
| Параметр | Тип | Описание |
|---|---|---|
keyPath | любой | Путь ключа, где компоненты пути разделены точками. Компонентами пути могут быть ключи в объекте или индексы в массиве. Если keyPath не является строкой, он преобразуется в строку. |
Синтаксис
getEventData(keyPath);
Соответствующие разрешения
getGoogleAuth
Возвращает объект авторизации, который при использовании с sendHttpGet или sendHttpRequest будет включать заголовок авторизации для API Google Cloud. Этот API использует учетные данные приложения по умолчанию для автоматического поиска учетных данных в серверной среде.
Пример
const getGoogleAuth = require('getGoogleAuth');
const logToConsole = require('logToConsole');
const sendHttpGet = require('sendHttpGet');
const auth = getGoogleAuth({
scopes: ['https://www.googleapis.com/auth/datastore']
});
sendHttpGet(
'https://firestore.googleapis.com/v1/projects/my-project/databases/(default)/documents/collection/document',
{authorization: auth}
).then((result) => {
if (result.statusCode >= 200 && result.statusCode < 300) {
logToConsole('Result: ' + result.body);
data.gtmOnSuccess();
} else {
data.gtmOnFailure();
}
});
Синтаксис
getGoogleAuth(scopes);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
scopes | Множество | Набор областей действия Google API OAuth 2.0, для которых запрашивается доступ. |
Соответствующие разрешения
Требуется разрешение use_google_credentials . Разрешение должно быть настроено с одним или несколькими разрешенными областями действия.
getGoogleScript
Получает ресурс из заранее определенного набора скриптов Google и возвращает промис , содержащий скрипт и связанные с ним метаданные для кэширования.
Промис разрешится в объект, содержащий два ключа: script и metadata . Если запрос не удастся, промис будет отклонен с указанием reason .
Объект metadata будет содержать следующие метаданные кэширования, основанные на заголовках ответа ресурса; каждое поле будет присутствовать только в том случае, если соответствующий заголовок присутствует в ответе ресурса.
{
'cache-control': string,
'expires': string,
'last-modified': string,
}
Пример
const getGoogleScript = require('getGoogleScript');
getGoogleScript('ANALYTICS').then((result) => {
// Operate on result.script and result.metadata here.
});
Синтаксис
getGoogleScript(script[, options]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
script | нить | Название скрипта. Поддерживаются скрипты 'ANALYTICS' , 'GTAG' и 'GTM' .Опция 'ANALYTICS' загружает скрипт Google Analytics с https://www.google-analytics.com/analytics.js .Опция 'GTAG' загружает глобальный скрипт тега сайта (gtag.js) с https://www.googletagmanager.com/gtag/js .Опция 'GTM' загружает скрипт Google Tag Manager с https://www.googletagmanager.com/gtm.js . |
options | объект | Дополнительные параметры запроса. Список поддерживаемых вариантов см. ниже. |
Параметры
| Вариант | Тип | Описание |
|---|---|---|
id | нить | Применимо к 'GTAG' с идентификатором измерения gtag и 'GTM' с идентификатором веб-контейнера (например, GTM-XXXX). |
debug | любой | Если значение истинно, запрашивает и возвращает отладочную версию скрипта измерений. |
timeout | число | Время ожидания запроса в миллисекундах; неположительные значения игнорируются. Если запрос истекает по таймауту, будет вызвана функция обратного вызова с значением скрипта undefined и объектом метаданных {} . |
Нераспознанные клавиши параметров игнорируются.
Соответствующие разрешения
Требуется разрешение send_http . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
- Разрешить домены Google
getRemoteAddress
Возвращает строковое представление IP-адреса, с которого был отправлен запрос, например, 12.345.67.890 для IPv4 или 2001:0db8:85a3:0:0:8a2e:0370:7334 для IPv6, путем чтения заголовков запроса, таких как Forwarded и X-Forwarded-For. Примечание: этот API прилагает все усилия для определения исходного IP-адреса, но не может гарантировать точность результата.
Синтаксис
getRemoteAddress();
Соответствующие разрешения
Требуется разрешение read_request ). Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
- Заголовки
ForwardedиX-Forwarded-For - Удаленный IP-адрес
getRequestBody
Возвращает тело запроса в виде строки , если оно присутствует, или undefined в противном случае.
Синтаксис
getRequestBody();
Соответствующие разрешения
getRequestHeader
Возвращает значение указанного заголовка запроса в виде строки , если он присутствует, или undefined в противном случае. Если заголовок повторяется, возвращаемые значения объединяются с помощью ', ' .
Пример
const getRequestHeader = require('getRequestHeader');
const host = getRequestHeader('host');
Синтаксис
getRequestHeader(headerName);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
headerName | нить | Название заголовка. Регистр символов не имеет значения. |
Соответствующие разрешения
getRequestMethod
Возвращает метод запроса, например 'GET' или 'POST' , в виде строки .
Пример
const getRequestMethod = require('getRequestMethod');
if (getRequestMethod() === 'POST') {
// Handle the POST request here.
}
Синтаксис
getRequestMethod();
Соответствующие разрешения
Никто.
getRequestPath
Возвращает путь запроса без строки запроса. Например, если URL — '/foo?id=123' , возвращается '/foo' . Автоматически удаляет префикс URL-адреса контейнера сервера из пути. Например, если URL-адрес контейнера сервера — https://example.com/analytics , а путь запроса — '/analytics/foo' , возвращается '/foo' .
Пример
const getRequestPath = require('getRequestPath');
const requestPath = getRequestPath();
if (requestPath === '/') {
// Handle a request for the root path.
}
Синтаксис
getRequestPath();
Соответствующие разрешения
getRequestQueryParameter
Возвращает декодированное значение именованного параметра строки запроса в виде строки или undefined , если параметр отсутствует. Если параметр повторяется в строке запроса, будет возвращено первое значение, которое встречается в строке запроса.
Пример
const getRequestQueryParameter = require('getRequestQueryParameter');
const query = getRequestQueryParameter('query');
if (query) {
// Process query here.
}
Синтаксис
getRequestQueryParameter(name);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
name | нить | Имя параметра запроса. |
Соответствующие разрешения
getRequestQueryParameters
Возвращает параметры запроса входящего HTTP-запроса в виде объекта, сопоставляющего имена параметров запроса с соответствующими значениями. Имена и значения параметров декодируются.
Пример
const getRequestQueryParameters = require('getRequestQueryParameters');
const queryParameters = getRequestQueryParameters();
if (queryParameters['search']) {
// Handle the search query here.
const maxResults = queryParameters['max_results'];
}
Синтаксис
getRequestQueryParameters();
Соответствующие разрешения
getRequestQueryString
Возвращает текст запроса в виде строки без вопросительного знака в начале или пустую строку, если URL-адрес запроса не содержит строки запроса.
Пример
const getRequestQueryString = require('getRequestQueryString');
const queryString = getRequestQueryString();
if (queryString !== '') {
// Handle the query string.
}
Синтаксис
getRequestQueryString();
Соответствующие разрешения
getTimestamp
Устарело. Предпочтительнее использовать getTimestampMillis .
Возвращает число , представляющее текущее время в миллисекундах с начала эпохи Unix, как это было возвращено функцией Date.now() .
Синтаксис
getTimestamp();
Соответствующие разрешения
Никто.
getTimestampMillis
Возвращает число , представляющее текущее время в миллисекундах с начала эпохи Unix, как это было возвращено функцией Date.now() .
Синтаксис
getTimestampMillis();
Соответствующие разрешения
Никто.
getType
Возвращает строку, описывающую тип заданного значения.
| Тип ввода | Возвращаемое значение |
|---|---|
| нить | 'string' |
| число | 'number' |
| логический | 'boolean' |
| нулевой | 'null' |
| неопределенный | 'undefined' |
| Множество | 'array' |
| Объект | 'object' |
| Функция | 'function' |
Пример
const getType = require('getType');
const type = getType(value);
if (type === 'string') {
// Handle string input.
} else if (type === 'number') {
// Handle numeric input.
} else {
logToConsole('Unsupported input type: ', type);
}
Синтаксис
getType(value);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
value | любой | Входное значение. |
Соответствующие разрешения
Никто.
hmacSha256
Вычисляет закодированную подпись с использованием хеш-кода аутентификации сообщений (HMAC) и алгоритма SHA-256. По умолчанию используется кодировка base64url .
Для использования этого API установите переменную среды SGTM_CREDENTIALS на сервере, указав путь к файлу ключа JSON в кодировке UTF-8 со следующим форматом:
{
"keys": {
"key1": "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5",
"key2": "OTg3NjU0MzIxMHp5eHd2dXRzcnFwb25tbGtqaWhnZmVkY2Jh",
...
}
}
Значения представляют собой закодированные в base64 ключи HMAC. Текст JSON не должен начинаться с маркера порядка байтов.
Пример
const hmacSha256 = require('hmacSha256');
const toBase64 = require('toBase64');
const header = toBase64('{"alg":"HS256","typ":"JWT"}', {urlEncoding: true});
const claim = toBase64('{"sub":"1234567890","iat":1698164946}', {urlEncoding: true});
const signature = hmacSha256(header + '.' + claim, 'key1');
const jwt = header + "." + claim + '.' + signature;
Синтаксис
hmacSha256(data, keyId, options)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
data | нить | Данные для вычисления значения HMAC. |
keyId | нить | Идентификатор ключа из JSON-файла, указывающий на используемый ключ. |
options | объект | Дополнительная настройка API. (См. раздел «Параметры» ниже.) |
Параметры
| Вариант | Тип | Описание |
|---|---|---|
outputEncoding | нить | Указывает формат кодировки возвращаемого значения. Поддерживаемые форматы: hex , base64 или base64url . По умолчанию используется base64url , если не указан. |
Соответствующие разрешения
Минимальная версия изображения
isRequestMpv1
Возвращает true если входящий запрос является запросом по протоколу Measurement Protocol V1, или false в противном случае.
Пример
const isRequestMpv1 = require('isRequestMpv1');
if (isRequestMpv1()) {
// Handle Measurement Protocol V1 request.
const events = extractEventsFromMpv1();
}
Синтаксис
isRequestMpv1();
Соответствующие разрешения
Никто.
isRequestMpv2
Возвращает true если входящий запрос является запросом по протоколу Measurement Protocol V2, или false в противном случае.
Пример
const isRequestMpv2 = require('isRequestMpv2');
if (isRequestMpv2()) {
// Handle Measurement Protocol V2 request.
const events = extractEventsFromMpv2();
}
Синтаксис
isRequestMpv2();
Соответствующие разрешения
Никто.
logToConsole
Выводит свои аргументы в консоль.
Эти журналы отображаются в Logs Explorer в консоли Google Cloud. В Logs Explorer выполните запрос logName =~ "stdout" чтобы увидеть записи журналов, созданные этим API.
Пример
const logToConsole = require('logToConsole');
const that = 123;
const those = { ... };
logToConsole('that is: ', that, ' and those is: ', those);
Синтаксис
logToConsole(argument1[, argument2, ...]);
Параметры
API принимает один или несколько аргументов, каждый из которых при необходимости преобразуется в строку и выводится в консоль.
Соответствующие разрешения
makeInteger
Преобразует заданное значение в число (целое число).
Синтаксис
makeInteger(value);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
value | любой тип | Значение для конвертации. |
Соответствующие разрешения
Никто.
makeNumber
Преобразует заданное значение в число .
Синтаксис
makeNumber(value);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
value | любой тип | Значение для конвертации. |
Соответствующие разрешения
Никто.
makeString
Возвращает заданное значение в виде строки .
Синтаксис
makeString(value);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
value | любой тип | Значение для конвертации. |
Соответствующие разрешения
Никто.
makeTableMap
Преобразует простой табличный объект с двумя столбцами в Map . Это используется для преобразования поля шаблона SIMPLE_TABLE с двумя столбцами в более удобный для управления формат.
Например, эта функция может преобразовать объект таблицы:
[
{'key': 'k1', 'value': 'v1'},
{'key': 'k2', 'value': 'v2'}
]
на карту:
{
'k1': 'v1',
'k2': 'v2'
}
Возвращает объект : преобразованная Map пар ключ-значение добавлена в него, в противном случае — null .
Синтаксис
makeTableMap(tableObj, keyColumnName, valueColumnName);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
tableObj | Список | Объект таблицы, который необходимо преобразовать. Это список карт, где каждая Map представляет собой строку в таблице. Имя свойства в объекте строки — это имя столбца, а значение свойства — это значение столбца в строке. |
keyColumnName | нить | Название столбца, значения которого станут ключами в преобразованной Map . |
valueColumnName | нить | Название столбца, значения которого станут значениями в преобразованной Map . |
Соответствующие разрешения
Никто.
parseUrl
Возвращает объект, содержащий все составляющие части заданного URL-адреса, аналогично объекту URL .
Для некорректно сформированных URL-адресов этот API вернет undefined . Для правильно отформатированных URL-адресов поля, отсутствующие в строке URL, будут иметь значение пустой строки, или, в случае searchParams , пустой объект.
Возвращаемый объект будет содержать следующие поля:
{
href: string,
origin: string,
protocol: string,
username: string,
password: string,
host: string,
hostname: string,
port: string,
pathname: string,
search: string,
searchParams: Object<string, (string|Array)>,
hash: string,
}
Пример
const parseUrl = require('parseUrl');
const urlObject = parseUrl('https://abc:xyz@example.com:8080/foo?param=val%2Cue#bar');
Синтаксис
parseUrl(url);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
url | нить | Полный URL-адрес, который будет проанализирован. |
Соответствующие разрешения
Никто.
returnResponse
Отправляет ответ, ранее заданный другими шаблонами, используя API, изменяющие ответ, включая setCookie , setPixelResponse , setResponseBody , setResponseHeader и setResponseStatus . По умолчанию используется HTTP-статус-код 200, пустое тело ответа и отсутствие заголовков.
Рекомендуется использовать этот API из клиентского шаблона.
Синтаксис
returnResponse();
Пример
См. пример runContainer .
Соответствующие разрешения
runContainer
Выполняет логику контейнера (переменные, триггеры, теги) в рамках события. Если этот API вызывается во время выполнения контейнера, контейнер запускается снова.
Коллбэки onComplete и onStart получают функцию с именем bindToEvent . Используйте bindToEvent для выполнения API в контексте события. Дополнительные сведения см. в примере addEventCallback .
Рекомендуется использовать этот API из клиентского шаблона.
const returnResponse = require('returnResponse');
const runContainer = require('runContainer');
// Runs the container with a simple pageview event and then returns a response.
runContainer({'event_name': 'pageview'}, () => returnResponse());
Синтаксис
runContainer(event, onComplete, onStart);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
event | объект | Параметры события. |
onComplete | функция | Функция обратного вызова, которая срабатывает после завершения обработки всех тегов. |
onStart | функция | Функция обратного вызова, которая срабатывает немедленно, до начала обработки тегов. |
Соответствующие разрешения
sendEventToGoogleAnalytics
Отправляет одно событие с использованием Common Event Data в Google Analytics и возвращает промис , который разрешается в объект с ключом location или отклоняется в объект с ключом reason . Место назначения, Google Analytics 4, определяется на основе идентификатора измерения в данных события.
Поле location устанавливается в значение заголовка location , если он присутствует.
Пример
const logToConsole = require('logToConsole');
const sendEventToGoogleAnalytics = require('sendEventToGoogleAnalytics');
const setResponseHeader = require('setResponseHeader');
const setResponseStatus = require('setResponseStatus');
// Sends an event to Google Analytics and returns failure if the request did not
// succeed. Additionally, if the request resulted in a redirect request, the
// code nominates a redirect response to be returned.
sendEventToGoogleAnalytics(event).then((response) => {
if (response.location) {
setResponseHeader('location', response.location);
setResponseStatus(302);
} else {
setResponseStatus(200);
}
data.gtmOnSuccess();
}).catch((error) => {
logToConsole(error.reason);
setResponseStatus(500);
data.gtmOnFailure();
});
Синтаксис
sendEventToGoogleAnalytics(event);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
event | объект | Событие представлено в формате унифицированной схемы. |
Соответствующие разрешения
Требуется разрешение send_http . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
- Разрешить домены Google
sendHttpGet
Выполняет HTTP GET-запрос к указанному URL и возвращает промис , который разрешается с результатом после завершения запроса или истечения времени ожидания.
Результатом запроса является объект, содержащий три ключа: statusCode , headers и body . Если запрос не удался (например, неверный URL, отсутствие маршрута к хосту, ошибка согласования SSL и т. д.), промис будет отклонен с ошибкой: {reason: 'failed'} . Если был установлен параметр timeout и запрос истек по времени, промис будет отклонен с ошибкой: {reason: 'timed_out'}
Пример
const sendHttpGet = require('sendHttpGet');
// Returns the response body as the value for a variable.
return sendHttpGet('https://example.com/item/' + data.itemId, {
headers: {key: 'value'},
timeout: 500,
}).then((result) => result.body, () => undefined);
Синтаксис
sendHttpGet(url[, options]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
url | нить | Запрошенный URL. |
options | объект | Дополнительные параметры запроса. (См. раздел «Параметры» ниже.) |
Параметры
| Вариант | Тип | Описание |
|---|---|---|
headers | нить | Дополнительные заголовки запроса. |
timeout | число | Время ожидания в миллисекундах, после которого запрос будет прерван. По умолчанию — 15000 . |
authorization | объект | Необязательный объект авторизации из вызова функции getGoogleAuth для включения заголовков авторизации при отправке запросов к googleapis.com . |
Соответствующие разрешения
sendHttpRequest
Выполняет HTTP-запрос к указанному URL и возвращает промис , который разрешается с ответом после завершения запроса или истечения времени ожидания.
Результатом запроса является объект, содержащий три ключа: statusCode , headers и body . Если запрос не удался (например, неверный URL, отсутствие маршрута к хосту, ошибка согласования SSL и т. д.), промис будет отклонен с ошибкой: {reason: 'failed'} . Если был установлен параметр timeout и запрос истек по времени, промис будет отклонен с ошибкой: {reason: 'timed_out'}
Пример
const sendHttpRequest = require('sendHttpRequest');
const setResponseBody = require('setResponseBody');
const setResponseHeader = require('setResponseHeader');
const setResponseStatus = require('setResponseStatus');
const postBody = 'interaction=click&campaign=promotion&medium=email';
// Sends a POST request and nominates response based on the response to the POST
// request.
sendHttpRequest('https://example.com/collect', {
headers: {key: 'value'},
method: 'POST',
timeout: 500,
}, postBody).then((result) => {
setResponseStatus(result.statusCode);
setResponseBody(result.body);
setResponseHeader('cache-control', result.headers['cache-control']);
});
Синтаксис
sendHttpRequest(url[, options[, body]]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
url | нить | Запрошенный URL. |
options | объект | Дополнительные параметры запроса. (См. раздел «Параметры» ниже.) |
body | нить | Необязательное тело запроса. |
Параметры
| Вариант | Тип | Описание |
|---|---|---|
headers | нить | Дополнительные заголовки запроса. |
method | объект | Метод запроса. По умолчанию используется GET . |
timeout | число | Время ожидания в миллисекундах, после которого запрос будет прерван. По умолчанию — 15000 . |
authorization | объект | Необязательный объект авторизации из вызова функции getGoogleAuth для включения заголовков авторизации при отправке запросов к googleapis.com . |
Соответствующие разрешения
sendPixelFromBrowser
Отправляет команду браузеру для загрузки указанного URL-адреса в виде тега <img> . Этот протокол команд поддерживается в веб-тегах Google Tag for GA4 и Google Analytics: GA Event . Необходимо настроить URL-адрес контейнера сервера. Дополнительные сведения см. в инструкциях .
Этот API возвращает false если входящий запрос не поддерживает протокол команд или если ответ уже был отправлен. В противном случае этот API возвращает true .
Пример:
const sendPixelFromBrowser = require('sendPixelFromBrowser');
sendPixelFromBrowser('https://example.com/?id=123');
Синтаксис
sendPixelFromBrowser(url)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
url | нить | URL-адрес, который нужно отправить в браузер. |
Соответствующие разрешения
setCookie
Устанавливает или удаляет cookie-файл с указанными параметрами.
Для удаления cookie-файла необходимо создать cookie-файл с тем же путем и доменом, что и при создании cookie-файла, и присвоить ему значение expires, указывающее на прошлое, например "Thu, 01 Jan 1970 00:00:00 GMT" .
Обратите внимание, что для отправки ответа клиенту необходимо вызвать метод returnResponse .
Пример
const setCookie = require('setCookie');
// Sets an httpOnly cookie with a max-age of 3600.
setCookie('cookieName', 'cookieValue', {'max-age': 3600, httpOnly: true});
Синтаксис
setCookie(name, value[, options[, noEncode]]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
name | нить | Название файла cookie. Регистр символов не имеет значения. |
value | нить | Значение cookie-файла. |
options | объект | Дополнительные атрибуты cookie: domain , expires , fallbackDomain , httpOnly , max-age , path , secure и sameSite . (См. раздел «Параметры » ниже.) |
noEncode | логический | Если значение истинно, то значение cookie не будет закодировано. По умолчанию — false . |
domain: Хост, на который будет отправлен cookie-файл. Если установлено специальное значение 'auto', то хост будет вычислен автоматически с использованием следующей стратегии:
- eTLD+1 заголовка
Forwarded, если он присутствует. - eTLD+1 заголовка
X-Forwarded-Host, если он присутствует. - eTLD+1 заголовка
Host.
- eTLD+1 заголовка
expires : Максимальный срок действия cookie-файла. Это должна быть строка даты в формате UTC, например, "Sat, 26 Oct 1985 08:21:00 GMT". Если заданы и
expires, иmax-age, приоритет имеетmax-age.httpOnly : Если
trueзапрещает JavaScript доступ к cookie.max-age : Количество секунд до истечения срока действия cookie-файла. Ноль или отрицательное число приведет к немедленному удалению cookie-файла. Если заданы оба параметра
expiresиmax-age, приоритет имеетmax-age.path : Путь, который должен присутствовать в запрашиваемом URL-адресе, иначе браузер не отправит заголовок Cookie.
secure : Если установлено значение
true, cookie отправляется на сервер только при запросе с конечной точкиhttps::.sameSite : Утверждает, что cookie-файл не должен отправляться с запросами из других источников. Должен быть
'strict','lax'или'none'.
Соответствующие разрешения
setPixelResponse
Устанавливает тело ответа в виде GIF-изображения размером 1x1, заголовок Content-Type в значение 'image/gif', задает заголовки кэширования таким образом, чтобы пользовательские агенты не кэшировали ответ, и устанавливает статус ответа в значение 200.
Обратите внимание, что для отправки ответа клиенту необходимо вызвать метод returnResponse .
Синтаксис
setPixelResponse();
Соответствующие разрешения
Требуется разрешение access_response . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
headers- Должны разрешать следующие ключи-
content-type -
cache-control -
expires -
pragma
-
-
body -
status
setResponseBody
Устанавливает тело ответа в соответствии с аргументом.
Обратите внимание, что для отправки ответа клиенту необходимо вызвать метод returnResponse .
Синтаксис
setResponseBody(body[, encoding]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
body | нить | Значение, которое следует установить в качестве тела ответа. |
encoding | нить | Кодировка символов тела ответа (по умолчанию 'utf8' ). Поддерживаемые значения: 'ascii' , 'utf8' , 'utf16le' , 'ucs2' , 'base64' , 'latin1' , 'binary' и 'hex' . |
Соответствующие разрешения
Требуется разрешение access_response . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
body
setResponseHeader
Устанавливает заголовок в возвращаемом ответе. Если заголовок с таким именем (регистр не имеет значения) был ранее установлен этим API, то последующий вызов перезапишет или очистит значение, установленное предыдущим вызовом.
Обратите внимание, что для отправки ответа клиенту необходимо вызвать метод returnResponse .
Синтаксис
setResponseHeader(name, value);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
name | нить | Название заголовка. Названия HTTP-заголовков нечувствительны к регистру, поэтому название заголовка будет написано строчными буквами. |
value | строка неопределена | Значение заголовка. Если оно равно null или не определено, то этот заголовок удаляется из возвращаемого ответа. |
Соответствующие разрешения
Требуется разрешение access_response . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
headers
setResponseStatus
Устанавливает HTTP-код состояния ответа, который будет возвращен.
Обратите внимание, что для отправки ответа клиенту необходимо вызвать метод returnResponse .
Синтаксис
setResponseStatus(statusCode);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
statusCode | число | Код состояния HTTP, который необходимо вернуть. |
Соответствующие разрешения
Требуется разрешение access_response . Разрешение должно быть настроено таким образом, чтобы обеспечить доступ как минимум к:
-
status
sha256
Вычисляет дайджест SHA-256 входных данных и вызывает функцию обратного вызова с дайджестом, закодированным в base64, если только объект options не указывает другую кодировку выходных данных.
Данная сигнатура и поведение API соответствуют API sha256 для веб-контейнеров; однако для упрощения кода в пользовательских шаблонах в серверных контейнерах следует использовать API sha256Sync .
Пример
const encodeUriComponent = require('encodeUriComponent');
const sendHttpGet = require('sendHttpGet');
const sha256 = require('sha256');
sha256('inputString', (digest) => {
sendHttpGet('https://example.com/collect?id=' + encodeUriComponent(digest));
});
sha256('inputString', (digest) => {
sendHttpGet('https://example.com/collect?id=' + encodeUriComponent(digest));
}, {outputEncoding: 'hex'});
Синтаксис
sha256(input, onSuccess, options = undefined);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
input | нить | Строка для хеширования. |
onSuccess | функция | Вызов осуществляется с полученным дайджестом, закодированным в base64, если объект options не указывает другую кодировку вывода. |
options | объект | Необязательный объект параметров для указания кодировки выходных данных. Если указан, объект должен содержать ключ outputEncoding со значением, равным одному из base64 или hex . |
Соответствующие разрешения
Никто.
sha256Sync
Вычисляет и возвращает дайджест SHA-256 входных данных, закодированный в base64, если в объекте options не указана другая кодировка выходных данных.
Пример
const encodeUriComponent = require('encodeUriComponent');
const sendHttpGet = require('sendHttpGet');
const sha256Sync = require('sha256Sync');
const digestBase64 = sha256Sync('inputString');
const digestHex = sha256Sync('inputString', {outputEncoding: 'hex'});
sendHttpGet('https://example.com/collect?id=' + encodeUriComponent(digestBase64));
sendHttpGet('https://example.com/collect?id=' + encodeUriComponent(digestHex));
Синтаксис
sha256Sync(input, options = undefined);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
input | нить | Строка для хеширования. |
options | объект | Необязательный объект параметров для указания кодировки выходных данных. Если указан, объект должен содержать ключ outputEncoding со значением, равным одному из base64 или hex . |
Соответствующие разрешения
Никто.
templateDataStorage
Возвращает объект с методами для доступа к хранилищу данных шаблона. Хранилище данных шаблона позволяет совместно использовать данные между выполнениями одного шаблона. Данные, хранящиеся в хранилище данных шаблона, сохраняются на сервере, на котором запущен контейнер. В большинстве случаев контейнер работает на нескольких серверах, поэтому хранение данных в хранилище данных шаблона не гарантирует, что каждый последующий запрос будет иметь доступ к этим данным.
Приставка «data» в названии «templateDataStorage» указывает на то, что с помощью этого API можно хранить только простые типы данных, не являющиеся функциями. Любые функции или ссылки на функции, переданные в API, будут храниться как null .
Синтаксис
const templateDataStorage = require('templateDataStorage');
// Returns a copy of the value stored for the given key, or null if nothing
// is stored with that key.
templateDataStorage.getItemCopy(key);
// Stores a copy of the value for the given key (or removes the data stored
// for the given key if the input value is null).
templateDataStorage.setItemCopy(key, value);
// Removes the value stored for the given key, if present.
templateDataStorage.removeItem(key);
// Deletes all values stored for the current template.
templateDataStorage.clear();
Пример
const sendHttpGet = require('sendHttpGet');
const setResponseBody = require('setResponseBody');
const setResponseStatus = require('setResponseStatus');
const templateDataStorage = require('templateDataStorage');
// Check to see if the item is in the cache.
const cachedBody = templateDataStorage.getItemCopy(data.key);
if (cachedBody) {
setResponseBody(cachedBody);
data.gtmOnSuccess();
return;
}
sendHttpGet(data.url).then((result) => {
if (result.statusCode >= 200 && result.statusCode < 300) {
setResponseBody(result.body);
templateDataStorage.setItemCopy(data.key, result.body);
data.gtmOnSuccess();
} else {
data.gtmOnFailure();
}
setResponseStatus(result.statusCode);
});
Соответствующие разрешения
testRegex
Проверяет строку на соответствие регулярному выражению, созданному с помощью API createRegex . Возвращает true если регулярное выражение совпадает. В противном случае возвращает false .
Регулярное выражение, созданное с использованием глобального флага, является состоянием. Подробности см. в документации по регулярным выражениям .
Пример
const createRegex = require('createRegex');
const testRegex = require('testRegex');
const domainRegex = createRegex('\\w+\\.com', 'i');
// createRegex returns null if the regex is invalid or Re2 is not available.
if (domainRegex === null) return;
// Returns true
testRegex(domainRegex, 'example.com/foobar');
Синтаксис
testRegex(regex, string);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
regex | Объект | Регулярное выражение для проверки, возвращаемое API функции createRegex. |
string | нить | Тестовая строка для проверки. |
Соответствующие разрешения
Никто.
toBase64
Кодирует строку в формате base64 или base64url. По умолчанию используется кодировка base64.
Синтаксис
toBase64(input, options);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
input | нить | Строка для кодирования. |
options | объект | Дополнительная настройка API. (См. раздел «Параметры» ниже.) |
Параметры
| Вариант | Тип | Описание | Минимальная версия |
|---|---|---|---|
urlEncoding | логический | Если это так, результат будет закодирован с использованием формата base64url . | 1.0.0 |
Пример
const toBase64 = require('toBase64');
const base64Hello = toBase64('hello');
const base64UrlHello = toBase64('hello', {urlEncoding: true});
Соответствующие разрешения
Никто.
BigQuery
Возвращает объект, предоставляющий функции BigQuery.
Функция BigQuery.insert позволяет записывать данные в таблицу BigQuery. Она возвращает промис , который разрешается при успешной вставке или отклоняется при ошибке.
Если вставка прошла успешно, обещание разрешается без аргументов.
Если вставка не удалась, промис отклоняется со списком объектов, содержащих причину ошибки и, возможно, объект строки, если произошла ошибка. Возможно, что часть запроса будет выполнена успешно, а другие части — нет. В этом случае промис отклоняется со списком ошибок для каждой строки, содержащим объект строки, помогающий определить, какие строки были вставлены (см. примеры ошибок ниже). Дополнительную информацию см. в документации BigQuery по сообщениям об ошибках .
Синтаксис
BigQuery.insert(connectionInfo, rows[, options]);
| Параметр | Тип | Описание |
|---|---|---|
connectionInfo | объект | Определяет информацию, необходимую для подключения к таблице BigQuery. Имеется один необязательный и два обязательных параметра:
|
rows | Множество | Строки, которые нужно вставить в таблицу. |
options | объект | Дополнительные параметры запроса. Поддерживаются следующие параметры: ignoreUnknownValues и skipInvalidRows . Неизвестные ключи параметров игнорируются. (См. раздел «Параметры» ниже.) |
| Параметр | Тип | Описание |
|---|---|---|
ignoreUnknownValues | логический | Если установлено true , то принимаются строки, содержащие значения, не соответствующие схеме. Неизвестные значения игнорируются. По умолчанию — false . |
skipInvalidRows | логический | Если установлено значение true , то будут вставлены все допустимые строки запроса, даже если существуют недопустимые строки. По умолчанию — false . |
Ошибка «модуль не найден» означает, что в вашем серверном контейнере, вероятно, используется более старая версия нашего образа, в которой модуль BigQuery еще не включен. Пожалуйста, повторно разверните ваш серверный контейнер с теми же настройками, используя наш скрипт развертывания . Модуль будет автоматически добавлен после завершения операции.
Ошибка, не связанная с вставкой, обычно имеет один объект ошибки с ключом reason :
[{reason: 'invalid'}]
Ошибка вставки может содержать несколько объектов error, включая массив errors и объект row . Ниже приведён пример ответа об ошибке при вставке двух строк, где ошибка обнаружена только в одной строке:
[
{
"errors": [
{
"reason":"invalid"
}
],
"row": {
"string_col":"otherString",
"number_col":-3,
"bool_col":3
}
},
{
"errors": [
{
"reason":"stopped"
}
],
"row": {
"string_col":"stringValue",
"number_col":5,
"bool_col:false
}
}
]
Пример
const BigQuery = require('BigQuery');
const connectionInfo = {
'projectId': 'gcp-cloud-project-id',
'datasetId': 'destination-dataset',
'tableId': 'destination-table',
};
const rows = [{
'column1': 'String1',
'column2': 1234,
}];
const options = {
'ignoreUnknownValues': true,
'skipInvalidRows': false,
};
BigQuery.insert(connectionInfo, rows, options)
.then(data.gtmOnSuccess, data.gtmOnFailure);
Соответствующие разрешения
Firestore
Возвращает объект, предоставляющий функции Firestore.
Этот API поддерживает только Firestore в нативном режиме , а не Firestore в режиме хранилища данных . Кроме того, API поддерживает только использование базы данных по умолчанию .
Firestore.read
Функция Firestore.read считывает данные из документа Firestore и возвращает промис , который разрешается в объект, содержащий два ключа: id и data . Если документ не существует, промис отклоняется с объектом, содержащим ключ reason равный not_found .
Синтаксис
Firestore.read(path[, options]);
| Параметр | Тип | Описание |
|---|---|---|
path | нить | Путь к документу или коллекции. Не должен начинаться или заканчиваться символом '/'. |
options | объект | Дополнительные параметры запроса. Поддерживаются следующие параметры: projectId , disableCache и transaction . Неизвестные ключи параметров игнорируются. (См. раздел «Параметры » ниже.) |
| Параметр | Тип | Описание |
|---|---|---|
projectId | нить | Необязательный параметр . Идентификатор проекта Google Cloud Platform. Если он опущен, идентификатор projectId извлекается из переменной среды GOOGLE_CLOUD_PROJECT если параметр разрешения access_firestore для идентификатора проекта установлен на * или GOOGLE_CLOUD_PROJECT . Если контейнер сервера работает в Google Cloud, GOOGLE_CLOUD_PROJECT уже будет установлена на идентификатор проекта Google Cloud. |
disableCache | логический | Необязательный параметр . Определяет, следует ли отключать кэширование. Кэширование включено по умолчанию, в этом случае результаты будут кэшироваться на время выполнения запроса. |
transaction | нить | Необязательный параметр . Значение, полученное из метода Firestore.runTransaction(). Указывает операцию, которая будет использоваться в рамках транзакции. |
Пример
const Firestore = require('Firestore');
return Firestore.read('collection/document', {
projectId: 'gcp-cloud-project-id',
}).then((result) => result.data.key, () => undefined);
Firestore.write
Функция Firestore.write записывает данные в документ или коллекцию Firestore. Если путь указывает на коллекцию, будет создан документ со случайно сгенерированным идентификатором. Если путь указывает на документ, который не существует, он будет создан. Этот API возвращает промис, который разрешается в идентификатор добавленного или измененного документа. Если используется опция транзакции, API также возвращает промис, но он не будет содержать идентификатор, поскольку запись выполняется пакетами.
Синтаксис
Firestore.write(path, input[, options]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
path | нить | Путь к документу или коллекции. Не должен начинаться или заканчиваться символом '/'. |
input | объект | Значение, которое нужно записать в документ. Если задан параметр слияния, API объединит ключи из входных данных с документом. |
options | объект | Дополнительные параметры запроса. Поддерживаются следующие параметры: projectId , merge и transaction . Неизвестные ключи параметров игнорируются. (См. раздел «Параметры » ниже.) |
| Параметр | Тип | Описание |
|---|---|---|
projectId | нить | Необязательный параметр . Идентификатор проекта Google Cloud Platform. Если он опущен, идентификатор projectId извлекается из переменной среды GOOGLE_CLOUD_PROJECT если параметр разрешения access_firestore для идентификатора проекта установлен на * или GOOGLE_CLOUD_PROJECT . Если контейнер сервера работает в Google Cloud, GOOGLE_CLOUD_PROJECT уже будет установлена на идентификатор проекта Google Cloud. |
merge | логический | Необязательный параметр . Если установлено значение true , то ключи из поля ввода объединяются с документом; в противном случае метод переопределит весь документ. По умолчанию — false . |
transaction | нить | Необязательный параметр . Значение, полученное из метода Firestore.runTransaction(). Указывает операцию, которая будет использоваться в рамках транзакции. |
Пример
const Firestore = require('Firestore');
const input = {key1: 'value1', key2: 12345};
Firestore.write('collection/document', input, {
projectId: 'gcp-cloud-project-id',
merge: true,
}).then((id) => {
data.gtmOnSuccess();
}, data.gtmOnFailure);
Firestore.query
Функция Firestore.query запрашивает данные из заданной коллекции и возвращает промис, который разрешается в массив документов Firestore, соответствующих условиям запроса. Объект документа Firestore аналогичен объекту Firestore.read , описанному выше. Если документов, соответствующих условиям запроса, нет, возвращаемый промис разрешится в пустой массив.
Синтаксис
Firestore.query(collection, queryConditions[, options]);
| Параметр | Тип | Описание |
|---|---|---|
collection | нить | Путь к коллекции. Не должен начинаться или заканчиваться символом '/'. |
queryConditions | Множество | Массив условий запроса. Каждый запрос представлен в виде массива с тремя значениями: ключ , оператор и ожидаемое значение . Например: [['id', '<', '5'], ['state', '==', 'CA']]. Для формирования результата запроса условия объединяются с помощью операции И. Список совместимых операторов запросов см. в документации Firestore . |
options | объект | Дополнительные параметры запроса. Поддерживаются следующие параметры: projectId , disableCache , limit и transaction . Неизвестные ключи параметров игнорируются. (См. раздел «Параметры » ниже.) |
| Параметр | Тип | Описание |
|---|---|---|
projectId | нить | Необязательный параметр . Идентификатор проекта Google Cloud Platform. Если он опущен, идентификатор projectId извлекается из переменной среды GOOGLE_CLOUD_PROJECT если параметр разрешения access_firestore для идентификатора проекта установлен на * или GOOGLE_CLOUD_PROJECT . Если контейнер сервера работает в Google Cloud, GOOGLE_CLOUD_PROJECT уже будет установлена на идентификатор проекта Google Cloud. |
disableCache | логический | Необязательный параметр . Определяет, следует ли отключать кэширование. Кэширование включено по умолчанию, в этом случае результаты будут кэшироваться на время выполнения запроса. |
limit | число | Необязательный параметр . Изменяет максимальное количество результатов, возвращаемых запросом; по умолчанию — 5 . |
transaction | нить | Необязательный параметр . Значение, полученное из метода Firestore.runTransaction(). Указывает операцию, которая будет использоваться в рамках транзакции. |
Пример
const Firestore = require('Firestore');
const queries = const queries = [['id', '==', '5']];
return Firestore.query('collection', queries, {
projectId: 'gcp-cloud-project-id',
limit: 1,
}).then((documents) => documents[0].data.key, () => undefined);
Firestore.runTransaction
Функция Firestore.runTransaction позволяет пользователю атомарно читать и записывать данные в Firestore. Если возникает конфликт между параллельной записью или другой транзакцией, транзакция будет повторена до двух раз. Если она завершится неудачей после трех попыток, API отклонит запрос с ошибкой. Этот API возвращает промис, который разрешается в массив идентификаторов документов для каждой операции записи, если транзакция успешна, и отклоняет запрос с ошибкой, если она не удалась.
Синтаксис
Firestore.runTransaction(callback[, options]);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
callback | функция | Функция обратного вызова, которая вызывается с идентификатором транзакции в виде строки. Идентификатор транзакции может передаваться в вызовы API для чтения/записи/запросов. Эта функция обратного вызова должна возвращать промис. Функция обратного вызова может выполняться до трех раз, прежде чем завершится с ошибкой. |
options | объект | Дополнительные параметры запроса. Поддерживается только параметр projectId . Неизвестные ключи параметров игнорируются. (См. раздел «Параметры» ниже.) |
| Параметр | Тип | Описание |
|---|---|---|
projectId | нить | Optional . Google Cloud Platform project ID. If omitted, the projectId is retrieved from the environment variable GOOGLE_CLOUD_PROJECT as long as the access_firestore permission setting for the project ID is set to * or GOOGLE_CLOUD_PROJECT . If the server container is running on Google Cloud, GOOGLE_CLOUD_PROJECT will already be set to the Google Cloud project's ID. |
Пример
const Firestore = require('Firestore');
const path = 'collection/document';
const projectId = 'gcp-cloud-project-id';
Firestore.runTransaction((transaction) => {
const transactionOptions = {
projectId: projectId,
transaction: transaction,
};
// Must return a promise.
return Firestore.read(path, transactionOptions).then((result) => {
const newInputCount = result.data.inputCount + 1;
const input = {key1: 'value1', inputCount: newInputCount};
return Firestore.write(path, input, transactionOptions);
});
}, {
projectId: projectId
}).then((ids) => {
data.gtmOnSuccess();
}, data.gtmOnFailure);
Errors are available in each Firestore function will be rejected with an object containing a reason key:
Firestore.read(...).then(onSuccess, (error) => {
if (error.reason === 'unknown') {
// Handle the unknown error here.
}
});
The error reasons can contain but are not limited to Firestore REST API Error Codes .
Associated permissions
JSON
Returns an object that provides JSON functions.
The parse() function parses a JSON string to construct the value or object described by the string. If the value cannot be parsed (eg malformed JSON), the function will return undefined . If the input value is not a string, the input will be coerced to a string.
The stringify() function converts the input into a JSON string. If the value cannot be parsed (eg the object has a cycle), the method will return undefined .
Пример
const JSON = require('JSON');
// The JSON input string is converted to an object.
const object = JSON.parse('{"foo":"bar"}');
// The input object is converted to a JSON string.
const str = JSON.stringify({foo: 'bar'});
Синтаксис
JSON.parse(stringInput);
JSON.stringify(value);
Associated permissions
Никто.
Math
An object providing Math functions.
Синтаксис
const Math = require('Math');
// Retrieve the absolute value.
const absolute = Math.abs(-3);
// Round the input down to the nearest integer.
const roundedDown = Math.floor(3.6);
// Round the input up to the nearest integer.
const roundedUp = Math.ceil(2.2);
// Round the input to the nearest integer.
const rounded = Math.round(3.1);
// Return the largest argument.
const biggest = Math.max(1, 3);
// Return the smallest argument.
const smallest = Math.min(3, 5);
// Return the first argument raised to the power of the second argument.
const powerful = Math.pow(3, 1);
// Return the square root of the argument.
const unsquared = Math.sqrt(9);
Параметры
Math function parameters are converted to numbers.
Associated permissions
Никто.
Messages
The following APIs work together to allow passing messages between different parts of a container.
addMessageListener
Adds a function that listens for a message of a particular type. When a message of that type is sent using the sendMessage API (typically by a tag), the callback will be run synchronously. The callback is run with two parameters:
-
messageType:string -
message:Object
If the callback is added in a client, the callback will receive messages across all of the events that client creates. If the callback should receive messages from only a certain event, then bind this API to the event using bindToEvent in the runContainer API's onStart function. See the example.
Синтаксис
const addMessageListener = require('addMessageListener');
addMessageListener('send_pixel', (messageType, message) => {
// This will be run whenever something sends a 'send_pixel' message.
});
Параметры
| Параметр | Тип | Описание |
|---|---|---|
messageType | нить | The message type to listen for. If the value is not a string, it will be coerced to a string. |
callback | функция | The callback to run when a message of the applicable message type is sent. If the callback is not a function, the API will do nothing. |
Пример
const addMessageListener = require('addMessageListener');
const claimRequest = require('claimRequest');
const extractEventsFromMpv1 = require('extractEventsFromMpv1');
const returnResponse = require('returnResponse');
const runContainer = require('runContainer');
claimRequest();
addMessageListener('send_pixel', (messageType, message) => {
// This will be run whenever a tag sends a 'send_pixel' message.
});
const events = extractEventsFromMpv1();
let eventsCompleted = 0;
events.forEach((event, i) => {
runContainer(events[i], /* onComplete= */ () => {
if (events.length === ++eventsCompleted) {
returnResponse();
}
}, /* onStart= */ (bindToEvent) => {
if (i === 0) {
bindToEvent(addMessageListener)('send_pixel', (messageType, message) => {
// This will be called whenever a tag for the first event sends a
// 'send_pixel' message.
});
}
});
});
Associated permissions
Requires use_message permission. The permission must be configured to permit at least:
- A message type with
Usageoflistenorlisten_and_send.
hasMessageListener
Returns true if a message listener has been added for the given message type. Returns false otherwise.
Синтаксис
const hasMessageListener = require('hasMessageListener');
hasMessageListener('send_pixel');
Associated permissions
Никто.
sendMessage
Sends a message of the specified type to a registered listener. This can be used to send messages from a tag back to the client that ran the container.
Синтаксис
const sendMessage = require('sendMessage');
sendMessage('send_pixel', {url: 'https://analytics.example.com/collect'});
Параметры
| Параметр | Тип | Описание |
|---|---|---|
messageType | нить | The message type to send. If the value is not a string, it will be coerced to a string. |
message | объект | The message to send. If the message is not an object, the API will do nothing. |
Associated permissions
Requires use_message permission. The permission must be configured to permit at least:
- A message type with
Usageoflisten_and_sendorsend.
Object
Returns an object that provides Object methods.
The keys() method provides the Standard Library Object.keys() behavior. It returns an array of a given object's own enumerable property names in the same order that a for...in... loop would. If the input value is not an object, it will be coerced to an object.
The values() method provides the Standard Library Object.values() behavior. It returns an array of a given object's own enumerable property values in the same order that a for...in... loop would. If the input value is not an object, it will be coerced to an object.
The entries() method provides the Standard Library Object.entries() behavior. It returns an array of a given object's own enumerable property [key, value] pairs in the same order that a for...in... loop would. If the input value is an not an object, it will be coerced to an object.
The freeze() method provides the Standard Library Object.freeze() behavior. A frozen object can no longer be changed; freezing an object prevents new properties from being added to it, existing properties from being removed, and the values of existing properties from being changed. freeze() returns the same object that was passed in. A primitive or null argument will be treated as if it were a frozen object, and will be returned.
The delete() method provides the Standard Library delete operator behavior. It removes the given key from the object unless the object is frozen. Like the Standard Library delete operator, it returns true if the first input value ( objectInput ) is an object that is not frozen even if the second input value ( keyToDelete ) specifies a key that does not exist. It returns false in all other cases. However, it differs from the Standard Library delete operator in the following ways:
-
keyToDeletecannot be a dot-delimited string that specifies a nested key. -
delete()cannot be used to remove elements from an array. -
delete()cannot be used to remove any properties from the global scope.
Синтаксис
Object.keys(objectInput)
Object.values(objectInput)
Object.entries(objectInput)
Object.freeze(objectInput)
Object.delete(objectInput, keyToDelete)
Параметры
Object.keys
| Параметр | Тип | Описание |
|---|---|---|
| objectInput | любой | The object whose keys to enumerate. If the input is not an object, it will be coerced to an object. |
Object.values
| Параметр | Тип | Описание |
|---|---|---|
| objectInput | любой | The object whose values to enumerate. If the input is not an object, it will be coerced to an object. |
Object.entries
| Параметр | Тип | Описание |
|---|---|---|
| objectInput | любой | The object whose key/value pairs to enumerate. If the input is not an object, it will be coerced to an object. |
Object.freeze
| Параметр | Тип | Описание |
|---|---|---|
| objectInput | любой | The object to freeze. If the input is not an object, it will be treated as a frozen object. |
Object.delete
| Параметр | Тип | Описание |
|---|---|---|
| objectInput | любой | The object whose key to delete. |
| keyToDelete | нить | The top-level key to delete. |
Пример
const Object = require('Object');
// The keys of an object are enumerated in an array.
const keys = Object.keys({foo: 'bar'});
// The values of an object are enumerated in an array.
const values = Object.values({foo: 'bar'});
// The key/value pairs of an object are enumerated in an array.
const entries = Object.entries({foo: 'bar'});
// The input object is frozen.
const frozen = Object.freeze({foo: 'bar'});
// The key is removed from the input object.
const obj1 = {deleteme: 'value'};
Object.delete(obj1, 'deleteme');
// Only a top-level key can be specified as the key to delete.
const obj2 = {nested: {key: 'value'}};
Object.delete(obj2, 'nested.key'); // This has no effect.
Object.delete(obj2.nested, 'key'); // This deletes the nested key.
Promise
Returns an object that provides methods for interacting with promises.
Promises are functionally equivalent to JavaScript promises. Each instance has three methods that return a Promise which allows further action when a promise settles:
-
.then()- Handles both the resolved and rejected cases. It takes two callbacks as parameters: one for the success case and one for the failure case. -
.catch()- Handles the rejected cases only. Takes one callback as a parameter. -
.finally()- Provides a way for code to be run whether the promise was resolved or rejected. Takes one callback as a parameter that is invoked with no argument.
A variable that returns a promise equals the resolved value of the promise, or false if the promise rejects.
Пример
promise.then((resolvedValue) => {
// Handles when promise resolves.
}, (rejectedValue) => {
// Handles when promise rejects.
});
promise.catch((rejectedValue) => {
// Handles when promise rejects.
});
promise.finally(() => {
// Runs regardless of whether or not the previous promise resolves or
// rejects.
});
Promise.all
Returns a promise that either:
- resolves when all the inputs have resolved, or
- rejects when any of the inputs reject
Синтаксис
Promise.all(inputs);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
inputs | Множество | An array of values or promises. If an input is not a promise, the input is passed through as if it's the resolved value of a promise. Throws an error if the input is not an array. |
Пример
const Promise = require('Promise');
const sendHttpGet = require('sendHttpGet');
return Promise.all(['a', sendHttpGet('https://example.com')])
.then((results) => {
// results will equal: ['a', {statusCode: 200, headers: {}, body: ''}]
});
Associated permissions
Никто.
Promise.create
Creates a promise that is functionally equivalent to a JavaScript promise.
Синтаксис
Promise.create(resolver);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
resolver | функция | A function that is invoked with two functions -- resolve and reject. The returned promise will resolve or reject when the corresponding parameter is invoked. Throws an error if resolver is not a function. |
Пример
const Promise = require('Promise');
return Promise.create((resolve, reject) => {
// Do asynchronous work that eventually calls resolve() or reject()
});
Associated permissions
Никто.
Test APIs
These APIs work with sandboxed JavaScript tests to build tests for custom templates in Google Tag Manager. These test APIs do not need a require() statement. [Learn more about custom template tests].
assertApi
Returns a matcher object that can be used to fluently make assertions about the given API.
Синтаксис
assertApi(apiName)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
apiName | нить | The name of the api to check; same string as passed to require() . |
Matchers
-
Subject.wasCalled() -
Subject.wasNotCalled() -
Subject.wasCalledWith(...expected) -
Subject.wasNotCalledWith(...expected)
Примеры
assertApi('sendPixel').wasCalled();
assertApi('getUrl').wasNotCalled();
assertApi('makeNumber').wasCalledWith('8');
assertApi('setInWindow').wasNotCalledWith('myVar', 'theWrongValue');
assertThat
The assertThat API is modeled after Google's [Truth] library. It returns an object that can be used to fluently make assertions about a subject's value. An assertion failure will immediately stop the test and mark it as failed. However, a failure in one test will not affect other test cases.
Синтаксис
assertThat(actual, opt_message)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
actual | любой | The value to use in the fluent checks. |
opt_message | нить | Optional message to print if the assertion fails. |
Matchers
| Совместитель | Описание |
|---|---|
isUndefined() | Asserts that the subject is undefined . |
isDefined() | Asserts that the subject is not undefined . |
isNull() | Asserts that the subject is null . |
isNotNull() | Asserts that the subject is not null . |
isFalse() | Asserts that the subject is false . |
isTrue() | Asserts that the subject is true . |
isFalsy() | Asserts that the subject is falsy. Falsy values are undefined , null , false , NaN , 0, and '' (empty string). |
isTruthy() | Asserts that the subject is truthy. Falsy values are undefined , null , false , NaN , 0, and '' (empty string). |
isNaN() | Asserts that the subject is the value NaN. |
isNotNaN() | Asserts that the subject is any value besides NaN. |
isInfinity() | Asserts that the subject is positive or negative Infinity. |
isNotInfinity() | Asserts that the subject is any value besides positive or negative Infinity. |
isEqualTo(expected) | Asserts that the subject is equal to the given value. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
isNotEqualTo(expected) | Asserts that the subject is not equal to the given value. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
isAnyOf(...expected) | Asserts that the subject is equal to one of the given value. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
isNoneOf(...expected) | Asserts that the subject is not equal to any of the given values. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
isStrictlyEqualTo(expected) | Asserts that the subject is strictly equal ( === ) to the given value. |
isNotStrictlyEqualTo(expected) | Asserts that the subject is not strictly equal ( !== ) to the given value. |
isGreaterThan(expected) | Asserts that the subject is greater than ( > ) the given value in an ordered comparison. |
isGreaterThanOrEqualTo(expected) | Asserts that the subject is greater than or equal to ( >= ) the given value in an ordered comparison. |
isLessThan(expected) | Asserts that the subject is less than ( < ) the given value in an ordered comparison. |
isLessThanOrEqualTo(expected) | Asserts that the subject is less than or equal to ( <= ) the given value in an ordered comparison. |
contains(...expected) | Asserts that the subject is an array or string that contains all of the given values in any order. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
doesNotContain(...expected) | Asserts that the subject is an array or string that contains none of the given values. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
containsExactly(...expected) | Asserts that the subject is an array that contains all of the given values in any order and no other values. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
doesNotContainExactly(...expected) | Asserts that the subject is an array that has contains a different set of values from the given values in any order. This is a value comparison, not a reference comparison. The contents of objects and arrays are compared recursively. |
hasLength(expected) | Asserts that the subject is an array or string with the given length. The assertion always fails if the value is not an array or string. |
isEmpty() | Asserts that the subject is an array or string that is empty (length = 0). The assertion always fails if the value is not an array or string. |
isNotEmpty() | Asserts that the subject is an array or string that is not empty (length > 0). The assertion always fails if the value is not an array or string. |
isArray() | Asserts that the type of the subject is an array. |
isBoolean() | Asserts that the type of the subject is a boolean. |
isFunction() | Asserts that the type of the subject is a function. |
isNumber() | Asserts that the type of the subject is a number. |
isObject() | Asserts that the type of the subject is an object. |
isString() | Asserts that the type of the subject is a string. |
Примеры
assertThat(undefined).isUndefined();
assertThat(id, 'ID must be defined').isDefined();
assertThat(null).isNull();
assertThat(undefined).isNotNull();
assertThat(true).isTrue();
assertThat(false).isFalse();
assertThat(1).isTruthy();
assertThat('').isFalsy();
assertThat(1/0).isInfinity();
assertThat(0).isNotInfinity();
assertThat(-'foo').isNaN();
assertThat(100).isNotNaN();
assertThat(sentUrl).isEqualTo('https://endpoint.example.com/?account=12345');
assertThat(category).isNotEqualTo('premium');
assertThat(5).isAnyOf(1, 2, 3, 4, 5);
assertThat(42).isNoneOf('the question', undefined, 41.9);
assertThat('value').isStrictlyEqualTo('value');
assertThat('4').isNotStrictlyEqualTo(4);
assertThat(['a', 'b', 'c']).contains('a', 'c');
assertThat(['x', 'y', 'z']).doesNotContain('f');
assertThat(['1', '2', '3']).containsExactly('3', '2', '1');
assertThat(['4', '5']).doesNotContainExactly('4');
assertThat('a string').hasLength(8);
assertThat([]).isEmpty();
assertThat('another string').isNotEmpty();
fail
Immediately fails the current test and prints the given message, if supplied.
Синтаксис
fail(opt_message);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
opt_message | нить | Optional error message text. |
Пример
fail('This test has failed.');
mock
The mock API allows you to override the behavior of Sandboxed APIs. The mock API is safe to use in template code, but it is operational only in test mode. Mocks are reset before each test is run.
Синтаксис
mock(apiName, returnValue);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
apiName | нить | The name of the API to mock; same string as passed to require() |
returnValue | любой | The value to return for the API or a function called in place of the API. If returnValue is a function, that function is called in place of the Sandboxed API; if returnValue is anything other than a function, that value is returned in place of the Sandboxed API. |
Примеры
mock('encodeUri', "https://endpoint.example.com/?account=12345");
mock('sendPixel', function(url, onSuccess, onFailure) {
onSuccess();
});
mockObject
The mockObject API lets you override the behavior of Sandboxed APIs that return an object. The API is safe to use in template code, but it is operational only in test mode. Mocks are reset before each test is run.
Синтаксис
mockObject(apiName, objectMock);
Параметры
| Параметр | Тип | Описание |
|---|---|---|
apiName | нить | The name of the API to mock; same string as passed to require() |
objectMock | объект | The value to return for the API or a function called in place of the API. Must be an object. |
Примеры
const storage = {};
let firestoreId = 1;
function asTestPromise(result) {
return {
then: (callback) => callback(result)
};
}
mockObject('Firestore', {
write: (collection, input) => {
storage[collection + '/' + (++firestoreId)] = input;
return asTestPromise(firestoreId);
},
read: (document) => asTestPromise({data: storage[document]})
});
runCode
Runs the code for the template, ie the content of the Code tab, in the current test environment with a given input data object.
Синтаксис
runCode(data)
Параметры
| Параметр | Тип | Описание |
|---|---|---|
data | объект | Data object to be used in the test. |
Возвращаемое значение
Returns the value of a variable for variable templates; returns undefined for all other template types.
Пример
runCode({field1: 123, field2: 'value'});