W tym dokumencie opisujemy interfejsy API do tagowania po stronie serwera.
addEventCallback
Rejestruje funkcję wywołania zwrotnego, która zostanie wywołana na końcu zdarzenia. Wywołanie zwrotne zostanie wywołane, gdy wszystkie tagi zdarzenia zostaną wykonane. Funkcja zwrotna otrzymuje 2 wartości: identyfikator kontenera, który wywołuje funkcję, oraz obiekt zawierający informacje o zdarzeniu.
Gdy ten interfejs API jest używany w tagu, jest powiązany z bieżącym zdarzeniem. Gdy ten interfejs API jest używany w kliencie, musi być powiązany z określonym zdarzeniem za pomocą funkcji bindToEvent interfejsu API runContainer. Więcej informacji znajdziesz w przykładzie.
Składnia
const addEventCallback = require('addEventCallback');
addEventCallback((containerId, eventData) => {
// Take some action based on the event data.
});
Parametry
| Parametr | Typ | Opis |
|---|---|---|
callback |
function | Funkcja, która ma zostać wywołana po zakończeniu wydarzenia. |
Obiekt eventData zawiera te dane:
| Nazwa klucza | Typ | Opis |
|---|---|---|
tags |
Tablica |
Tablica obiektów danych tagu. Każdy tag, który został uruchomiony podczas zdarzenia, będzie miał wpis w tej tablicy. Obiekt danych tagu zawiera identyfikator tagu (id), jego stan wykonania (status) i czas wykonania (executionTime). Dane tagu będą też zawierać dodatkowe metadane tagu, które zostały w nim skonfigurowane.
|
W przypadku klienta:
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();
}
});
});
W tagu:
const addEventCallback = require('addEventCallback');
addEventCallback((containerId, eventData) => {
// This will be called at the end of the current event.
});
Powiązane uprawnienia
callLater
Planuje asynchroniczne wywołanie funkcji. Funkcja zostanie wywołana po zwróceniu bieżącego kodu. Jest to odpowiednik setTimeout(<function>, 0).
Przykład
const callLater = require('callLater');
const logToConsole = require('logToConsole');
callLater(() => {
logToConsole('Logged asynchronously');
});
Składnia
callLater(function)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
function |
function | Funkcja do wywołania. |
Powiązane uprawnienia
Brak.
claimRequest
Użyj tego interfejsu API w kliencie, aby odebrać żądanie. Gdy żądanie zostanie odebrane, kontener nie uruchamia dodatkowych klientów.
Jeśli ten interfejs API zostanie wywołany w tagu lub zmiennej, zwróci wyjątek. Ten interfejs API zgłasza wyjątek, jeśli zostanie wywołany po zwróceniu klienta (np. jeśli zostanie wywołany w asynchronicznym wywołaniu zwrotnym, takim jak w funkcji callLater lub runContainer onComplete).
Przed wywołaniem interfejsu runContainer klient powinien zgłosić żądanie za pomocą tego interfejsu API.
Przykład
const claimRequest = require('claimRequest');
claimRequest();
Składnia
claimRequest();
Powiązane uprawnienia
Brak.
computeEffectiveTldPlusOne
Zwraca skuteczną domenę najwyższego poziomu + 1 (eTLD+1) podanej domeny lub adresu URL. eTLD+1 jest obliczana na podstawie reguł Listy sufiksów publicznych. eTLD+1 to zwykle domena najwyższego poziomu, w której możesz ustawić plik cookie.
Jeśli argument ma wartość null lub undefined, zwracana jest jego wartość bez zmian. W przeciwnym razie argument jest przekształcany w ciąg znaków. Jeśli argument nie jest prawidłową domeną lub adresem URL, zwracany jest pusty ciąg. Jeśli serwer nie może pobrać listy przyrostków publicznych, zwracana jest niezmieniona wartość argumentu.
Przykład
const computeEffectiveTldPlusOne = require('computeEffectiveTldPlusOne');
// Returns 'example.co.uk'
computeEffectiveTldPlusOne('analytics.example.co.uk');
// Returns 'example.co.uk'
computeEffectiveTldPlusOne('https://analytics.example.co.uk/path');
Składnia
computeEffectiveTldPlusOne(domainOrUrl);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
domainOrUrl |
string | Domena lub adres URL, na podstawie którego ma zostać obliczona wartość eTLD+1. |
Powiązane uprawnienia
Brak.
createRegex
Tworzy nową instancję wyrażenia regularnego i zwraca ją w obiekcie. Nie możesz bezpośrednio uzyskać dostępu do wyrażenia regularnego. Możesz jednak przekazać go do interfejsów API testRegex, String.replace(), String.match() i String.search().
Zwraca null, jeśli wyrażenie regularne jest nieprawidłowe lub Re2 jest niedostępne na serwerze.
Ten interfejs API korzysta z implementacji Re2. Obraz Dockera serwera musi być w 2.0.0 lub nowszej.
Przykład
const createRegex = require('createRegex');
const domainRegex = createRegex('\\w+\\.com', 'i');
// Returns '/foobar'
'example.com/foobar'.replace(domainRegex, '');
Składnia
createRegex(pattern, flags);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
pattern |
string | Tekst wyrażenia regularnego. |
flags |
string | Opcjonalny ciąg znaków zawierający flagi tworzonego wyrażenia regularnego. Obsługiwane są flagi „g” (global) i „i” (ignore case). Wszystkie pozostałe znaki są ignorowane. |
Powiązane uprawnienia
Brak.
Minimalna wersja obrazu
decodeUri
Dekoduje wszystkie zakodowane znaki w podanym URI. Zwraca ciąg tekstowy, który reprezentuje zdekodowany identyfikator URI. Zwraca undefined, gdy otrzyma nieprawidłowe dane wejściowe.
Przykład
const decodeUri = require('decodeUri');
const decodedUrl = decodeUri(data.encodedUrl);
if (decodedUrl) {
// ...
}
Składnia
decodeUri(encoded_uri);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
encoded_uri |
string |
Identyfikator URI zakodowany za pomocą funkcji encodeUri() lub w inny sposób.
|
Powiązane uprawnienia
Brak.
decodeUriComponent
Dekoduje wszystkie zakodowane znaki w podanym komponencie URI. Zwraca ciąg reprezentujący zdekodowany komponent URI. Zwraca undefined, gdy podano nieprawidłowe dane wejściowe.
Przykład
const decodeUriComponent = require('decodeUriComponent');
const decodedQuery = decodeUriComponent(data.query);
if (decodedQuery) {
// ...
}
Składnia
decodeUriComponent(encoded_uri_component);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
encoded_uri_component |
string |
Składnik URI, który został zakodowany za pomocą funkcji encodeUriComponent() lub w inny sposób.
|
Powiązane uprawnienia
Brak.
encodeUri
Zwraca zakodowany identyfikator URI, w którym znaki specjalne zostały zastąpione znakami ucieczki. Zwraca ciąg znaków reprezentujący podany ciąg znaków zakodowany jako identyfikator URI.
Przykład
const encodeUri = require('encodeUri');
const sendHttpGet = require('sendHttpGet');
sendHttpGet('https://www.example.com/' + encodeUri(pathInput));
Składnia
encodeUri(uri);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
uri |
string | Pełny identyfikator URI. |
Powiązane uprawnienia
Brak.
encodeUriComponent
Zwraca zakodowany identyfikator URI, w którym znaki specjalne zostały zastąpione znakami ucieczki. Zwraca ciąg znaków reprezentujący podany ciąg znaków zakodowany jako identyfikator URI.
Przykład
const encodeUriComponent = require('encodeUriComponent');
const sendHttpGet = require('sendHttpGet');
sendHttpGet('https://www.example.com/?' + encodeUriComponent(queryInput));
Składnia
encodeUriComponent(str);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
str |
string | Składnik identyfikatora URI. |
Powiązane uprawnienia
Brak.
extractEventsFromMpv1
Tłumaczy przychodzące żądanie Measurement Protocol w wersji 1 na listę zdarzeń w formacie Unified Schema. Zwraca listę wyodrębnionych zdarzeń. Zwraca błąd, jeśli żądanie ma nieprawidłowy format.
Przykład
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.
}
}
Składnia
extractEventsFromMpv1();
Powiązane uprawnienia
Wymaga uprawnień read_request. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
bodyquery parameters
extractEventsFromMpv2
Tłumaczy przychodzące żądanie Measurement Protocol w wersji 2 na listę zdarzeń w formacie Unified Schema. Zwraca listę wyodrębnionych zdarzeń. Zwraca błąd, jeśli żądanie ma nieprawidłowy format.
Przykład
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.
}
}
Składnia
extractEventsFromMpv2();
Powiązane uprawnienia
Wymaga uprawnień read_request. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
bodyquery parameters
fromBase64
Dekoduje ciąg zakodowany w formacie Base64. Zwraca undefined, jeśli dane wejściowe są nieprawidłowe.
Składnia
fromBase64(base64EncodedString);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
base64EncodedString |
string | Ciąg zakodowany w formacie Base64. |
Przykład
const fromBase64 = require('fromBase64');
const greeting = fromBase64('aGVsbG8=');
if (greeting === 'hello') {
// ...
}
Powiązane uprawnienia
Brak.
generateRandom
Zwraca losową liczbę (całkowitą) z podanego zakresu.
Przykład
const generateRandom = require('generateRandom');
const randomValue = generateRandom(0, 10000000);
Składnia
generateRandom(min, max);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
min |
number | Minimalna potencjalna wartość zwracanej liczby całkowitej (włącznie). |
max |
number | Maksymalna potencjalna wartość zwracanej liczby całkowitej (włącznie). |
Powiązane uprawnienia
Brak.
getAllEventData
Zwraca kopię danych zdarzenia.
Składnia
getAllEventData();
Powiązane uprawnienia
getClientName
Zwraca ciąg tekstowy zawierający nazwę bieżącego klienta.
Składnia
getClientName();
Powiązane uprawnienia
getContainerVersion
Zwraca obiekt zawierający dane o bieżącym kontenerze. Zwrócony obiekt będzie zawierać te pola:
{
containerId: string,
debugMode: boolean,
environmentName: string,
environmentMode: boolean,
previewMode: boolean,
version: string,
}
Przykład
const getContainerVersion = require('getContainerVersion');
const containerVersion = getContainerVersion();
const containerId = containerVersion['containerId'];
const isDebug = containerVersion['debugMode'];
Składnia
getContainerVersion();
Powiązane uprawnienia
getCookieValues
Zwraca tablicę zawierającą wartości wszystkich plików cookie o podanej nazwie.
Przykład
const getCookieValues = require('getCookieValues');
const lastVisit = getCookieValues('lastVisit')[0];
if (lastVisit) {
// ...
}
Składnia
getCookieValues(name[, noDecode]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
name |
string | Nazwa pliku cookie. |
noDecode |
wartość logiczna |
Jeśli wartość to true, wartości plików cookie nie będą dekodowane przed zwróceniem. Domyślna wartość to false.
|
Powiązane uprawnienia
getEventData
Zwraca kopię wartości w danej ścieżce w danych zdarzenia. Zwraca wartość
undefined, jeśli nie ma danych zdarzenia lub jeśli w podanej ścieżce nie ma wartości.
Przykład
const getEventData = require('getEventData');
const campaignId = getEventData('campaign.id');
const itemId = getEventData('items.0.id');
const referrer = getEventData('page_referrer');
Parametry
| Parametr | Typ | Opis |
|---|---|---|
keyPath |
dowolny |
Ścieżka klucza, w której poszczególne komponenty są rozdzielone kropkami. Komponentami ścieżki mogą być klucze w obiekcie lub indeksy w tablicy. Jeśli keyPath nie jest ciągiem znaków, zostanie przekształcony w ciąg znaków.
|
Składnia
getEventData(keyPath);
Powiązane uprawnienia
getGoogleAuth
Zwraca obiekt autoryzacji, który po użyciu z sendHttpGet lub sendHttpRequest będzie zawierać nagłówek autoryzacji dla interfejsów API Google Cloud. Ten interfejs API używa domyślnego uwierzytelniania aplikacji do automatycznego znajdowania danych logowania w środowisku serwera.
Przykład
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();
}
});
Składnia
getGoogleAuth(scopes);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
scopes
|
Tablica | Tablica zakresów protokołu OAuth 2.0 interfejsu API Google, o które chcesz poprosić o dostęp. |
Powiązane uprawnienia
Wymaga uprawnień use_google_credentials. Uprawnienie musi być skonfigurowane z co najmniej 1 dozwolonym zakresem.
getGoogleScript
Pobiera zasób z określonego zestawu skryptów Google i zwraca obietnicę ze skryptem i powiązanymi metadanymi pamięci podręcznej.
Obietnica zostanie rozwiązana w obiekcie zawierającym 2 klucze: script i metadata. Jeśli żądanie się nie powiedzie, obietnica zostanie odrzucona z kluczem reason.
Obiekt metadata będzie zawierać te metadane buforowania na podstawie nagłówków odpowiedzi zasobu. Każde pole będzie obecne tylko wtedy, gdy odpowiedni nagłówek znajduje się w odpowiedzi zasobu.
{
'cache-control': string,
'expires': string,
'last-modified': string,
}
Przykład
const getGoogleScript = require('getGoogleScript');
getGoogleScript('ANALYTICS').then((result) => {
// Operate on result.script and result.metadata here.
});
Składnia
getGoogleScript(script[, options]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
script |
string |
Nazwa skryptu. Obsługiwane skrypty to 'ANALYTICS', 'GTAG' i 'GTM'.Opcja 'ANALYTICS'
pobiera skrypt Google Analytics z https://www.google-analytics.com/analytics.js.Opcja 'GTAG' pobiera skrypt globalnego tagu witryny (gtag.js) z https://www.googletagmanager.com/gtag/js.Opcja 'GTM' pobiera skrypt Menedżera tagów Google z domeny https://www.googletagmanager.com/gtm.js.
|
options |
object | Opcjonalne opcje żądania. Obsługiwane opcje znajdziesz poniżej. |
Opcje
| Opcja | Typ | Opis |
|---|---|---|
id |
string |
Dotyczy 'GTAG' z identyfikatorem pomiaru gtag i 'GTM' z identyfikatorem kontenera internetowego (np. GTM-XXXX).
|
debug |
dowolny | Jeśli wartość jest prawdziwa, żąda i zwraca wersję debugowania skryptu pomiarowego. |
timeout |
number |
Czas oczekiwania na żądanie w milisekundach. Wartości nie dodatnie są ignorowane. Jeśli żądanie przekroczy limit czasu, wywołanie zwrotne zostanie wywołane z wartością undefined dla wartości skryptu i {} dla obiektu metadanych.
|
Nierozpoznane klucze opcji są ignorowane.
Powiązane uprawnienia
Wymaga uprawnień send_http. Uprawnienia muszą być skonfigurowane tak, aby zezwalały na dostęp co najmniej do:
- Zezwól na używanie domen Google
getRemoteAddress
Zwraca ciąg znaków reprezentujący adres IP, z którego pochodzi żądanie, np. 12.345.67.890 w przypadku IPv4 lub 2001:0db8:85a3:0:0:8a2e:0370:7334 w przypadku IPv6, odczytując nagłówki żądań, takie jak Forwarded i X-Forwarded-For.
Uwaga: ten interfejs API podejmuje próbę wykrycia pierwotnego adresu IP, ale nie może zagwarantować, że wynik będzie dokładny.
Składnia
getRemoteAddress();
Powiązane uprawnienia
Wymaga uprawnień read_request. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
- Nagłówki
ForwardediX-Forwarded-For - Zdalny adres IP
getRequestBody
Zwraca treść żądania jako ciąg tekstowy, jeśli jest obecna, lub undefined w przeciwnym razie.
Składnia
getRequestBody();
Powiązane uprawnienia
getRequestHeader
Zwraca wartość nazwanego nagłówka żądania jako ciąg tekstowy, jeśli jest obecny, lub undefined w przeciwnym razie. Jeśli nagłówek jest powtórzony, zwrócone wartości są łączone za pomocą znaku ', '.
Przykład
const getRequestHeader = require('getRequestHeader');
const host = getRequestHeader('host');
Składnia
getRequestHeader(headerName);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
headerName |
string | Nazwa nagłówka. Wielkość liter w tej wartości nie jest rozróżniana. |
Powiązane uprawnienia
getRequestMethod
Zwraca metodę żądania, np. 'GET' lub 'POST', jako ciąg znaków.
Przykład
const getRequestMethod = require('getRequestMethod');
if (getRequestMethod() === 'POST') {
// Handle the POST request here.
}
Składnia
getRequestMethod();
Powiązane uprawnienia
Brak.
getRequestPath
Zwraca ścieżkę żądania bez ciągu zapytania. Jeśli np. adres URL to '/foo?id=123', funkcja zwraca '/foo'. Automatycznie usuwa z ścieżki prefiks adresu URL kontenera serwera. Jeśli np. adres URL kontenera serwera to https://example.com/analytics, a ścieżka żądania to '/analytics/foo', ta funkcja zwraca wartość '/foo'.
Przykład
const getRequestPath = require('getRequestPath');
const requestPath = getRequestPath();
if (requestPath === '/') {
// Handle a request for the root path.
}
Składnia
getRequestPath();
Powiązane uprawnienia
getRequestQueryParameter
Zwraca zdekodowaną wartość nazwanego parametru ciągu zapytania jako ciąg znaków lub undefined, jeśli parametr nie jest obecny. Jeśli parametr powtarza się w ciągu zapytania, zwracana jest pierwsza wartość, która pojawia się w tym ciągu.
Przykład
const getRequestQueryParameter = require('getRequestQueryParameter');
const query = getRequestQueryParameter('query');
if (query) {
// Process query here.
}
Składnia
getRequestQueryParameter(name);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
name |
string | Nazwa parametru zapytania. |
Powiązane uprawnienia
getRequestQueryParameters
Zwraca parametry zapytania przychodzącego żądania HTTP jako obiekt, który mapuje nazwy parametrów zapytania na odpowiednie wartości. Nazwy i wartości parametrów są dekodowane.
Przykład
const getRequestQueryParameters = require('getRequestQueryParameters');
const queryParameters = getRequestQueryParameters();
if (queryParameters['search']) {
// Handle the search query here.
const maxResults = queryParameters['max_results'];
}
Składnia
getRequestQueryParameters();
Powiązane uprawnienia
getRequestQueryString
Zwraca zapytanie w żądaniu w postaci ciągu znaków bez początkowego znaku zapytania lub pusty ciąg znaków, jeśli adres URL żądania nie zawiera ciągu zapytania.
Przykład
const getRequestQueryString = require('getRequestQueryString');
const queryString = getRequestQueryString();
if (queryString !== '') {
// Handle the query string.
}
Składnia
getRequestQueryString();
Powiązane uprawnienia
getTimestamp
Wycofano. Zalecamy używanie funkcji getTimestampMillis.
Zwraca liczbę reprezentującą bieżący czas w milisekundach od początku epoki systemu Unix, zgodnie z wartością zwracaną przez Date.now().
Składnia
getTimestamp();
Powiązane uprawnienia
Brak.
getTimestampMillis
Zwraca liczbę reprezentującą bieżący czas w milisekundach od początku epoki systemu Unix, zgodnie z wartością zwracaną przez Date.now().
Składnia
getTimestampMillis();
Powiązane uprawnienia
Brak.
getType
Zwraca ciąg tekstowy opisujący typ danej wartości.
| Typ wejściowy | Zwracana wartość |
|---|---|
| string | 'string' |
| number | 'number' |
| wartość logiczna | 'boolean' |
| null | 'null' |
| undefined | 'undefined' |
| Tablica | 'array' |
| Obiekt | 'object' |
| Funkcja | 'function' |
Przykład
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);
}
Składnia
getType(value);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
value |
dowolny | Wartość wejściowa. |
Powiązane uprawnienia
Brak.
hmacSha256
Oblicza zakodowany podpis za pomocą kodu HMAC z SHA-256. Domyślnie używane jest kodowanie base64url.
Aby korzystać z tego interfejsu API, ustaw na serwerze zmienną środowiskową SGTM_CREDENTIALS na ścieżkę pliku klucza JSON zakodowanego w UTF-8 w tym formacie:
{
"keys": {
"key1": "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5",
"key2": "OTg3NjU0MzIxMHp5eHd2dXRzcnFwb25tbGtqaWhnZmVkY2Jh",
...
}
}
Wartości to klucze HMAC zakodowane w formacie base64. Tekst JSON nie może zaczynać się od znacznika kolejności bajtów.
Przykład
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;
Składnia
hmacSha256(data, keyId, options)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
data |
string | Dane do obliczenia wartości HMAC. |
keyId
|
string | Identyfikator klucza z pliku kluczy JSON, który odnosi się do klucza, którego chcesz użyć. |
options
|
object | Opcjonalna konfiguracja interfejsu API. (Zobacz Opcje poniżej). |
Opcje
| Opcja | Typ | Opis |
|---|---|---|
outputEncoding
|
string | Określa format kodowania wartości zwracanej. Obsługiwane formaty to hex, base64 lub base64url. Jeśli nie zostanie podana, domyślnie przyjmuje wartość base64url. |
Powiązane uprawnienia
Minimalna wersja obrazu
isRequestMpv1
Zwraca wartość true, jeśli przychodzące żądanie jest żądaniem Measurement Protocol w wersji 1, lub false w innych przypadkach.
Przykład
const isRequestMpv1 = require('isRequestMpv1');
if (isRequestMpv1()) {
// Handle Measurement Protocol V1 request.
const events = extractEventsFromMpv1();
}
Składnia
isRequestMpv1();
Powiązane uprawnienia
Brak.
isRequestMpv2
Zwraca wartość true, jeśli przychodzące żądanie jest żądaniem Measurement Protocol 2, lub false w innych przypadkach.
Przykład
const isRequestMpv2 = require('isRequestMpv2');
if (isRequestMpv2()) {
// Handle Measurement Protocol V2 request.
const events = extractEventsFromMpv2();
}
Składnia
isRequestMpv2();
Powiązane uprawnienia
Brak.
logToConsole
Zapisuje argumenty w konsoli.
Te logi są widoczne w Eksploratorze logów w konsoli Google Cloud.
W Eksploratorze logów uruchom zapytanie logName =~ "stdout", aby wyświetlić wpisy w logach utworzone przez ten interfejs API.
Przykład
const logToConsole = require('logToConsole');
const that = 123;
const those = { ... };
logToConsole('that is: ', that, ' and those is: ', those);
Składnia
logToConsole(argument1[, argument2, ...]);
Parametry
Interfejs API przyjmuje co najmniej 1 argument, z którego każdy jest w razie potrzeby konwertowany na ciąg znaków i rejestrowany w konsoli.
Powiązane uprawnienia
makeInteger
Konwertuje podaną wartość na liczbę (całkowitą).
Składnia
makeInteger(value);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
value |
dowolny typ | Wartość do przekonwertowania. |
Powiązane uprawnienia
Brak.
makeNumber
Konwertuje podaną wartość na liczbę.
Składnia
makeNumber(value);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
value |
dowolny typ | Wartość do przekonwertowania. |
Powiązane uprawnienia
Brak.
makeString
Zwraca podaną wartość jako ciąg tekstowy.
Składnia
makeString(value);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
value |
dowolny typ | Wartość do przekonwertowania. |
Powiązane uprawnienia
Brak.
makeTableMap
Konwertuje prosty obiekt tabeli z 2 kolumnami na Map. Służy do przekształcania pola szablonu SIMPLE_TABLE z 2 kolumnami w łatwiejszy w obsłudze format.
Na przykład ta funkcja może przekształcić obiekt tabeli:
[
{'key': 'k1', 'value': 'v1'},
{'key': 'k2', 'value': 'v2'}
]
na mapę:
{
'k1': 'v1',
'k2': 'v2'
}
Zwraca obiekt: dodano do niego przekonwertowane Map par klucz-wartość lub null w innych przypadkach.
Składnia
makeTableMap(tableObj, keyColumnName, valueColumnName);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
tableObj |
Wyświetl listę |
Obiekt tabeli do przekonwertowania. Jest to lista map, w której każdy element Map reprezentuje wiersz w tabeli. Każda nazwa właściwości w obiekcie wiersza jest nazwą kolumny, a wartość właściwości jest wartością kolumny w wierszu.
|
keyColumnName |
string |
Nazwa kolumny, której wartości staną się kluczami w przekonwertowanym plikuMap.
|
valueColumnName |
string |
Nazwa kolumny, której wartości staną się wartościami w przekonwertowanym polu Map.
|
Powiązane uprawnienia
Brak.
parseUrl
Zwraca obiekt zawierający wszystkie części składowe danego adresu URL, podobnie jak obiekt URL.
W przypadku nieprawidłowego adresu URL ten interfejs API zwróci wartość undefined. W przypadku prawidłowo sformatowanych adresów URL pola, które nie występują w ciągu adresu URL, będą miały wartość pustego ciągu znaków lub, w przypadku pola searchParams, pustego obiektu.
Zwrócony obiekt będzie zawierać te pola:
{
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,
}
Przykład
const parseUrl = require('parseUrl');
const urlObject = parseUrl('https://abc:xyz@example.com:8080/foo?param=val%2Cue#bar');
Składnia
parseUrl(url);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
url |
string | Pełny adres URL, który zostanie przeanalizowany. |
Powiązane uprawnienia
Brak.
returnResponse
Wysyła odpowiedź, która została wcześniej ustawiona przez inne szablony za pomocą interfejsów API modyfikujących odpowiedź, w tym setCookie, setPixelResponse, setResponseBody, setResponseHeader i setResponseStatus. Domyślnie jest to kod stanu HTTP 200, pusta treść i brak nagłówków.
Zalecamy używanie tego interfejsu API w szablonie klienta.
Składnia
returnResponse();
Przykład
Zobacz runContainer przykład.
Powiązane uprawnienia
runContainer
Uruchamia logikę kontenera (zmienne, reguły, tagi) w zakresie zdarzenia. Jeśli ten interfejs API zostanie wywołany podczas wykonywania kontenera, kontener zostanie uruchomiony ponownie.
Wywołania zwrotne onComplete i onStart otrzymują funkcję o nazwie bindToEvent. Użyj bindToEvent, aby uruchomić interfejs API w kontekście wydarzenia.
Więcej informacji znajdziesz w przykładzie addEventCallback.
Zalecamy używanie tego interfejsu API w szablonie klienta.
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());
Składnia
runContainer(event, onComplete, onStart);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
event |
object | Parametry zdarzenia. |
onComplete |
function | Wywołanie zwrotne, które jest wywoływane po uruchomieniu wszystkich tagów. |
onStart |
function | Funkcja zwrotna wywoływana natychmiast, zanim zaczną się uruchamiać tagi. |
Powiązane uprawnienia
sendEventToGoogleAnalytics
Wysyła do Google Analytics pojedyncze zdarzenie za pomocą danych zdarzenia wspólnego i zwraca obietnicę, która jest rozwiązywana jako obiekt z kluczem location lub odrzucana jako obiekt z kluczem reason. Miejsce docelowe, czyli Google Analytics 4, jest określane na podstawie identyfikatora pomiaru w danych zdarzenia.
Pole location jest ustawione na nagłówek location, jeśli jest obecny.
Przykład
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();
});
Składnia
sendEventToGoogleAnalytics(event);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
event |
object | Zdarzenie w formacie ujednoliconego schematu. |
Powiązane uprawnienia
Wymaga uprawnień send_http. Uprawnienia muszą być skonfigurowane tak, aby zezwalały na dostęp co najmniej do:
- Zezwól na używanie domen Google
sendHttpGet
Wysyła żądanie HTTP GET na określony adres URL i zwraca obietnicę, która jest realizowana z wynikiem po zakończeniu żądania lub przekroczeniu limitu czasu.
Wynikiem jest obiekt zawierający 3 klucze: statusCode, headers i body. Jeśli żądanie się nie powiedzie (np. nieprawidłowy adres URL, brak trasy do hosta, nieudane negocjacje SSL itp.), obietnica zostanie odrzucona z błędem: {reason:
'failed'}. Jeśli opcja timeout została ustawiona, a limit czasu żądania upłynął, obietnica zostanie odrzucona z tym błędem: {reason: 'timed_out'}
Przykład
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);
Składnia
sendHttpGet(url[, options]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
url |
string | Żądany adres URL. |
options
|
object | Opcjonalne opcje żądania. (Zobacz Opcje poniżej). |
Opcje
| Opcja | Typ | Opis |
|---|---|---|
headers |
string | Dodatkowe nagłówki żądań. |
timeout
|
number | Czas oczekiwania (w milisekundach) przed przerwaniem żądania. Domyślna wartość to 15000. |
authorization
|
object | Opcjonalny obiekt autoryzacji z wywołania funkcji getGoogleAuth, który umożliwia dołączanie nagłówków autoryzacji podczas wysyłania żądań do usługi googleapis.com. |
Powiązane uprawnienia
sendHttpRequest
Wysyła żądanie HTTP na określony adres URL i zwraca obietnicę, która jest spełniana po zakończeniu żądania lub przekroczeniu limitu czasu.
Wynikiem jest obiekt zawierający 3 klucze: statusCode, headers i body. Jeśli żądanie się nie powiedzie (np. nieprawidłowy adres URL, brak trasy do hosta, nieudane negocjacje SSL itp.), obietnica zostanie odrzucona z błędem: {reason:
'failed'}. Jeśli opcja timeout została ustawiona, a limit czasu żądania upłynął, obietnica zostanie odrzucona z tym błędem: {reason: 'timed_out'}
Przykład
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']);
});
Składnia
sendHttpRequest(url[, options[, body]]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
url |
string | Żądany adres URL. |
options
|
object | Opcjonalne opcje żądania. (Zobacz Opcje poniżej). |
body |
string | Opcjonalna treść żądania. |
Opcje
| Opcja | Typ | Opis |
|---|---|---|
headers |
string | Dodatkowe nagłówki żądań. |
method |
object | Metoda żądania. Domyślna wartość to GET. |
timeout
|
number | Czas oczekiwania (w milisekundach) przed przerwaniem żądania. Domyślna wartość to 15000. |
authorization
|
object | Opcjonalny obiekt autoryzacji z wywołania funkcji getGoogleAuth, który umożliwia dołączanie nagłówków autoryzacji podczas wysyłania żądań do usługi googleapis.com. |
Powiązane uprawnienia
sendPixelFromBrowser
Wysyła do przeglądarki polecenie wczytania podanego adresu URL jako tagu <img>. Ten protokół poleceń jest obsługiwany w tagu Google w GA4 i w tagach internetowych Google Analytics: zdarzenie GA. Musisz skonfigurować adres URL kontenera serwera. Więcej informacji znajdziesz w instrukcjach.
Ten interfejs API zwraca wartość false, jeśli żądanie przychodzące nie obsługuje protokołu poleceń lub jeśli odpowiedź została już opróżniona. W przeciwnym razie interfejs API zwraca true.
Przykład:
const sendPixelFromBrowser = require('sendPixelFromBrowser');
sendPixelFromBrowser('https://example.com/?id=123');
Składnia
sendPixelFromBrowser(url)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
url |
string | Adres URL, który ma zostać wysłany do przeglądarki. |
Powiązane uprawnienia
setCookie
Ustawia lub usuwa plik cookie z określonymi opcjami.
Aby usunąć plik cookie, musisz ustawić plik cookie z tą samą ścieżką i domeną, w której został utworzony, i przypisać mu wartość wygaśnięcia z przeszłości, np. "Thu, 01 Jan 1970 00:00:00 GMT".
Pamiętaj, że aby odpowiedź została odesłana do klienta, musisz wywołać funkcję returnResponse.
Przykład
const setCookie = require('setCookie');
// Sets an httpOnly cookie with a max-age of 3600.
setCookie('cookieName', 'cookieValue', {'max-age': 3600, httpOnly: true});
Składnia
setCookie(name, value[, options[, noEncode]]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
name |
string | Nazwa pliku cookie. W nazwie nie jest rozróżniana wielkość liter. |
value |
string | Wartość pliku cookie. |
options |
object | Opcjonalne atrybuty plików cookie:domain, expires, fallbackDomain, httpOnly, max-age, path, secure i sameSite. (Zobacz Opcje poniżej). |
noEncode |
wartość logiczna |
Jeśli wartość to „prawda”, wartość pliku cookie nie będzie kodowana. Domyślna wartość to false.
|
domain:host, do którego zostanie wysłany plik cookie. Jeśli ustawisz specjalną wartość „auto”, host zostanie automatycznie obliczony zgodnie z tą strategią:
- eTLD+1 nagłówka
Forwarded, jeśli jest obecny. - eTLD+1 nagłówka
X-Forwarded-Host, jeśli jest obecny. - eTLD+1 nagłówka
Host.
- eTLD+1 nagłówka
expires: maksymalny okres ważności pliku cookie. Musi to być ciąg daty w formacie UTC, np. „Sat, 26 Oct 1985 08:21:00 GMT”. Jeśli ustawione są zarówno wartości
expires, jak imax-age, pierwszeństwo ma wartośćmax-age.httpOnly: uniemożliwia JavaScriptowi dostęp do pliku cookie, jeśli
true.max-age: liczba sekund do wygaśnięcia pliku cookie. Wartość zero lub ujemna spowoduje natychmiastowe wygaśnięcie pliku cookie. Jeśli ustawione są zarówno parametr
expires, jak i parametrmax-age, pierwszeństwo ma parametrmax-age.path: ścieżka, która musi występować w żądanym adresie URL, w przeciwnym razie przeglądarka nie wyśle nagłówka Cookie.
secure: jeśli ustawisz wartość
true, plik cookie będzie wysyłany na serwer tylko wtedy, gdy żądanie zostanie wysłane z punktu końcowegohttps:.sameSite: potwierdza, że plik cookie nie może być wysyłany w przypadku żądań z innych domen. Musi to być wartość
'strict','lax'lub'none'.
Powiązane uprawnienia
setPixelResponse
Ustawia treść odpowiedzi na GIF-a o rozmiarach 1x1, ustawia nagłówek Content-Type na „image/gif”, ustawia nagłówki buforowania tak, aby agenci użytkownika nie buforowali odpowiedzi, i ustawia stan odpowiedzi na 200.
Pamiętaj, że aby odpowiedź została odesłana do klienta, musisz wywołać funkcję returnResponse.
Składnia
setPixelResponse();
Powiązane uprawnienia
Wymaga uprawnień access_response. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
headers– musi zezwalać na te klucze:content-typecache-controlexpirespragma
bodystatus
setResponseBody
Ustawia treść odpowiedzi na argument.
Pamiętaj, że aby odpowiedź została odesłana do klienta, musisz wywołać funkcję returnResponse.
Składnia
setResponseBody(body[, encoding]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
body |
string | Wartość, która ma być ustawiona jako treść odpowiedzi. |
encoding |
string |
Kodowanie znaków treści odpowiedzi (domyślnie 'utf8'). Obsługiwane wartości to 'ascii', 'utf8', 'utf16le', 'ucs2', 'base64', 'latin1', 'binary' i 'hex'.
|
Powiązane uprawnienia
Wymaga uprawnień access_response. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
body
setResponseHeader
Ustawia nagłówek w zwracanej odpowiedzi. Jeśli nagłówek o tej nazwie (bez uwzględniania wielkości liter) został wcześniej ustawiony przez ten interfejs API, późniejsze wywołanie zastąpi lub wyczyści wartość ustawioną przez poprzedniego wywołującego.
Pamiętaj, że aby odpowiedź została odesłana do klienta, musisz wywołać funkcję returnResponse.
Składnia
setResponseHeader(name, value);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
name |
string | Nazwa nagłówka. W nazwach nagłówków HTTP nie jest rozróżniana wielkość liter, więc nazwa nagłówka zostanie zapisana małymi literami. |
value |
string undefined | Wartość nagłówka. Jeśli wartość to null lub undefined, powoduje to usunięcie nazwanego nagłówka z odpowiedzi, która zostanie zwrócona. |
Powiązane uprawnienia
Wymaga uprawnień access_response. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
headers
setResponseStatus
Ustawia kod stanu HTTP odpowiedzi, która zostanie zwrócona.
Pamiętaj, że aby odpowiedź została odesłana do klienta, musisz wywołać funkcję returnResponse.
Składnia
setResponseStatus(statusCode);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
statusCode |
number | Kod stanu HTTP, który ma zostać zwrócony. |
Powiązane uprawnienia
Wymaga uprawnień access_response. Uprawnienia muszą być skonfigurowane tak, aby zezwalać na dostęp co najmniej do:
status
sha256
Oblicza skrót SHA-256 danych wejściowych i wywołuje wywołanie zwrotne ze skrótem zakodowanym w formacie base64, chyba że obiekt options określa inne kodowanie wyjściowe.
Sygnatura i działanie tego interfejsu API są zgodne z interfejsem sha256 API w przypadku kontenerów internetowych. Szablony niestandardowe w kontenerach serwera powinny jednak używać interfejsu sha256Sync API, aby uprościć kod.
Przykład
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'});
Składnia
sha256(input, onSuccess, options = undefined);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
input |
string | Ciąg znaków do zaszyfrowania. |
onSuccess |
function |
Wywoływana z wynikowym skrótem zakodowanym w formacie Base64, chyba że obiekt options określa inne kodowanie wyjściowe.
|
options |
object |
Opcjonalny obiekt opcji określający kodowanie danych wyjściowych. Jeśli obiekt został określony, powinien zawierać klucz outputEncoding z wartością base64 lub hex.
|
Powiązane uprawnienia
Brak.
sha256Sync
Oblicza i zwraca skrót SHA-256 danych wejściowych zakodowany w formacie base64, chyba że obiekt options określa inne kodowanie wyjściowe.
Przykład
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));
Składnia
sha256Sync(input, options = undefined);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
input |
string | Ciąg znaków do zaszyfrowania. |
options |
object |
Opcjonalny obiekt opcji określający kodowanie danych wyjściowych. Jeśli obiekt został określony, powinien zawierać klucz outputEncoding z wartością base64 lub hex.
|
Powiązane uprawnienia
Brak.
templateDataStorage
Zwraca obiekt z metodami dostępu do pamięci danych szablonu. Przechowywanie danych szablonu umożliwia udostępnianie danych w ramach wielu wykonań jednego szablonu. Dane przechowywane w pamięci danych szablonu są zachowywane na serwerze, na którym działa kontener. W większości przypadków kontener jest uruchamiany na wielu serwerach, więc przechowywanie danych w pamięci danych szablonu nie gwarantuje, że każde kolejne żądanie będzie miało do nich dostęp.
Słowo „data” w nazwie „templateDataStorage” oznacza, że za pomocą tego interfejsu API można przechowywać tylko proste typy danych, które nie są funkcjami. Wszelkie funkcje lub odwołania do funkcji przekazywane do interfejsu API będą przechowywane jako null.
Składnia
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();
Przykład
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);
});
Powiązane uprawnienia
testRegex
Sprawdza, czy ciąg znaków pasuje do wyrażenia regularnego utworzonego za pomocą interfejsu createRegex API. Zwraca true, jeśli wyrażenie regularne jest zgodne. W przeciwnym razie zwraca wartość false.
Wyrażenie regularne utworzone z flagą globalną jest stanowe. Szczegółowe informacje znajdziesz w dokumentacji RegExp.
Przykład
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');
Składnia
testRegex(regex, string);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
regex |
Obiekt | Wyrażenie regularne do testowania, zwracane przez interfejs createRegex API. |
string |
string | Ciąg testowy do przetestowania. |
Powiązane uprawnienia
Brak.
toBase64
Koduje ciąg znaków w formacie base64 lub base64url. Domyślnie używane jest kodowanie base64.
Składnia
toBase64(input, options);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
input |
string | Ciąg znaków do zakodowania. |
options
|
object | Opcjonalna konfiguracja interfejsu API. (Zobacz Opcje poniżej). |
Opcje
| Opcja | Typ | Opis | Wersja minimalna |
|---|---|---|---|
urlEncoding
|
wartość logiczna | Jeśli ma wartość „prawda”, wynik zostanie zakodowany w formacie base64url. |
1.0.0 |
Przykład
const toBase64 = require('toBase64');
const base64Hello = toBase64('hello');
const base64UrlHello = toBase64('hello', {urlEncoding: true});
Powiązane uprawnienia
Brak.
BigQuery
Zwraca obiekt, który udostępnia funkcje BigQuery.
Funkcja BigQuery.insert umożliwia zapisywanie danych w tabeli BigQuery. Zwraca obietnicę, która jest spełniana po pomyślnym wstawieniu lub odrzucana w przypadku błędu.
Gdy wstawianie się powiedzie, obietnica zostanie spełniona bez argumentów.
Jeśli wstawianie się nie powiedzie, obietnica zostanie odrzucona z listą obiektów zawierających przyczynę błędu i ewentualnie obiekt wiersza, jeśli wystąpi błąd. Możliwe jest, że część żądania zostanie zrealizowana, a część nie. W tym przypadku obietnica jest odrzucana z listą błędów dla każdego wiersza z obiektem wiersza, aby ułatwić odróżnienie wstawionych wierszy (patrz Przykłady błędów poniżej). Więcej informacji znajdziesz w dokumentacji BigQuery dotyczącej komunikatów o błędach.
Składnia
BigQuery.insert(connectionInfo, rows[, options]);
| Parametr | Typ | Opis |
|---|---|---|
connectionInfo |
object |
Określa informacje wymagane do połączenia z tabelą BigQuery. Dostępny jest 1 parametr opcjonalny i 2 parametry wymagane:
|
rows |
Tablica | Wiersze do wstawienia do tabeli. |
options |
object | Opcjonalne opcje żądania. Obsługiwane opcje to:ignoreUnknownValues i skipInvalidRows. Nieznane klucze opcji są ignorowane. (Zobacz Opcje poniżej). |
| Parametr | Typ | Opis |
|---|---|---|
ignoreUnknownValues |
wartość logiczna | Jeśli ta opcja jest ustawiona na true, akceptuj wiersze zawierające wartości, które nie pasują do schematu. Nieznane wartości są ignorowane. Domyślna wartość to false. |
skipInvalidRows |
wartość logiczna | Jeśli ustawisz wartość true, wstawisz wszystkie prawidłowe wiersze żądania, nawet jeśli istnieją nieprawidłowe wiersze. Domyślna wartość to false. |
Błąd „Nie znaleziono modułu” oznacza, że kontener serwera prawdopodobnie korzysta ze starszej wersji naszego obrazu, która nie zawierała jeszcze modułu BigQuery. Ponownie wdróż kontener serwera z tymi samymi ustawieniami, korzystając z naszego skryptu wdrażania. Po zakończeniu operacji moduł zostanie automatycznie uwzględniony.
Błąd związany z brakiem wstawienia zwykle zawiera 1 obiekt błędu z kluczem reason:
[{reason: 'invalid'}]
Błąd wstawiania może zawierać wiele obiektów błędów z tablicą errors i obiektem row. Oto przykład odpowiedzi o błędzie podczas wstawiania 2 wierszy, z których tylko 1 zawiera błąd:
[
{
"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
}
}
]
Przykład
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);
Powiązane uprawnienia
Firestore
Zwraca obiekt, który udostępnia funkcje Firestore.
Ten interfejs API obsługuje tylko Firestore w trybie natywnym, a nie Firestore w trybie Datastore. Interfejs API obsługuje też tylko domyślną bazę danych.
Firestore.read
Funkcja Firestore.read odczytuje dane z dokumentu Firestore i zwraca obietnicę, która jest rozwiązywana jako obiekt zawierający 2 klucze: id i data. Jeśli dokument nie istnieje, obietnica zostanie odrzucona z obiektem zawierającym klucz reason o wartości not_found.
Składnia
Firestore.read(path[, options]);
| Parametr | Typ | Opis |
|---|---|---|
path |
string | Ścieżka do dokumentu lub kolekcji. Nie może zaczynać się ani kończyć znakiem „/”. |
options |
object | Opcjonalne opcje żądania. Obsługiwane opcje to: projectId, disableCache i transaction. Klucze opcji Unknown są ignorowane. (Zobacz Opcje poniżej). |
| Parametr | Typ | Opis |
|---|---|---|
projectId |
string | Opcjonalnie. Identyfikator projektu Google Cloud Platform. Jeśli ten parametr zostanie pominięty, wartość projectId zostanie pobrana ze zmiennej środowiskowej GOOGLE_CLOUD_PROJECT, o ile ustawienie uprawnień access_firestore dla identyfikatora projektu ma wartość * lub GOOGLE_CLOUD_PROJECT. Jeśli kontener serwera działa w Google Cloud, zmienna GOOGLE_CLOUD_PROJECT będzie już ustawiona na identyfikator projektu Google Cloud. |
disableCache |
wartość logiczna | Opcjonalnie. Określa, czy pamięć podręczna ma zostać wyłączona. Pamięć podręczna jest domyślnie włączona, co oznacza, że wyniki będą przechowywane w pamięci podręcznej przez czas trwania żądania. |
transaction |
string | Opcjonalnie. Wartość pobrana z funkcji Firestore.runTransaction(). Oznacza operację, która ma być używana w transakcji. |
Przykład
const Firestore = require('Firestore');
return Firestore.read('collection/document', {
projectId: 'gcp-cloud-project-id',
}).then((result) => result.data.key, () => undefined);
Firestore.write
Funkcja Firestore.write zapisuje dane w dokumencie lub kolekcji Firestore. Jeśli ścieżka prowadzi do kolekcji, zostanie utworzony dokument z losowo wygenerowanym identyfikatorem. Jeśli ścieżka prowadzi do dokumentu, który nie istnieje, zostanie on utworzony. Ten interfejs API zwraca obietnicę, która jest rozwiązywana jako identyfikator dodanego lub zmodyfikowanego dokumentu. Jeśli użyjesz opcji transakcji, interfejs API nadal zwróci obietnicę, ale nie będzie ona zawierać identyfikatora, ponieważ zapisy są wykonywane w pakietach.
Składnia
Firestore.write(path, input[, options]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
path |
string | Ścieżka do dokumentu lub kolekcji. Nie może zaczynać się ani kończyć znakiem „/”. |
input |
object | Wartość do zapisania w dokumencie. Jeśli opcja scalania jest ustawiona, interfejs API scali klucze z danych wejściowych z dokumentem. |
options |
object | Opcjonalne opcje żądania. Obsługiwane opcje to: projectId, merge i transaction. Nieznane klucze opcji są ignorowane. (Zobacz Opcje poniżej). |
| Parametr | Typ | Opis |
|---|---|---|
projectId |
string | Opcjonalnie. Identyfikator projektu Google Cloud Platform. Jeśli ten parametr zostanie pominięty, wartość projectId zostanie pobrana ze zmiennej środowiskowej GOOGLE_CLOUD_PROJECT, o ile ustawienie uprawnień access_firestore dla identyfikatora projektu ma wartość * lub GOOGLE_CLOUD_PROJECT. Jeśli kontener serwera działa w Google Cloud, zmienna GOOGLE_CLOUD_PROJECT będzie już ustawiona na identyfikator projektu Google Cloud. |
merge |
wartość logiczna | Opcjonalnie. Jeśli wartość to true, klucze z danych wejściowych zostaną scalone z dokumentem. W przeciwnym razie metoda zastąpi cały dokument. Domyślna wartość to false. |
transaction |
string | Opcjonalnie. Wartość pobrana z funkcji Firestore.runTransaction(). Oznacza operację, która ma być używana w transakcji. |
Przykład
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
Funkcja Firestore.query wysyła zapytanie do podanej kolekcji i zwraca obietnicę, która jest rozwiązywana jako tablica dokumentów Firestore pasujących do warunków zapytania. Obiekt dokumentu Firestore jest taki sam jak wymieniony powyżej w sekcji Firestore.read. Jeśli nie ma dokumentów spełniających warunki zapytania, zwrócona obietnica zostanie rozwiązana jako pusta tablica.
Składnia
Firestore.query(collection, queryConditions[, options]);
| Parametr | Typ | Opis |
|---|---|---|
collection |
string | Ścieżka do kolekcji. Nie może zaczynać się ani kończyć znakiem „/”. |
queryConditions |
Tablica | Tablica warunków zapytania. Każde zapytanie ma postać tablicy z 3 wartościami: klucz, operator i oczekiwanaWartość. np.:
[[‘id’, ‘<’, ‘5’], [‘state’, ‘==’, ‘CA’]]. Warunki są połączone operatorem AND, aby utworzyć wynik zapytania. Listę zgodnych operatorów zapytań znajdziesz w operatorach zapytań Firestore. |
options |
object | Opcjonalne opcje żądania. Obsługiwane opcje to: projectId, disableCache, limit i transaction. Klucze opcji Unknown są ignorowane. (Zobacz Opcje poniżej). |
| Parametr | Typ | Opis |
|---|---|---|
projectId |
string | Opcjonalnie. Identyfikator projektu Google Cloud Platform. Jeśli ten parametr zostanie pominięty, wartość projectId zostanie pobrana ze zmiennej środowiskowej GOOGLE_CLOUD_PROJECT, o ile ustawienie uprawnień access_firestore dla identyfikatora projektu ma wartość * lub GOOGLE_CLOUD_PROJECT. Jeśli kontener serwera działa w Google Cloud, zmienna GOOGLE_CLOUD_PROJECT będzie już ustawiona na identyfikator projektu Google Cloud. |
disableCache |
wartość logiczna | Opcjonalnie. Określa, czy pamięć podręczna ma zostać wyłączona. Pamięć podręczna jest domyślnie włączona, co oznacza, że wyniki będą przechowywane w pamięci podręcznej przez czas trwania żądania. |
limit |
number | Opcjonalnie. Zmienia maksymalną liczbę wyników zwracanych przez zapytanie. Domyślna wartość to 5. |
transaction |
string | Opcjonalnie. Wartość pobrana z funkcji Firestore.runTransaction(). Oznacza operację, która ma być używana w transakcji. |
Przykład
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
Funkcja Firestore.runTransaction umożliwia użytkownikowi atomowe odczytywanie i zapisywanie danych w Firestore. Jeśli wystąpi jednoczesny zapis lub inny konflikt transakcji, transakcja zostanie ponowiona maksymalnie 2 razy. Jeśli po 3 próbach nie uda się tego zrobić, interfejs API odrzuci żądanie i zwróci błąd. Ten interfejs API zwraca obietnicę, która w przypadku powodzenia transakcji jest rozwiązywana jako tablica identyfikatorów dokumentów dla każdej operacji zapisu, a w przypadku niepowodzenia jest odrzucana z błędem.
Składnia
Firestore.runTransaction(callback[, options]);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
callback |
function | Wywołanie zwrotne, które jest wywoływane z identyfikatorem transakcji w formie ciągu znaków. Identyfikator transakcji można przekazywać do wywołań interfejsu API do odczytu, zapisu i wykonywania zapytań. To wywołanie zwrotne musi zwracać obietnicę. Wywołanie zwrotne może zostać wykonane maksymalnie 3 razy, zanim zakończy się niepowodzeniem. |
options |
object | Opcjonalne opcje żądania. Jedyną obsługiwaną opcją jest projectId. Nieznane klucze opcji są ignorowane. (Zobacz Opcje poniżej). |
| Parametr | Typ | Opis |
|---|---|---|
projectId |
string | Opcjonalnie. Identyfikator projektu Google Cloud Platform. Jeśli ten parametr zostanie pominięty, wartość projectId zostanie pobrana ze zmiennej środowiskowej GOOGLE_CLOUD_PROJECT, o ile ustawienie uprawnień access_firestore dla identyfikatora projektu ma wartość * lub GOOGLE_CLOUD_PROJECT. Jeśli kontener serwera działa w Google Cloud, zmienna GOOGLE_CLOUD_PROJECT będzie już ustawiona na identyfikator projektu Google Cloud. |
Przykład
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);
Błędy są dostępne w każdej funkcji Firestore i będą odrzucane z obiektem zawierającym klucz reason:
Firestore.read(...).then(onSuccess, (error) => {
if (error.reason === 'unknown') {
// Handle the unknown error here.
}
});
Przyczyny błędu mogą obejmować m.in. kody błędów interfejsu Firestore REST API.
Powiązane uprawnienia
JSON
Zwraca obiekt, który udostępnia funkcje JSON.
Funkcja parse() analizuje ciąg znaków JSON, aby utworzyć wartość lub obiekt opisany przez ten ciąg. Jeśli nie można przeanalizować wartości (np. nieprawidłowy format JSON), funkcja zwróci undefined. Jeśli wartość wejściowa nie jest ciągiem znaków, zostanie przekształcona w ciąg znaków.
Funkcja stringify() konwertuje dane wejściowe na ciąg znaków w formacie JSON. Jeśli wartości nie można przeanalizować (np. obiekt ma cykl), metoda zwraca wartość undefined.
Przykład
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'});
Składnia
JSON.parse(stringInput);
JSON.stringify(value);
Powiązane uprawnienia
Brak.
Math
Obiekt udostępniający funkcje Math.
Składnia
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);
Parametry
Parametry funkcji matematycznych są przekształcane w liczby.
Powiązane uprawnienia
Brak.
Messages
Te interfejsy API współpracują ze sobą, aby umożliwić przekazywanie wiadomości między różnymi częściami kontenera.
addMessageListener
Dodaje funkcję, która nasłuchuje wiadomości określonego typu. Gdy wiadomość tego typu zostanie wysłana za pomocą interfejsu sendMessage API (zwykle przez tag), wywołanie zwrotne zostanie wykonane synchronicznie. Wywołanie zwrotne jest wykonywane z 2 parametrami:
messageType:stringmessage:Object
Jeśli wywołanie zwrotne zostanie dodane w kliencie, będzie otrzymywać wiadomości ze wszystkich zdarzeń utworzonych przez tego klienta. Jeśli wywołanie zwrotne ma otrzymywać wiadomości tylko z określonego zdarzenia, powiąż ten interfejs API ze zdarzeniem za pomocą bindToEvent w funkcji onStart interfejsu API runContainer. Zobacz przykład.
Składnia
const addMessageListener = require('addMessageListener');
addMessageListener('send_pixel', (messageType, message) => {
// This will be run whenever something sends a 'send_pixel' message.
});
Parametry
| Parametr | Typ | Opis |
|---|---|---|
messageType |
string | Typ wiadomości, której chcesz nasłuchiwać. Jeśli wartość nie jest ciągiem znaków, zostanie przekształcona w ciąg znaków. |
callback |
function | Funkcja zwrotna, która ma zostać uruchomiona po wysłaniu wiadomości odpowiedniego typu. Jeśli wywołanie zwrotne nie jest funkcją, interfejs API nie podejmie żadnych działań. |
Przykład
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.
});
}
});
});
Powiązane uprawnienia
Wymaga uprawnień use_message. Uprawnienia muszą być skonfigurowane tak, aby zezwalać co najmniej na:
- Typ wiadomości z wartością
Usagerównąlistenlublisten_and_send.
hasMessageListener
Zwraca wartość „true”, jeśli dodano odbiornik wiadomości dla danego typu wiadomości. W przeciwnym razie zwraca wartość „fałsz”.
Składnia
const hasMessageListener = require('hasMessageListener');
hasMessageListener('send_pixel');
Powiązane uprawnienia
Brak.
sendMessage
Wysyła wiadomość określonego typu do zarejestrowanego odbiorcy. Może to służyć do wysyłania wiadomości z tagu z powrotem do klienta, który uruchomił kontener.
Składnia
const sendMessage = require('sendMessage');
sendMessage('send_pixel', {url: 'https://analytics.example.com/collect'});
Parametry
| Parametr | Typ | Opis |
|---|---|---|
messageType |
string | Typ wiadomości do wysłania. Jeśli wartość nie jest ciągiem znaków, zostanie przekształcona w ciąg znaków. |
message |
object | Wiadomość do wysłania. Jeśli wiadomość nie jest obiektem, interfejs API nie podejmie żadnych działań. |
Powiązane uprawnienia
Wymaga uprawnień use_message. Uprawnienia muszą być skonfigurowane tak, aby zezwalać co najmniej na:
- Typ wiadomości z wartością
Usagerównąlisten_and_sendlubsend.
Object
Zwraca obiekt, który udostępnia metody Object.
Metoda keys() zapewnia działanie Object.keys()
biblioteki standardowej. Zwraca tablicę nazw własnych, wyliczalnych właściwości danego obiektu w tej samej kolejności, w jakiej zrobiłaby to pętla for...in.... Jeśli wartość wejściowa nie jest obiektem, zostanie przekształcona w obiekt.
Metoda values() zapewnia działanie funkcji Object.values() z biblioteki standardowej. Zwraca tablicę wartości własnych właściwości obiektu, które można wyliczyć, w tej samej kolejności, w jakiej zwróciłaby je pętla for...in.... Jeśli wartość wejściowa nie jest obiektem, zostanie przekształcona w obiekt.
Metoda entries() zapewnia działanie funkcji Object.entries() z biblioteki standardowej. Zwraca tablicę par [key, value] własnych, wyliczalnych właściwości danego obiektu w tej samej kolejności, w jakiej zwróciłaby je pętla for...in.... Jeśli wartość wejściowa nie jest obiektem, zostanie przekształcona w obiekt.
Metoda freeze() zapewnia działanie Object.freeze() z biblioteki standardowej. Zamrożonego obiektu nie można już zmieniać. Zamrożenie obiektu uniemożliwia dodawanie do niego nowych właściwości, usuwanie istniejących właściwości i zmianę wartości istniejących właściwości. freeze() zwraca ten sam obiekt, który został przekazany. Argument typu prostego lub argument o wartości null będzie traktowany jako zamrożony obiekt i zostanie zwrócony.
Metoda delete() zapewnia działanie operatora usuwania z biblioteki standardowej. Usuwa podany klucz z obiektu, chyba że obiekt jest zamrożony.
Podobnie jak operator usuwania w bibliotece standardowej zwraca wartość true, jeśli pierwsza wartość wejściowa (objectInput) jest obiektem, który nie jest zamrożony, nawet jeśli druga wartość wejściowa (keyToDelete) określa klucz, który nie istnieje. W pozostałych przypadkach zwraca wartość false. Różni się jednak od operatora usuwania z biblioteki standardowej tym, że:
keyToDeletenie może być ciągiem znaków rozdzielonym kropkami, który określa klucz zagnieżdżony.- Nie można użyć funkcji
delete()do usunięcia elementów z tablicy. - Za pomocą parametru
delete()nie można usuwać żadnych usług z zakresu globalnego.
Składnia
Object.keys(objectInput)
Object.values(objectInput)
Object.entries(objectInput)
Object.freeze(objectInput)
Object.delete(objectInput, keyToDelete)
Parametry
Object.keys
| Parametr | Typ | Opis |
|---|---|---|
| objectInput | dowolny | Obiekt, którego klucze mają zostać wyliczone. Jeśli dane wejściowe nie są obiektem, zostaną przekształcone w obiekt. |
Object.values
| Parametr | Typ | Opis |
|---|---|---|
| objectInput | dowolny | Obiekt, którego wartości mają być wyliczane. Jeśli dane wejściowe nie są obiektem, zostaną przekształcone w obiekt. |
Object.entries
| Parametr | Typ | Opis |
|---|---|---|
| objectInput | dowolny | Obiekt, którego pary klucz-wartość mają być wyliczane. Jeśli dane wejściowe nie są obiektem, zostaną przekształcone w obiekt. |
Object.freeze
| Parametr | Typ | Opis |
|---|---|---|
| objectInput | dowolny | Obiekt do zamrożenia. Jeśli dane wejściowe nie są obiektem, będą traktowane jako zamrożony obiekt. |
Object.delete
| Parametr | Typ | Opis |
|---|---|---|
| objectInput | dowolny | Obiekt, którego klucz ma zostać usunięty. |
| keyToDelete | string | Klucz najwyższego poziomu do usunięcia. |
Przykład
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
Zwraca obiekt, który udostępnia metody interakcji z obietnicami.
Obietnice są funkcjonalnie równoważne obietnicom JavaScript. Każda instancja ma 3 metody, które zwracają obiekt Promise, co umożliwia dalsze działanie po rozstrzygnięciu obietnicy:
.then()– obsługuje zarówno rozwiązane, jak i odrzucone zgłoszenia. Przyjmuje 2 funkcje zwrotne jako parametry: jedną w przypadku powodzenia i jedną w przypadku niepowodzenia..catch()– obsługuje tylko odrzucone zgłoszenia. Przyjmuje jedno wywołanie zwrotne jako parametr..finally()– umożliwia uruchomienie kodu niezależnie od tego, czy obietnica została spełniona czy odrzucona. Przyjmuje jako parametr jedną funkcję wywołania zwrotnego, która jest wywoływana bez argumentu.
Zmienna, która zwraca obietnicę, jest równa rozwiązanej wartości obietnicy lub false, jeśli obietnica zostanie odrzucona.
Przykład
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
Zwraca obietnicę, która:
- zostanie rozwiązana, gdy wszystkie dane wejściowe zostaną rozwiązane, lub
- odrzuca, gdy którekolwiek z danych wejściowych zostanie odrzucone.
Składnia
Promise.all(inputs);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
inputs |
Tablica | Tablica wartości lub obietnic. Jeśli dane wejściowe nie są obietnicą, są przekazywane tak, jakby były rozwiązaną wartością obietnicy. Zwraca błąd, jeśli dane wejściowe nie są tablicą. |
Przykład
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: ''}]
});
Powiązane uprawnienia
Brak.
Promise.create
Tworzy obietnicę, która jest funkcjonalnie równoważna obietnicy JavaScript.
Składnia
Promise.create(resolver);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
resolver |
function | Funkcja, która jest wywoływana z 2 funkcjami: resolve i reject. Zwrócony obiekt Promise zostanie rozwiązany lub odrzucony, gdy zostanie wywołany odpowiedni parametr. Zwraca błąd, jeśli funkcja rozpoznawania nie jest funkcją. |
Przykład
const Promise = require('Promise');
return Promise.create((resolve, reject) => {
// Do asynchronous work that eventually calls resolve() or reject()
});
Powiązane uprawnienia
Brak.
Testowanie interfejsów API
Te interfejsy API współpracują z testami JavaScriptu w piaskownicy, aby tworzyć testy szablonów niestandardowych w Menedżerze tagów Google. Te interfejsy API do testowania nie wymagają require()oświadczenia. [Więcej informacji o testach szablonów niestandardowych]
assertApi
Zwraca obiekt dopasowania, którego można użyć do płynnego tworzenia asercji dotyczących danego interfejsu API.
Składnia
assertApi(apiName)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
apiName |
string | Nazwa interfejsu API do sprawdzenia; ten sam ciąg znaków, który został przekazany do funkcji require().
|
Dopasowywanie
Subject.wasCalled()Subject.wasNotCalled()Subject.wasCalledWith(...expected)Subject.wasNotCalledWith(...expected)
Przykłady
assertApi('sendPixel').wasCalled();
assertApi('getUrl').wasNotCalled();
assertApi('makeNumber').wasCalledWith('8');
assertApi('setInWindow').wasNotCalledWith('myVar', 'theWrongValue');
assertThat
Interfejs assertThat API jest wzorowany na bibliotece [Truth] Google. Zwraca obiekt, którego można użyć do płynnego tworzenia asercji dotyczących wartości obiektu. Błąd asercji natychmiast zatrzyma test i oznaczy go jako nieudany. Niepowodzenie w jednym teście nie wpłynie jednak na inne przypadki testowe.
Składnia
assertThat(actual, opt_message)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
actual |
dowolny | Wartość do użycia w testach płynności. |
opt_message |
string | Opcjonalna wiadomość do wydrukowania, jeśli asercja się nie powiedzie. |
Dopasowywanie
| Matcher | Opis |
|---|---|
isUndefined() |
Potwierdza, że podmiot jest undefined. |
isDefined() |
Potwierdza, że podmiot nie jest undefined. |
isNull() |
Potwierdza, że podmiot jest null. |
isNotNull() |
Potwierdza, że podmiot nie jest null. |
isFalse() |
Potwierdza, że podmiot jest false. |
isTrue() |
Potwierdza, że podmiot jest true. |
isFalsy() |
Sprawdza, czy obiekt jest fałszywy. Wartości fałszywe to undefined, null, false, NaN, 0 i „” (pusty ciąg znaków). |
isTruthy() |
Sprawdza, czy element jest prawdziwy. Wartości fałszywe to undefined, null, false, NaN, 0 i „” (pusty ciąg znaków). |
isNaN() |
Sprawdza, czy podmiot jest wartością NaN. |
isNotNaN() |
Sprawdza, czy obiekt ma dowolną wartość inną niż NaN. |
isInfinity() |
Sprawdza, czy wartość jest dodatnią lub ujemną nieskończonością. |
isNotInfinity() |
Sprawdza, czy wartość nie jest dodatnią ani ujemną nieskończonością. |
isEqualTo(expected) |
Sprawdza, czy obiekt jest równy podanej wartości. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
isNotEqualTo(expected) |
Sprawdza, czy podmiot nie jest równy podanej wartości. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
isAnyOf(...expected) |
Sprawdza, czy obiekt jest równy jednej z podanych wartości. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
isNoneOf(...expected) |
Stwierdza, że podmiot nie jest równy żadnej z podanych wartości. To porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
isStrictlyEqualTo(expected) |
Sprawdza, czy obiekt jest ściśle równy (===) podanej wartości. |
isNotStrictlyEqualTo(expected) |
Stwierdza, że podmiot nie jest ściśle równy (!==) podanej wartości. |
isGreaterThan(expected) |
Sprawdza, czy wartość jest większa niż (>) podana wartość w porównaniu uporządkowanym. |
isGreaterThanOrEqualTo(expected) |
Sprawdza, czy wartość jest większa lub równa (>=) podanej wartości w porównaniu uporządkowanym. |
isLessThan(expected) |
Sprawdza, czy wartość jest mniejsza niż (<) podana wartość w porównaniu uporządkowanym. |
isLessThanOrEqualTo(expected) |
Sprawdza, czy wartość jest mniejsza lub równa (<=) podanej wartości w porównaniu uporządkowanym. |
contains(...expected) |
Sprawdza, czy obiekt jest tablicą lub ciągiem znaków, który zawiera wszystkie podane wartości w dowolnej kolejności. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
doesNotContain(...expected) |
Sprawdza, czy obiekt jest tablicą lub ciągiem, który nie zawiera żadnej z podanych wartości. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
containsExactly(...expected) |
Sprawdza, czy obiekt jest tablicą, która zawiera wszystkie podane wartości w dowolnej kolejności i nie zawiera żadnych innych wartości. Jest to porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
doesNotContainExactly(...expected) |
Sprawdza, czy obiekt jest tablicą, która zawiera inny zestaw wartości niż podane wartości w dowolnej kolejności. To porównanie wartości, a nie porównanie referencyjne. Zawartość obiektów i tablic jest porównywana rekurencyjnie. |
hasLength(expected) |
Sprawdza, czy obiekt jest tablicą lub ciągiem znaków o podanej długości. Jeśli wartość nie jest tablicą ani ciągiem znaków, asercja zawsze kończy się niepowodzeniem. |
isEmpty() |
Sprawdza, czy obiekt jest pustą tablicą lub pustym ciągiem znaków (długość ≤ 0). Jeśli wartość nie jest tablicą ani ciągiem znaków, asercja zawsze kończy się niepowodzeniem. |
isNotEmpty() |
Sprawdza, czy obiekt jest tablicą lub ciągiem znaków, który nie jest pusty (długość > 0). Jeśli wartość nie jest tablicą ani ciągiem znaków, asercja zawsze kończy się niepowodzeniem. |
isArray() |
Sprawdza, czy typ podmiotu jest tablicą. |
isBoolean() |
Sprawdza, czy typ podmiotu to wartość logiczna. |
isFunction() |
Sprawdza, czy typ obiektu jest funkcją. |
isNumber() |
Sprawdza, czy typ podmiotu jest liczbą. |
isObject() |
Stwierdza, że typ podmiotu jest obiektem. |
isString() |
Sprawdza, czy typ podmiotu jest ciągiem znaków. |
Przykłady
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
Natychmiast przerywa bieżący test i wyświetla podany komunikat (jeśli został podany).
Składnia
fail(opt_message);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
opt_message |
string | Opcjonalny tekst komunikatu o błędzie. |
Przykład
fail('This test has failed.');
mock
Interfejs mock API umożliwia zastępowanie działania interfejsów API w piaskownicy. Interfejs Mock API można bezpiecznie stosować w kodzie szablonu, ale działa on tylko w trybie testowym.
Makiety są resetowane przed uruchomieniem każdego testu.
Składnia
mock(apiName, returnValue);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
apiName |
string | Nazwa interfejsu API do symulacji. Jest to ten sam ciąg znaków, który został przekazany do funkcji
require() |
returnValue |
dowolny | Wartość do zwrócenia w przypadku interfejsu API lub funkcji wywoływanej zamiast interfejsu API. Jeśli returnValue jest funkcją, jest ona wywoływana zamiast interfejsu Sandboxed API. Jeśli returnValue jest czymś innym niż funkcją, zwracana jest ta wartość zamiast interfejsu Sandboxed API. |
Przykłady
mock('encodeUri', "https://endpoint.example.com/?account=12345");
mock('sendPixel', function(url, onSuccess, onFailure) {
onSuccess();
});
mockObject
Interfejs mockObject API umożliwia zastąpienie działania interfejsów Sandboxed API, które zwracają obiekt. Interfejs API jest bezpieczny w użyciu w kodzie szablonu, ale działa tylko w trybie testowym. Makiety są resetowane przed uruchomieniem każdego testu.
Składnia
mockObject(apiName, objectMock);
Parametry
| Parametr | Typ | Opis |
|---|---|---|
apiName |
string | Nazwa interfejsu API do symulacji. Jest to ten sam ciąg znaków, który został przekazany do funkcji
require() |
objectMock |
object | Wartość do zwrócenia w przypadku interfejsu API lub funkcji wywoływanej zamiast interfejsu API. Musi to być obiekt. |
Przykłady
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
Uruchamia kod szablonu, czyli zawartość karty Kod, w bieżącym środowisku testowym z danym obiektem danych wejściowych.
Składnia
runCode(data)
Parametry
| Parametr | Typ | Opis |
|---|---|---|
data |
object | Obiekt danych, który ma być użyty w teście. |
Zwracana wartość
Zwraca wartość zmiennej w przypadku szablonów zmiennych, a w przypadku wszystkich innych typów szablonów zwraca undefined.
Przykład
runCode({field1: 123, field2: 'value'});