UNPKG

@thoughtspot/visual-embed-sdk

Version:
120 lines 4.27 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.processEventData = exports.processAuthFailure = exports.processCustomAction = void 0; const embedConfig_1 = require("../embed/embedConfig"); const base_1 = require("../embed/base"); const auth_1 = require("../auth"); const types_1 = require("../types"); const answerService_1 = require("./graphql/answerService/answerService"); const authToken_1 = require("../authToken"); const errors_1 = require("../errors"); /** * * @param e * @param thoughtSpotHost */ function processCustomAction(e, thoughtSpotHost) { const { session, embedAnswerData, contextMenuPoints } = e.data; const answerService = new answerService_1.AnswerService(session, embedAnswerData || {}, thoughtSpotHost, contextMenuPoints === null || contextMenuPoints === void 0 ? void 0 : contextMenuPoints.selectedPoints); return { ...e, answerService, }; } exports.processCustomAction = processCustomAction; /** * Responds to AuthInit sent from host signifying successful authentication in host. * @param e * @returns {any} */ function processAuthInit(e) { var _a, _b; (0, base_1.notifyAuthSuccess)(); // Expose only allowed details (eg: userGUID) back to SDK users. return { ...e, data: { userGUID: ((_a = e.data) === null || _a === void 0 ? void 0 : _a.userGUID) || ((_b = e.payload) === null || _b === void 0 ? void 0 : _b.userGUID), }, }; } /** * * @param e * @param containerEl */ function processNoCookieAccess(e, containerEl) { const { loginFailedMessage, suppressNoCookieAccessAlert, ignoreNoCookieAccess, suppressErrorAlerts, } = (0, embedConfig_1.getEmbedConfig)(); if (!ignoreNoCookieAccess) { if (!suppressNoCookieAccessAlert && !suppressErrorAlerts) { // eslint-disable-next-line no-alert alert(errors_1.ERROR_MESSAGE.THIRD_PARTY_COOKIE_BLOCKED_ALERT); } // eslint-disable-next-line no-param-reassign containerEl.innerHTML = loginFailedMessage; } (0, base_1.notifyAuthFailure)(auth_1.AuthFailureType.NO_COOKIE_ACCESS); return e; } /** * * @param e * @param containerEl */ function processAuthFailure(e, containerEl) { const { loginFailedMessage, authType, disableLoginFailurePage, autoLogin, } = (0, embedConfig_1.getEmbedConfig)(); if (autoLogin && (authType === types_1.AuthType.TrustedAuthToken || authType === types_1.AuthType.TrustedAuthTokenCookieless)) { // eslint-disable-next-line no-param-reassign containerEl.innerHTML = loginFailedMessage; (0, base_1.notifyAuthFailure)(auth_1.AuthFailureType.IDLE_SESSION_TIMEOUT); } else if (authType !== types_1.AuthType.None && !disableLoginFailurePage) { // eslint-disable-next-line no-param-reassign containerEl.innerHTML = loginFailedMessage; (0, base_1.notifyAuthFailure)(auth_1.AuthFailureType.OTHER); } (0, authToken_1.resetCachedAuthToken)(); return e; } exports.processAuthFailure = processAuthFailure; /** * * @param e * @param containerEl */ function processAuthLogout(e, containerEl) { const { loginFailedMessage } = (0, embedConfig_1.getEmbedConfig)(); // eslint-disable-next-line no-param-reassign containerEl.innerHTML = loginFailedMessage; (0, authToken_1.resetCachedAuthToken)(); (0, base_1.disableAutoLogin)(); (0, base_1.notifyLogout)(); return e; } /** * * @param type * @param e * @param thoughtSpotHost * @param containerEl */ function processEventData(type, e, thoughtSpotHost, containerEl) { switch (type) { case types_1.EmbedEvent.CustomAction: return processCustomAction(e, thoughtSpotHost); case types_1.EmbedEvent.AuthInit: return processAuthInit(e); case types_1.EmbedEvent.NoCookieAccess: return processNoCookieAccess(e, containerEl); case types_1.EmbedEvent.AuthFailure: return processAuthFailure(e, containerEl); case types_1.EmbedEvent.AuthLogout: return processAuthLogout(e, containerEl); default: } return e; } exports.processEventData = processEventData; //# sourceMappingURL=processData.js.map