@elliemae/ssf-host 2.22.1 → 2.22.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cjs/host.js CHANGED
@@ -333,7 +333,7 @@ class SSFHost {
333
333
  requestId,
334
334
  response: objects
335
335
  });
336
- this.#logger.audit({
336
+ this.#logger.debug({
337
337
  message: `name of scripting objects returned`,
338
338
  requestId,
339
339
  objects,
@@ -376,7 +376,7 @@ class SSFHost {
376
376
  requestId,
377
377
  response: this.#encodeResponse(obj, guest)
378
378
  });
379
- this.#logger.audit({
379
+ this.#logger.debug({
380
380
  message: `Scripting Object returned`,
381
381
  requestId,
382
382
  scriptingObject: objectId,
@@ -538,7 +538,7 @@ class SSFHost {
538
538
  requestId,
539
539
  response: this.#encodeResponse(val, guest)
540
540
  });
541
- this.#logger.audit({
541
+ this.#logger.debug({
542
542
  message: `Value returned for Scripting Object method call`,
543
543
  requestId,
544
544
  scriptingObject: objectId,
@@ -552,7 +552,7 @@ class SSFHost {
552
552
  requestId,
553
553
  ex
554
554
  });
555
- this.#logger.audit({
555
+ this.#logger.error({
556
556
  message: `Exception thrown for Scripting Object method call`,
557
557
  requestId,
558
558
  scriptingObject: objectId,
@@ -996,7 +996,7 @@ class SSFHost {
996
996
  );
997
997
  timingMetricStarted = true;
998
998
  }
999
- this.#logger.audit({
999
+ this.#logger.debug({
1000
1000
  message: "Event dispatched and awaiting feedback",
1001
1001
  scriptingEventId: id,
1002
1002
  ...guestInfo
@@ -1006,7 +1006,7 @@ class SSFHost {
1006
1006
  messageType: import_microfe_common.MessageType.ObjectEvent,
1007
1007
  messageBody: eventObj
1008
1008
  });
1009
- this.#logger.audit({
1009
+ this.#logger.debug({
1010
1010
  message: "Event dispatched",
1011
1011
  scriptingEventId: id,
1012
1012
  ...guestInfo
@@ -1015,7 +1015,7 @@ class SSFHost {
1015
1015
  }
1016
1016
  });
1017
1017
  const retValue = await Promise.all(guestPromises).then((values) => {
1018
- this.#logger.audit({
1018
+ this.#logger.debug({
1019
1019
  message: "Event feedback received",
1020
1020
  scriptingEventId: id
1021
1021
  });
package/dist/esm/host.js CHANGED
@@ -320,7 +320,7 @@ class SSFHost {
320
320
  requestId,
321
321
  response: objects
322
322
  });
323
- this.#logger.audit({
323
+ this.#logger.debug({
324
324
  message: `name of scripting objects returned`,
325
325
  requestId,
326
326
  objects,
@@ -363,7 +363,7 @@ class SSFHost {
363
363
  requestId,
364
364
  response: this.#encodeResponse(obj, guest)
365
365
  });
366
- this.#logger.audit({
366
+ this.#logger.debug({
367
367
  message: `Scripting Object returned`,
368
368
  requestId,
369
369
  scriptingObject: objectId,
@@ -525,7 +525,7 @@ class SSFHost {
525
525
  requestId,
526
526
  response: this.#encodeResponse(val, guest)
527
527
  });
528
- this.#logger.audit({
528
+ this.#logger.debug({
529
529
  message: `Value returned for Scripting Object method call`,
530
530
  requestId,
531
531
  scriptingObject: objectId,
@@ -539,7 +539,7 @@ class SSFHost {
539
539
  requestId,
540
540
  ex
541
541
  });
542
- this.#logger.audit({
542
+ this.#logger.error({
543
543
  message: `Exception thrown for Scripting Object method call`,
544
544
  requestId,
545
545
  scriptingObject: objectId,
@@ -983,7 +983,7 @@ class SSFHost {
983
983
  );
984
984
  timingMetricStarted = true;
985
985
  }
986
- this.#logger.audit({
986
+ this.#logger.debug({
987
987
  message: "Event dispatched and awaiting feedback",
988
988
  scriptingEventId: id,
989
989
  ...guestInfo
@@ -993,7 +993,7 @@ class SSFHost {
993
993
  messageType: MessageType.ObjectEvent,
994
994
  messageBody: eventObj
995
995
  });
996
- this.#logger.audit({
996
+ this.#logger.debug({
997
997
  message: "Event dispatched",
998
998
  scriptingEventId: id,
999
999
  ...guestInfo
@@ -1002,7 +1002,7 @@ class SSFHost {
1002
1002
  }
1003
1003
  });
1004
1004
  const retValue = await Promise.all(guestPromises).then((values) => {
1005
- this.#logger.audit({
1005
+ this.#logger.debug({
1006
1006
  message: "Event feedback received",
1007
1007
  scriptingEventId: id
1008
1008
  });
