diff --git a/artifacts/src/mosip-plugins/sign-in-button-plugin.js b/artifacts/src/mosip-plugins/sign-in-button-plugin.js new file mode 100644 index 00000000..9d61e22d --- /dev/null +++ b/artifacts/src/mosip-plugins/sign-in-button-plugin.js @@ -0,0 +1,687 @@ +/****************************************************************************** +Thu Aug 28 2025 10:39:44 GMT+0000 (Coordinated Universal Time) +sign-in-with-esignet v0.9.0 +A vanilla javascript component for rendering “Sign in with..” button on mosip client’s web page for oidc integration. +Copyright 2025 +MPL-2.0 license +******************************************************************************/ +var SignInWithEsignetButton = (function (exports) { + 'use strict'; + + /****************************************************************************** + Copyright (c) Microsoft Corporation. + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH + REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, + INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM + LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR + OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + PERFORMANCE OF THIS SOFTWARE. + ***************************************************************************** */ + + function __rest(s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; + } + + function __awaiter(thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + } + + function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype); + return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (g && (g = 0, op[0] && (_ = 0)), _) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + } + + typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) { + var e = new Error(message); + return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e; + }; + + var img = ""; + + var validResponseTypes = ["code"]; + var validDisplays = ["page", "popup", "touch", "wap"]; + var validPrompt = ["none", "login", "consent", "select_account"]; + var defaultThemes = { + outline: "outline", + filledOrange: "filled_orange", + filledBlack: "filled_black", + custom: "custom", + }; + var defaultShapes = { + sharpEdges: "sharp_edges", + softEdges: "soft_edges", + roundedEdges: "rounded_edges", + }; + var buttonTypes = { + standard: "standard", + icon: "icon", + }; + var errorMessage = { + requestUriTimeout: "Request timed out while fetching Request URI. Please try again later.", + requestUriFailed: "Failed to get Request URI. Please try again later.", + clientIdMissing: "Client ID missing.", + generic: "An unexpected error occurred. Please try again.", + dpopFailed: "DPoP callback failed. Please try again." + }; + var defaultButtonLabel = "Sign in with e-Signet"; + + function styleInject(css, ref) { + if ( ref === void 0 ) ref = {}; + var insertAt = ref.insertAt; + + if (!css || typeof document === 'undefined') { return; } + + var head = document.head || document.getElementsByTagName('head')[0]; + var style = document.createElement('style'); + style.type = 'text/css'; + + if (insertAt === 'top') { + if (head.firstChild) { + head.insertBefore(style, head.firstChild); + } else { + head.appendChild(style); + } + } else { + head.appendChild(style); + } + + if (style.styleSheet) { + style.styleSheet.cssText = css; + } else { + style.appendChild(document.createTextNode(css)); + } + } + + var css_248z = "/* Theme specific css */\n.SignInWithEsignet-module_standardOutline__la5Rh {\n border: 2px solid #d8d8d8;\n background: #ffffff 0% 0% no-repeat padding-box;\n color: black;\n font: normal normal 600 14px/17px arial;\n}\n\n.SignInWithEsignet-module_filledOrange__0uQsC {\n border: 2px solid #eb6f2d;\n background: #eb6f2d 0% 0% no-repeat padding-box;\n color: white;\n font: normal normal 600 14px/17px arial;\n}\n\n.SignInWithEsignet-module_filledBlack__fo-0k {\n border: 2px solid #333333;\n background: #333333 0% 0% no-repeat padding-box;\n color: white;\n font: normal normal 600 14px/17px arial;\n}\n\n/* Common css */\n.SignInWithEsignet-module_sharpRectBox__jYEvo {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n padding-left: 2px;\n padding-right: 2px;\n}\n\n.SignInWithEsignet-module_softRectBox__hXT5v {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n padding-left: 2px;\n padding-right: 2px;\n}\n\n.SignInWithEsignet-module_roundedRectBox__Gxr6n {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n border-radius: 46px;\n padding-left: 3px;\n padding-right: 3px;\n}\n\n.SignInWithEsignet-module_sharpRectIcon__ux3fm {\n display: inline-block;\n}\n\n.SignInWithEsignet-module_softRectIcon__3TVEe {\n display: inline-block;\n border-radius: 8px;\n}\n\n.SignInWithEsignet-module_roundedRectIcon__dfq2Q {\n display: inline-block;\n border-radius: 46px;\n}\n\n.SignInWithEsignet-module_sharpLogoBox__DYo-n {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 44px;\n height: 44px;\n background: #ffffff 0% 0% no-repeat padding-box;\n}\n\n.SignInWithEsignet-module_softLogoBox__jj7aZ {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 44px;\n height: 44px;\n background: #ffffff 0% 0% no-repeat padding-box;\n border-radius: 6px;\n}\n\n.SignInWithEsignet-module_roundedLogoBox__KiQM1 {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 38px;\n height: 38px;\n background: #ffffff 0% 0% no-repeat padding-box;\n border-radius: 36px;\n}\n\n.SignInWithEsignet-module_sharpLogo__wyaBH {\n width: 38px;\n height: 38px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_softLogo__Gk5mu {\n width: 38px;\n height: 38px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_roundedLogo__cwx4t {\n width: 28px;\n height: 28px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_textbox__k2CkO {\n text-align: left;\n padding-left: 16px;\n padding-right: 16px;\n letter-spacing: 0px;\n}\n"; + var styles = {"standardOutline":"SignInWithEsignet-module_standardOutline__la5Rh","filledOrange":"SignInWithEsignet-module_filledOrange__0uQsC","filledBlack":"SignInWithEsignet-module_filledBlack__fo-0k","sharpRectBox":"SignInWithEsignet-module_sharpRectBox__jYEvo","softRectBox":"SignInWithEsignet-module_softRectBox__hXT5v","roundedRectBox":"SignInWithEsignet-module_roundedRectBox__Gxr6n","sharpRectIcon":"SignInWithEsignet-module_sharpRectIcon__ux3fm","softRectIcon":"SignInWithEsignet-module_softRectIcon__3TVEe","roundedRectIcon":"SignInWithEsignet-module_roundedRectIcon__dfq2Q","sharpLogoBox":"SignInWithEsignet-module_sharpLogoBox__DYo-n","softLogoBox":"SignInWithEsignet-module_softLogoBox__jj7aZ","roundedLogoBox":"SignInWithEsignet-module_roundedLogoBox__KiQM1","sharpLogo":"SignInWithEsignet-module_sharpLogo__wyaBH","softLogo":"SignInWithEsignet-module_softLogo__Gk5mu","roundedLogo":"SignInWithEsignet-module_roundedLogo__cwx4t","textbox":"SignInWithEsignet-module_textbox__k2CkO"}; + styleInject(css_248z); + + var defaultResponseType = "code"; + /** + * Validates oidc configuration for required params and valid values + * @param oidcConfig oidc configuration prop + * @returns Error object with error code and error msg. + */ + function validateInput(oidcConfig) { + //Required parameters + if (!oidcConfig || + !oidcConfig.authorizeUri || + !oidcConfig.redirect_uri || + !oidcConfig.client_id || + !oidcConfig.scope) { + return "Required parameter is missing"; + } + //if the param is not null and has and an invalid value return error msg. + if (oidcConfig.response_type && + !validResponseTypes.includes(oidcConfig.response_type)) { + return "Invalid Response Type"; + } + if (oidcConfig.display && !validDisplays.includes(oidcConfig.display)) { + return "Invalid display value"; + } + if (oidcConfig.prompt && !validPrompt.includes(oidcConfig.prompt)) { + return "Invalid prompt value"; + } + return ""; + } + /** + * Builds redirect URL to navigate to id provider's portal. + * @param oidcConfig + * @returns URL + */ + function buildRedirectURL(oidcConfig, dpop_jkt) { + var urlToNavigate = (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.authorizeUri) + "?"; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.nonce) + urlToNavigate += "nonce=" + oidcConfig.nonce + "&"; + //Generating random state if not provided + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.state) { + urlToNavigate += "state=" + oidcConfig.state; + } + else { + var randomNum = window.crypto.getRandomValues(new Uint32Array(1)); + var randomState = randomNum[0].toString(36).substring(5); + urlToNavigate += "state=" + randomState; + } + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.client_id) + urlToNavigate += "&client_id=" + oidcConfig.client_id; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.redirect_uri) + urlToNavigate += "&redirect_uri=" + oidcConfig.redirect_uri; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.scope) + urlToNavigate += "&scope=" + oidcConfig.scope; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.response_type) { + urlToNavigate += "&response_type=" + oidcConfig.response_type; + } + else { + urlToNavigate += "&response_type=" + defaultResponseType; + } + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.acr_values) + urlToNavigate += "&acr_values=" + (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.acr_values); + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.claims) + urlToNavigate += "&claims=" + encodeURI(JSON.stringify(oidcConfig.claims)); + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.claims_locales) + urlToNavigate += "&claims_locales=" + oidcConfig.claims_locales; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.display) + urlToNavigate += "&display=" + oidcConfig.display; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.prompt) + urlToNavigate += "&prompt=" + oidcConfig.prompt; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.max_age) + urlToNavigate += "&max_age=" + oidcConfig.max_age; + if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.ui_locales) + urlToNavigate += "&ui_locales=" + oidcConfig.ui_locales; + if (dpop_jkt) { + urlToNavigate += "&dpop_jkt=" + dpop_jkt; + } + return urlToNavigate; + } + /** + * builds classes based on input shape, theme and button type. + * + * if theme is 'custom' then standard classes are applied and these clases + * are expected to be added by the button implementer. + * + * @param buttonConfig + * @returns classes + */ + function buildButtonClasses(buttonConfig) { + var outerDivClasses = ""; + var logoDivClasses = ""; + var logoImgClasses = ""; + var labelSpanClasses = styles.textbox; + if (buttonConfig.theme == defaultThemes.custom) { + return { + outerDivClasses: (outerDivClasses = + buttonConfig.type == buttonTypes.icon + ? "sign-in-outer-div-container-icon" + : "sign-in-outer-div-container-standard"), + logoDivClasses: "sign-in-logo-div-container", + logoImgClasses: "sign-in-logo-img", + labelSpanClasses: "sign-in-label-span", + }; + } + //theme based styling + switch (buttonConfig.theme) { + case defaultThemes.outline: + outerDivClasses = styles.standardOutline; + break; + case defaultThemes.filledOrange: + outerDivClasses = styles.filledOrange; + break; + case defaultThemes.filledBlack: + outerDivClasses = styles.filledBlack; + break; + default: //default theme outline + outerDivClasses = styles.standardOutline; + } + //shaped based styling + switch (buttonConfig.shape) { + case defaultShapes.sharpEdges: + //default button type is standard. Setting shape based on button type + outerDivClasses += + " " + + (buttonConfig.type == buttonTypes.icon + ? styles.sharpRectIcon + : styles.sharpRectBox); + logoDivClasses = styles.sharpLogoBox; + logoImgClasses = styles.sharpLogo; + break; + case defaultShapes.softEdges: + outerDivClasses += + " " + + (buttonConfig.type == buttonTypes.icon + ? styles.softRectIcon + : styles.softRectBox); + logoDivClasses = styles.softLogoBox; + logoImgClasses = styles.softLogo; + break; + case defaultShapes.roundedEdges: + outerDivClasses += + " " + + (buttonConfig.type == buttonTypes.icon + ? styles.roundedRectIcon + : styles.roundedRectBox); + logoDivClasses = styles.roundedLogoBox; + logoImgClasses = styles.roundedLogo; + break; + default: //default shaped SharpEdges + outerDivClasses += + " " + + (buttonConfig.type == buttonTypes.icon + ? styles.sharpRectIcon + : styles.sharpRectBox); + logoDivClasses = styles.sharpLogoBox; + logoImgClasses = styles.sharpLogo; + } + return { + outerDivClasses: outerDivClasses, + logoDivClasses: logoDivClasses, + logoImgClasses: logoImgClasses, + labelSpanClasses: labelSpanClasses, + }; + } + /** + * builds style for the outer div by updating baseStyle by adding/overriding + * button config styling parameters. + * @param baseStyle + * @param buttonConfig + * @returns style + */ + function buildButtonStyles(baseStyle, buttonConfig) { + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.width) + baseStyle["width"] = buttonConfig.width; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.background) + baseStyle["background"] = buttonConfig.background; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.textColor) + baseStyle["color"] = buttonConfig.textColor; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.borderWidth) + baseStyle["border-width"] = buttonConfig.borderWidth; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.borderColor) + baseStyle["border-color"] = buttonConfig.borderColor; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.font) + baseStyle["font"] = buttonConfig.font; + if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.fontFamily) { + baseStyle["font-family"] = buttonConfig.fontFamily; + } + else { + //default font-family + baseStyle["font-family"] = + "-apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen','Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',sans-serif"; + } + return baseStyle; + } + /** + * builds style based on button type and custom style. + * + * if theme is 'custom' then standard classes are applied and these clases + * are expected to be added by the button implementer. + * @param baseStyle + * @param buttonConfig + * @returns + */ + function buildButtonCustomStyles(baseStyle, buttonConfig) { + if (!buttonConfig.customStyle) { + return {}; + } + var outerDiv = buttonConfig.type == buttonTypes.icon + ? buttonConfig.customStyle.outerDivStyleIcon + : buttonConfig.customStyle.outerDivStyleStandard; + Object.assign(baseStyle, outerDiv); + return { + outerDivStyle: buildButtonStyles(baseStyle, buttonConfig), + logoDivStyle: buttonConfig.customStyle.logoDivStyle, + logoImgStyle: buttonConfig.customStyle.logoImgStyle, + labelSpanStyle: buttonConfig.customStyle.labelSpanStyle, + }; + } + /** + * style attrs applied on the element + * @param element + * @param attrs + */ + var setStyleAttribute = function (element, attrs) { + if (attrs !== undefined) { + Object.keys(attrs).forEach(function (key) { + element.style.setProperty(key, attrs[key]); + }); + } + }; + /** + * + * Builds button while adding styles and classes on individual element + * + * In case of buttonClasses, the button should render like this. + * --conditional + * {errorObj + ". Please report to site admin"} + * + * + *
+ *
+ * + *
+ * {buttonLabel} --conditional + *
+ *
+ * @param buttonLabel + * @param urlToNavigate + * @param buttonCustomStyle + * @param buttonClasses + * @param buttonStyle + * @param logoPath + * @param errorMsg + * @param type + * @returns + */ + var createButton = function (buttonLabel, urlToNavigate, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, type, onClickHandler) { + var _a, _b, _c, _d; + //Button + var anchor; + if (onClickHandler) { + anchor = document.createElement("button"); + anchor.type = "button"; + anchor.addEventListener("click", onClickHandler); + } + else { + anchor = document.createElement("a"); + anchor.href = urlToNavigate; + anchor.style.textDecoration = "none"; + } + var outerDiv = document.createElement("div"); + var logoDiv = document.createElement("div"); + var logoImg = document.createElement("img"); + logoImg.src = logoPath; + var labelSpan = document.createElement("span"); + labelSpan.innerHTML = buttonLabel; + if (buttonCustomStyle) { + //apply custom style + if (buttonCustomStyle.outerDivStyle) + anchor.style.width = buttonCustomStyle.outerDivStyle["width"]; + setStyleAttribute(outerDiv, buttonCustomStyle.outerDivStyle); + setStyleAttribute(logoDiv, buttonCustomStyle.logoDivStyle); + setStyleAttribute(logoImg, buttonCustomStyle.logoImgStyle); + setStyleAttribute(labelSpan, buttonCustomStyle.labelSpanStyle); + } + else if (buttonClasses) { + //or apply classes + if (buttonStyle) + anchor.style.width = buttonStyle["width"]; + setStyleAttribute(outerDiv, buttonStyle); + (_a = outerDiv.classList).add.apply(_a, buttonClasses.outerDivClasses.split(" ")); + (_b = logoDiv.classList).add.apply(_b, buttonClasses.logoDivClasses.split(" ")); + (_c = logoImg.classList).add.apply(_c, buttonClasses.logoImgClasses.split(" ")); + (_d = labelSpan.classList).add.apply(_d, buttonClasses.labelSpanClasses.split(" ")); + } + logoDiv.appendChild(logoImg); + outerDiv.appendChild(logoDiv); + //Do not add label span for icon button + if (type != buttonTypes.icon) { + outerDiv.appendChild(labelSpan); + } + if (errorMsg) { + //adding error span + var errorSpan = document.createElement("span"); + errorSpan.style.color = "red"; + errorSpan.style.color = "14px"; + errorSpan.innerHTML = errorMsg + ". Please report to site admin"; + anchor.appendChild(errorSpan); + } + anchor.appendChild(outerDiv); + return anchor; + }; + function rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonType) { + signInElement.innerHTML = ""; + signInElement.appendChild(createButton(label, "", buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonType)); + } + function buildErrorRedirectUrl(errorDescription, errorCode, oidcConfig) { + if (!oidcConfig.redirect_uri) + return false; + var params = new URLSearchParams(); + if (errorDescription) + params.set("error_description", errorDescription); + params.set("error", errorCode); + window.location.replace("".concat(oidcConfig.redirect_uri, "?").concat(params.toString())); + return true; + } + function promiseWithTimeout(promise, ms) { + return Promise.race([ + promise, + new Promise(function (resolve) { + return setTimeout(function () { return resolve("timeout"); }, ms); + }), + ]); + } + function par_callback(callbackFunction, oidcConfig, dpop_jkt) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!oidcConfig.client_id) { + return [2 /*return*/, errorMessage.clientIdMissing]; + } + _a.label = 1; + case 1: + _a.trys.push([1, 3, , 4]); + return [4 /*yield*/, callbackFunction(oidcConfig.client_id, oidcConfig.state, oidcConfig.ui_locales, dpop_jkt)]; + case 2: return [2 /*return*/, _a.sent()]; + case 3: + _a.sent(); + return [2 /*return*/, errorMessage.requestUriFailed]; + case 4: return [2 /*return*/]; + } + }); + }); + } + function dpop_callback(callbackFunction, oidcConfig) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + if (!oidcConfig.client_id) { + return [2 /*return*/, errorMessage.clientIdMissing]; + } + _a.label = 1; + case 1: + _a.trys.push([1, 3, , 4]); + return [4 /*yield*/, callbackFunction(oidcConfig.client_id, oidcConfig.state)]; + case 2: return [2 /*return*/, _a.sent()]; + case 3: + _a.sent(); + return [2 /*return*/, errorMessage.dpopFailed]; + case 4: return [2 /*return*/]; + } + }); + }); + } + function getTimeoutMs(timeout, fallback) { + if (fallback === void 0) { fallback = 5000; } + var parsed = typeof timeout === "string" ? parseInt(timeout, 10) : timeout; + return typeof parsed === "number" && Number.isFinite(parsed) && parsed > 0 + ? parsed + : fallback; + } + var SignInWithEsignet = function (_a) { return __awaiter(void 0, void 0, void 0, function () { + var oidcConfig, buttonConfig, signInElement, style, hasFunction, hasDpopCallback, hasParCallback, errorMsg, urlToNavigate, handleParCallback, handleDPopCallback, onClickHandler, label, logoPath, baseStyle, buttonCustomStyle, buttonClasses, buttonStyle, button; + var _b, _c; + var props = __rest(_a, []); + return __generator(this, function (_d) { + oidcConfig = props.oidcConfig, buttonConfig = props.buttonConfig, signInElement = props.signInElement, style = props.style; + hasFunction = function (fn) { return typeof fn === "function"; }; + hasDpopCallback = oidcConfig && hasFunction(oidcConfig.dpop_callback); + hasParCallback = oidcConfig && hasFunction(oidcConfig.par_callback); + if (signInElement == null) { + return [2 /*return*/, signInElement]; + } + errorMsg = validateInput(oidcConfig); + urlToNavigate = "#"; + handleParCallback = function (event, dpop_jkt) { return __awaiter(void 0, void 0, void 0, function () { + var timeoutMs, result, redirected_1, redirected; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + event.preventDefault(); + timeoutMs = getTimeoutMs(oidcConfig.par_callback_timeout, 5000); + return [4 /*yield*/, promiseWithTimeout(par_callback(oidcConfig.par_callback, oidcConfig, dpop_jkt), timeoutMs)]; + case 1: + result = _a.sent(); + if (result === "timeout") { + redirected_1 = buildErrorRedirectUrl(errorMessage.requestUriTimeout, "request_uri_timeout", oidcConfig); + if (!redirected_1) { + errorMsg = errorMessage.requestUriTimeout; + rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type); + } + return [2 /*return*/]; + } + if (typeof result === "string" && + result.startsWith("urn:ietf:params:oauth:request_uri:")) { + urlToNavigate = "".concat(oidcConfig.authorizeUri, "?client_id=").concat(encodeURIComponent(oidcConfig.client_id), "&request_uri=").concat(encodeURIComponent(result)); + window.location.href = urlToNavigate; + return [2 /*return*/]; + } + redirected = buildErrorRedirectUrl(errorMessage.requestUriFailed, "request_uri_error", oidcConfig); + if (!redirected) { + errorMsg = errorMessage.requestUriFailed; + rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type); + } + return [2 /*return*/]; + } + }); + }); }; + handleDPopCallback = function (event) { return __awaiter(void 0, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + event.preventDefault(); + return [4 /*yield*/, dpop_callback(oidcConfig.dpop_callback, oidcConfig)]; + case 1: return [2 /*return*/, _a.sent()]; + } + }); + }); }; + onClickHandler = function (event) { return __awaiter(void 0, void 0, void 0, function () { + var dpop_jkt, dpop_response, redirected, err_1; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + event.preventDefault(); + _a.label = 1; + case 1: + _a.trys.push([1, 10, , 11]); + dpop_jkt = ""; + if (!hasDpopCallback) return [3 /*break*/, 6]; + return [4 /*yield*/, handleDPopCallback(event)]; + case 2: + dpop_response = _a.sent(); + if (dpop_response && !Object.values(errorMessage).includes(dpop_response)) { + dpop_jkt = dpop_response; + } + else { + redirected = buildErrorRedirectUrl(dpop_response, "dpop_failed", oidcConfig); + if (!redirected) { + errorMsg = errorMessage.dpopFailed; + rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type); + } + return [2 /*return*/]; + } + if (!hasParCallback) return [3 /*break*/, 4]; + // Then handle PAR if available + return [4 /*yield*/, handleParCallback(event, dpop_jkt)]; + case 3: + // Then handle PAR if available + _a.sent(); + return [3 /*break*/, 5]; + case 4: + if (!errorMsg) { + urlToNavigate = buildRedirectURL(oidcConfig, dpop_jkt); + window.location.href = urlToNavigate; + } + _a.label = 5; + case 5: return [3 /*break*/, 9]; + case 6: + if (!hasParCallback) return [3 /*break*/, 8]; + // Only PAR + return [4 /*yield*/, handleParCallback(event)]; + case 7: + // Only PAR + _a.sent(); + return [3 /*break*/, 9]; + case 8: + if (!errorMsg) { + // Fallback redirect + urlToNavigate = buildRedirectURL(oidcConfig); + window.location.href = urlToNavigate; + } + _a.label = 9; + case 9: return [3 /*break*/, 11]; + case 10: + err_1 = _a.sent(); + console.error("Error in button handler:", err_1); + return [3 /*break*/, 11]; + case 11: return [2 /*return*/]; + } + }); + }); }; + if (!buttonConfig) { + //default values + buttonConfig = { + type: buttonTypes.standard, + theme: defaultThemes.outline, + labelText: defaultButtonLabel, + shape: defaultShapes.sharpEdges, + }; + } + label = (_b = buttonConfig.labelText) !== null && _b !== void 0 ? _b : defaultButtonLabel; + logoPath = (_c = buttonConfig.logoPath) !== null && _c !== void 0 ? _c : img; + baseStyle = style || {}; + buttonCustomStyle = null; + buttonClasses = null; + buttonStyle = {}; + // customStyle has precedence over buttonClasses + if (buttonConfig.customStyle) { + buttonCustomStyle = buildButtonCustomStyles(baseStyle, buttonConfig); + } + else { + buttonClasses = buildButtonClasses(buttonConfig); + buttonStyle = buildButtonStyles(baseStyle, buttonConfig); + } + button = createButton(label, urlToNavigate, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type, onClickHandler); + signInElement.innerHTML = ""; + signInElement.appendChild(button); + return [2 /*return*/, signInElement]; + }); + }); }; + var init = function (_a) { return __awaiter(void 0, void 0, void 0, function () { + var props = __rest(_a, []); + return __generator(this, function (_b) { + switch (_b.label) { + case 0: return [4 /*yield*/, SignInWithEsignet(props)]; + case 1: return [2 /*return*/, _b.sent()]; + } + }); + }); }; + + exports.init = init; + + Object.defineProperty(exports, '__esModule', { value: true }); + + return exports; + +})({});