siarashield_workspace 0.0.33 → 0.0.36
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/README.md +105 -195
- package/esm2022/lib/siara-shield-script-utils.mjs +3 -2
- package/esm2022/lib/siara-shield-vendor-runtime.mjs +98 -0
- package/esm2022/lib/siara-shield.component.mjs +29 -15
- package/esm2022/lib/siara-shield.mjs +29 -15
- package/fesm2022/siarashield_workspace.mjs +182 -57
- package/fesm2022/siarashield_workspace.mjs.map +1 -1
- package/lib/siara-shield-vendor-runtime.d.ts +1 -0
- package/lib/siara-shield.component.d.ts +3 -1
- package/lib/siara-shield.d.ts +3 -1
- package/package.json +1 -1
- package/siarashield_workspace-0.0.36.tgz +0 -0
- package/siarashield_workspace-0.0.33.tgz +0 -0
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { getSiaraShieldGlobals } from './siara-shield.globals';
|
|
2
|
+
const VENDOR_RUNTIME_PATCH_KEY = '__siaraShieldVendorRuntimePatchInstalled__';
|
|
3
|
+
const VENDOR_TOKEN_BRIDGE_KEY = '__siaraShieldVendorTokenBridgeInstalled__';
|
|
4
|
+
const WRAPPED_FN_PREFIX = '__siaraShieldWrappedVendorFn__';
|
|
5
|
+
function isKnownVendorNullDomError(error) {
|
|
6
|
+
const msg = error instanceof Error ? error.message.toLowerCase() : String(error ?? '').toLowerCase();
|
|
7
|
+
return (msg.includes("cannot read properties of null (reading 'style')") ||
|
|
8
|
+
msg.includes("cannot read properties of null (reading 'queryselector')") ||
|
|
9
|
+
msg.includes("cannot read properties of null (reading 'removechild')"));
|
|
10
|
+
}
|
|
11
|
+
function runFallbackChallengeOpen(excluding) {
|
|
12
|
+
const globals = getSiaraShieldGlobals();
|
|
13
|
+
const candidates = ['OpenCaptchaSlid', 'GetCyberSiara', 'Open_Pluin', 'Open_Plugin', 'Open_Plugin_'];
|
|
14
|
+
for (const name of candidates) {
|
|
15
|
+
if (name === excluding)
|
|
16
|
+
continue;
|
|
17
|
+
const fn = globals[name];
|
|
18
|
+
if (typeof fn !== 'function')
|
|
19
|
+
continue;
|
|
20
|
+
try {
|
|
21
|
+
fn();
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
// Try next candidate.
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
function wrapVendorOpenFunction(name) {
|
|
30
|
+
const globals = getSiaraShieldGlobals();
|
|
31
|
+
const marker = `${WRAPPED_FN_PREFIX}${name}`;
|
|
32
|
+
if (globals[marker] === true)
|
|
33
|
+
return;
|
|
34
|
+
const candidate = globals[name];
|
|
35
|
+
if (typeof candidate !== 'function')
|
|
36
|
+
return;
|
|
37
|
+
const original = candidate;
|
|
38
|
+
globals[name] = ((...args) => {
|
|
39
|
+
try {
|
|
40
|
+
return original(...args);
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
if (!isKnownVendorNullDomError(error)) {
|
|
44
|
+
throw error;
|
|
45
|
+
}
|
|
46
|
+
// Vendor challenge opener hit a missing DOM node.
|
|
47
|
+
// Try alternative open functions so challenge can still render.
|
|
48
|
+
runFallbackChallengeOpen(name);
|
|
49
|
+
return undefined;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
globals[marker] = true;
|
|
53
|
+
}
|
|
54
|
+
function installVerifiedSubmitTokenBridge() {
|
|
55
|
+
const globals = getSiaraShieldGlobals();
|
|
56
|
+
if (globals[VENDOR_TOKEN_BRIDGE_KEY])
|
|
57
|
+
return;
|
|
58
|
+
const patchAjaxOwner = (owner) => {
|
|
59
|
+
if (!owner || typeof owner.ajax !== 'function')
|
|
60
|
+
return;
|
|
61
|
+
const originalAjax = owner.ajax.bind(owner);
|
|
62
|
+
owner.ajax = ((...args) => {
|
|
63
|
+
const firstArg = args[0];
|
|
64
|
+
if (!firstArg || typeof firstArg !== 'object') {
|
|
65
|
+
return originalAjax(...args);
|
|
66
|
+
}
|
|
67
|
+
const options = firstArg;
|
|
68
|
+
const url = String(options['url'] ?? '').toLowerCase();
|
|
69
|
+
const originalSuccess = options['success'];
|
|
70
|
+
if (!url.includes('/submitcaptcha/verifiedsubmit') || typeof originalSuccess !== 'function') {
|
|
71
|
+
return originalAjax(options);
|
|
72
|
+
}
|
|
73
|
+
options['success'] = ((response, ...rest) => {
|
|
74
|
+
const payload = response;
|
|
75
|
+
const maybeTokenRaw = payload?.data ?? payload?.Data;
|
|
76
|
+
if (typeof maybeTokenRaw === 'string' && maybeTokenRaw.trim()) {
|
|
77
|
+
globals.CyberSiaraToken = maybeTokenRaw.trim();
|
|
78
|
+
}
|
|
79
|
+
return originalSuccess(response, ...rest);
|
|
80
|
+
});
|
|
81
|
+
return originalAjax(options);
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
patchAjaxOwner(globals.$);
|
|
85
|
+
patchAjaxOwner(globals.JQuryName);
|
|
86
|
+
globals[VENDOR_TOKEN_BRIDGE_KEY] = true;
|
|
87
|
+
}
|
|
88
|
+
export function installVendorChallengeRuntimePatch() {
|
|
89
|
+
const globals = getSiaraShieldGlobals();
|
|
90
|
+
if (globals[VENDOR_RUNTIME_PATCH_KEY])
|
|
91
|
+
return;
|
|
92
|
+
wrapVendorOpenFunction('Open_Pluin');
|
|
93
|
+
wrapVendorOpenFunction('Open_Plugin');
|
|
94
|
+
wrapVendorOpenFunction('Open_Plugin_');
|
|
95
|
+
installVerifiedSubmitTokenBridge();
|
|
96
|
+
globals[VENDOR_RUNTIME_PATCH_KEY] = true;
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield-vendor-runtime.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield-vendor-runtime.ts"],"names":[],"mappings":"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","sourcesContent":["import { getSiaraShieldGlobals } from './siara-shield.globals';\r\n\r\nconst VENDOR_RUNTIME_PATCH_KEY = '__siaraShieldVendorRuntimePatchInstalled__';\r\nconst VENDOR_TOKEN_BRIDGE_KEY = '__siaraShieldVendorTokenBridgeInstalled__';\r\nconst WRAPPED_FN_PREFIX = '__siaraShieldWrappedVendorFn__';\r\n\r\ntype VendorFnName = 'Open_Pluin' | 'Open_Plugin' | 'Open_Plugin_';\r\ntype OptionalVendorFnName = VendorFnName | 'OpenCaptchaSlid' | 'GetCyberSiara';\r\ntype VendorFn = (...args: unknown[]) => unknown;\r\n\r\nfunction isKnownVendorNullDomError(error: unknown): boolean {\r\n  const msg = error instanceof Error ? error.message.toLowerCase() : String(error ?? '').toLowerCase();\r\n  return (\r\n    msg.includes(\"cannot read properties of null (reading 'style')\") ||\r\n    msg.includes(\"cannot read properties of null (reading 'queryselector')\") ||\r\n    msg.includes(\"cannot read properties of null (reading 'removechild')\")\r\n  );\r\n}\r\n\r\nfunction runFallbackChallengeOpen(excluding: OptionalVendorFnName): void {\r\n  const globals = getSiaraShieldGlobals() as typeof globalThis & Record<string, unknown>;\r\n  const candidates: OptionalVendorFnName[] = ['OpenCaptchaSlid', 'GetCyberSiara', 'Open_Pluin', 'Open_Plugin', 'Open_Plugin_'];\r\n\r\n  for (const name of candidates) {\r\n    if (name === excluding) continue;\r\n    const fn = globals[name];\r\n    if (typeof fn !== 'function') continue;\r\n    try {\r\n      (fn as VendorFn)();\r\n      return;\r\n    } catch {\r\n      // Try next candidate.\r\n    }\r\n  }\r\n}\r\n\r\nfunction wrapVendorOpenFunction(name: VendorFnName): void {\r\n  const globals = getSiaraShieldGlobals() as typeof globalThis & Record<string, unknown>;\r\n  const marker = `${WRAPPED_FN_PREFIX}${name}`;\r\n  if (globals[marker] === true) return;\r\n\r\n  const candidate = globals[name];\r\n  if (typeof candidate !== 'function') return;\r\n\r\n  const original = candidate as VendorFn;\r\n  globals[name] = ((...args: unknown[]) => {\r\n    try {\r\n      return original(...args);\r\n    } catch (error) {\r\n      if (!isKnownVendorNullDomError(error)) {\r\n        throw error;\r\n      }\r\n\r\n      // Vendor challenge opener hit a missing DOM node.\r\n      // Try alternative open functions so challenge can still render.\r\n      runFallbackChallengeOpen(name);\r\n      return undefined;\r\n    }\r\n  }) as unknown;\r\n  globals[marker] = true;\r\n}\r\n\r\nfunction installVerifiedSubmitTokenBridge(): void {\r\n  const globals = getSiaraShieldGlobals() as typeof globalThis & {\r\n    [VENDOR_TOKEN_BRIDGE_KEY]?: boolean;\r\n    JQuryName?: { ajax?: (...args: unknown[]) => unknown };\r\n    $?: { ajax?: (...args: unknown[]) => unknown };\r\n    CyberSiaraToken?: string;\r\n  };\r\n  if (globals[VENDOR_TOKEN_BRIDGE_KEY]) return;\r\n\r\n  const patchAjaxOwner = (owner: { ajax?: (...args: unknown[]) => unknown } | undefined): void => {\r\n    if (!owner || typeof owner.ajax !== 'function') return;\r\n    const originalAjax = owner.ajax.bind(owner);\r\n\r\n    owner.ajax = ((...args: unknown[]) => {\r\n      const firstArg = args[0];\r\n      if (!firstArg || typeof firstArg !== 'object') {\r\n        return originalAjax(...args);\r\n      }\r\n\r\n      const options = firstArg as Record<string, unknown>;\r\n      const url = String(options['url'] ?? '').toLowerCase();\r\n      const originalSuccess = options['success'];\r\n      if (!url.includes('/submitcaptcha/verifiedsubmit') || typeof originalSuccess !== 'function') {\r\n        return originalAjax(options);\r\n      }\r\n\r\n      options['success'] = ((response: unknown, ...rest: unknown[]) => {\r\n        const payload = response as { data?: unknown; Data?: unknown } | null;\r\n        const maybeTokenRaw = payload?.data ?? payload?.Data;\r\n        if (typeof maybeTokenRaw === 'string' && maybeTokenRaw.trim()) {\r\n          globals.CyberSiaraToken = maybeTokenRaw.trim();\r\n        }\r\n\r\n        return (originalSuccess as (...fnArgs: unknown[]) => unknown)(response, ...rest);\r\n      }) as unknown;\r\n\r\n      return originalAjax(options);\r\n    }) as typeof owner.ajax;\r\n  };\r\n\r\n  patchAjaxOwner(globals.$);\r\n  patchAjaxOwner(globals.JQuryName);\r\n  globals[VENDOR_TOKEN_BRIDGE_KEY] = true;\r\n}\r\n\r\nexport function installVendorChallengeRuntimePatch(): void {\r\n  const globals = getSiaraShieldGlobals() as typeof globalThis & {\r\n    [VENDOR_RUNTIME_PATCH_KEY]?: boolean;\r\n  };\r\n  if (globals[VENDOR_RUNTIME_PATCH_KEY]) return;\r\n\r\n  wrapVendorOpenFunction('Open_Pluin');\r\n  wrapVendorOpenFunction('Open_Plugin');\r\n  wrapVendorOpenFunction('Open_Plugin_');\r\n  installVerifiedSubmitTokenBridge();\r\n  globals[VENDOR_RUNTIME_PATCH_KEY] = true;\r\n}\r\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';
|
|
3
3
|
import { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';
|
|
4
|
-
import { prepareScriptNonce } from './siara-shield-script-utils';
|
|
5
4
|
import { installCaptchaSubmitGuard } from './siara-shield-submit-guard';
|
|
5
|
+
import { installVendorChallengeRuntimePatch } from './siara-shield-vendor-runtime';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "./siara-shield-loader.service";
|
|
8
8
|
const JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';
|
|
@@ -66,22 +66,18 @@ export class SiaraShieldComponent {
|
|
|
66
66
|
if (!options.publicKey) {
|
|
67
67
|
throw new Error('SiaraShieldComponent: publicKey is required.');
|
|
68
68
|
}
|
|
69
|
-
const cspNonce = prepareScriptNonce(this.host.nativeElement.ownerDocument, options.cspNonce);
|
|
70
69
|
if ((options.loadJQuery ?? true) && !this.isJQueryAlreadyAvailable()) {
|
|
71
|
-
await this.loader.loadScript(JQUERY_FALLBACK_SRC
|
|
70
|
+
await this.loader.loadScript(JQUERY_FALLBACK_SRC);
|
|
72
71
|
}
|
|
73
|
-
await this.loader.loadScript(CAPTCHA_SCRIPT_SRC
|
|
74
|
-
|
|
75
|
-
});
|
|
76
|
-
await this.loader.loadScript(VALIDATION_SCRIPT_SRC, {
|
|
77
|
-
nonce: cspNonce,
|
|
78
|
-
});
|
|
72
|
+
await this.loader.loadScript(CAPTCHA_SCRIPT_SRC);
|
|
73
|
+
await this.loader.loadScript(VALIDATION_SCRIPT_SRC);
|
|
79
74
|
const g = getSiaraShieldGlobals();
|
|
80
75
|
ensureAccessibilityPopupAliases();
|
|
81
76
|
this.preventDuplicateValidationBootstrap(g);
|
|
77
|
+
installVendorChallengeRuntimePatch();
|
|
82
78
|
const initCaptchaFn = getInitCaptchaFn(g);
|
|
83
79
|
if (!initCaptchaFn) {
|
|
84
|
-
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts.
|
|
80
|
+
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts.');
|
|
85
81
|
}
|
|
86
82
|
if (!options.allowVendorConsoleLogs) {
|
|
87
83
|
suppressVendorConsoleWindow();
|
|
@@ -123,7 +119,7 @@ export class SiaraShieldComponent {
|
|
|
123
119
|
}
|
|
124
120
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
125
121
|
}
|
|
126
|
-
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.
|
|
122
|
+
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.');
|
|
127
123
|
}
|
|
128
124
|
/**
|
|
129
125
|
* Calls the global `CheckCaptcha()` from SiaraShield script.
|
|
@@ -132,7 +128,7 @@ export class SiaraShieldComponent {
|
|
|
132
128
|
checkCaptcha() {
|
|
133
129
|
const g = getSiaraShieldGlobals();
|
|
134
130
|
if (!g.CheckCaptcha) {
|
|
135
|
-
throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run
|
|
131
|
+
throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run?');
|
|
136
132
|
}
|
|
137
133
|
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
138
134
|
if (existingToken) {
|
|
@@ -156,15 +152,33 @@ export class SiaraShieldComponent {
|
|
|
156
152
|
const timeoutMs = options?.timeoutMs ?? 2000;
|
|
157
153
|
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
158
154
|
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
155
|
+
const retryOnFalseMs = options?.retryOnFalseMs ?? 0;
|
|
156
|
+
const falseResultTokenWaitMs = options?.falseResultTokenWaitMs ?? 900;
|
|
159
157
|
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
160
158
|
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
161
159
|
this.token.emit(existingToken);
|
|
162
160
|
return true;
|
|
163
161
|
}
|
|
164
162
|
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
165
|
-
|
|
166
|
-
|
|
163
|
+
let ok = this.checkCaptcha();
|
|
164
|
+
// Optional retry for integrations that observe late vendor-state settling.
|
|
165
|
+
if (!ok && retryOnFalseMs > 0) {
|
|
166
|
+
await new Promise((resolve) => setTimeout(resolve, retryOnFalseMs));
|
|
167
|
+
ok = this.checkCaptcha();
|
|
168
|
+
}
|
|
169
|
+
if (!ok) {
|
|
170
|
+
// Some vendor flows return false first, then set token shortly after.
|
|
171
|
+
const falseStartedAt = Date.now();
|
|
172
|
+
while (Date.now() - falseStartedAt < falseResultTokenWaitMs) {
|
|
173
|
+
await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
|
|
174
|
+
const token = getSiaraShieldGlobals().CyberSiaraToken;
|
|
175
|
+
if (typeof token === 'string' && token.length > 0) {
|
|
176
|
+
this.token.emit(token);
|
|
177
|
+
return true;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
167
180
|
return false;
|
|
181
|
+
}
|
|
168
182
|
const g = getSiaraShieldGlobals();
|
|
169
183
|
if (typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0) {
|
|
170
184
|
return true;
|
|
@@ -203,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
203
217
|
}], token: [{
|
|
204
218
|
type: Output
|
|
205
219
|
}] } });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield.component.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\nimport { SiaraShieldLoaderService } from './siara-shield-loader.service';\nimport { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';\nimport { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';\nimport { prepareScriptNonce } from './siara-shield-script-utils';\nimport { installCaptchaSubmitGuard } from './siara-shield-submit-guard';\n\nconst JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';\nconst CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';\nconst VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';\nconst CAPTCHA_READY_TIMEOUT_MS = 8000;\n\nfunction ensureAccessibilityPopupAliases(): void {\n  const g = globalThis as typeof globalThis & Record<string, unknown>;\n  const aliasNames = [\n    'RemoveAccesibilityPopup',\n    '_RemoveAccesibilityPopup',\n    'RemoveAccesiblityPopup',\n    '_RemoveAccesiblityPopup',\n  ] as const;\n\n  const existing = aliasNames\n    .map((name) => g[name])\n    .find((value): value is () => void => typeof value === 'function');\n\n  const stableFn = existing ?? (() => undefined);\n  for (const name of aliasNames) {\n    g[name] = stableFn;\n  }\n}\n\nfunction runInRootZone<T>(fn: () => T): T {\n  const g = globalThis as typeof globalThis & { Zone?: { root?: { run?: <U>(cb: () => U) => U } } };\n  const zoneRootRun = g.Zone?.root?.run;\n  if (typeof zoneRootRun === 'function') {\n    return zoneRootRun.call(g.Zone?.root, fn) as T;\n  }\n  return fn();\n}\n\nexport interface SiaraShieldInitOptions {\n  /** SiaraShield public key. Use \"TEST-CYBERSIARA\" for staging/development. */\n  publicKey: string;\n  /** Loads jQuery before SiaraShield script. Default is true for easier integration. Set to false only if your page already includes jQuery. */\n  loadJQuery?: boolean;\n  /** CSP nonce for strict policies (`script-src 'nonce-...'`). Pair with `getSiaraShieldCspPolicy()`. */\n  cspNonce?: string;\n  /** Set true only when actively debugging vendor/runtime internals in browser console. */\n  allowVendorConsoleLogs?: boolean;\n}\n\n@Component({\n  selector: 'siara-shield',\n  standalone: true,\n  template: `<div class=\"SiaraShield\"></div>`,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SiaraShieldComponent implements AfterViewInit {\n  @Input({ required: true }) publicKey!: string;\n  @Input() loadJQuery = true;\n  @Input() cspNonce?: string;\n  @Input() allowVendorConsoleLogs = false;\n\n  /**\n   * Emits the current `CyberSiaraToken` right after a successful `checkCaptcha()`.\n   */\n  @Output() token = new EventEmitter<string>();\n\n  private initialized = false;\n\n  constructor(\n    private readonly host: ElementRef<HTMLElement>,\n    private readonly loader: SiaraShieldLoaderService,\n  ) {}\n\n  async ngAfterViewInit(): Promise<void> {\n    await this.init({\n      publicKey: this.publicKey,\n      loadJQuery: this.loadJQuery,\n      cspNonce: this.cspNonce,\n      allowVendorConsoleLogs: this.allowVendorConsoleLogs,\n    });\n  }\n\n  async init(options: SiaraShieldInitOptions): Promise<void> {\n    if (this.initialized) return;\n\n    // Ensure the host element is in DOM before scripts run.\n    void this.host.nativeElement;\n    installCaptchaSubmitGuard();\n\n    if (!options.publicKey) {\n      throw new Error('SiaraShieldComponent: publicKey is required.');\n    }\n    const cspNonce = prepareScriptNonce(this.host.nativeElement.ownerDocument, options.cspNonce);\n\n    if ((options.loadJQuery ?? true) && !this.isJQueryAlreadyAvailable()) {\n      await this.loader.loadScript(JQUERY_FALLBACK_SRC, { nonce: cspNonce });\n    }\n\n    await this.loader.loadScript(CAPTCHA_SCRIPT_SRC, {\n      nonce: cspNonce,\n    });\n    await this.loader.loadScript(VALIDATION_SCRIPT_SRC, {\n      nonce: cspNonce,\n    });\n\n    const g = getSiaraShieldGlobals();\n    ensureAccessibilityPopupAliases();\n    this.preventDuplicateValidationBootstrap(g);\n    const initCaptchaFn = getInitCaptchaFn(g);\n    if (!initCaptchaFn) {\n      throw new Error(\n        'SiaraShield: InitCaptcha() is not available after loading scripts. Check whether CSP blocked vendor scripts or inline execution.',\n      );\n    }\n\n    if (!options.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n      installVendorRuntimeErrorSuppression();\n    }\n    runInRootZone(() => initCaptchaFn(options.publicKey));\n    await this.waitForCheckCaptchaApi();\n    this.initialized = true;\n  }\n\n  /**\n   * Detect preloaded jQuery from global object or an existing script tag.\n   */\n  private isJQueryAlreadyAvailable(): boolean {\n    const g = getSiaraShieldGlobals();\n    if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {\n      return true;\n    }\n\n    const existingJqueryScript = this.host.nativeElement.ownerDocument.querySelector<HTMLScriptElement>(\n      'script[src*=\"jquery\"]',\n    );\n    return Boolean(existingJqueryScript);\n  }\n\n  private preventDuplicateValidationBootstrap(g: ReturnType<typeof getSiaraShieldGlobals>): void {\n    const originalAppendValidation = g.AppendValidationJS;\n    if (typeof originalAppendValidation !== 'function') {\n      return;\n    }\n\n    g.AppendValidationJS = () => {\n      const existing = this.host.nativeElement.ownerDocument.querySelector<HTMLScriptElement>(\n        `script[src=\"${VALIDATION_SCRIPT_SRC}\"]`,\n      );\n      if (existing) {\n        return;\n      }\n\n      originalAppendValidation();\n    };\n  }\n\n  private async waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS): Promise<void> {\n    const startedAt = Date.now();\n    while (Date.now() - startedAt < timeoutMs) {\n      if (getSiaraShieldGlobals().CheckCaptcha) {\n        return;\n      }\n      await new Promise((resolve) => setTimeout(resolve, 100));\n    }\n    throw new Error('SiaraShield: CheckCaptcha() was not available within timeout. This can happen when CSP blocks the captcha runtime.');\n  }\n\n  /**\n   * Calls the global `CheckCaptcha()` from SiaraShield script.\n   * Returns true when captcha is valid; emits token if available.\n   */\n  checkCaptcha(): boolean {\n    const g = getSiaraShieldGlobals();\n    if (!g.CheckCaptcha) {\n      throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run, and is CSP allowing the captcha scripts?');\n    }\n\n    const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;\n    if (existingToken) {\n      this.token.emit(existingToken);\n      return true;\n    }\n\n    if (!this.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n    }\n    const ok = g.CheckCaptcha();\n    if (ok && typeof g.CyberSiaraToken === 'string') {\n      this.token.emit(g.CyberSiaraToken);\n    }\n    return ok;\n  }\n\n  /**\n   * Async-friendly captcha validation to avoid first-click timing issues.\n   * Performs one validation call and waits for token propagation.\n   */\n  async checkCaptchaAsync(options?: { timeoutMs?: number; pollIntervalMs?: number; beforeCheckDelayMs?: number }): Promise<boolean> {\n    const timeoutMs = options?.timeoutMs ?? 2000;\n    const pollIntervalMs = options?.pollIntervalMs ?? 120;\n    const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;\n    const existingToken = getSiaraShieldGlobals().CyberSiaraToken;\n    if (typeof existingToken === 'string' && existingToken.length > 0) {\n      this.token.emit(existingToken);\n      return true;\n    }\n    await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));\n    const ok = this.checkCaptcha();\n    if (!ok) return false;\n\n    const g = getSiaraShieldGlobals();\n    if (typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0) {\n      return true;\n    }\n\n    const startedAt = Date.now();\n    while (Date.now() - startedAt < timeoutMs) {\n      await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n      const token = getSiaraShieldGlobals().CyberSiaraToken;\n      if (typeof token === 'string' && token.length > 0) {\n        this.token.emit(token);\n        return true;\n      }\n    }\n\n    return true;\n  }\n}\n\n"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield.component.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\nimport { SiaraShieldLoaderService } from './siara-shield-loader.service';\nimport { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';\nimport { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';\nimport { installCaptchaSubmitGuard } from './siara-shield-submit-guard';\nimport { installVendorChallengeRuntimePatch } from './siara-shield-vendor-runtime';\n\nconst JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';\nconst CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';\nconst VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';\nconst CAPTCHA_READY_TIMEOUT_MS = 8000;\n\nfunction ensureAccessibilityPopupAliases(): void {\n  const g = globalThis as typeof globalThis & Record<string, unknown>;\n  const aliasNames = [\n    'RemoveAccesibilityPopup',\n    '_RemoveAccesibilityPopup',\n    'RemoveAccesiblityPopup',\n    '_RemoveAccesiblityPopup',\n  ] as const;\n\n  const existing = aliasNames\n    .map((name) => g[name])\n    .find((value): value is () => void => typeof value === 'function');\n\n  const stableFn = existing ?? (() => undefined);\n  for (const name of aliasNames) {\n    g[name] = stableFn;\n  }\n}\n\nfunction runInRootZone<T>(fn: () => T): T {\n  const g = globalThis as typeof globalThis & { Zone?: { root?: { run?: <U>(cb: () => U) => U } } };\n  const zoneRootRun = g.Zone?.root?.run;\n  if (typeof zoneRootRun === 'function') {\n    return zoneRootRun.call(g.Zone?.root, fn) as T;\n  }\n  return fn();\n}\n\nexport interface SiaraShieldInitOptions {\n  /** SiaraShield public key. Use \"TEST-CYBERSIARA\" for staging/development. */\n  publicKey: string;\n  /** Loads jQuery before SiaraShield script. Default is true for easier integration. Set to false only if your page already includes jQuery. */\n  loadJQuery?: boolean;\n  /** Reserved for backward compatibility. CSP nonce is ignored in this test variant. */\n  cspNonce?: string;\n  /** Set true only when actively debugging vendor/runtime internals in browser console. */\n  allowVendorConsoleLogs?: boolean;\n}\n\n@Component({\n  selector: 'siara-shield',\n  standalone: true,\n  template: `<div class=\"SiaraShield\"></div>`,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SiaraShieldComponent implements AfterViewInit {\n  @Input({ required: true }) publicKey!: string;\n  @Input() loadJQuery = true;\n  @Input() cspNonce?: string;\n  @Input() allowVendorConsoleLogs = false;\n\n  /**\n   * Emits the current `CyberSiaraToken` right after a successful `checkCaptcha()`.\n   */\n  @Output() token = new EventEmitter<string>();\n\n  private initialized = false;\n\n  constructor(\n    private readonly host: ElementRef<HTMLElement>,\n    private readonly loader: SiaraShieldLoaderService,\n  ) {}\n\n  async ngAfterViewInit(): Promise<void> {\n    await this.init({\n      publicKey: this.publicKey,\n      loadJQuery: this.loadJQuery,\n      cspNonce: this.cspNonce,\n      allowVendorConsoleLogs: this.allowVendorConsoleLogs,\n    });\n  }\n\n  async init(options: SiaraShieldInitOptions): Promise<void> {\n    if (this.initialized) return;\n\n    // Ensure the host element is in DOM before scripts run.\n    void this.host.nativeElement;\n    installCaptchaSubmitGuard();\n\n    if (!options.publicKey) {\n      throw new Error('SiaraShieldComponent: publicKey is required.');\n    }\n    if ((options.loadJQuery ?? true) && !this.isJQueryAlreadyAvailable()) {\n      await this.loader.loadScript(JQUERY_FALLBACK_SRC);\n    }\n\n    await this.loader.loadScript(CAPTCHA_SCRIPT_SRC);\n    await this.loader.loadScript(VALIDATION_SCRIPT_SRC);\n\n    const g = getSiaraShieldGlobals();\n    ensureAccessibilityPopupAliases();\n    this.preventDuplicateValidationBootstrap(g);\n    installVendorChallengeRuntimePatch();\n    const initCaptchaFn = getInitCaptchaFn(g);\n    if (!initCaptchaFn) {\n      throw new Error(\n        'SiaraShield: InitCaptcha() is not available after loading scripts.',\n      );\n    }\n\n    if (!options.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n      installVendorRuntimeErrorSuppression();\n    }\n    runInRootZone(() => initCaptchaFn(options.publicKey));\n    await this.waitForCheckCaptchaApi();\n    this.initialized = true;\n  }\n\n  /**\n   * Detect preloaded jQuery from global object or an existing script tag.\n   */\n  private isJQueryAlreadyAvailable(): boolean {\n    const g = getSiaraShieldGlobals();\n    if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {\n      return true;\n    }\n\n    const existingJqueryScript = this.host.nativeElement.ownerDocument.querySelector<HTMLScriptElement>(\n      'script[src*=\"jquery\"]',\n    );\n    return Boolean(existingJqueryScript);\n  }\n\n  private preventDuplicateValidationBootstrap(g: ReturnType<typeof getSiaraShieldGlobals>): void {\n    const originalAppendValidation = g.AppendValidationJS;\n    if (typeof originalAppendValidation !== 'function') {\n      return;\n    }\n\n    g.AppendValidationJS = () => {\n      const existing = this.host.nativeElement.ownerDocument.querySelector<HTMLScriptElement>(\n        `script[src=\"${VALIDATION_SCRIPT_SRC}\"]`,\n      );\n      if (existing) {\n        return;\n      }\n\n      originalAppendValidation();\n    };\n  }\n\n  private async waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS): Promise<void> {\n    const startedAt = Date.now();\n    while (Date.now() - startedAt < timeoutMs) {\n      if (getSiaraShieldGlobals().CheckCaptcha) {\n        return;\n      }\n      await new Promise((resolve) => setTimeout(resolve, 100));\n    }\n    throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.');\n  }\n\n  /**\n   * Calls the global `CheckCaptcha()` from SiaraShield script.\n   * Returns true when captcha is valid; emits token if available.\n   */\n  checkCaptcha(): boolean {\n    const g = getSiaraShieldGlobals();\n    if (!g.CheckCaptcha) {\n      throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run?');\n    }\n\n    const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;\n    if (existingToken) {\n      this.token.emit(existingToken);\n      return true;\n    }\n\n    if (!this.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n    }\n    const ok = g.CheckCaptcha();\n    if (ok && typeof g.CyberSiaraToken === 'string') {\n      this.token.emit(g.CyberSiaraToken);\n    }\n    return ok;\n  }\n\n  /**\n   * Async-friendly captcha validation to avoid first-click timing issues.\n   * Performs one validation call and waits for token propagation.\n   */\n  async checkCaptchaAsync(options?: {\n    timeoutMs?: number;\n    pollIntervalMs?: number;\n    beforeCheckDelayMs?: number;\n    retryOnFalseMs?: number;\n    falseResultTokenWaitMs?: number;\n  }): Promise<boolean> {\n    const timeoutMs = options?.timeoutMs ?? 2000;\n    const pollIntervalMs = options?.pollIntervalMs ?? 120;\n    const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;\n    const retryOnFalseMs = options?.retryOnFalseMs ?? 0;\n    const falseResultTokenWaitMs = options?.falseResultTokenWaitMs ?? 900;\n    const existingToken = getSiaraShieldGlobals().CyberSiaraToken;\n    if (typeof existingToken === 'string' && existingToken.length > 0) {\n      this.token.emit(existingToken);\n      return true;\n    }\n    await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));\n    let ok = this.checkCaptcha();\n    // Optional retry for integrations that observe late vendor-state settling.\n    if (!ok && retryOnFalseMs > 0) {\n      await new Promise((resolve) => setTimeout(resolve, retryOnFalseMs));\n      ok = this.checkCaptcha();\n    }\n    if (!ok) {\n      // Some vendor flows return false first, then set token shortly after.\n      const falseStartedAt = Date.now();\n      while (Date.now() - falseStartedAt < falseResultTokenWaitMs) {\n        await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n        const token = getSiaraShieldGlobals().CyberSiaraToken;\n        if (typeof token === 'string' && token.length > 0) {\n          this.token.emit(token);\n          return true;\n        }\n      }\n      return false;\n    }\n\n    const g = getSiaraShieldGlobals();\n    if (typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0) {\n      return true;\n    }\n\n    const startedAt = Date.now();\n    while (Date.now() - startedAt < timeoutMs) {\n      await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n      const token = getSiaraShieldGlobals().CyberSiaraToken;\n      if (typeof token === 'string' && token.length > 0) {\n        this.token.emit(token);\n        return true;\n      }\n    }\n\n    return true;\n  }\n}\n\n"]}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';
|
|
2
2
|
import { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';
|
|
3
|
-
import { loadScript
|
|
3
|
+
import { loadScript } from './siara-shield-script-utils';
|
|
4
4
|
import { installCaptchaSubmitGuard } from './siara-shield-submit-guard';
|
|
5
|
+
import { installVendorChallengeRuntimePatch } from './siara-shield-vendor-runtime';
|
|
5
6
|
const JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';
|
|
6
7
|
const CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';
|
|
7
8
|
const VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';
|
|
@@ -61,7 +62,7 @@ async function waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS) {
|
|
|
61
62
|
}
|
|
62
63
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
63
64
|
}
|
|
64
|
-
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.
|
|
65
|
+
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.');
|
|
65
66
|
}
|
|
66
67
|
/**
|
|
67
68
|
* Drop-in initializer for SiaraShield.
|
|
@@ -81,22 +82,18 @@ export async function initSiaraShield(options) {
|
|
|
81
82
|
}
|
|
82
83
|
pending = (async () => {
|
|
83
84
|
installCaptchaSubmitGuard();
|
|
84
|
-
const cspNonce = prepareScriptNonce(document, options.cspNonce);
|
|
85
85
|
if ((options.loadJQuery ?? true) && !isJQueryAlreadyAvailable()) {
|
|
86
|
-
await loadScript(document, JQUERY_FALLBACK_SRC
|
|
86
|
+
await loadScript(document, JQUERY_FALLBACK_SRC);
|
|
87
87
|
}
|
|
88
|
-
await loadScript(document, CAPTCHA_SCRIPT_SRC
|
|
89
|
-
|
|
90
|
-
});
|
|
91
|
-
await loadScript(document, VALIDATION_SCRIPT_SRC, {
|
|
92
|
-
nonce: cspNonce,
|
|
93
|
-
});
|
|
88
|
+
await loadScript(document, CAPTCHA_SCRIPT_SRC);
|
|
89
|
+
await loadScript(document, VALIDATION_SCRIPT_SRC);
|
|
94
90
|
const g = getSiaraShieldGlobals();
|
|
95
91
|
ensureAccessibilityPopupAliases();
|
|
96
92
|
preventDuplicateValidationBootstrap(g);
|
|
93
|
+
installVendorChallengeRuntimePatch();
|
|
97
94
|
const initCaptchaFn = getInitCaptchaFn(g);
|
|
98
95
|
if (!initCaptchaFn) {
|
|
99
|
-
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts.
|
|
96
|
+
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts.');
|
|
100
97
|
}
|
|
101
98
|
if (!options.allowVendorConsoleLogs) {
|
|
102
99
|
suppressVendorConsoleWindow();
|
|
@@ -120,7 +117,7 @@ export async function initSiaraShield(options) {
|
|
|
120
117
|
export function checkSiaraShieldCaptcha(options) {
|
|
121
118
|
const g = getSiaraShieldGlobals();
|
|
122
119
|
if (!g.CheckCaptcha) {
|
|
123
|
-
throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run
|
|
120
|
+
throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run?');
|
|
124
121
|
}
|
|
125
122
|
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
126
123
|
if (existingToken) {
|
|
@@ -140,14 +137,31 @@ export async function checkSiaraShieldCaptchaAsync(options) {
|
|
|
140
137
|
const timeoutMs = options?.timeoutMs ?? 1200;
|
|
141
138
|
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
142
139
|
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
140
|
+
const retryOnFalseMs = options?.retryOnFalseMs ?? 0;
|
|
141
|
+
const falseResultTokenWaitMs = options?.falseResultTokenWaitMs ?? 900;
|
|
143
142
|
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
144
143
|
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
145
144
|
return { ok: true, token: existingToken };
|
|
146
145
|
}
|
|
147
146
|
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
148
|
-
|
|
149
|
-
if (!firstCheck.ok)
|
|
147
|
+
let firstCheck = checkSiaraShieldCaptcha(); // one API call only
|
|
148
|
+
if (!firstCheck.ok && retryOnFalseMs > 0) {
|
|
149
|
+
// Optional retry for integrations that observe late vendor-state settling.
|
|
150
|
+
await new Promise((resolve) => setTimeout(resolve, retryOnFalseMs));
|
|
151
|
+
firstCheck = checkSiaraShieldCaptcha();
|
|
152
|
+
}
|
|
153
|
+
if (!firstCheck.ok) {
|
|
154
|
+
// Some vendor flows return false first, then set token shortly after.
|
|
155
|
+
const falseStartedAt = Date.now();
|
|
156
|
+
while (Date.now() - falseStartedAt < falseResultTokenWaitMs) {
|
|
157
|
+
await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
|
|
158
|
+
const token = getSiaraShieldGlobals().CyberSiaraToken;
|
|
159
|
+
if (typeof token === 'string' && token.length > 0) {
|
|
160
|
+
return { ok: true, token };
|
|
161
|
+
}
|
|
162
|
+
}
|
|
150
163
|
return firstCheck;
|
|
164
|
+
}
|
|
151
165
|
if (firstCheck.token)
|
|
152
166
|
return firstCheck;
|
|
153
167
|
const startedAt = Date.now();
|
|
@@ -161,4 +175,4 @@ export async function checkSiaraShieldCaptchaAsync(options) {
|
|
|
161
175
|
}
|
|
162
176
|
return { ok: true };
|
|
163
177
|
}
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield.ts"],"names":[],"mappings":"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","sourcesContent":["import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';\nimport { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';\nimport { loadScript, prepareScriptNonce } from './siara-shield-script-utils';\nimport { installCaptchaSubmitGuard } from './siara-shield-submit-guard';\n\nconst JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';\nconst CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';\nconst VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';\nconst CAPTCHA_READY_TIMEOUT_MS = 8000;\n\nexport interface InitSiaraShieldOptions {\n  /** SiaraShield public key. Use \"TEST-CYBERSIARA\" for staging/development. */\n  publicKey: string;\n  /**\n   * Loads jQuery before SiaraShield script.\n   * Default is true for easier integration.\n   * Set to false only if your site/app already loads jQuery.\n   */\n  loadJQuery?: boolean;\n  /** CSP nonce for strict policies (`script-src 'nonce-...'`). Pair with `getSiaraShieldCspPolicy()`. */\n  cspNonce?: string;\n  /** Set true only when actively debugging vendor/runtime internals in browser console. */\n  allowVendorConsoleLogs?: boolean;\n}\n\nlet pending: Promise<void> | null = null;\nlet initialized = false;\n\nfunction ensureAccessibilityPopupAliases(): void {\n  const g = globalThis as typeof globalThis & Record<string, unknown>;\n  const aliasNames = [\n    'RemoveAccesibilityPopup',\n    '_RemoveAccesibilityPopup',\n    'RemoveAccesiblityPopup',\n    '_RemoveAccesiblityPopup',\n  ] as const;\n\n  const existing = aliasNames\n    .map((name) => g[name])\n    .find((value): value is () => void => typeof value === 'function');\n\n  const stableFn = existing ?? (() => undefined);\n  for (const name of aliasNames) {\n    g[name] = stableFn;\n  }\n}\n\nfunction isJQueryAlreadyAvailable(): boolean {\n  const g = getSiaraShieldGlobals();\n  if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {\n    return true;\n  }\n\n  const existingJqueryScript = document.querySelector<HTMLScriptElement>('script[src*=\"jquery\"]');\n  return Boolean(existingJqueryScript);\n}\n\nfunction runInRootZone<T>(fn: () => T): T {\n  const g = globalThis as typeof globalThis & { Zone?: { root?: { run?: <U>(cb: () => U) => U } } };\n  const zoneRootRun = g.Zone?.root?.run;\n  if (typeof zoneRootRun === 'function') {\n    return zoneRootRun.call(g.Zone?.root, fn) as T;\n  }\n  return fn();\n}\n\nfunction preventDuplicateValidationBootstrap(g: ReturnType<typeof getSiaraShieldGlobals>): void {\n  const originalAppendValidation = g.AppendValidationJS;\n  if (typeof originalAppendValidation !== 'function') {\n    return;\n  }\n\n  g.AppendValidationJS = () => {\n    const existing = document.querySelector<HTMLScriptElement>(`script[src=\"${VALIDATION_SCRIPT_SRC}\"]`);\n    if (existing) {\n      return;\n    }\n\n    originalAppendValidation();\n  };\n}\n\nasync function waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS): Promise<void> {\n  const startedAt = Date.now();\n  while (Date.now() - startedAt < timeoutMs) {\n    if (getSiaraShieldGlobals().CheckCaptcha) {\n      return;\n    }\n    await new Promise((resolve) => setTimeout(resolve, 100));\n  }\n  throw new Error('SiaraShield: CheckCaptcha() was not available within timeout. This can happen when CSP blocks the captcha runtime.');\n}\n\n/**\n * Drop-in initializer for SiaraShield.\n * - Loads required scripts (optionally jQuery)\n * - Calls global `initCaptcha(publicKey)`\n *\n * Requirements in your HTML/template:\n * - You must render: `<div class=\"SiaraShield\"></div>`\n */\nexport async function initSiaraShield(options: InitSiaraShieldOptions): Promise<void> {\n  if (initialized) return;\n  if (pending) return pending;\n\n  if (!options?.publicKey) {\n    throw new Error('initSiaraShield: publicKey is required.');\n  }\n\n  pending = (async () => {\n    installCaptchaSubmitGuard();\n    const cspNonce = prepareScriptNonce(document, options.cspNonce);\n\n    if ((options.loadJQuery ?? true) && !isJQueryAlreadyAvailable()) {\n      await loadScript(document, JQUERY_FALLBACK_SRC, { nonce: cspNonce });\n    }\n\n    await loadScript(document, CAPTCHA_SCRIPT_SRC, {\n      nonce: cspNonce,\n    });\n    await loadScript(document, VALIDATION_SCRIPT_SRC, {\n      nonce: cspNonce,\n    });\n\n    const g = getSiaraShieldGlobals();\n    ensureAccessibilityPopupAliases();\n    preventDuplicateValidationBootstrap(g);\n    const initCaptchaFn = getInitCaptchaFn(g);\n    if (!initCaptchaFn) {\n      throw new Error(\n        'SiaraShield: InitCaptcha() is not available after loading scripts. Check whether CSP blocked vendor scripts or inline execution.',\n      );\n    }\n\n    if (!options.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n      installVendorRuntimeErrorSuppression();\n    }\n    runInRootZone(() => initCaptchaFn(options.publicKey));\n    await waitForCheckCaptchaApi();\n    initialized = true;\n  })();\n\n  try {\n    await pending;\n  } finally {\n    // keep `pending` cached for subsequent callers\n  }\n}\n\n/**\n * Calls global `CheckCaptcha()` and returns its boolean result.\n * If successful, returns `{ ok: true, token?: string }`.\n */\nexport function checkSiaraShieldCaptcha(options?: { allowVendorConsoleLogs?: boolean }): { ok: boolean; token?: string } {\n  const g = getSiaraShieldGlobals();\n  if (!g.CheckCaptcha) {\n    throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run, and is CSP allowing the captcha scripts?');\n  }\n\n  const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;\n  if (existingToken) {\n    return { ok: true, token: existingToken };\n  }\n\n  if (!options?.allowVendorConsoleLogs) {\n    suppressVendorConsoleWindow();\n  }\n  const ok = g.CheckCaptcha();\n  const token = typeof g.CyberSiaraToken === 'string' ? g.CyberSiaraToken : undefined;\n  return ok ? { ok: true, token } : { ok: false };\n}\n\n/**\n * Async-friendly captcha check to handle delayed token population.\n */\nexport async function checkSiaraShieldCaptchaAsync(options?: {\n  timeoutMs?: number;\n  pollIntervalMs?: number;\n  beforeCheckDelayMs?: number;\n}): Promise<{ ok: boolean; token?: string }> {\n  const timeoutMs = options?.timeoutMs ?? 1200;\n  const pollIntervalMs = options?.pollIntervalMs ?? 120;\n  const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;\n  const existingToken = getSiaraShieldGlobals().CyberSiaraToken;\n  if (typeof existingToken === 'string' && existingToken.length > 0) {\n    return { ok: true, token: existingToken };\n  }\n  await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));\n  const firstCheck = checkSiaraShieldCaptcha(); // one API call only\n  if (!firstCheck.ok) return firstCheck;\n  if (firstCheck.token) return firstCheck;\n\n  const startedAt = Date.now();\n  // Token can be assigned slightly after successful verification.\n  while (Date.now() - startedAt < timeoutMs) {\n    await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n    const token = getSiaraShieldGlobals().CyberSiaraToken;\n    if (typeof token === 'string' && token.length > 0) {\n      return { ok: true, token };\n    }\n  }\n\n  return { ok: true };\n}\n\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield.ts"],"names":[],"mappings":"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","sourcesContent":["import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';\nimport { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';\nimport { loadScript } from './siara-shield-script-utils';\nimport { installCaptchaSubmitGuard } from './siara-shield-submit-guard';\nimport { installVendorChallengeRuntimePatch } from './siara-shield-vendor-runtime';\n\nconst JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';\nconst CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';\nconst VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';\nconst CAPTCHA_READY_TIMEOUT_MS = 8000;\n\nexport interface InitSiaraShieldOptions {\n  /** SiaraShield public key. Use \"TEST-CYBERSIARA\" for staging/development. */\n  publicKey: string;\n  /**\n   * Loads jQuery before SiaraShield script.\n   * Default is true for easier integration.\n   * Set to false only if your site/app already loads jQuery.\n   */\n  loadJQuery?: boolean;\n  /** Reserved for backward compatibility. CSP nonce is ignored in this test variant. */\n  cspNonce?: string;\n  /** Set true only when actively debugging vendor/runtime internals in browser console. */\n  allowVendorConsoleLogs?: boolean;\n}\n\nlet pending: Promise<void> | null = null;\nlet initialized = false;\n\nfunction ensureAccessibilityPopupAliases(): void {\n  const g = globalThis as typeof globalThis & Record<string, unknown>;\n  const aliasNames = [\n    'RemoveAccesibilityPopup',\n    '_RemoveAccesibilityPopup',\n    'RemoveAccesiblityPopup',\n    '_RemoveAccesiblityPopup',\n  ] as const;\n\n  const existing = aliasNames\n    .map((name) => g[name])\n    .find((value): value is () => void => typeof value === 'function');\n\n  const stableFn = existing ?? (() => undefined);\n  for (const name of aliasNames) {\n    g[name] = stableFn;\n  }\n}\n\nfunction isJQueryAlreadyAvailable(): boolean {\n  const g = getSiaraShieldGlobals();\n  if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {\n    return true;\n  }\n\n  const existingJqueryScript = document.querySelector<HTMLScriptElement>('script[src*=\"jquery\"]');\n  return Boolean(existingJqueryScript);\n}\n\nfunction runInRootZone<T>(fn: () => T): T {\n  const g = globalThis as typeof globalThis & { Zone?: { root?: { run?: <U>(cb: () => U) => U } } };\n  const zoneRootRun = g.Zone?.root?.run;\n  if (typeof zoneRootRun === 'function') {\n    return zoneRootRun.call(g.Zone?.root, fn) as T;\n  }\n  return fn();\n}\n\nfunction preventDuplicateValidationBootstrap(g: ReturnType<typeof getSiaraShieldGlobals>): void {\n  const originalAppendValidation = g.AppendValidationJS;\n  if (typeof originalAppendValidation !== 'function') {\n    return;\n  }\n\n  g.AppendValidationJS = () => {\n    const existing = document.querySelector<HTMLScriptElement>(`script[src=\"${VALIDATION_SCRIPT_SRC}\"]`);\n    if (existing) {\n      return;\n    }\n\n    originalAppendValidation();\n  };\n}\n\nasync function waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS): Promise<void> {\n  const startedAt = Date.now();\n  while (Date.now() - startedAt < timeoutMs) {\n    if (getSiaraShieldGlobals().CheckCaptcha) {\n      return;\n    }\n    await new Promise((resolve) => setTimeout(resolve, 100));\n  }\n  throw new Error('SiaraShield: CheckCaptcha() was not available within timeout.');\n}\n\n/**\n * Drop-in initializer for SiaraShield.\n * - Loads required scripts (optionally jQuery)\n * - Calls global `initCaptcha(publicKey)`\n *\n * Requirements in your HTML/template:\n * - You must render: `<div class=\"SiaraShield\"></div>`\n */\nexport async function initSiaraShield(options: InitSiaraShieldOptions): Promise<void> {\n  if (initialized) return;\n  if (pending) return pending;\n\n  if (!options?.publicKey) {\n    throw new Error('initSiaraShield: publicKey is required.');\n  }\n\n  pending = (async () => {\n    installCaptchaSubmitGuard();\n    if ((options.loadJQuery ?? true) && !isJQueryAlreadyAvailable()) {\n      await loadScript(document, JQUERY_FALLBACK_SRC);\n    }\n\n    await loadScript(document, CAPTCHA_SCRIPT_SRC);\n    await loadScript(document, VALIDATION_SCRIPT_SRC);\n\n    const g = getSiaraShieldGlobals();\n    ensureAccessibilityPopupAliases();\n    preventDuplicateValidationBootstrap(g);\n    installVendorChallengeRuntimePatch();\n    const initCaptchaFn = getInitCaptchaFn(g);\n    if (!initCaptchaFn) {\n      throw new Error(\n        'SiaraShield: InitCaptcha() is not available after loading scripts.',\n      );\n    }\n\n    if (!options.allowVendorConsoleLogs) {\n      suppressVendorConsoleWindow();\n      installVendorRuntimeErrorSuppression();\n    }\n    runInRootZone(() => initCaptchaFn(options.publicKey));\n    await waitForCheckCaptchaApi();\n    initialized = true;\n  })();\n\n  try {\n    await pending;\n  } finally {\n    // keep `pending` cached for subsequent callers\n  }\n}\n\n/**\n * Calls global `CheckCaptcha()` and returns its boolean result.\n * If successful, returns `{ ok: true, token?: string }`.\n */\nexport function checkSiaraShieldCaptcha(options?: { allowVendorConsoleLogs?: boolean }): { ok: boolean; token?: string } {\n  const g = getSiaraShieldGlobals();\n  if (!g.CheckCaptcha) {\n    throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run?');\n  }\n\n  const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;\n  if (existingToken) {\n    return { ok: true, token: existingToken };\n  }\n\n  if (!options?.allowVendorConsoleLogs) {\n    suppressVendorConsoleWindow();\n  }\n  const ok = g.CheckCaptcha();\n  const token = typeof g.CyberSiaraToken === 'string' ? g.CyberSiaraToken : undefined;\n  return ok ? { ok: true, token } : { ok: false };\n}\n\n/**\n * Async-friendly captcha check to handle delayed token population.\n */\nexport async function checkSiaraShieldCaptchaAsync(options?: {\n  timeoutMs?: number;\n  pollIntervalMs?: number;\n  beforeCheckDelayMs?: number;\n  retryOnFalseMs?: number;\n  falseResultTokenWaitMs?: number;\n}): Promise<{ ok: boolean; token?: string }> {\n  const timeoutMs = options?.timeoutMs ?? 1200;\n  const pollIntervalMs = options?.pollIntervalMs ?? 120;\n  const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;\n  const retryOnFalseMs = options?.retryOnFalseMs ?? 0;\n  const falseResultTokenWaitMs = options?.falseResultTokenWaitMs ?? 900;\n  const existingToken = getSiaraShieldGlobals().CyberSiaraToken;\n  if (typeof existingToken === 'string' && existingToken.length > 0) {\n    return { ok: true, token: existingToken };\n  }\n  await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));\n  let firstCheck = checkSiaraShieldCaptcha(); // one API call only\n  if (!firstCheck.ok && retryOnFalseMs > 0) {\n    // Optional retry for integrations that observe late vendor-state settling.\n    await new Promise((resolve) => setTimeout(resolve, retryOnFalseMs));\n    firstCheck = checkSiaraShieldCaptcha();\n  }\n  if (!firstCheck.ok) {\n    // Some vendor flows return false first, then set token shortly after.\n    const falseStartedAt = Date.now();\n    while (Date.now() - falseStartedAt < falseResultTokenWaitMs) {\n      await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n      const token = getSiaraShieldGlobals().CyberSiaraToken;\n      if (typeof token === 'string' && token.length > 0) {\n        return { ok: true, token };\n      }\n    }\n    return firstCheck;\n  }\n  if (firstCheck.token) return firstCheck;\n\n  const startedAt = Date.now();\n  // Token can be assigned slightly after successful verification.\n  while (Date.now() - startedAt < timeoutMs) {\n    await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));\n    const token = getSiaraShieldGlobals().CyberSiaraToken;\n    if (typeof token === 'string' && token.length > 0) {\n      return { ok: true, token };\n    }\n  }\n\n  return { ok: true };\n}\n\n"]}
|