@@ -1 +1 @@
1
- <!doctype html><html lang="en"><head><meta charset="UTF-8"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><meta name="viewport" content="width=device-width,initial-scale=1"/><title>Host</title><script src="https://cdn.tailwindcss.com?plugins=forms"></script><script src="https://cdn.mortgagetech.q1.ice.com/pui-diagnostics@3"></script><script defer="defer" src="js/emuiSsfHost.a1d3542194a2fb9e9816.js"></script></head><body><header class="bg-indigo-300 h-10 flex place-items-center"><div class="px-2">ICE Mortgage Product</div></header><main class="mx-auto max-w-7xl px-2 sm:px-6 lg:px-8"><div class="min-w-0 flex-1 mt-4"><h1 class="text-2xl font-bold leading-7 text-gray-900 sm:truncate sm:text-3xl sm:tracking-tight">Loan Application</h1></div><div id="successFeedback" class="hidden rounded-md bg-green-50 p-4"><div class="flex"><div class="flex-shrink-0"><svg class="h-5 w-5 text-green-400" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z" clip-rule="evenodd"/></svg></div><div class="ml-3"><p class="text-sm font-medium text-green-800">Loan Saved Successfully</p></div></div></div><div id="errorFeedback" class="hidden rounded-md bg-red-50 p-4"><div class="flex"><div class="flex-shrink-0"><svg class="h-5 w-5 text-red-400" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zM8.28 7.22a.75.75 0 00-1.06 1.06L8.94 10l-1.72 1.72a.75.75 0 101.06 1.06L10 11.06l1.72 1.72a.75.75 0 101.06-1.06L11.06 10l1.72-1.72a.75.75 0 00-1.06-1.06L10 8.94 8.28 7.22z" clip-rule="evenodd"/></svg></div><div class="ml-3"><h3 class="text-sm font-medium text-red-800">Credit Score is not meeting the requirement</h3></div></div></div><div class="mt-2 sm:grid sm:grid-cols-2 sm:gap-2"><form class="px-2 py-2 space-y-8 divide-y divide-gray-200 bg-gray-50"><div class="space-y-8 divide-y divide-gray-200 sm:space-y-5"><div class="space-y-6 sm:space-y-5"><div><h3 class="text-lg font-medium leading-6 text-gray-900">Personal Information</h3></div><div class="space-y-6 sm:space-y-5"><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="firstName" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">First name</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input name="firstName" id="firstName" autocomplete="given-name" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="John" placeholder="John"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="lastName" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Last name</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input name="lastName" id="lastName" autocomplete="family-name" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="Doe" placeholder="Doe"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="ssn" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">SSN</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="ssn" id="ssn" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="123456789" placeholder="123456789"/></div></div></div><div><h3 class="text-lg font-medium leading-6 text-gray-900">Loan Information</h3></div><div class="space-y-6 sm:space-y-5"><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="amount" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Amount</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="amount" id="amount" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="500000" placeholder="500000"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="Term" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Term (years)</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="term" id="term" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="30" placeholder="30"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="downPayment" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Down Payment</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="downPayment" id="downPayment" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="50000" placeholder="50000"/></div></div><div><h3 class="text-lg font-medium leading-6 text-gray-900">Order Services</h3></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><div class="mt-1 sm:mt-0"><button id="title" type="button" class="inline-flex items-center rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 disabled:opacity-50 disabled:cursor-not-allowed focus:ring-offset-2"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="w-6 h-6"><path fill-rule="evenodd" d="M7.502 6h7.128A3.375 3.375 0 0118 9.375v9.375a3 3 0 003-3V6.108c0-1.505-1.125-2.811-2.664-2.94a48.972 48.972 0 00-.673-.05A3 3 0 0015 1.5h-1.5a3 3 0 00-2.663 1.618c-.225.015-.45.032-.673.05C8.662 3.295 7.554 4.542 7.502 6zM13.5 3A1.5 1.5 0 0012 4.5h4.5A1.5 1.5 0 0015 3h-1.5z" clip-rule="evenodd"/><path fill-rule="evenodd" d="M3 9.375C3 8.339 3.84 7.5 4.875 7.5h9.75c1.036 0 1.875.84 1.875 1.875v11.25c0 1.035-.84 1.875-1.875 1.875h-9.75A1.875 1.875 0 013 20.625V9.375zM6 12a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V12zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75zM6 15a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V15zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75zM6 18a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V18zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75z" clip-rule="evenodd"/></svg> Title</button></div><div class="mt-1 sm:mt-0"><button id="credit" type="button" class="inline-flex items-center rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 disabled:opacity-50 disabled:cursor-not-allowed focus:ring-offset-2"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="w-6 h-6"><path fill-rule="evenodd" d="M2.25 13.5a8.25 8.25 0 018.25-8.25.75.75 0 01.75.75v6.75H18a.75.75 0 01.75.75 8.25 8.25 0 01-16.5 0z" clip-rule="evenodd"/><path fill-rule="evenodd" d="M12.75 3a.75.75 0 01.75-.75 8.25 8.25 0 018.25 8.25.75.75 0 01-.75.75h-7.5a.75.75 0 01-.75-.75V3z" clip-rule="evenodd"/></svg> Credit Score</button></div></div></div></div></div><div class="flex flex-col"><button id="saveLoan" type="button" class="rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2">Save</button></div></form><div id="aside-container" class="flex flex-col gap-4 items-start mt-4 border-2 p-2 rounded-lg border-dashed border-cyan-300 sm:mt-0"></div></div><div id="bottom-container" class="flex flex-col gap-4 items-start mt-4 p-2 sm:mt-0"></div></main><script src="./init.js" type="module"></script></body></html>
1
+ <!doctype html><html lang="en"><head><meta charset="UTF-8"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><meta name="viewport" content="width=device-width,initial-scale=1"/><title>Host</title><script src="https://cdn.tailwindcss.com?plugins=forms"></script><script src="https://cdn.mortgagetech.q1.ice.com/pui-diagnostics@3"></script><script defer="defer" src="js/emuiSsfHost.7b0555015fdcf2116165.js"></script></head><body><header class="bg-indigo-300 h-10 flex place-items-center"><div class="px-2">ICE Mortgage Product</div></header><main class="mx-auto max-w-7xl px-2 sm:px-6 lg:px-8"><div class="min-w-0 flex-1 mt-4"><h1 class="text-2xl font-bold leading-7 text-gray-900 sm:truncate sm:text-3xl sm:tracking-tight">Loan Application</h1></div><div id="successFeedback" class="hidden rounded-md bg-green-50 p-4"><div class="flex"><div class="flex-shrink-0"><svg class="h-5 w-5 text-green-400" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z" clip-rule="evenodd"/></svg></div><div class="ml-3"><p class="text-sm font-medium text-green-800">Loan Saved Successfully</p></div></div></div><div id="errorFeedback" class="hidden rounded-md bg-red-50 p-4"><div class="flex"><div class="flex-shrink-0"><svg class="h-5 w-5 text-red-400" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true"><path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zM8.28 7.22a.75.75 0 00-1.06 1.06L8.94 10l-1.72 1.72a.75.75 0 101.06 1.06L10 11.06l1.72 1.72a.75.75 0 101.06-1.06L11.06 10l1.72-1.72a.75.75 0 00-1.06-1.06L10 8.94 8.28 7.22z" clip-rule="evenodd"/></svg></div><div class="ml-3"><h3 class="text-sm font-medium text-red-800">Credit Score is not meeting the requirement</h3></div></div></div><div class="mt-2 sm:grid sm:grid-cols-2 sm:gap-2"><form class="px-2 py-2 space-y-8 divide-y divide-gray-200 bg-gray-50"><div class="space-y-8 divide-y divide-gray-200 sm:space-y-5"><div class="space-y-6 sm:space-y-5"><div><h3 class="text-lg font-medium leading-6 text-gray-900">Personal Information</h3></div><div class="space-y-6 sm:space-y-5"><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="firstName" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">First name</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input name="firstName" id="firstName" autocomplete="given-name" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="John" placeholder="John"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="lastName" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Last name</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input name="lastName" id="lastName" autocomplete="family-name" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="Doe" placeholder="Doe"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="ssn" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">SSN</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="ssn" id="ssn" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="123456789" placeholder="123456789"/></div></div></div><div><h3 class="text-lg font-medium leading-6 text-gray-900">Loan Information</h3></div><div class="space-y-6 sm:space-y-5"><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="amount" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Amount</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="amount" id="amount" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="500000" placeholder="500000"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="Term" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Term (years)</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="term" id="term" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="30" placeholder="30"/></div></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><label for="downPayment" class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2">Down Payment</label><div class="mt-1 sm:col-span-2 sm:mt-0"><input type="number" name="downPayment" id="downPayment" class="block w-full max-w-lg rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 sm:max-w-xs sm:text-sm" value="50000" placeholder="50000"/></div></div><div><h3 class="text-lg font-medium leading-6 text-gray-900">Order Services</h3></div><div class="sm:grid sm:grid-cols-3 sm:items-start sm:gap-4 sm:border-gray-200"><div class="mt-1 sm:mt-0"><button id="title" type="button" class="inline-flex items-center rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 disabled:opacity-50 disabled:cursor-not-allowed focus:ring-offset-2"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="w-6 h-6"><path fill-rule="evenodd" d="M7.502 6h7.128A3.375 3.375 0 0118 9.375v9.375a3 3 0 003-3V6.108c0-1.505-1.125-2.811-2.664-2.94a48.972 48.972 0 00-.673-.05A3 3 0 0015 1.5h-1.5a3 3 0 00-2.663 1.618c-.225.015-.45.032-.673.05C8.662 3.295 7.554 4.542 7.502 6zM13.5 3A1.5 1.5 0 0012 4.5h4.5A1.5 1.5 0 0015 3h-1.5z" clip-rule="evenodd"/><path fill-rule="evenodd" d="M3 9.375C3 8.339 3.84 7.5 4.875 7.5h9.75c1.036 0 1.875.84 1.875 1.875v11.25c0 1.035-.84 1.875-1.875 1.875h-9.75A1.875 1.875 0 013 20.625V9.375zM6 12a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V12zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75zM6 15a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V15zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75zM6 18a.75.75 0 01.75-.75h.008a.75.75 0 01.75.75v.008a.75.75 0 01-.75.75H6.75a.75.75 0 01-.75-.75V18zm2.25 0a.75.75 0 01.75-.75h3.75a.75.75 0 010 1.5H9a.75.75 0 01-.75-.75z" clip-rule="evenodd"/></svg> Title</button></div><div class="mt-1 sm:mt-0"><button id="credit" type="button" class="inline-flex items-center rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 disabled:opacity-50 disabled:cursor-not-allowed focus:ring-offset-2"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="w-6 h-6"><path fill-rule="evenodd" d="M2.25 13.5a8.25 8.25 0 018.25-8.25.75.75 0 01.75.75v6.75H18a.75.75 0 01.75.75 8.25 8.25 0 01-16.5 0z" clip-rule="evenodd"/><path fill-rule="evenodd" d="M12.75 3a.75.75 0 01.75-.75 8.25 8.25 0 018.25 8.25.75.75 0 01-.75.75h-7.5a.75.75 0 01-.75-.75V3z" clip-rule="evenodd"/></svg> Credit Score</button></div></div></div></div></div><div class="flex flex-col"><button id="saveLoan" type="button" class="rounded-md border border-transparent bg-indigo-600 px-4 py-2 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2">Save</button></div></form><div id="aside-container" class="flex flex-col gap-4 items-start mt-4 border-2 p-2 rounded-lg border-dashed border-cyan-300 sm:mt-0"></div></div><div id="bottom-container" class="flex flex-col gap-4 items-start mt-4 p-2 sm:mt-0"></div></main><script src="./init.js" type="module"></script></body></html>
@@ -1,3 +1,3 @@
1
- (function(I,y){typeof exports=="object"&&typeof module=="object"?module.exports=y():typeof define=="function"&&define.amd?define([],y):typeof exports=="object"?exports.ice=y():(I.ice=I.ice||{},I.ice.host=y())})(globalThis,()=>(()=>{"use strict";var v={};v.d=(n,e)=>{for(var t in e)v.o(e,t)&&!v.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},v.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),v.r=n=>{typeof Symbol<"u"&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})};var I={};v.r(I),v.d(I,{Event:()=>y,Guest:()=>q,IFrameSandboxValues:()=>E,OpenMode:()=>w,SANDBOX_DEFAULT:()=>B,SSFHost:()=>te,ScriptingObject:()=>T});class y{name;objectId;id;constructor(e){const{name:t,objectId:i}=e;if(!t)throw new Error("Event name is required");if(!i)throw new Error("Scripting object id is required");this.objectId=i,this.name=t,this.id=`${this.objectId}.${this.name}`.toLowerCase()}}class A{static[Symbol.hasInstance](e){return e.getType?.()==="ProxyEvent"}#e;objectId;name;id;getType(){return"ProxyEvent"}constructor(e){const{name:t,objectId:i,eventSrc:s}=e;this.objectId=i,this.name=t,this.#e=s,this.id=`${this.objectId}.${this.name}`.toLowerCase()}subscribe=e=>this.#e.subscribe({eventId:this.id,callback:e});unsubscribe=e=>{this.#e.unsubscribe({eventId:this.id,token:e})}}const H=n=>n instanceof y,ie=(n,e)=>`${n.toLowerCase()}.${e.toLowerCase()}`,W="function",J=(n,e)=>typeof n===W&&!!e&&!e.startsWith("_");class T{#e;#i="Object";constructor(e,t){this.#e=e,this.#i=t||this.#i}get id(){return this.#e}get objectType(){return this.#i}_toJSON=()=>{const e=[],t=[];return Object.keys(this).forEach(i=>{const s=this[i];H(s)?t.push(i):J(s,i)&&e.push(i)}),{objectId:this.#e,objectType:this.#i,functions:e,events:t}};_dispose=()=>{};dispose=()=>{}}var l=(n=>(n.GuestClose="guest:close",n.GuestEventSubscribe="guest:eventSubscribe",n.GuestEventUnsubscribe="guest:eventUnsubscribe",n.GuestFocus="guest:focus",n.GuestReady="guest:ready",n.GuestReadyComplete="guest:readyComplete",n.GuestResize="guest:resize",n.HandShake="handshake",n.HandShakeAck="handshake:ack",n.HostClose="host:close",n.HostConfig="host:config",n.ListObjects="list:objects",n.ObjectEvent="object:event",n.ObjectGet="object:get",n.ObjectInvoke="object:invoke",n))(l||{}),w=(n=>(n.Popup="popup",n.Embed="embed",n))(w||{}),E=(n=>(n.AllowDownloadsWithoutUserActivation="allow-downloads-without-user-activation",n.AllowDownloads="allow-downloads",n.AllowForms="allow-forms",n.AllowModals="allow-modals",n.AllowOrientationLock="allow-orientation-lock",n.AllowPointerLock="allow-pointer-lock",n.AllowPopups="allow-popups",n.AllowPopupsToEscapeSandbox="allow-popups-to-escape-sandbox",n.AllowPresentation="allow-presentation",n.AllowSameOrigin="allow-same-origin",n.AllowScripts="allow-scripts",n.AllowStorageAccessByUserActivation="allow-storage-access-by-user-activation",n.AllowTopNavigation="allow-top-navigation",n.AllowTopNavigationByUserActivation="allow-top-navigation-by-user-activation",n))(E||{});const Y=n=>{if(n==="about:blank")return"*";try{const{origin:e}=new URL(n);return e==="null"||!e?n:e}catch{const{origin:t}=new URL(n,document.baseURI);return t}},U=(n,e=[])=>{const t=e||[];return n&&n.forEach?n.forEach(i=>{U(i,t)}):typeof n<"u"&&t.push(n),t},se=n=>typeof n?._toJSON=="function";function R(n){return typeof n=="function"}const ne=n=>n?.id??n;class q{id;title;url;searchParams;domElement;window;openMode;origin;initialized=!1;ready=!1;capabilities;#e;#i;constructor(e){const{guestId:t,domElement:i=null,title:s,url:o,window:r,searchParams:c={},openMode:a=w.Embed,remoting:d,analyticsObj:u}=e;this.id=t,this.title=s,this.url=o,this.origin=Y(o),this.searchParams=c,this.domElement=i,this.window=r,this.openMode=a,this.capabilities={},this.#i=u,this.#e=d}dispose=()=>{if(this.openMode===w.Popup&&!this.window.closed)try{this.window.document,this.window.close()}catch{this.#e.send({targetWin:this.window,targetOrigin:this.origin,messageType:l.HostClose,messageBody:{}})}else this.domElement?.remove?.();this.#e.removeSender({origin:this.origin,window:this.window})};getInfo=()=>({guestId:this.id,guestTitle:this.title,guestUrl:this.url});handShake=()=>new Promise(e=>{let t=0;const i=5,s=setInterval(()=>{t>=i?(clearInterval(s),e(!1)):(this.#e.send({targetWin:this.window,targetOrigin:this.origin,messageType:l.HandShake,messageBody:{}}),t+=1)},1e3);this.#e.listen({messageType:l.HandShakeAck,callback:()=>{clearInterval(s),e(!0)}})});init=()=>{this.#e.addSender({origin:this.origin,window:this.window}),this.openMode===w.Popup&&this.handShake().catch(()=>{})};dispatchEvent=(e,t)=>(this.#i.startTiming(`ScriptingObject.Event.${e.object.objectId}.${e.eventName}`,{appId:this.id,appUrl:this.url}).catch(()=>{}),this.#e.invoke({targetWin:this.window,targetOrigin:this.origin,messageType:l.ObjectEvent,messageBody:e,responseTimeoutMs:t}).finally(()=>{this.#i.endTiming(`ScriptingObject.Event.${e.object.objectId}.${e.eventName}`,{appId:this.id,appUrl:this.url}).catch(()=>{})}));send=e=>{this.#e.send({targetWin:this.window,targetOrigin:this.origin,...e})}}const L={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};let G;const X=new Uint8Array(16);function K(){if(!G&&(G=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!G))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return G(X)}const h=[];for(let n=0;n<256;++n)h.push((n+256).toString(16).slice(1));function _(n,e=0){return h[n[e+0]]+h[n[e+1]]+h[n[e+2]]+h[n[e+3]]+"-"+h[n[e+4]]+h[n[e+5]]+"-"+h[n[e+6]]+h[n[e+7]]+"-"+h[n[e+8]]+h[n[e+9]]+"-"+h[n[e+10]]+h[n[e+11]]+h[n[e+12]]+h[n[e+13]]+h[n[e+14]]+h[n[e+15]]}function re(n,e=0){const t=_(n,e);if(!validate(t))throw TypeError("Stringified UUID is invalid");return t}const ce=null;function Q(n,e,t){if(L.randomUUID&&!e&&!n)return L.randomUUID();n=n||{};const i=n.random||(n.rng||K)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,e){t=t||0;for(let s=0;s<16;++s)e[t+s]=i[s];return e}return _(i)}const C=Q,M="elli:remoting",x="elli:remoting:response",N="elli:remoting:exception",$=({messageType:n,messageBody:e,onewayMsg:t=!1})=>({requestId:t?null:C(),source:M,type:n,body:e}),ae=n=>{const{targetWin:e,targetOrigin:t,messageType:i,messageBody:s}=n,o=$({messageType:i,messageBody:s});e.postMessage(o,t)};class V{#e;#i;#t=new Map;#n=new Map;#s=null;#o=new Map;#r;constructor(e,t,i){if(!e)throw new Error("logger is required");if(!t)throw new Error("correlationId is required");this.#e=t,this.#i=e,this.#r=i?.unsafeAllowAnyGuestOrigin??!1}#a=e=>this.#r?"*":e;#h=()=>{const e=Date.now(),t=[];this.#n.forEach((i,s)=>{const{requestId:o,cancelTime:r}=i;this.#i.debug(`Checking response timeout for requestId: ${o}) @ ${r??""}`),i.cancelTime&&i.cancelTime<e&&(this.#i.debug(`Detected response timeout for requestId: ${o}...`),t.push(s),i.resolve(),this.#i.debug(`Aborted waiting for response to requestid: ${o})`))}),t.forEach(i=>{this.#i.debug(`removing invocations with requestId ${i} from cache since response time has expired`),this.#n.delete(i)}),this.#n.size===0&&(this.#i.debug("stopping response monitor"),this.#p())};#g=()=>{this.#s===null&&(this.#i.debug("Staring response timeout evaluator"),this.#s=window.setInterval(this.#h,200))};#p=()=>{this.#s!==null&&(window.clearInterval(this.#s),this.#s=null,this.#i.debug("Stopped response timeout evaluator"))};#b=e=>{const t=this.#n.get(e);return this.#i.debug(`serving requestId: ${e}`),this.#n.delete(e),t};#d=e=>{const{requestId:t}=e;this.#i.debug(`Response received for invocation requestId: ${t}`);const i=this.#b(t);return i?(i.resolve(e.body),!0):(this.#i.debug(`Received response to stale/invalid request with requestId: ${t}`),!1)};#u=e=>{this.#i.debug(`Exception received for invocation (requestId = ${e.requestId})`);const t=this.#b(e.requestId);return t?(t.reject(new Error(e.body)),!0):(this.#i.warn(`Received exception for stale/invalid request (requestId = ${e.requestId})`),!1)};#l=({sourceWin:e,sourceOrigin:t,message:i})=>{this.#i.debug(`Received message of type "${i.type}"`);const s=this.#t.get(i.type);return s?(s.forEach(o=>{this.#i.debug(`Invoking message handler ${o.name}`),o({sourceWin:e,sourceOrigin:t,requestId:i.requestId,type:i.type,body:i.body})}),!0):!1};#c=e=>{if(this.#i.debug(`Remoting: Received message ${JSON.stringify(e.data)}`),this.#o.size===0||!e.source)return!1;const t=this.#o.get(e.source);return!t||e?.data?.source!==M?!1:(e.data.type===x?this.#d(e.data):e.data.type===N?this.#u(e.data):this.#l({sourceWin:e.source,sourceOrigin:t,message:e.data}),!0)};addSender=e=>{const{origin:t,window:i}=e;if(!t)throw new Error("origin is required");if(!i)throw new Error("window is required");this.#o.set(i,t)};initialize=e=>{e.removeEventListener("message",this.#c),e.addEventListener("message",this.#c),this.#i.debug(`initialized remoting id: ${this.#e}`)};close=()=>{window.removeEventListener("message",this.#c),this.#i.debug(`closed remoting id: ${this.#e}`)};invoke=e=>{const{targetWin:t,targetOrigin:i,messageType:s,messageBody:o,responseTimeoutMs:r}=e;return new Promise((c,a)=>{const d=$({messageType:s,messageBody:o});this.#n.set(d.requestId,{requestId:d.requestId,resolve:c,reject:a,cancelTime:r?Date.now()+Number.parseInt(r,10):null}),t.postMessage(d,this.#a(i));const{requestId:u}=d;this.#i.debug(`Posted invocation message of type ${s} requestId: ${u||""}`),r&&(this.#i.debug(`starting response monitor for requestId: ${u||""} for ${r} ms`),this.#g())})};listen=e=>{const{messageType:t,callback:i}=e,s=this.#t.get(t)||[];s.push(i),this.#t.set(t,s)};send=e=>{const{targetWin:t,targetOrigin:i,messageType:s,messageBody:o}=e,r=$({messageType:s,messageBody:o,onewayMsg:!0});t.postMessage(r,this.#a(i)),this.#i.debug(`Posted one-way message of type "${s}"`)};removeSender=e=>{const{window:t}=e;t&&this.#o.delete(t)};respond=e=>{const{targetWin:t,targetOrigin:i,requestId:s,response:o}=e,r=$({messageType:x,messageBody:o});r.requestId=s,t.postMessage(r,this.#a(i)),this.#i.debug(`Response sent to caller for invocation requestId: ${s}`)};raiseException=e=>{const{targetWin:t,targetOrigin:i,requestId:s,ex:o}=e,r=$({messageType:N,messageBody:o});r.requestId=s,t.postMessage(r,this.#a(i)),this.#i.debug(`Exception sent to caller for invocation. requestId: ${s}`)}}const z="module";var Z=(n=>(n.USER="USER",n.PARTNER="PARTNER",n))(Z||{});class ee{#e=new Map;#i=new Map;#t=e=>{const{so:t,guestId:i}=e,s=t.id.toLowerCase(),o=this.#i.get(i);if(!o)this.#i.set(i,new Map([[s,e]]));else{if(o.has(s))throw new Error(`Scripting Object ${t.id} already exists for guest ${i}`);o.set(s,e)}};#n=({so:e})=>{e._dispose&&typeof e._dispose=="function"&&e._dispose()};#s=({objectId:e,guestId:t})=>{if(e===z&&!t)for(const[,s]of this.#i){const o=s.get(e);if(o)return o}const i=t?this.#i.get(t):null;return i?i.get(e)??null:null};#o=({objectId:e,guestId:t}={})=>{if(t){if(!e){const s=this.#i.get(t);s&&s.forEach(this.#n),this.#i.delete(t);return}const i=this.#i.get(t);if(i){const s=i.get(e);s&&this.#n(s),i.delete(e)}}else e&&this.#i.forEach(i=>{const s=i.get(e);s&&this.#n(s),i.delete(e)})};addScriptingObject=(e,t)=>{const{guestId:i}=t||{};if(!e?.id||!e?._toJSON)throw new Error("Object is not derived from ScriptingObject");const s=e.id.toLowerCase();if(s.trim().toLowerCase()===z&&!i)throw new Error("Guest id is required to add Module scripting object");if(i){this.#t({so:e,...t,guestId:i});return}if(this.#e.has(s))throw new Error(`Scripting Object ${e.id} already exists`);this.#e.set(s,{so:e,...t})};getObject=(e,t)=>{const i=e.trim().toLowerCase();let s=this.#s({objectId:i,guestId:t?.id});s=s??this.#e.get(i)??null;const{so:o}=s||{};return o||null};has=(e,t)=>this.getObject(e,t)!==null;listScriptingObjects=e=>{let t=Array.from(this.#e.keys());const i=this.#i.get(e);return t=i?t.concat(Array.from(i.keys())):t,Array.from(new Set(t))};removeScriptingObject=(e,t)=>{const i=e.toLowerCase();if(t)this.#o({objectId:i,guestId:t});else{this.#o({objectId:i});const s=this.#e.get(i);s&&this.#n(s),this.#e.delete(i)}};removeAllScriptingObjects=e=>{e?this.#o({guestId:e}):(this.#e.forEach(this.#n),this.#e.clear())}}class de{__TYPE__="Proxy";id;objectType;constructor(e,t){this.id=e,this.objectType=t}}const D=n=>n?.constructor?.name==="Proxy"||n?.constructor?.name==="ScriptingObjectProxy"||n?.__TYPE__==="Proxy",B=[E.AllowScripts,E.AllowPopups,E.AllowModals,E.AllowForms,E.AllowDownloads,E.AllowSameOrigin];class te{hostId;#e;#i;#t;#n;#s=new Map;#o=new Map;#r;#a=null;#h=null;#g=null;#p=null;constructor(e,t){if(this.hostId=e,!t?.logger)throw new Error("Logger is required");if(!t?.analyticsObj)throw new Error("Analytics object is required");if(this.#t=t.logger,this.#n=t.analyticsObj,this.#i=C(),this.#e=new V(this.#t,this.#i,{unsafeAllowAnyGuestOrigin:t?.unsafeAllowAnyGuestOrigin}),t?.readyStateCallback&&typeof t?.readyStateCallback!="function")throw new Error("readyStateCallback must be a function");this.#a=t?.readyStateCallback||null,this.#g=t?.onGuestEventSubscribe||null,this.#p=t?.onGuestEventUnsubscribe||null,this.#r=new ee,this.#e.initialize(window),this.#R(),window.addEventListener("beforeunload",this.#l),this.#L(),this.#t.debug(`host is initialized. hostId: ${this.hostId}, correlationId: ${this.#i}`)}#b=(e,t)=>{const i={event:e,...t};this.#n.sendBAEvent(i).catch(()=>{})};#d=(e,t)=>{this.#n.startTiming(e,t).catch(()=>{})};#u=(e,t)=>{this.#n.endTiming(e,t).catch(()=>{})};#l=()=>{for(const e of this.#s.values())e.openMode===w.Popup&&this.unloadGuest(e.id)};#c=e=>Array.from(this.#s.values()).find(t=>t.window===e);#E=e=>{for(const t of this.#s.values())if(t.url===e)return t;return null};#j=e=>typeof e?._toJSON=="function";#w=(e,t)=>this.#j(e)?(this.#r.has(e?.id,t)||this.#r.addScriptingObject(e,t?{guestId:t?.id}:{}),{type:"object",object:e._toJSON()}):{type:"value",value:e};#x=e=>typeof e=="string"?e:e instanceof Error?e.message:"An unexpected error occurred in the host application";#m=e=>{e.ready&&this.#e.send({targetWin:e.window,targetOrigin:e.origin,messageType:l.HostConfig,messageBody:{logLevel:this.#t.getLogLevel(),...e.getInfo()}})};#O=({guest:e,obj:t,functionName:i,functionParams:s})=>{const o=t[i];return R(o)?(this.#t.debug(`Invoking host implementation of ${t.id}.${String(i)}()`),new Promise(r=>{Object.defineProperty(o,"callContext",{value:{guest:e},configurable:!0,enumerable:!0,writable:!0}),r(o(...s))})):(this.#t.warn(`Attempt to call invalid function on object type ${t.objectType}: ${String(i)}`),Promise.reject(new Error(`Method '${i}' not found in Scripting Object '${t.id}'`)))};#v=({sourceWin:e,sourceOrigin:t,requestId:i})=>{const s=this.#c(e);if(!s){this.#t.warn(`Received ready event for unknown guest. requestId: ${i}`);return}if(!s.initialized){this.#t.warn("Guest must be initialized before it is marked as ready"),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:"Guest must be initialized before it is marked as ready"});return}if(!s.ready){s.ready=!0;const o=s.getInfo();this.#u("SSF.Guest.Load",{appId:o.guestId,appUrl:o.guestUrl}),this.#m(s),this.#a?.(s),this.#t.audit({message:"Guest is ready",...o})}};#S=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const o=this.#c(e);if(!o){this.#t.warn(`Received ready event for unknown guest. requestid = ${i}`);return}o.initialized||(o.initialized=!0,o.capabilities=s||{},this.#t.audit({message:"Guest is initialized",...o.getInfo()})),(!s||!s.onReady)&&this.#v({sourceWin:e,sourceOrigin:t,requestId:i,type:"",body:null})};#I=async({sourceWin:e})=>{if(e?.window){const t=this.#f(e);t&&!await t.handShake()&&this.unloadGuest(e)}};#$=({sourceWin:e,sourceOrigin:t,requestId:i})=>{this.#t.debug(`Processing listObjects request. requestId = ${i}`);const s=this.#c(e);if(!s)return this.#t.warn("Rejected object request from unknown guest window"),!1;const o=this.#r.listScriptingObjects(s.id);return this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:o}),this.#t.audit({message:"name of scripting objects returned",requestId:i,objects:o,...s.getInfo()}),!0};#k=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const{objectId:o}=s;this.#t.debug(`Processing getObject request for object ${o}. requestId = ${i}`);const r=this.#c(e);if(!r)return this.#t.warn("Rejected object request from unknown guest window"),!1;const c=this.getScriptingObject(o,{guest:r});return c?(this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:this.#w(c,r)}),this.#t.audit({message:"Scripting Object returned",requestId:i,scriptingObject:o,...r.getInfo()}),!0):(this.#t.warn(`unknown or unauthorized object ${o} from guest ${r.id}`),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:`The requested object (${o}) is not available`}),!1)};#G=({sourceWin:e,requestId:t,body:i})=>{const{eventId:s,criteria:o,token:r}=i;this.#t.debug(`Processing guest event subscribe request for event ${s}. requestId = ${t}`);const c=this.#c(e);if(!c){this.#t.warn("Rejected event subscribe request from unknown guest window");return}setTimeout(()=>{try{this.#g?.({guestId:c.id,eventId:s,criteria:o,token:r})}catch{}},0)};#P=({sourceWin:e,requestId:t,body:i})=>{const{eventId:s,token:o}=i;this.#t.debug(`Processing guest event unsubscribe request for event ${s}. requestId = ${t}`);const r=this.#c(e);if(!r){this.#t.warn("Rejected event unsubscribe request from unknown guest window");return}setTimeout(()=>{try{this.#p?.({guestId:r.id,eventId:s,token:o})}catch{}},0)};#A=({sourceWin:e,requestId:t,body:i})=>{const s=this.#c(e);if(!s){this.#t.warn(`Received resize event from unknown guest. requestid = ${t}`);return}s.domElement&&(s.domElement.style.height=`${i.height}px`),this.#t.debug(`Guest ${s.id} resized to ${i.width}x${i.height}`)};#T=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const{objectId:o}=s,r=this.#c(e);if(!r)return this.#t.warn("Rejected method invocation request from unknown guest window"),!1;this.#t.debug(`Function ${o}.${String(s.functionName)}() called from guest "${r.id}" (requestId = ${i})`);const c=this.getScriptingObject(o,{guest:r});if(!c)return this.#t.warn(`Invocation of unknown or unauthorized object ${o} from guest ${r.id}`),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:`The requested object (${o}) is not available`}),!1;const a=r.getInfo();return this.#d(`ScriptingObject.API.${o}.${s.functionName}`,{appId:a.guestId,appUrl:a.guestUrl}),this.#O({guest:r,obj:c,functionName:s.functionName,functionParams:s.functionParams}).then(d=>{this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:this.#w(d,r)}),this.#t.audit({message:"Value returned for Scripting Object method call",requestId:i,scriptingObject:o,scriptingMethod:s.functionName,...a})}).catch(d=>{this.#e.raiseException({targetWin:e,targetOrigin:r.origin,requestId:i,ex:d}),this.#t.audit({message:"Exception thrown for Scripting Object method call",requestId:i,scriptingObject:o,scriptingMethod:s.functionName,...a})}).finally(()=>{this.#u(`ScriptingObject.API.${o}.${s.functionName}`,{appId:a.guestId,appUrl:a.guestUrl})}),!0};#U=()=>{this.#e.listen({messageType:l.GuestResize,callback:this.#A})};#R=()=>{this.#e.listen({messageType:l.GuestReady,callback:this.#S}),this.#e.listen({messageType:l.GuestReadyComplete,callback:this.#v}),this.#e.listen({messageType:l.GuestClose,callback:this.#I}),this.#e.listen({messageType:l.ListObjects,callback:this.#$}),this.#e.listen({messageType:l.ObjectGet,callback:this.#k}),this.#e.listen({messageType:l.ObjectInvoke,callback:this.#T}),this.#e.listen({messageType:l.GuestEventSubscribe,callback:this.#G}),this.#e.listen({messageType:l.GuestEventUnsubscribe,callback:this.#P})};#q=e=>e instanceof A||typeof e?.subscribe=="function";#y=e=>{const t=new q({...e,remoting:this.#e,analyticsObj:this.#n});return t.init(),this.#s.set(e.guestId,t),t};#f=e=>{let t=typeof e=="string"?this.#s.get(e):null;return t||(t=Array.from(this.#s.values()).find(i=>i.window===e||i.domElement===e)),t};#L=()=>{this.#h=setInterval(()=>{const e=[];this.#s.forEach(t=>{t.openMode===w.Popup&&t.window.closed&&e.push(t)}),e.forEach(t=>{const{id:i}=t;this.unloadGuest(i),this.#o.get(i)?.forEach(o=>{o({id:i}).catch(()=>{})})})},1e3)};#_=e=>{const{url:t,title:i,popupWindowFeatures:s={},searchParams:o,guestId:r,onLoad:c,onError:a}=e,{width:d=800,height:u=600,top:j=100,left:m=100}=s;let g=this.#E(t);if(g)g.window.closed||g.send({messageType:l.GuestFocus,messageBody:{}});else{const O=[{key:"width",value:d},{key:"height",value:u},{key:"top",value:j},{key:"left",value:m}].reduce((f,p,b)=>(b>0&&p.value&&(f+=","),p.value?`${f}${p.key}=${p.value}`:f),""),S=window.open(t,i,`popup, ${O}`);if(S)try{setTimeout(()=>{c?.(r)},0)}catch(f){this.#t.debug(`Error occurred in onLoad for guest with id '${r}': ${f.message}`)}else{try{setTimeout(()=>{a?.(r)},0)}catch(f){this.#t.debug(`Error occurred in onError for guest with id '${r}': ${f.message}`)}throw new Error("Failed to open guest application in popup window")}S.opener=null,g=this.#y({guestId:r,window:S,title:i,url:t,searchParams:o,openMode:w.Popup})}return g};#C=e=>{const{url:t,title:i,targetElement:s,searchParams:o,guestId:r,onLoad:c,onError:a,options:d={}}=e,u=s.ownerDocument??document,{fitToContent:j=!1,disableSandbox:m=!1,sandboxValues:g=[],customSandboxValues:O=[],style:S="",permissionPolicy:f=""}=d;if(!i)throw new Error("title is required");j&&this.#U();const p=u.createElement("iframe");p.setAttribute("id",r);const b=()=>{setTimeout(()=>{try{c?.(r)}catch(P){this.#t.debug(`Error occurred in onLoad for guest with id '${r}': ${P.message}`)}},0),this.#t.debug(`frame loaded for guest with id '${r}'`),p.removeEventListener("load",b)},k=()=>{setTimeout(()=>{try{a?.(r)}catch(P){this.#t.debug(`Error occurred in onError for guest with id '${r}': ${P.message}`)}},0),this.#t.error(`frame load failed for guest with id '${r}'`),p.removeEventListener("error",k)};p.addEventListener("load",b),p.addEventListener("error",k),p.setAttribute("style",`min-width: 100%; height: 100%; border: 0px; ${S}`),m||p.setAttribute("sandbox",O.length>0?O.join(" "):[...B,...g].join(" ")),p.setAttribute("title",i),p.setAttribute("src",t),f&&p.setAttribute("allow",f),s.appendChild(p);const F=u.getElementById(r);return this.#y({guestId:r,domElement:F,window:F.contentWindow,title:i,url:t,searchParams:o,openMode:w.Embed})};#M=(e,t)=>{let i="";return Object.keys(t).forEach(s=>{i+=`${(i.length?"&":"")+encodeURIComponent(s)}=${encodeURIComponent(t[s])}`}),e+(i?(e.indexOf("?")>=0?"&":"?")+i:"")};addScriptingObject=(e,t)=>{if(D(e)){const i=this.cloneScriptingObject(e);this.#r.addScriptingObject(i,t)}else this.#r.addScriptingObject(e,t)};cloneScriptingObject=e=>{if(!e)throw new Error("proxy is required");const t=new T(e.id,e.objectType);let i=[];return Object.keys(e).forEach(s=>{const o=e[s];if(this.#q(o)){const r=new y({name:o.name||s,objectId:t.id});if(Object.defineProperty(t,s,{value:r,enumerable:!0}),o instanceof A){const c=({eventParams:d,eventOptions:u})=>this.dispatchEvent({event:r,eventParams:d,eventOptions:u}),a=o.subscribe(c);i.push(()=>{o.unsubscribe(a)})}else{const c=o.subscribe?.((a,d,u)=>this.dispatchEvent({event:r,eventParams:d,eventOptions:u}));i.push(()=>{o.unsubscribe?.(c)})}}else if(R(o)&&(Object.defineProperty(t,s,{value:async(...r)=>{const c=await o(...r);return D(c)?this.cloneScriptingObject(c):c},enumerable:!0}),s==="dispose")){const r=t.dispose;Object.defineProperty(t,s,{value:()=>(t._dispose(),r.apply(t)),enumerable:!0})}}),t._dispose=()=>{i.forEach(s=>{s?.()}),i=[]},t};close=()=>{clearInterval(this.#h),this.#l(),this.#e.close(),window.removeEventListener("beforeunload",this.#l),this.#t.debug(`host is closed. hostId: ${this.hostId}, correlationId: ${this.#i}`)};dispatchEvent=async e=>{const{event:{id:t,name:i},eventParams:s,eventOptions:o={}}=e,{eventHandler:r=null,timeout:c=null,window:a=null,guestId:d}=o,u=t.split(".")[0],j=d||a,m=j?this.#f(j):null,g=m?this.getScriptingObject(u,{guest:m}):this.getScriptingObject(u);if(!g)return this.#t.warn(`Attempt to dispatch event ${i} on unknown object ${u}`),Promise.resolve([]);const O={object:g._toJSON(),eventName:i,eventParams:s,eventHandler:r,eventOptions:{allowsFeedback:!1}};c&&!Number.isNaN(c)&&(O.eventOptions={allowsFeedback:!0,timeout:Number(c)});const S=[];let f=!1;return this.#s.forEach(b=>{const k=b.getInfo();(!a||a===b.window)&&(c&&b?.capabilities?.eventFeedback?(S.push(b.dispatchEvent(O,c)),f||(this.#d(`ScriptingObject.Event.${g.id}.${i}`,{appId:this.hostId,appUrl:window.location.href}),f=!0),this.#t.audit({message:"Event dispatched and awaiting feedback",scriptingEventId:t,...k})):(b.send({messageType:l.ObjectEvent,messageBody:O}),this.#t.audit({message:"Event dispatched",scriptingEventId:t,...k})))}),await Promise.all(S).then(b=>(this.#t.audit({message:"Event feedback received",scriptingEventId:t}),U(b))).catch(b=>{throw this.#t.error({message:"Error processing event",eventId:t,exception:b}),b}).finally(()=>{f&&this.#u(`ScriptingObject.Event.${g.id}.${i}`,{appId:this.hostId,appUrl:window.location.href})})};getGuests=()=>{const e=[];return this.#s.forEach(t=>{e.push(t)}),e};getScriptingObject=(e,t)=>this.#r.getObject(e,t?.guest);loadGuest=e=>{const{id:t,url:i,targetElement:s,title:o,searchParams:r={},onLoad:c,onError:a,options:d={}}=e;if(!t)throw new Error("id for guest application is required");const{openMode:u=w.Embed,popupWindowFeatures:j={}}=d,m=this.#M(i,r);let g=null;if(this.#d("SSF.Guest.Load",{appId:t,appUrl:m}),u===w.Popup)g=this.#_({guestId:t,url:m,title:o,searchParams:r,popupWindowFeatures:j,onLoad:c,onError:a});else if(u===w.Embed)g=this.#C({guestId:t,url:m,title:o,targetElement:s,searchParams:r,onLoad:c,onError:a,options:d});else throw new Error(`Invalid openMode: ${u}`);return this.#t.audit({message:"Guest loaded",...g.getInfo()}),g};loadGuests=e=>{const{id:t,url:i,targetElement:s,title:o,searchParamsList:r=[],options:c={}}=e;r.forEach((a,d)=>{this.loadGuest({id:`${t}-${d}`,url:i,title:o,targetElement:s,searchParams:a,options:c})},this)};removeAllScriptingObjects=e=>{this.#r.removeAllScriptingObjects(e)};removeScriptingObject=(e,t)=>{this.#r.removeScriptingObject(e,t)};setLogLevel=e=>{this.#t.setLogLevel(e),this.#s.forEach(this.#m),this.#t.debug("Dispatched config events to all guests")};unloadGuest=e=>{const t=this.#f(e);t&&(t.dispose(),this.#s.delete(t.id),this.#t.audit({message:"Guest is removed from host",...t.getInfo()}))};onGuestClose=e=>{const{id:t,guestCloseCallback:i}=e,s=this.#o.get(t)||[];s.push(i),this.#o.set(t,s)}}return I})());
1
+ (function(I,y){typeof exports=="object"&&typeof module=="object"?module.exports=y():typeof define=="function"&&define.amd?define([],y):typeof exports=="object"?exports.ice=y():(I.ice=I.ice||{},I.ice.host=y())})(globalThis,()=>(()=>{"use strict";var v={};v.d=(n,e)=>{for(var t in e)v.o(e,t)&&!v.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},v.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),v.r=n=>{typeof Symbol<"u"&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})};var I={};v.r(I),v.d(I,{Event:()=>y,Guest:()=>q,IFrameSandboxValues:()=>E,OpenMode:()=>w,SANDBOX_DEFAULT:()=>B,SSFHost:()=>te,ScriptingObject:()=>T});class y{name;objectId;id;constructor(e){const{name:t,objectId:i}=e;if(!t)throw new Error("Event name is required");if(!i)throw new Error("Scripting object id is required");this.objectId=i,this.name=t,this.id=`${this.objectId}.${this.name}`.toLowerCase()}}class A{static[Symbol.hasInstance](e){return e.getType?.()==="ProxyEvent"}#e;objectId;name;id;getType(){return"ProxyEvent"}constructor(e){const{name:t,objectId:i,eventSrc:s}=e;this.objectId=i,this.name=t,this.#e=s,this.id=`${this.objectId}.${this.name}`.toLowerCase()}subscribe=e=>this.#e.subscribe({eventId:this.id,callback:e});unsubscribe=e=>{this.#e.unsubscribe({eventId:this.id,token:e})}}const H=n=>n instanceof y,ie=(n,e)=>`${n.toLowerCase()}.${e.toLowerCase()}`,W="function",J=(n,e)=>typeof n===W&&!!e&&!e.startsWith("_");class T{#e;#i="Object";constructor(e,t){this.#e=e,this.#i=t||this.#i}get id(){return this.#e}get objectType(){return this.#i}_toJSON=()=>{const e=[],t=[];return Object.keys(this).forEach(i=>{const s=this[i];H(s)?t.push(i):J(s,i)&&e.push(i)}),{objectId:this.#e,objectType:this.#i,functions:e,events:t}};_dispose=()=>{};dispose=()=>{}}var l=(n=>(n.GuestClose="guest:close",n.GuestEventSubscribe="guest:eventSubscribe",n.GuestEventUnsubscribe="guest:eventUnsubscribe",n.GuestFocus="guest:focus",n.GuestReady="guest:ready",n.GuestReadyComplete="guest:readyComplete",n.GuestResize="guest:resize",n.HandShake="handshake",n.HandShakeAck="handshake:ack",n.HostClose="host:close",n.HostConfig="host:config",n.ListObjects="list:objects",n.ObjectEvent="object:event",n.ObjectGet="object:get",n.ObjectInvoke="object:invoke",n))(l||{}),w=(n=>(n.Popup="popup",n.Embed="embed",n))(w||{}),E=(n=>(n.AllowDownloadsWithoutUserActivation="allow-downloads-without-user-activation",n.AllowDownloads="allow-downloads",n.AllowForms="allow-forms",n.AllowModals="allow-modals",n.AllowOrientationLock="allow-orientation-lock",n.AllowPointerLock="allow-pointer-lock",n.AllowPopups="allow-popups",n.AllowPopupsToEscapeSandbox="allow-popups-to-escape-sandbox",n.AllowPresentation="allow-presentation",n.AllowSameOrigin="allow-same-origin",n.AllowScripts="allow-scripts",n.AllowStorageAccessByUserActivation="allow-storage-access-by-user-activation",n.AllowTopNavigation="allow-top-navigation",n.AllowTopNavigationByUserActivation="allow-top-navigation-by-user-activation",n))(E||{});const Y=n=>{if(n==="about:blank")return"*";try{const{origin:e}=new URL(n);return e==="null"||!e?n:e}catch{const{origin:t}=new URL(n,document.baseURI);return t}},U=(n,e=[])=>{const t=e||[];return n&&n.forEach?n.forEach(i=>{U(i,t)}):typeof n<"u"&&t.push(n),t},se=n=>typeof n?._toJSON=="function";function R(n){return typeof n=="function"}const ne=n=>n?.id??n;class q{id;title;url;searchParams;domElement;window;openMode;origin;initialized=!1;ready=!1;capabilities;#e;#i;constructor(e){const{guestId:t,domElement:i=null,title:s,url:o,window:r,searchParams:c={},openMode:a=w.Embed,remoting:d,analyticsObj:u}=e;this.id=t,this.title=s,this.url=o,this.origin=Y(o),this.searchParams=c,this.domElement=i,this.window=r,this.openMode=a,this.capabilities={},this.#i=u,this.#e=d}dispose=()=>{if(this.openMode===w.Popup&&!this.window.closed)try{this.window.document,this.window.close()}catch{this.#e.send({targetWin:this.window,targetOrigin:this.origin,messageType:l.HostClose,messageBody:{}})}else this.domElement?.remove?.();this.#e.removeSender({origin:this.origin,window:this.window})};getInfo=()=>({guestId:this.id,guestTitle:this.title,guestUrl:this.url});handShake=()=>new Promise(e=>{let t=0;const i=5,s=setInterval(()=>{t>=i?(clearInterval(s),e(!1)):(this.#e.send({targetWin:this.window,targetOrigin:this.origin,messageType:l.HandShake,messageBody:{}}),t+=1)},1e3);this.#e.listen({messageType:l.HandShakeAck,callback:()=>{clearInterval(s),e(!0)}})});init=()=>{this.#e.addSender({origin:this.origin,window:this.window}),this.openMode===w.Popup&&this.handShake().catch(()=>{})};dispatchEvent=(e,t)=>(this.#i.startTiming(`ScriptingObject.Event.${e.object.objectId}.${e.eventName}`,{appId:this.id,appUrl:this.url}).catch(()=>{}),this.#e.invoke({targetWin:this.window,targetOrigin:this.origin,messageType:l.ObjectEvent,messageBody:e,responseTimeoutMs:t}).finally(()=>{this.#i.endTiming(`ScriptingObject.Event.${e.object.objectId}.${e.eventName}`,{appId:this.id,appUrl:this.url}).catch(()=>{})}));send=e=>{this.#e.send({targetWin:this.window,targetOrigin:this.origin,...e})}}const L={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};let G;const X=new Uint8Array(16);function K(){if(!G&&(G=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!G))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return G(X)}const h=[];for(let n=0;n<256;++n)h.push((n+256).toString(16).slice(1));function _(n,e=0){return h[n[e+0]]+h[n[e+1]]+h[n[e+2]]+h[n[e+3]]+"-"+h[n[e+4]]+h[n[e+5]]+"-"+h[n[e+6]]+h[n[e+7]]+"-"+h[n[e+8]]+h[n[e+9]]+"-"+h[n[e+10]]+h[n[e+11]]+h[n[e+12]]+h[n[e+13]]+h[n[e+14]]+h[n[e+15]]}function re(n,e=0){const t=_(n,e);if(!validate(t))throw TypeError("Stringified UUID is invalid");return t}const ce=null;function Q(n,e,t){if(L.randomUUID&&!e&&!n)return L.randomUUID();n=n||{};const i=n.random||(n.rng||K)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,e){t=t||0;for(let s=0;s<16;++s)e[t+s]=i[s];return e}return _(i)}const C=Q,M="elli:remoting",x="elli:remoting:response",N="elli:remoting:exception",$=({messageType:n,messageBody:e,onewayMsg:t=!1})=>({requestId:t?null:C(),source:M,type:n,body:e}),ae=n=>{const{targetWin:e,targetOrigin:t,messageType:i,messageBody:s}=n,o=$({messageType:i,messageBody:s});e.postMessage(o,t)};class V{#e;#i;#t=new Map;#n=new Map;#s=null;#o=new Map;#r;constructor(e,t,i){if(!e)throw new Error("logger is required");if(!t)throw new Error("correlationId is required");this.#e=t,this.#i=e,this.#r=i?.unsafeAllowAnyGuestOrigin??!1}#a=e=>this.#r?"*":e;#h=()=>{const e=Date.now(),t=[];this.#n.forEach((i,s)=>{const{requestId:o,cancelTime:r}=i;this.#i.debug(`Checking response timeout for requestId: ${o}) @ ${r??""}`),i.cancelTime&&i.cancelTime<e&&(this.#i.debug(`Detected response timeout for requestId: ${o}...`),t.push(s),i.resolve(),this.#i.debug(`Aborted waiting for response to requestid: ${o})`))}),t.forEach(i=>{this.#i.debug(`removing invocations with requestId ${i} from cache since response time has expired`),this.#n.delete(i)}),this.#n.size===0&&(this.#i.debug("stopping response monitor"),this.#p())};#g=()=>{this.#s===null&&(this.#i.debug("Staring response timeout evaluator"),this.#s=window.setInterval(this.#h,200))};#p=()=>{this.#s!==null&&(window.clearInterval(this.#s),this.#s=null,this.#i.debug("Stopped response timeout evaluator"))};#b=e=>{const t=this.#n.get(e);return this.#i.debug(`serving requestId: ${e}`),this.#n.delete(e),t};#d=e=>{const{requestId:t}=e;this.#i.debug(`Response received for invocation requestId: ${t}`);const i=this.#b(t);return i?(i.resolve(e.body),!0):(this.#i.debug(`Received response to stale/invalid request with requestId: ${t}`),!1)};#u=e=>{this.#i.debug(`Exception received for invocation (requestId = ${e.requestId})`);const t=this.#b(e.requestId);return t?(t.reject(new Error(e.body)),!0):(this.#i.warn(`Received exception for stale/invalid request (requestId = ${e.requestId})`),!1)};#l=({sourceWin:e,sourceOrigin:t,message:i})=>{this.#i.debug(`Received message of type "${i.type}"`);const s=this.#t.get(i.type);return s?(s.forEach(o=>{this.#i.debug(`Invoking message handler ${o.name}`),o({sourceWin:e,sourceOrigin:t,requestId:i.requestId,type:i.type,body:i.body})}),!0):!1};#c=e=>{if(this.#i.debug(`Remoting: Received message ${JSON.stringify(e.data)}`),this.#o.size===0||!e.source)return!1;const t=this.#o.get(e.source);return!t||e?.data?.source!==M?!1:(e.data.type===x?this.#d(e.data):e.data.type===N?this.#u(e.data):this.#l({sourceWin:e.source,sourceOrigin:t,message:e.data}),!0)};addSender=e=>{const{origin:t,window:i}=e;if(!t)throw new Error("origin is required");if(!i)throw new Error("window is required");this.#o.set(i,t)};initialize=e=>{e.removeEventListener("message",this.#c),e.addEventListener("message",this.#c),this.#i.debug(`initialized remoting id: ${this.#e}`)};close=()=>{window.removeEventListener("message",this.#c),this.#i.debug(`closed remoting id: ${this.#e}`)};invoke=e=>{const{targetWin:t,targetOrigin:i,messageType:s,messageBody:o,responseTimeoutMs:r}=e;return new Promise((c,a)=>{const d=$({messageType:s,messageBody:o});this.#n.set(d.requestId,{requestId:d.requestId,resolve:c,reject:a,cancelTime:r?Date.now()+Number.parseInt(r,10):null}),t.postMessage(d,this.#a(i));const{requestId:u}=d;this.#i.debug(`Posted invocation message of type ${s} requestId: ${u||""}`),r&&(this.#i.debug(`starting response monitor for requestId: ${u||""} for ${r} ms`),this.#g())})};listen=e=>{const{messageType:t,callback:i}=e,s=this.#t.get(t)||[];s.push(i),this.#t.set(t,s)};send=e=>{const{targetWin:t,targetOrigin:i,messageType:s,messageBody:o}=e,r=$({messageType:s,messageBody:o,onewayMsg:!0});t.postMessage(r,this.#a(i)),this.#i.debug(`Posted one-way message of type "${s}"`)};removeSender=e=>{const{window:t}=e;t&&this.#o.delete(t)};respond=e=>{const{targetWin:t,targetOrigin:i,requestId:s,response:o}=e,r=$({messageType:x,messageBody:o});r.requestId=s,t.postMessage(r,this.#a(i)),this.#i.debug(`Response sent to caller for invocation requestId: ${s}`)};raiseException=e=>{const{targetWin:t,targetOrigin:i,requestId:s,ex:o}=e,r=$({messageType:N,messageBody:o});r.requestId=s,t.postMessage(r,this.#a(i)),this.#i.debug(`Exception sent to caller for invocation. requestId: ${s}`)}}const z="module";var Z=(n=>(n.USER="USER",n.PARTNER="PARTNER",n))(Z||{});class ee{#e=new Map;#i=new Map;#t=e=>{const{so:t,guestId:i}=e,s=t.id.toLowerCase(),o=this.#i.get(i);if(!o)this.#i.set(i,new Map([[s,e]]));else{if(o.has(s))throw new Error(`Scripting Object ${t.id} already exists for guest ${i}`);o.set(s,e)}};#n=({so:e})=>{e._dispose&&typeof e._dispose=="function"&&e._dispose()};#s=({objectId:e,guestId:t})=>{if(e===z&&!t)for(const[,s]of this.#i){const o=s.get(e);if(o)return o}const i=t?this.#i.get(t):null;return i?i.get(e)??null:null};#o=({objectId:e,guestId:t}={})=>{if(t){if(!e){const s=this.#i.get(t);s&&s.forEach(this.#n),this.#i.delete(t);return}const i=this.#i.get(t);if(i){const s=i.get(e);s&&this.#n(s),i.delete(e)}}else e&&this.#i.forEach(i=>{const s=i.get(e);s&&this.#n(s),i.delete(e)})};addScriptingObject=(e,t)=>{const{guestId:i}=t||{};if(!e?.id||!e?._toJSON)throw new Error("Object is not derived from ScriptingObject");const s=e.id.toLowerCase();if(s.trim().toLowerCase()===z&&!i)throw new Error("Guest id is required to add Module scripting object");if(i){this.#t({so:e,...t,guestId:i});return}if(this.#e.has(s))throw new Error(`Scripting Object ${e.id} already exists`);this.#e.set(s,{so:e,...t})};getObject=(e,t)=>{const i=e.trim().toLowerCase();let s=this.#s({objectId:i,guestId:t?.id});s=s??this.#e.get(i)??null;const{so:o}=s||{};return o||null};has=(e,t)=>this.getObject(e,t)!==null;listScriptingObjects=e=>{let t=Array.from(this.#e.keys());const i=this.#i.get(e);return t=i?t.concat(Array.from(i.keys())):t,Array.from(new Set(t))};removeScriptingObject=(e,t)=>{const i=e.toLowerCase();if(t)this.#o({objectId:i,guestId:t});else{this.#o({objectId:i});const s=this.#e.get(i);s&&this.#n(s),this.#e.delete(i)}};removeAllScriptingObjects=e=>{e?this.#o({guestId:e}):(this.#e.forEach(this.#n),this.#e.clear())}}class de{__TYPE__="Proxy";id;objectType;constructor(e,t){this.id=e,this.objectType=t}}const D=n=>n?.constructor?.name==="Proxy"||n?.constructor?.name==="ScriptingObjectProxy"||n?.__TYPE__==="Proxy",B=[E.AllowScripts,E.AllowPopups,E.AllowModals,E.AllowForms,E.AllowDownloads,E.AllowSameOrigin];class te{hostId;#e;#i;#t;#n;#s=new Map;#o=new Map;#r;#a=null;#h=null;#g=null;#p=null;constructor(e,t){if(this.hostId=e,!t?.logger)throw new Error("Logger is required");if(!t?.analyticsObj)throw new Error("Analytics object is required");if(this.#t=t.logger,this.#n=t.analyticsObj,this.#i=C(),this.#e=new V(this.#t,this.#i,{unsafeAllowAnyGuestOrigin:t?.unsafeAllowAnyGuestOrigin}),t?.readyStateCallback&&typeof t?.readyStateCallback!="function")throw new Error("readyStateCallback must be a function");this.#a=t?.readyStateCallback||null,this.#g=t?.onGuestEventSubscribe||null,this.#p=t?.onGuestEventUnsubscribe||null,this.#r=new ee,this.#e.initialize(window),this.#R(),window.addEventListener("beforeunload",this.#l),this.#L(),this.#t.debug(`host is initialized. hostId: ${this.hostId}, correlationId: ${this.#i}`)}#b=(e,t)=>{const i={event:e,...t};this.#n.sendBAEvent(i).catch(()=>{})};#d=(e,t)=>{this.#n.startTiming(e,t).catch(()=>{})};#u=(e,t)=>{this.#n.endTiming(e,t).catch(()=>{})};#l=()=>{for(const e of this.#s.values())e.openMode===w.Popup&&this.unloadGuest(e.id)};#c=e=>Array.from(this.#s.values()).find(t=>t.window===e);#E=e=>{for(const t of this.#s.values())if(t.url===e)return t;return null};#j=e=>typeof e?._toJSON=="function";#w=(e,t)=>this.#j(e)?(this.#r.has(e?.id,t)||this.#r.addScriptingObject(e,t?{guestId:t?.id}:{}),{type:"object",object:e._toJSON()}):{type:"value",value:e};#x=e=>typeof e=="string"?e:e instanceof Error?e.message:"An unexpected error occurred in the host application";#m=e=>{e.ready&&this.#e.send({targetWin:e.window,targetOrigin:e.origin,messageType:l.HostConfig,messageBody:{logLevel:this.#t.getLogLevel(),...e.getInfo()}})};#O=({guest:e,obj:t,functionName:i,functionParams:s})=>{const o=t[i];return R(o)?(this.#t.debug(`Invoking host implementation of ${t.id}.${String(i)}()`),new Promise(r=>{Object.defineProperty(o,"callContext",{value:{guest:e},configurable:!0,enumerable:!0,writable:!0}),r(o(...s))})):(this.#t.warn(`Attempt to call invalid function on object type ${t.objectType}: ${String(i)}`),Promise.reject(new Error(`Method '${i}' not found in Scripting Object '${t.id}'`)))};#v=({sourceWin:e,sourceOrigin:t,requestId:i})=>{const s=this.#c(e);if(!s){this.#t.warn(`Received ready event for unknown guest. requestId: ${i}`);return}if(!s.initialized){this.#t.warn("Guest must be initialized before it is marked as ready"),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:"Guest must be initialized before it is marked as ready"});return}if(!s.ready){s.ready=!0;const o=s.getInfo();this.#u("SSF.Guest.Load",{appId:o.guestId,appUrl:o.guestUrl}),this.#m(s),this.#a?.(s),this.#t.audit({message:"Guest is ready",...o})}};#S=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const o=this.#c(e);if(!o){this.#t.warn(`Received ready event for unknown guest. requestid = ${i}`);return}o.initialized||(o.initialized=!0,o.capabilities=s||{},this.#t.audit({message:"Guest is initialized",...o.getInfo()})),(!s||!s.onReady)&&this.#v({sourceWin:e,sourceOrigin:t,requestId:i,type:"",body:null})};#I=async({sourceWin:e})=>{if(e?.window){const t=this.#f(e);t&&!await t.handShake()&&this.unloadGuest(e)}};#$=({sourceWin:e,sourceOrigin:t,requestId:i})=>{this.#t.debug(`Processing listObjects request. requestId = ${i}`);const s=this.#c(e);if(!s)return this.#t.warn("Rejected object request from unknown guest window"),!1;const o=this.#r.listScriptingObjects(s.id);return this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:o}),this.#t.debug({message:"name of scripting objects returned",requestId:i,objects:o,...s.getInfo()}),!0};#k=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const{objectId:o}=s;this.#t.debug(`Processing getObject request for object ${o}. requestId = ${i}`);const r=this.#c(e);if(!r)return this.#t.warn("Rejected object request from unknown guest window"),!1;const c=this.getScriptingObject(o,{guest:r});return c?(this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:this.#w(c,r)}),this.#t.debug({message:"Scripting Object returned",requestId:i,scriptingObject:o,...r.getInfo()}),!0):(this.#t.warn(`unknown or unauthorized object ${o} from guest ${r.id}`),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:`The requested object (${o}) is not available`}),!1)};#G=({sourceWin:e,requestId:t,body:i})=>{const{eventId:s,criteria:o,token:r}=i;this.#t.debug(`Processing guest event subscribe request for event ${s}. requestId = ${t}`);const c=this.#c(e);if(!c){this.#t.warn("Rejected event subscribe request from unknown guest window");return}setTimeout(()=>{try{this.#g?.({guestId:c.id,eventId:s,criteria:o,token:r})}catch{}},0)};#P=({sourceWin:e,requestId:t,body:i})=>{const{eventId:s,token:o}=i;this.#t.debug(`Processing guest event unsubscribe request for event ${s}. requestId = ${t}`);const r=this.#c(e);if(!r){this.#t.warn("Rejected event unsubscribe request from unknown guest window");return}setTimeout(()=>{try{this.#p?.({guestId:r.id,eventId:s,token:o})}catch{}},0)};#A=({sourceWin:e,requestId:t,body:i})=>{const s=this.#c(e);if(!s){this.#t.warn(`Received resize event from unknown guest. requestid = ${t}`);return}s.domElement&&(s.domElement.style.height=`${i.height}px`),this.#t.debug(`Guest ${s.id} resized to ${i.width}x${i.height}`)};#T=({sourceWin:e,sourceOrigin:t,requestId:i,body:s})=>{const{objectId:o}=s,r=this.#c(e);if(!r)return this.#t.warn("Rejected method invocation request from unknown guest window"),!1;this.#t.debug(`Function ${o}.${String(s.functionName)}() called from guest "${r.id}" (requestId = ${i})`);const c=this.getScriptingObject(o,{guest:r});if(!c)return this.#t.warn(`Invocation of unknown or unauthorized object ${o} from guest ${r.id}`),this.#e.raiseException({targetWin:e,targetOrigin:t,requestId:i,ex:`The requested object (${o}) is not available`}),!1;const a=r.getInfo();return this.#d(`ScriptingObject.API.${o}.${s.functionName}`,{appId:a.guestId,appUrl:a.guestUrl}),this.#O({guest:r,obj:c,functionName:s.functionName,functionParams:s.functionParams}).then(d=>{this.#e.respond({targetWin:e,targetOrigin:t,requestId:i,response:this.#w(d,r)}),this.#t.debug({message:"Value returned for Scripting Object method call",requestId:i,scriptingObject:o,scriptingMethod:s.functionName,...a})}).catch(d=>{this.#e.raiseException({targetWin:e,targetOrigin:r.origin,requestId:i,ex:d}),this.#t.error({message:"Exception thrown for Scripting Object method call",requestId:i,scriptingObject:o,scriptingMethod:s.functionName,...a})}).finally(()=>{this.#u(`ScriptingObject.API.${o}.${s.functionName}`,{appId:a.guestId,appUrl:a.guestUrl})}),!0};#U=()=>{this.#e.listen({messageType:l.GuestResize,callback:this.#A})};#R=()=>{this.#e.listen({messageType:l.GuestReady,callback:this.#S}),this.#e.listen({messageType:l.GuestReadyComplete,callback:this.#v}),this.#e.listen({messageType:l.GuestClose,callback:this.#I}),this.#e.listen({messageType:l.ListObjects,callback:this.#$}),this.#e.listen({messageType:l.ObjectGet,callback:this.#k}),this.#e.listen({messageType:l.ObjectInvoke,callback:this.#T}),this.#e.listen({messageType:l.GuestEventSubscribe,callback:this.#G}),this.#e.listen({messageType:l.GuestEventUnsubscribe,callback:this.#P})};#q=e=>e instanceof A||typeof e?.subscribe=="function";#y=e=>{const t=new q({...e,remoting:this.#e,analyticsObj:this.#n});return t.init(),this.#s.set(e.guestId,t),t};#f=e=>{let t=typeof e=="string"?this.#s.get(e):null;return t||(t=Array.from(this.#s.values()).find(i=>i.window===e||i.domElement===e)),t};#L=()=>{this.#h=setInterval(()=>{const e=[];this.#s.forEach(t=>{t.openMode===w.Popup&&t.window.closed&&e.push(t)}),e.forEach(t=>{const{id:i}=t;this.unloadGuest(i),this.#o.get(i)?.forEach(o=>{o({id:i}).catch(()=>{})})})},1e3)};#_=e=>{const{url:t,title:i,popupWindowFeatures:s={},searchParams:o,guestId:r,onLoad:c,onError:a}=e,{width:d=800,height:u=600,top:j=100,left:m=100}=s;let g=this.#E(t);if(g)g.window.closed||g.send({messageType:l.GuestFocus,messageBody:{}});else{const O=[{key:"width",value:d},{key:"height",value:u},{key:"top",value:j},{key:"left",value:m}].reduce((f,p,b)=>(b>0&&p.value&&(f+=","),p.value?`${f}${p.key}=${p.value}`:f),""),S=window.open(t,i,`popup, ${O}`);if(S)try{setTimeout(()=>{c?.(r)},0)}catch(f){this.#t.debug(`Error occurred in onLoad for guest with id '${r}': ${f.message}`)}else{try{setTimeout(()=>{a?.(r)},0)}catch(f){this.#t.debug(`Error occurred in onError for guest with id '${r}': ${f.message}`)}throw new Error("Failed to open guest application in popup window")}S.opener=null,g=this.#y({guestId:r,window:S,title:i,url:t,searchParams:o,openMode:w.Popup})}return g};#C=e=>{const{url:t,title:i,targetElement:s,searchParams:o,guestId:r,onLoad:c,onError:a,options:d={}}=e,u=s.ownerDocument??document,{fitToContent:j=!1,disableSandbox:m=!1,sandboxValues:g=[],customSandboxValues:O=[],style:S="",permissionPolicy:f=""}=d;if(!i)throw new Error("title is required");j&&this.#U();const p=u.createElement("iframe");p.setAttribute("id",r);const b=()=>{setTimeout(()=>{try{c?.(r)}catch(P){this.#t.debug(`Error occurred in onLoad for guest with id '${r}': ${P.message}`)}},0),this.#t.debug(`frame loaded for guest with id '${r}'`),p.removeEventListener("load",b)},k=()=>{setTimeout(()=>{try{a?.(r)}catch(P){this.#t.debug(`Error occurred in onError for guest with id '${r}': ${P.message}`)}},0),this.#t.error(`frame load failed for guest with id '${r}'`),p.removeEventListener("error",k)};p.addEventListener("load",b),p.addEventListener("error",k),p.setAttribute("style",`min-width: 100%; height: 100%; border: 0px; ${S}`),m||p.setAttribute("sandbox",O.length>0?O.join(" "):[...B,...g].join(" ")),p.setAttribute("title",i),p.setAttribute("src",t),f&&p.setAttribute("allow",f),s.appendChild(p);const F=u.getElementById(r);return this.#y({guestId:r,domElement:F,window:F.contentWindow,title:i,url:t,searchParams:o,openMode:w.Embed})};#M=(e,t)=>{let i="";return Object.keys(t).forEach(s=>{i+=`${(i.length?"&":"")+encodeURIComponent(s)}=${encodeURIComponent(t[s])}`}),e+(i?(e.indexOf("?")>=0?"&":"?")+i:"")};addScriptingObject=(e,t)=>{if(D(e)){const i=this.cloneScriptingObject(e);this.#r.addScriptingObject(i,t)}else this.#r.addScriptingObject(e,t)};cloneScriptingObject=e=>{if(!e)throw new Error("proxy is required");const t=new T(e.id,e.objectType);let i=[];return Object.keys(e).forEach(s=>{const o=e[s];if(this.#q(o)){const r=new y({name:o.name||s,objectId:t.id});if(Object.defineProperty(t,s,{value:r,enumerable:!0}),o instanceof A){const c=({eventParams:d,eventOptions:u})=>this.dispatchEvent({event:r,eventParams:d,eventOptions:u}),a=o.subscribe(c);i.push(()=>{o.unsubscribe(a)})}else{const c=o.subscribe?.((a,d,u)=>this.dispatchEvent({event:r,eventParams:d,eventOptions:u}));i.push(()=>{o.unsubscribe?.(c)})}}else if(R(o)&&(Object.defineProperty(t,s,{value:async(...r)=>{const c=await o(...r);return D(c)?this.cloneScriptingObject(c):c},enumerable:!0}),s==="dispose")){const r=t.dispose;Object.defineProperty(t,s,{value:()=>(t._dispose(),r.apply(t)),enumerable:!0})}}),t._dispose=()=>{i.forEach(s=>{s?.()}),i=[]},t};close=()=>{clearInterval(this.#h),this.#l(),this.#e.close(),window.removeEventListener("beforeunload",this.#l),this.#t.debug(`host is closed. hostId: ${this.hostId}, correlationId: ${this.#i}`)};dispatchEvent=async e=>{const{event:{id:t,name:i},eventParams:s,eventOptions:o={}}=e,{eventHandler:r=null,timeout:c=null,window:a=null,guestId:d}=o,u=t.split(".")[0],j=d||a,m=j?this.#f(j):null,g=m?this.getScriptingObject(u,{guest:m}):this.getScriptingObject(u);if(!g)return this.#t.warn(`Attempt to dispatch event ${i} on unknown object ${u}`),Promise.resolve([]);const O={object:g._toJSON(),eventName:i,eventParams:s,eventHandler:r,eventOptions:{allowsFeedback:!1}};c&&!Number.isNaN(c)&&(O.eventOptions={allowsFeedback:!0,timeout:Number(c)});const S=[];let f=!1;return this.#s.forEach(b=>{const k=b.getInfo();(!a||a===b.window)&&(c&&b?.capabilities?.eventFeedback?(S.push(b.dispatchEvent(O,c)),f||(this.#d(`ScriptingObject.Event.${g.id}.${i}`,{appId:this.hostId,appUrl:window.location.href}),f=!0),this.#t.debug({message:"Event dispatched and awaiting feedback",scriptingEventId:t,...k})):(b.send({messageType:l.ObjectEvent,messageBody:O}),this.#t.debug({message:"Event dispatched",scriptingEventId:t,...k})))}),await Promise.all(S).then(b=>(this.#t.debug({message:"Event feedback received",scriptingEventId:t}),U(b))).catch(b=>{throw this.#t.error({message:"Error processing event",eventId:t,exception:b}),b}).finally(()=>{f&&this.#u(`ScriptingObject.Event.${g.id}.${i}`,{appId:this.hostId,appUrl:window.location.href})})};getGuests=()=>{const e=[];return this.#s.forEach(t=>{e.push(t)}),e};getScriptingObject=(e,t)=>this.#r.getObject(e,t?.guest);loadGuest=e=>{const{id:t,url:i,targetElement:s,title:o,searchParams:r={},onLoad:c,onError:a,options:d={}}=e;if(!t)throw new Error("id for guest application is required");const{openMode:u=w.Embed,popupWindowFeatures:j={}}=d,m=this.#M(i,r);let g=null;if(this.#d("SSF.Guest.Load",{appId:t,appUrl:m}),u===w.Popup)g=this.#_({guestId:t,url:m,title:o,searchParams:r,popupWindowFeatures:j,onLoad:c,onError:a});else if(u===w.Embed)g=this.#C({guestId:t,url:m,title:o,targetElement:s,searchParams:r,onLoad:c,onError:a,options:d});else throw new Error(`Invalid openMode: ${u}`);return this.#t.audit({message:"Guest loaded",...g.getInfo()}),g};loadGuests=e=>{const{id:t,url:i,targetElement:s,title:o,searchParamsList:r=[],options:c={}}=e;r.forEach((a,d)=>{this.loadGuest({id:`${t}-${d}`,url:i,title:o,targetElement:s,searchParams:a,options:c})},this)};removeAllScriptingObjects=e=>{this.#r.removeAllScriptingObjects(e)};removeScriptingObject=(e,t)=>{this.#r.removeScriptingObject(e,t)};setLogLevel=e=>{this.#t.setLogLevel(e),this.#s.forEach(this.#m),this.#t.debug("Dispatched config events to all guests")};unloadGuest=e=>{const t=this.#f(e);t&&(t.dispose(),this.#s.delete(t.id),this.#t.audit({message:"Guest is removed from host",...t.getInfo()}))};onGuestClose=e=>{const{id:t,guestCloseCallback:i}=e,s=this.#o.get(t)||[];s.push(i),this.#o.set(t,s)}}return I})());
2
2
 
3
- //# sourceMappingURL=emuiSsfHost.a1d3542194a2fb9e9816.js.map
3
+ //# sourceMappingURL=emuiSsfHost.7b0555015fdcf2116165.js.map