siarashield_workspace 0.0.31 → 0.0.33
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/esm2022/lib/siara-shield-csp.mjs +80 -0
- package/esm2022/lib/siara-shield-loader.service.mjs +23 -0
- package/esm2022/lib/siara-shield-log-utils.mjs +103 -0
- package/esm2022/lib/siara-shield-script-utils.mjs +225 -0
- package/esm2022/lib/siara-shield-submit-guard.mjs +30 -0
- package/esm2022/lib/siara-shield.component.mjs +206 -0
- package/esm2022/lib/siara-shield.globals.mjs +7 -0
- package/esm2022/lib/siara-shield.mjs +164 -0
- package/esm2022/lib/siarashield-workspace.mjs +4 -0
- package/esm2022/public-api.mjs +10 -0
- package/esm2022/siarashield_workspace.mjs +5 -0
- package/fesm2022/siarashield_workspace.mjs +32 -9
- package/fesm2022/siarashield_workspace.mjs.map +1 -1
- package/index.d.ts +5 -0
- package/lib/siara-shield-csp.d.ts +14 -0
- package/lib/siara-shield-loader.service.d.ts +9 -0
- package/lib/siara-shield-log-utils.d.ts +6 -0
- package/lib/siara-shield-script-utils.d.ts +7 -0
- package/lib/siara-shield-submit-guard.d.ts +1 -0
- package/lib/siara-shield.component.d.ts +51 -0
- package/lib/siara-shield.d.ts +44 -0
- package/lib/siara-shield.globals.d.ts +13 -0
- package/lib/siarashield-workspace.d.ts +3 -0
- package/package.json +5 -3
- package/public-api.d.ts +6 -0
- package/siarashield_workspace-0.0.33.tgz +0 -0
- package/siarashield_workspace-0.0.31.tgz +0 -0
- package/types/siarashield_workspace.d.ts +0 -140
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';
|
|
3
|
+
import { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';
|
|
4
|
+
import { prepareScriptNonce } from './siara-shield-script-utils';
|
|
5
|
+
import { installCaptchaSubmitGuard } from './siara-shield-submit-guard';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./siara-shield-loader.service";
|
|
8
|
+
const JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';
|
|
9
|
+
const CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';
|
|
10
|
+
const VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';
|
|
11
|
+
const CAPTCHA_READY_TIMEOUT_MS = 8000;
|
|
12
|
+
function ensureAccessibilityPopupAliases() {
|
|
13
|
+
const g = globalThis;
|
|
14
|
+
const aliasNames = [
|
|
15
|
+
'RemoveAccesibilityPopup',
|
|
16
|
+
'_RemoveAccesibilityPopup',
|
|
17
|
+
'RemoveAccesiblityPopup',
|
|
18
|
+
'_RemoveAccesiblityPopup',
|
|
19
|
+
];
|
|
20
|
+
const existing = aliasNames
|
|
21
|
+
.map((name) => g[name])
|
|
22
|
+
.find((value) => typeof value === 'function');
|
|
23
|
+
const stableFn = existing ?? (() => undefined);
|
|
24
|
+
for (const name of aliasNames) {
|
|
25
|
+
g[name] = stableFn;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
function runInRootZone(fn) {
|
|
29
|
+
const g = globalThis;
|
|
30
|
+
const zoneRootRun = g.Zone?.root?.run;
|
|
31
|
+
if (typeof zoneRootRun === 'function') {
|
|
32
|
+
return zoneRootRun.call(g.Zone?.root, fn);
|
|
33
|
+
}
|
|
34
|
+
return fn();
|
|
35
|
+
}
|
|
36
|
+
export class SiaraShieldComponent {
|
|
37
|
+
host;
|
|
38
|
+
loader;
|
|
39
|
+
publicKey;
|
|
40
|
+
loadJQuery = true;
|
|
41
|
+
cspNonce;
|
|
42
|
+
allowVendorConsoleLogs = false;
|
|
43
|
+
/**
|
|
44
|
+
* Emits the current `CyberSiaraToken` right after a successful `checkCaptcha()`.
|
|
45
|
+
*/
|
|
46
|
+
token = new EventEmitter();
|
|
47
|
+
initialized = false;
|
|
48
|
+
constructor(host, loader) {
|
|
49
|
+
this.host = host;
|
|
50
|
+
this.loader = loader;
|
|
51
|
+
}
|
|
52
|
+
async ngAfterViewInit() {
|
|
53
|
+
await this.init({
|
|
54
|
+
publicKey: this.publicKey,
|
|
55
|
+
loadJQuery: this.loadJQuery,
|
|
56
|
+
cspNonce: this.cspNonce,
|
|
57
|
+
allowVendorConsoleLogs: this.allowVendorConsoleLogs,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
async init(options) {
|
|
61
|
+
if (this.initialized)
|
|
62
|
+
return;
|
|
63
|
+
// Ensure the host element is in DOM before scripts run.
|
|
64
|
+
void this.host.nativeElement;
|
|
65
|
+
installCaptchaSubmitGuard();
|
|
66
|
+
if (!options.publicKey) {
|
|
67
|
+
throw new Error('SiaraShieldComponent: publicKey is required.');
|
|
68
|
+
}
|
|
69
|
+
const cspNonce = prepareScriptNonce(this.host.nativeElement.ownerDocument, options.cspNonce);
|
|
70
|
+
if ((options.loadJQuery ?? true) && !this.isJQueryAlreadyAvailable()) {
|
|
71
|
+
await this.loader.loadScript(JQUERY_FALLBACK_SRC, { nonce: cspNonce });
|
|
72
|
+
}
|
|
73
|
+
await this.loader.loadScript(CAPTCHA_SCRIPT_SRC, {
|
|
74
|
+
nonce: cspNonce,
|
|
75
|
+
});
|
|
76
|
+
await this.loader.loadScript(VALIDATION_SCRIPT_SRC, {
|
|
77
|
+
nonce: cspNonce,
|
|
78
|
+
});
|
|
79
|
+
const g = getSiaraShieldGlobals();
|
|
80
|
+
ensureAccessibilityPopupAliases();
|
|
81
|
+
this.preventDuplicateValidationBootstrap(g);
|
|
82
|
+
const initCaptchaFn = getInitCaptchaFn(g);
|
|
83
|
+
if (!initCaptchaFn) {
|
|
84
|
+
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts. Check whether CSP blocked vendor scripts or inline execution.');
|
|
85
|
+
}
|
|
86
|
+
if (!options.allowVendorConsoleLogs) {
|
|
87
|
+
suppressVendorConsoleWindow();
|
|
88
|
+
installVendorRuntimeErrorSuppression();
|
|
89
|
+
}
|
|
90
|
+
runInRootZone(() => initCaptchaFn(options.publicKey));
|
|
91
|
+
await this.waitForCheckCaptchaApi();
|
|
92
|
+
this.initialized = true;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Detect preloaded jQuery from global object or an existing script tag.
|
|
96
|
+
*/
|
|
97
|
+
isJQueryAlreadyAvailable() {
|
|
98
|
+
const g = getSiaraShieldGlobals();
|
|
99
|
+
if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {
|
|
100
|
+
return true;
|
|
101
|
+
}
|
|
102
|
+
const existingJqueryScript = this.host.nativeElement.ownerDocument.querySelector('script[src*="jquery"]');
|
|
103
|
+
return Boolean(existingJqueryScript);
|
|
104
|
+
}
|
|
105
|
+
preventDuplicateValidationBootstrap(g) {
|
|
106
|
+
const originalAppendValidation = g.AppendValidationJS;
|
|
107
|
+
if (typeof originalAppendValidation !== 'function') {
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
g.AppendValidationJS = () => {
|
|
111
|
+
const existing = this.host.nativeElement.ownerDocument.querySelector(`script[src="${VALIDATION_SCRIPT_SRC}"]`);
|
|
112
|
+
if (existing) {
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
originalAppendValidation();
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
async waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS) {
|
|
119
|
+
const startedAt = Date.now();
|
|
120
|
+
while (Date.now() - startedAt < timeoutMs) {
|
|
121
|
+
if (getSiaraShieldGlobals().CheckCaptcha) {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
125
|
+
}
|
|
126
|
+
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout. This can happen when CSP blocks the captcha runtime.');
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Calls the global `CheckCaptcha()` from SiaraShield script.
|
|
130
|
+
* Returns true when captcha is valid; emits token if available.
|
|
131
|
+
*/
|
|
132
|
+
checkCaptcha() {
|
|
133
|
+
const g = getSiaraShieldGlobals();
|
|
134
|
+
if (!g.CheckCaptcha) {
|
|
135
|
+
throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run, and is CSP allowing the captcha scripts?');
|
|
136
|
+
}
|
|
137
|
+
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
138
|
+
if (existingToken) {
|
|
139
|
+
this.token.emit(existingToken);
|
|
140
|
+
return true;
|
|
141
|
+
}
|
|
142
|
+
if (!this.allowVendorConsoleLogs) {
|
|
143
|
+
suppressVendorConsoleWindow();
|
|
144
|
+
}
|
|
145
|
+
const ok = g.CheckCaptcha();
|
|
146
|
+
if (ok && typeof g.CyberSiaraToken === 'string') {
|
|
147
|
+
this.token.emit(g.CyberSiaraToken);
|
|
148
|
+
}
|
|
149
|
+
return ok;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Async-friendly captcha validation to avoid first-click timing issues.
|
|
153
|
+
* Performs one validation call and waits for token propagation.
|
|
154
|
+
*/
|
|
155
|
+
async checkCaptchaAsync(options) {
|
|
156
|
+
const timeoutMs = options?.timeoutMs ?? 2000;
|
|
157
|
+
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
158
|
+
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
159
|
+
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
160
|
+
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
161
|
+
this.token.emit(existingToken);
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
165
|
+
const ok = this.checkCaptcha();
|
|
166
|
+
if (!ok)
|
|
167
|
+
return false;
|
|
168
|
+
const g = getSiaraShieldGlobals();
|
|
169
|
+
if (typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0) {
|
|
170
|
+
return true;
|
|
171
|
+
}
|
|
172
|
+
const startedAt = Date.now();
|
|
173
|
+
while (Date.now() - startedAt < timeoutMs) {
|
|
174
|
+
await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
|
|
175
|
+
const token = getSiaraShieldGlobals().CyberSiaraToken;
|
|
176
|
+
if (typeof token === 'string' && token.length > 0) {
|
|
177
|
+
this.token.emit(token);
|
|
178
|
+
return true;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
return true;
|
|
182
|
+
}
|
|
183
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldComponent, deps: [{ token: i0.ElementRef }, { token: i1.SiaraShieldLoaderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
184
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SiaraShieldComponent, isStandalone: true, selector: "siara-shield", inputs: { publicKey: "publicKey", loadJQuery: "loadJQuery", cspNonce: "cspNonce", allowVendorConsoleLogs: "allowVendorConsoleLogs" }, outputs: { token: "token" }, ngImport: i0, template: `<div class="SiaraShield"></div>`, isInline: true, encapsulation: i0.ViewEncapsulation.None });
|
|
185
|
+
}
|
|
186
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldComponent, decorators: [{
|
|
187
|
+
type: Component,
|
|
188
|
+
args: [{
|
|
189
|
+
selector: 'siara-shield',
|
|
190
|
+
standalone: true,
|
|
191
|
+
template: `<div class="SiaraShield"></div>`,
|
|
192
|
+
encapsulation: ViewEncapsulation.None,
|
|
193
|
+
}]
|
|
194
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.SiaraShieldLoaderService }], propDecorators: { publicKey: [{
|
|
195
|
+
type: Input,
|
|
196
|
+
args: [{ required: true }]
|
|
197
|
+
}], loadJQuery: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], cspNonce: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], allowVendorConsoleLogs: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], token: [{
|
|
204
|
+
type: Output
|
|
205
|
+
}] } });
|
|
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"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export function getSiaraShieldGlobals() {
|
|
2
|
+
return globalThis;
|
|
3
|
+
}
|
|
4
|
+
export function getInitCaptchaFn(g) {
|
|
5
|
+
return g.initCaptcha ?? g.InitCaptcha;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lhcmEtc2hpZWxkLmdsb2JhbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWFyYXNoaWVsZC13b3Jrc3BhY2Uvc3JjL2xpYi9zaWFyYS1zaGllbGQuZ2xvYmFscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhQSxNQUFNLFVBQVUscUJBQXFCO0lBQ25DLE9BQVEsVUFBd0UsQ0FBQztBQUNuRixDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLENBQXFCO0lBQ3BELE9BQU8sQ0FBQyxDQUFDLFdBQVcsSUFBSSxDQUFDLENBQUMsV0FBVyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBJbml0Q2FwdGNoYUZuID0gKHB1YmxpY0tleTogc3RyaW5nKSA9PiB2b2lkO1xuZXhwb3J0IHR5cGUgQ2hlY2tDYXB0Y2hhRm4gPSAoKSA9PiBib29sZWFuO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNpYXJhU2hpZWxkR2xvYmFscyB7XG4gIGluaXRDYXB0Y2hhPzogSW5pdENhcHRjaGFGbjtcbiAgSW5pdENhcHRjaGE/OiBJbml0Q2FwdGNoYUZuO1xuICBDaGVja0NhcHRjaGE/OiBDaGVja0NhcHRjaGFGbjtcbiAgQXBwZW5kVmFsaWRhdGlvbkpTPzogKCkgPT4gdm9pZDtcbiAgQ3liZXJTaWFyYVRva2VuPzogc3RyaW5nO1xuICBqUXVlcnk/OiB1bmtub3duO1xuICAkPzogdW5rbm93bjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFNpYXJhU2hpZWxkR2xvYmFscygpOiBTaWFyYVNoaWVsZEdsb2JhbHMge1xuICByZXR1cm4gKGdsb2JhbFRoaXMgYXMgdW5rbm93biBhcyB7IFtrOiBzdHJpbmddOiB1bmtub3duIH0pIGFzIFNpYXJhU2hpZWxkR2xvYmFscztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEluaXRDYXB0Y2hhRm4oZzogU2lhcmFTaGllbGRHbG9iYWxzKTogSW5pdENhcHRjaGFGbiB8IHVuZGVmaW5lZCB7XG4gIHJldHVybiBnLmluaXRDYXB0Y2hhID8/IGcuSW5pdENhcHRjaGE7XG59XG4iXX0=
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { getInitCaptchaFn, getSiaraShieldGlobals } from './siara-shield.globals';
|
|
2
|
+
import { installVendorRuntimeErrorSuppression, suppressVendorConsoleWindow } from './siara-shield-log-utils';
|
|
3
|
+
import { loadScript, prepareScriptNonce } from './siara-shield-script-utils';
|
|
4
|
+
import { installCaptchaSubmitGuard } from './siara-shield-submit-guard';
|
|
5
|
+
const JQUERY_FALLBACK_SRC = 'https://embedcdn.mycybersiara.com/capcha-temple/js/jquery.min.js';
|
|
6
|
+
const CAPTCHA_SCRIPT_SRC = 'https://embedcdn.mycybersiara.com/CaptchaFormate/CaptchaResources.js';
|
|
7
|
+
const VALIDATION_SCRIPT_SRC = 'https://embed.mycybersiara.com/CaptchaFormate/SiaraShield_Validation.js';
|
|
8
|
+
const CAPTCHA_READY_TIMEOUT_MS = 8000;
|
|
9
|
+
let pending = null;
|
|
10
|
+
let initialized = false;
|
|
11
|
+
function ensureAccessibilityPopupAliases() {
|
|
12
|
+
const g = globalThis;
|
|
13
|
+
const aliasNames = [
|
|
14
|
+
'RemoveAccesibilityPopup',
|
|
15
|
+
'_RemoveAccesibilityPopup',
|
|
16
|
+
'RemoveAccesiblityPopup',
|
|
17
|
+
'_RemoveAccesiblityPopup',
|
|
18
|
+
];
|
|
19
|
+
const existing = aliasNames
|
|
20
|
+
.map((name) => g[name])
|
|
21
|
+
.find((value) => typeof value === 'function');
|
|
22
|
+
const stableFn = existing ?? (() => undefined);
|
|
23
|
+
for (const name of aliasNames) {
|
|
24
|
+
g[name] = stableFn;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
function isJQueryAlreadyAvailable() {
|
|
28
|
+
const g = getSiaraShieldGlobals();
|
|
29
|
+
if (typeof g.jQuery === 'function' || typeof g.$ === 'function') {
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
const existingJqueryScript = document.querySelector('script[src*="jquery"]');
|
|
33
|
+
return Boolean(existingJqueryScript);
|
|
34
|
+
}
|
|
35
|
+
function runInRootZone(fn) {
|
|
36
|
+
const g = globalThis;
|
|
37
|
+
const zoneRootRun = g.Zone?.root?.run;
|
|
38
|
+
if (typeof zoneRootRun === 'function') {
|
|
39
|
+
return zoneRootRun.call(g.Zone?.root, fn);
|
|
40
|
+
}
|
|
41
|
+
return fn();
|
|
42
|
+
}
|
|
43
|
+
function preventDuplicateValidationBootstrap(g) {
|
|
44
|
+
const originalAppendValidation = g.AppendValidationJS;
|
|
45
|
+
if (typeof originalAppendValidation !== 'function') {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
g.AppendValidationJS = () => {
|
|
49
|
+
const existing = document.querySelector(`script[src="${VALIDATION_SCRIPT_SRC}"]`);
|
|
50
|
+
if (existing) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
originalAppendValidation();
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
async function waitForCheckCaptchaApi(timeoutMs = CAPTCHA_READY_TIMEOUT_MS) {
|
|
57
|
+
const startedAt = Date.now();
|
|
58
|
+
while (Date.now() - startedAt < timeoutMs) {
|
|
59
|
+
if (getSiaraShieldGlobals().CheckCaptcha) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
63
|
+
}
|
|
64
|
+
throw new Error('SiaraShield: CheckCaptcha() was not available within timeout. This can happen when CSP blocks the captcha runtime.');
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Drop-in initializer for SiaraShield.
|
|
68
|
+
* - Loads required scripts (optionally jQuery)
|
|
69
|
+
* - Calls global `initCaptcha(publicKey)`
|
|
70
|
+
*
|
|
71
|
+
* Requirements in your HTML/template:
|
|
72
|
+
* - You must render: `<div class="SiaraShield"></div>`
|
|
73
|
+
*/
|
|
74
|
+
export async function initSiaraShield(options) {
|
|
75
|
+
if (initialized)
|
|
76
|
+
return;
|
|
77
|
+
if (pending)
|
|
78
|
+
return pending;
|
|
79
|
+
if (!options?.publicKey) {
|
|
80
|
+
throw new Error('initSiaraShield: publicKey is required.');
|
|
81
|
+
}
|
|
82
|
+
pending = (async () => {
|
|
83
|
+
installCaptchaSubmitGuard();
|
|
84
|
+
const cspNonce = prepareScriptNonce(document, options.cspNonce);
|
|
85
|
+
if ((options.loadJQuery ?? true) && !isJQueryAlreadyAvailable()) {
|
|
86
|
+
await loadScript(document, JQUERY_FALLBACK_SRC, { nonce: cspNonce });
|
|
87
|
+
}
|
|
88
|
+
await loadScript(document, CAPTCHA_SCRIPT_SRC, {
|
|
89
|
+
nonce: cspNonce,
|
|
90
|
+
});
|
|
91
|
+
await loadScript(document, VALIDATION_SCRIPT_SRC, {
|
|
92
|
+
nonce: cspNonce,
|
|
93
|
+
});
|
|
94
|
+
const g = getSiaraShieldGlobals();
|
|
95
|
+
ensureAccessibilityPopupAliases();
|
|
96
|
+
preventDuplicateValidationBootstrap(g);
|
|
97
|
+
const initCaptchaFn = getInitCaptchaFn(g);
|
|
98
|
+
if (!initCaptchaFn) {
|
|
99
|
+
throw new Error('SiaraShield: InitCaptcha() is not available after loading scripts. Check whether CSP blocked vendor scripts or inline execution.');
|
|
100
|
+
}
|
|
101
|
+
if (!options.allowVendorConsoleLogs) {
|
|
102
|
+
suppressVendorConsoleWindow();
|
|
103
|
+
installVendorRuntimeErrorSuppression();
|
|
104
|
+
}
|
|
105
|
+
runInRootZone(() => initCaptchaFn(options.publicKey));
|
|
106
|
+
await waitForCheckCaptchaApi();
|
|
107
|
+
initialized = true;
|
|
108
|
+
})();
|
|
109
|
+
try {
|
|
110
|
+
await pending;
|
|
111
|
+
}
|
|
112
|
+
finally {
|
|
113
|
+
// keep `pending` cached for subsequent callers
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Calls global `CheckCaptcha()` and returns its boolean result.
|
|
118
|
+
* If successful, returns `{ ok: true, token?: string }`.
|
|
119
|
+
*/
|
|
120
|
+
export function checkSiaraShieldCaptcha(options) {
|
|
121
|
+
const g = getSiaraShieldGlobals();
|
|
122
|
+
if (!g.CheckCaptcha) {
|
|
123
|
+
throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run, and is CSP allowing the captcha scripts?');
|
|
124
|
+
}
|
|
125
|
+
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
126
|
+
if (existingToken) {
|
|
127
|
+
return { ok: true, token: existingToken };
|
|
128
|
+
}
|
|
129
|
+
if (!options?.allowVendorConsoleLogs) {
|
|
130
|
+
suppressVendorConsoleWindow();
|
|
131
|
+
}
|
|
132
|
+
const ok = g.CheckCaptcha();
|
|
133
|
+
const token = typeof g.CyberSiaraToken === 'string' ? g.CyberSiaraToken : undefined;
|
|
134
|
+
return ok ? { ok: true, token } : { ok: false };
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Async-friendly captcha check to handle delayed token population.
|
|
138
|
+
*/
|
|
139
|
+
export async function checkSiaraShieldCaptchaAsync(options) {
|
|
140
|
+
const timeoutMs = options?.timeoutMs ?? 1200;
|
|
141
|
+
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
142
|
+
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
143
|
+
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
144
|
+
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
145
|
+
return { ok: true, token: existingToken };
|
|
146
|
+
}
|
|
147
|
+
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
148
|
+
const firstCheck = checkSiaraShieldCaptcha(); // one API call only
|
|
149
|
+
if (!firstCheck.ok)
|
|
150
|
+
return firstCheck;
|
|
151
|
+
if (firstCheck.token)
|
|
152
|
+
return firstCheck;
|
|
153
|
+
const startedAt = Date.now();
|
|
154
|
+
// Token can be assigned slightly after successful verification.
|
|
155
|
+
while (Date.now() - startedAt < timeoutMs) {
|
|
156
|
+
await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
|
|
157
|
+
const token = getSiaraShieldGlobals().CyberSiaraToken;
|
|
158
|
+
if (typeof token === 'string' && token.length > 0) {
|
|
159
|
+
return { ok: true, token };
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
return { ok: true };
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"siara-shield.js","sourceRoot":"","sources":["../../../../projects/siarashield-workspace/src/lib/siara-shield.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AACjF,OAAO,EAAE,oCAAoC,EAAE,2BAA2B,EAAE,MAAM,0BAA0B,CAAC;AAC7G,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAC7E,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AAExE,MAAM,mBAAmB,GAAG,kEAAkE,CAAC;AAC/F,MAAM,kBAAkB,GAAG,sEAAsE,CAAC;AAClG,MAAM,qBAAqB,GAAG,yEAAyE,CAAC;AACxG,MAAM,wBAAwB,GAAG,IAAI,CAAC;AAiBtC,IAAI,OAAO,GAAyB,IAAI,CAAC;AACzC,IAAI,WAAW,GAAG,KAAK,CAAC;AAExB,SAAS,+BAA+B;IACtC,MAAM,CAAC,GAAG,UAAyD,CAAC;IACpE,MAAM,UAAU,GAAG;QACjB,yBAAyB;QACzB,0BAA0B;QAC1B,wBAAwB;QACxB,yBAAyB;KACjB,CAAC;IAEX,MAAM,QAAQ,GAAG,UAAU;SACxB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACtB,IAAI,CAAC,CAAC,KAAK,EAAuB,EAAE,CAAC,OAAO,KAAK,KAAK,UAAU,CAAC,CAAC;IAErE,MAAM,QAAQ,GAAG,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC;IAC/C,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;QAC9B,CAAC,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC;IACrB,CAAC;AACH,CAAC;AAED,SAAS,wBAAwB;IAC/B,MAAM,CAAC,GAAG,qBAAqB,EAAE,CAAC;IAClC,IAAI,OAAO,CAAC,CAAC,MAAM,KAAK,UAAU,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,UAAU,EAAE,CAAC;QAChE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,oBAAoB,GAAG,QAAQ,CAAC,aAAa,CAAoB,uBAAuB,CAAC,CAAC;IAChG,OAAO,OAAO,CAAC,oBAAoB,CAAC,CAAC;AACvC,CAAC;AAED,SAAS,aAAa,CAAI,EAAW;IACnC,MAAM,CAAC,GAAG,UAAuF,CAAC;IAClG,MAAM,WAAW,GAAG,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC;IACtC,IAAI,OAAO,WAAW,KAAK,UAAU,EAAE,CAAC;QACtC,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAM,CAAC;IACjD,CAAC;IACD,OAAO,EAAE,EAAE,CAAC;AACd,CAAC;AAED,SAAS,mCAAmC,CAAC,CAA2C;IACtF,MAAM,wBAAwB,GAAG,CAAC,CAAC,kBAAkB,CAAC;IACtD,IAAI,OAAO,wBAAwB,KAAK,UAAU,EAAE,CAAC;QACnD,OAAO;IACT,CAAC;IAED,CAAC,CAAC,kBAAkB,GAAG,GAAG,EAAE;QAC1B,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAoB,eAAe,qBAAqB,IAAI,CAAC,CAAC;QACrG,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO;QACT,CAAC;QAED,wBAAwB,EAAE,CAAC;IAC7B,CAAC,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,sBAAsB,CAAC,SAAS,GAAG,wBAAwB;IACxE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC7B,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,GAAG,SAAS,EAAE,CAAC;QAC1C,IAAI,qBAAqB,EAAE,CAAC,YAAY,EAAE,CAAC;YACzC,OAAO;QACT,CAAC;QACD,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;IAC3D,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;AACxI,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAA+B;IACnE,IAAI,WAAW;QAAE,OAAO;IACxB,IAAI,OAAO;QAAE,OAAO,OAAO,CAAC;IAE5B,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IAED,OAAO,GAAG,CAAC,KAAK,IAAI,EAAE;QACpB,yBAAyB,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,kBAAkB,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;QAEhE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,CAAC;YAChE,MAAM,UAAU,CAAC,QAAQ,EAAE,mBAAmB,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QACvE,CAAC;QAED,MAAM,UAAU,CAAC,QAAQ,EAAE,kBAAkB,EAAE;YAC7C,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;QACH,MAAM,UAAU,CAAC,QAAQ,EAAE,qBAAqB,EAAE;YAChD,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,qBAAqB,EAAE,CAAC;QAClC,+BAA+B,EAAE,CAAC;QAClC,mCAAmC,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,aAAa,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CACb,kIAAkI,CACnI,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;YACpC,2BAA2B,EAAE,CAAC;YAC9B,oCAAoC,EAAE,CAAC;QACzC,CAAC;QACD,aAAa,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;QACtD,MAAM,sBAAsB,EAAE,CAAC;QAC/B,WAAW,GAAG,IAAI,CAAC;IACrB,CAAC,CAAC,EAAE,CAAC;IAEL,IAAI,CAAC;QACH,MAAM,OAAO,CAAC;IAChB,CAAC;YAAS,CAAC;QACT,+CAA+C;IACjD,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,uBAAuB,CAAC,OAA8C;IACpF,MAAM,CAAC,GAAG,qBAAqB,EAAE,CAAC;IAClC,IAAI,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CAAC,mHAAmH,CAAC,CAAC;IACvI,CAAC;IAED,MAAM,aAAa,GAAG,OAAO,CAAC,CAAC,eAAe,KAAK,QAAQ,IAAI,CAAC,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC;IAC5H,IAAI,aAAa,EAAE,CAAC;QAClB,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;IAC5C,CAAC;IAED,IAAI,CAAC,OAAO,EAAE,sBAAsB,EAAE,CAAC;QACrC,2BAA2B,EAAE,CAAC;IAChC,CAAC;IACD,MAAM,EAAE,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC;IAC5B,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,eAAe,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC;IACpF,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC;AAClD,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAC,OAIlD;IACC,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,IAAI,CAAC;IAC7C,MAAM,cAAc,GAAG,OAAO,EAAE,cAAc,IAAI,GAAG,CAAC;IACtD,MAAM,kBAAkB,GAAG,OAAO,EAAE,kBAAkB,IAAI,GAAG,CAAC;IAC9D,MAAM,aAAa,GAAG,qBAAqB,EAAE,CAAC,eAAe,CAAC;IAC9D,IAAI,OAAO,aAAa,KAAK,QAAQ,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;IAC5C,CAAC;IACD,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxE,MAAM,UAAU,GAAG,uBAAuB,EAAE,CAAC,CAAC,oBAAoB;IAClE,IAAI,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,UAAU,CAAC;IACtC,IAAI,UAAU,CAAC,KAAK;QAAE,OAAO,UAAU,CAAC;IAExC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC7B,gEAAgE;IAChE,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,GAAG,SAAS,EAAE,CAAC;QAC1C,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC;QACpE,MAAM,KAAK,GAAG,qBAAqB,EAAE,CAAC,eAAe,CAAC;QACtD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClD,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC;AACtB,CAAC","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"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { SiaraShieldComponent } from './siara-shield.component';
|
|
2
|
+
export { SiaraShieldLoaderService } from './siara-shield-loader.service';
|
|
3
|
+
export { getSiaraShieldGlobals } from './siara-shield.globals';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lhcmFzaGllbGQtd29ya3NwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc2lhcmFzaGllbGQtd29ya3NwYWNlL3NyYy9saWIvc2lhcmFzaGllbGQtd29ya3NwYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgU2lhcmFTaGllbGRDb21wb25lbnQgfSBmcm9tICcuL3NpYXJhLXNoaWVsZC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2lhcmFTaGllbGRMb2FkZXJTZXJ2aWNlIH0gZnJvbSAnLi9zaWFyYS1zaGllbGQtbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0IHsgZ2V0U2lhcmFTaGllbGRHbG9iYWxzIH0gZnJvbSAnLi9zaWFyYS1zaGllbGQuZ2xvYmFscyc7XG4iXX0=
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of siarashield-workspace
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/siarashield-workspace';
|
|
5
|
+
export * from './lib/siara-shield.component';
|
|
6
|
+
export * from './lib/siara-shield-loader.service';
|
|
7
|
+
export * from './lib/siara-shield.globals';
|
|
8
|
+
export * from './lib/siara-shield';
|
|
9
|
+
export * from './lib/siara-shield-csp';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3NpYXJhc2hpZWxkLXdvcmtzcGFjZS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBzaWFyYXNoaWVsZC13b3Jrc3BhY2VcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaWFyYXNoaWVsZC13b3Jrc3BhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2lhcmEtc2hpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaWFyYS1zaGllbGQtbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2lhcmEtc2hpZWxkLmdsb2JhbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2lhcmEtc2hpZWxkJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NpYXJhLXNoaWVsZC1jc3AnO1xuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lhcmFzaGllbGRfd29ya3NwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvc2lhcmFzaGllbGQtd29ya3NwYWNlL3NyYy9zaWFyYXNoaWVsZF93b3Jrc3BhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -83,8 +83,12 @@ function isLikelyVendorScriptRuntimeError(message, source) {
|
|
|
83
83
|
const normalizedMessage = String(message ?? '').trim().toLowerCase();
|
|
84
84
|
const normalizedSource = String(source ?? '').trim().toLowerCase();
|
|
85
85
|
const fromSiaraHost = normalizedSource.includes('embed.mycybersiara.com') || normalizedSource.includes('embedcdn.mycybersiara.com');
|
|
86
|
+
const isKnownVendorDomError = normalizedMessage.includes("cannot read properties of null (reading 'removechild')") &&
|
|
87
|
+
(normalizedSource.includes('jquery') || normalizedSource.includes('captcharesources'));
|
|
86
88
|
if (fromSiaraHost)
|
|
87
89
|
return true;
|
|
90
|
+
if (isKnownVendorDomError)
|
|
91
|
+
return true;
|
|
88
92
|
return normalizedMessage === 'script error.' || normalizedMessage === 'script error';
|
|
89
93
|
}
|
|
90
94
|
/**
|
|
@@ -282,8 +286,9 @@ function resolveCspNonce(documentRef, explicitNonce) {
|
|
|
282
286
|
function prepareScriptNonce(documentRef, explicitNonce) {
|
|
283
287
|
const resolvedNonce = resolveCspNonce(documentRef, explicitNonce);
|
|
284
288
|
const patchState = getDynamicScriptNoncePatchState();
|
|
285
|
-
patchDynamicScriptInsertion();
|
|
286
289
|
if (resolvedNonce) {
|
|
290
|
+
// DOM patching is only needed when a CSP nonce must be propagated.
|
|
291
|
+
patchDynamicScriptInsertion();
|
|
287
292
|
patchState.nonceByDocument.set(documentRef, resolvedNonce);
|
|
288
293
|
ensureNonceMutationObserver(documentRef);
|
|
289
294
|
}
|
|
@@ -370,10 +375,10 @@ class SiaraShieldLoaderService {
|
|
|
370
375
|
loadScript(src, options) {
|
|
371
376
|
return loadScript(this.document, src, options);
|
|
372
377
|
}
|
|
373
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
374
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
378
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldLoaderService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
379
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldLoaderService, providedIn: 'root' });
|
|
375
380
|
}
|
|
376
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
381
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldLoaderService, decorators: [{
|
|
377
382
|
type: Injectable,
|
|
378
383
|
args: [{ providedIn: 'root' }]
|
|
379
384
|
}], ctorParameters: () => [{ type: Document, decorators: [{
|
|
@@ -405,7 +410,7 @@ function runInRootZone$1(fn) {
|
|
|
405
410
|
const g = globalThis;
|
|
406
411
|
const zoneRootRun = g.Zone?.root?.run;
|
|
407
412
|
if (typeof zoneRootRun === 'function') {
|
|
408
|
-
return zoneRootRun(fn);
|
|
413
|
+
return zoneRootRun.call(g.Zone?.root, fn);
|
|
409
414
|
}
|
|
410
415
|
return fn();
|
|
411
416
|
}
|
|
@@ -510,6 +515,11 @@ class SiaraShieldComponent {
|
|
|
510
515
|
if (!g.CheckCaptcha) {
|
|
511
516
|
throw new Error('SiaraShield: CheckCaptcha() is not available. Did init() run, and is CSP allowing the captcha scripts?');
|
|
512
517
|
}
|
|
518
|
+
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
519
|
+
if (existingToken) {
|
|
520
|
+
this.token.emit(existingToken);
|
|
521
|
+
return true;
|
|
522
|
+
}
|
|
513
523
|
if (!this.allowVendorConsoleLogs) {
|
|
514
524
|
suppressVendorConsoleWindow();
|
|
515
525
|
}
|
|
@@ -527,6 +537,11 @@ class SiaraShieldComponent {
|
|
|
527
537
|
const timeoutMs = options?.timeoutMs ?? 2000;
|
|
528
538
|
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
529
539
|
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
540
|
+
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
541
|
+
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
542
|
+
this.token.emit(existingToken);
|
|
543
|
+
return true;
|
|
544
|
+
}
|
|
530
545
|
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
531
546
|
const ok = this.checkCaptcha();
|
|
532
547
|
if (!ok)
|
|
@@ -546,10 +561,10 @@ class SiaraShieldComponent {
|
|
|
546
561
|
}
|
|
547
562
|
return true;
|
|
548
563
|
}
|
|
549
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
550
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
564
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldComponent, deps: [{ token: i0.ElementRef }, { token: SiaraShieldLoaderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
565
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SiaraShieldComponent, isStandalone: true, selector: "siara-shield", inputs: { publicKey: "publicKey", loadJQuery: "loadJQuery", cspNonce: "cspNonce", allowVendorConsoleLogs: "allowVendorConsoleLogs" }, outputs: { token: "token" }, ngImport: i0, template: `<div class="SiaraShield"></div>`, isInline: true, encapsulation: i0.ViewEncapsulation.None });
|
|
551
566
|
}
|
|
552
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
567
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SiaraShieldComponent, decorators: [{
|
|
553
568
|
type: Component,
|
|
554
569
|
args: [{
|
|
555
570
|
selector: 'siara-shield',
|
|
@@ -604,7 +619,7 @@ function runInRootZone(fn) {
|
|
|
604
619
|
const g = globalThis;
|
|
605
620
|
const zoneRootRun = g.Zone?.root?.run;
|
|
606
621
|
if (typeof zoneRootRun === 'function') {
|
|
607
|
-
return zoneRootRun(fn);
|
|
622
|
+
return zoneRootRun.call(g.Zone?.root, fn);
|
|
608
623
|
}
|
|
609
624
|
return fn();
|
|
610
625
|
}
|
|
@@ -690,6 +705,10 @@ function checkSiaraShieldCaptcha(options) {
|
|
|
690
705
|
if (!g.CheckCaptcha) {
|
|
691
706
|
throw new Error('SiaraShield: CheckCaptcha() is not available. Did initSiaraShield() run, and is CSP allowing the captcha scripts?');
|
|
692
707
|
}
|
|
708
|
+
const existingToken = typeof g.CyberSiaraToken === 'string' && g.CyberSiaraToken.length > 0 ? g.CyberSiaraToken : undefined;
|
|
709
|
+
if (existingToken) {
|
|
710
|
+
return { ok: true, token: existingToken };
|
|
711
|
+
}
|
|
693
712
|
if (!options?.allowVendorConsoleLogs) {
|
|
694
713
|
suppressVendorConsoleWindow();
|
|
695
714
|
}
|
|
@@ -704,6 +723,10 @@ async function checkSiaraShieldCaptchaAsync(options) {
|
|
|
704
723
|
const timeoutMs = options?.timeoutMs ?? 1200;
|
|
705
724
|
const pollIntervalMs = options?.pollIntervalMs ?? 120;
|
|
706
725
|
const beforeCheckDelayMs = options?.beforeCheckDelayMs ?? 140;
|
|
726
|
+
const existingToken = getSiaraShieldGlobals().CyberSiaraToken;
|
|
727
|
+
if (typeof existingToken === 'string' && existingToken.length > 0) {
|
|
728
|
+
return { ok: true, token: existingToken };
|
|
729
|
+
}
|
|
707
730
|
await new Promise((resolve) => setTimeout(resolve, beforeCheckDelayMs));
|
|
708
731
|
const firstCheck = checkSiaraShieldCaptcha(); // one API call only
|
|
709
732
|
if (!firstCheck.ok)
|