___TERMS_OF_SERVICE___ By creating or modifying this file you agree to Google Tag Manager's Community Template Gallery Developer Terms of Service available at https://developers.google.com/tag-manager/gallery-tos (or such other URL as Google may provide), as modified from time to time. ___INFO___ { "type": "TAG", "id": "cvt_temp_public_id", "version": 1, "securityGroups": [], "displayName": "Moengage initialisation tag", "brand": { "id": "brand_dummy", "displayName": "", "thumbnail": "\u003d\u003d" }, "description": "This tag will add Moengage web SDK into your website", "containerContexts": [ "WEB" ] } ___TEMPLATE_PARAMETERS___ [ { "type": "TEXT", "name": "app_id", "displayName": "App ID", "simpleValueType": true, "valueValidators": [ { "type": "NON_EMPTY" } ], "help": "Enter the app App ID found in your Moengage Dashboard" }, { "type": "SELECT", "name": "debug_logs", "displayName": "Debug Logs", "macrosInSelect": false, "selectItems": [ { "value": 0, "displayValue": "0" }, { "value": 1, "displayValue": "1" } ], "simpleValueType": true, "defaultValue": 0 }, { "type": "TEXT", "name": "cluster", "displayName": "Data center", "simpleValueType": true, "defaultValue": "DC_1" }, { "type": "TEXT", "name": "swPath", "displayName": "Serviceworker custom path", "simpleValueType": true }, { "type": "TEXT", "name": "swScope", "displayName": "Serviceworker scope", "simpleValueType": true }, { "type": "CHECKBOX", "name": "disable_onsite", "checkboxText": "Is Onsite-Messaging disabled?", "simpleValueType": true, "defaultValue": false }, { "type": "CHECKBOX", "name": "enableSPA", "checkboxText": "Is SPA enabled?", "simpleValueType": true, "defaultValue": false }, { "type": "CHECKBOX", "name": "enableWebpV2", "checkboxText": "Enable Web Personalization", "simpleValueType": true }, { "type": "TEXT", "name": "cards", "displayName": "Cards Config (in JSON)", "simpleValueType": true } ] ___SANDBOXED_JS_FOR_WEB_TEMPLATE___ // Enter your template code here. const log = require('logToConsole'); const queryPermission = require('queryPermission'); const injectScript = require('injectScript'); const callInWindow = require('callInWindow'); const JSON = require('JSON'); const cluster = data.cluster || 'DC_1'; const url = "https://cdn.moengage.com/release/" + cluster.toLowerCase() + "/moe_webSdk.min.latest.js"; const message = 'Moengage: '; const onSuccess = () => { if(data.cards) { data.cards = JSON.parse(data.cards); } callInWindow('moe', data); if(data.enableWebpV2) { const webPURL = 'https://cdn.moengage.com/release/' + cluster.toLowerCase() + '/moe_webSdk_webp.min.latest.js?app_id=' + data.app_id + '&cluster=' + data.cluster; injectScript(webPURL, () => { data.gtmOnSuccess();}, onFailure, webPURL); } else { data.gtmOnSuccess(); } }; const onFailure = (err) => { log(message, 'Error loading Moengage Web SDK from ' + url, err); data.gtmOnFailure(); }; if (queryPermission('inject_script', url)) { injectScript(url, onSuccess, onFailure, url); } else { log(message, "Load script " + url + " failed due to permissions mismatch!"); } ___WEB_PERMISSIONS___ [ { "instance": { "key": { "publicId": "logging", "versionId": "1" }, "param": [ { "key": "environments", "value": { "type": 1, "string": "debug" } } ] }, "clientAnnotations": { "isEditedByUser": true }, "isRequired": true }, { "instance": { "key": { "publicId": "inject_script", "versionId": "1" }, "param": [ { "key": "urls", "value": { "type": 2, "listItem": [ { "type": 1, "string": "https://cdn.moengage.com/*" } ] } } ] }, "clientAnnotations": { "isEditedByUser": true }, "isRequired": true }, { "instance": { "key": { "publicId": "access_globals", "versionId": "1" }, "param": [ { "key": "keys", "value": { "type": 2, "listItem": [ { "type": 3, "mapKey": [ { "type": 1, "string": "key" }, { "type": 1, "string": "read" }, { "type": 1, "string": "write" }, { "type": 1, "string": "execute" } ], "mapValue": [ { "type": 1, "string": "moe" }, { "type": 8, "boolean": true }, { "type": 8, "boolean": true }, { "type": 8, "boolean": true } ] }, { "type": 3, "mapKey": [ { "type": 1, "string": "key" }, { "type": 1, "string": "read" }, { "type": 1, "string": "write" }, { "type": 1, "string": "execute" } ], "mapValue": [ { "type": 1, "string": "Moengage" }, { "type": 8, "boolean": true }, { "type": 8, "boolean": true }, { "type": 8, "boolean": true } ] } ] } } ] }, "clientAnnotations": { "isEditedByUser": true }, "isRequired": true } ] ___TESTS___ scenarios: - name: Test whether the script has been successfully loaded code: |2- runCode(mockData); // Test whether the injectScript functions work properly assertApi('injectScript').wasCalledWith(scriptUrl, success, failure, scriptUrl); assertApi('gtmOnSuccess').wasCalled(); - name: Initializes successfully code: |- runCode(mockData); // Verify that the tag finished successfully. assertApi('callInWindow').wasCalled(); assertApi('gtmOnSuccess').wasCalled(); setup: |- const callInWindow = require('callInWindow'); const log = require('logToConsole'); const message = 'Moengage: '; const mockData = { app_id: '1234' }; const scriptUrl = 'https://cdn.moengage.com/webpush/moe_webSdk.min.latest.js'; let success, failure; mock('injectScript', (url, onsuccess, onfailure) => { success = onsuccess; failure = onfailure; onsuccess(); }); ___NOTES___ Created on 06/12/2023, 19:36:08