@aakash58/chatbot 1.1.13 → 1.1.15
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/fesm2022/aakash58-chatbot.mjs +170 -272
- package/fesm2022/aakash58-chatbot.mjs.map +1 -1
- package/index.d.ts +8 -29
- package/package.json +1 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as i1$2 from '@angular/common';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import * as i0 from '@angular/core';
|
|
4
|
-
import { isDevMode,
|
|
5
|
-
import {
|
|
4
|
+
import { isDevMode, InjectionToken, signal, Injectable, inject, effect, EventEmitter, Output, Input, Component, Pipe, ViewChild, Inject, HostListener, Directive, computed, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef, ViewEncapsulation, ContentChildren, makeEnvironmentProviders } from '@angular/core';
|
|
5
|
+
import { delay, retry, map, catchError, of, BehaviorSubject, firstValueFrom, throwError, tap, Observable, Subject, lastValueFrom, switchMap, filter, take } from 'rxjs';
|
|
6
6
|
import { JwtHelperService } from '@auth0/angular-jwt';
|
|
7
7
|
import * as i1 from '@angular/common/http';
|
|
8
8
|
import { HttpHeaders, HttpEventType, HttpClient, HttpErrorResponse, provideHttpClient, HTTP_INTERCEPTORS, withInterceptorsFromDi } from '@angular/common/http';
|
|
@@ -61,21 +61,6 @@ const DoohbotConst = {
|
|
|
61
61
|
botAvatar: '',
|
|
62
62
|
};
|
|
63
63
|
|
|
64
|
-
// export const environment = {
|
|
65
|
-
// staging: false,
|
|
66
|
-
// development: false,
|
|
67
|
-
// production: true,
|
|
68
|
-
// chatApiUrl: 'https://api.production.com',
|
|
69
|
-
// apiKey: '',
|
|
70
|
-
// };
|
|
71
|
-
const environment = {
|
|
72
|
-
config: 'const/app-const.json',
|
|
73
|
-
production: false,
|
|
74
|
-
apiBaseUrl: '',
|
|
75
|
-
loginEndpoint: '',
|
|
76
|
-
apiSegment: 'api/v1/',
|
|
77
|
-
};
|
|
78
|
-
|
|
79
64
|
class Logger {
|
|
80
65
|
static prefix = '[Doohbot]';
|
|
81
66
|
// 🎨 Color styles
|
|
@@ -116,61 +101,6 @@ class Logger {
|
|
|
116
101
|
}
|
|
117
102
|
}
|
|
118
103
|
|
|
119
|
-
class AppConst {
|
|
120
|
-
static appBaseUrl = environment.apiBaseUrl;
|
|
121
|
-
static data;
|
|
122
|
-
config$ = new ReplaySubject(1);
|
|
123
|
-
constructor() { }
|
|
124
|
-
async load() {
|
|
125
|
-
const filePath = `./assets/${environment.production ? environment.config : environment.config}?t=${new Date().getTime()}`;
|
|
126
|
-
const response = await fetch(filePath);
|
|
127
|
-
if (!response.ok) {
|
|
128
|
-
Logger.error('============================ ERROR ============================');
|
|
129
|
-
Logger.error(`Could not find file ${filePath}`);
|
|
130
|
-
Logger.error('============================ ERROR ============================');
|
|
131
|
-
}
|
|
132
|
-
Logger.error('============================ AppConst ============================', filePath);
|
|
133
|
-
if (response.ok) {
|
|
134
|
-
try {
|
|
135
|
-
AppConst.data = await response.json();
|
|
136
|
-
this.config$.next(AppConst.data);
|
|
137
|
-
Logger.error('============================ AppConst ============================', AppConst.data);
|
|
138
|
-
// Override apiBaseUrl if present in environment
|
|
139
|
-
// if (environment.apiBaseUrl) {
|
|
140
|
-
// AppConst.data.apiBaseUrl = environment.apiBaseUrl;
|
|
141
|
-
// }
|
|
142
|
-
// // Override loginEndpoint if present in environment
|
|
143
|
-
// if (environment.loginEndpoint) {
|
|
144
|
-
// AppConst.data.loginEndpoint = environment.loginEndpoint;
|
|
145
|
-
// }
|
|
146
|
-
}
|
|
147
|
-
catch (error) {
|
|
148
|
-
Logger.error('============================ ERROR ============================');
|
|
149
|
-
Logger.error(`Could not find file ${filePath}.\nMESSAGE: ${error.message}`);
|
|
150
|
-
Logger.error('============================ ERROR ============================');
|
|
151
|
-
}
|
|
152
|
-
if (AppConst.data && !Object.keys(AppConst.data).length) {
|
|
153
|
-
Logger.error('============================ ERROR ============================');
|
|
154
|
-
Logger.error(`No data found in file ${filePath}`);
|
|
155
|
-
Logger.error('============================ ERROR ============================');
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
else {
|
|
159
|
-
Logger.error('============================ ERROR ============================');
|
|
160
|
-
Logger.error(`Failed to load file ${filePath}.\nMESSAGE: Request failed with ${response.status} / ${response.statusText}`);
|
|
161
|
-
Logger.error('============================ ERROR ============================');
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AppConst, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
165
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AppConst, providedIn: 'root' });
|
|
166
|
-
}
|
|
167
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AppConst, decorators: [{
|
|
168
|
-
type: Injectable,
|
|
169
|
-
args: [{
|
|
170
|
-
providedIn: 'root',
|
|
171
|
-
}]
|
|
172
|
-
}], ctorParameters: () => [] });
|
|
173
|
-
|
|
174
104
|
/**
|
|
175
105
|
* Utility class for common snackbar operations
|
|
176
106
|
* Provides reusable snackbar configurations for consistency across the application
|
|
@@ -231,13 +161,78 @@ const DOOHBOT_ADVANCED_CONFIG = new InjectionToken('DOOHBOT_ADVANCED_CONFIG', {
|
|
|
231
161
|
}),
|
|
232
162
|
});
|
|
233
163
|
|
|
164
|
+
class DoohbotInput {
|
|
165
|
+
username = '';
|
|
166
|
+
password = '';
|
|
167
|
+
authToken;
|
|
168
|
+
license = '';
|
|
169
|
+
licenseCode = '';
|
|
170
|
+
licenseKey = '';
|
|
171
|
+
licenseFilePath = '';
|
|
172
|
+
apiBaseUrl = '';
|
|
173
|
+
apiSegment = '';
|
|
174
|
+
tenancyName = '';
|
|
175
|
+
storageKey = '';
|
|
176
|
+
secretKey = '';
|
|
177
|
+
companyCode = '';
|
|
178
|
+
buttonStyle;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
class CoreConfigService {
|
|
182
|
+
configSignal = signal(new DoohbotInput(), ...(ngDevMode ? [{ debugName: "configSignal" }] : []));
|
|
183
|
+
config$ = this.configSignal.asReadonly();
|
|
184
|
+
/**
|
|
185
|
+
* Updates the global library configuration
|
|
186
|
+
*/
|
|
187
|
+
updateConfig(config) {
|
|
188
|
+
this.configSignal.set(config);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Dynamic getters for common config properties
|
|
192
|
+
*/
|
|
193
|
+
get apiUrl() {
|
|
194
|
+
const config = this.configSignal();
|
|
195
|
+
return `${config.apiBaseUrl}${config.apiSegment}`;
|
|
196
|
+
}
|
|
197
|
+
get storageKey() {
|
|
198
|
+
return this.configSignal().storageKey || '';
|
|
199
|
+
}
|
|
200
|
+
get secretKey() {
|
|
201
|
+
return this.configSignal().secretKey || '';
|
|
202
|
+
}
|
|
203
|
+
get companyCode() {
|
|
204
|
+
return this.configSignal().companyCode || '';
|
|
205
|
+
}
|
|
206
|
+
get tenancyName() {
|
|
207
|
+
return this.configSignal().tenancyName || '';
|
|
208
|
+
}
|
|
209
|
+
get licenseKey() {
|
|
210
|
+
return this.configSignal().licenseKey || '';
|
|
211
|
+
}
|
|
212
|
+
get licenseFilePath() {
|
|
213
|
+
return this.configSignal().licenseFilePath || '';
|
|
214
|
+
}
|
|
215
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CoreConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
216
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CoreConfigService, providedIn: 'root' });
|
|
217
|
+
}
|
|
218
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: CoreConfigService, decorators: [{
|
|
219
|
+
type: Injectable,
|
|
220
|
+
args: [{
|
|
221
|
+
providedIn: 'root',
|
|
222
|
+
}]
|
|
223
|
+
}] });
|
|
224
|
+
|
|
234
225
|
class StorageService {
|
|
235
|
-
|
|
236
|
-
|
|
226
|
+
coreConfig;
|
|
227
|
+
get storageKey() {
|
|
228
|
+
return this.coreConfig.storageKey;
|
|
229
|
+
}
|
|
230
|
+
get secretKey() {
|
|
231
|
+
return this.coreConfig.secretKey;
|
|
232
|
+
}
|
|
237
233
|
storage;
|
|
238
|
-
constructor() {
|
|
239
|
-
this.
|
|
240
|
-
this.secretKey = AppConst?.data?.secretKey || 'doohbot_secret';
|
|
234
|
+
constructor(coreConfig) {
|
|
235
|
+
this.coreConfig = coreConfig;
|
|
241
236
|
// Determine initial storage
|
|
242
237
|
// If session storage has data, use it (implies remember me was false)
|
|
243
238
|
// Otherwise default/fallback to local storage
|
|
@@ -324,7 +319,7 @@ class StorageService {
|
|
|
324
319
|
return null;
|
|
325
320
|
}
|
|
326
321
|
}
|
|
327
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
322
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StorageService, deps: [{ token: CoreConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
328
323
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StorageService, providedIn: 'root' });
|
|
329
324
|
}
|
|
330
325
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: StorageService, decorators: [{
|
|
@@ -332,18 +327,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
332
327
|
args: [{
|
|
333
328
|
providedIn: 'root',
|
|
334
329
|
}]
|
|
335
|
-
}], ctorParameters: () => [] });
|
|
330
|
+
}], ctorParameters: () => [{ type: CoreConfigService }] });
|
|
336
331
|
|
|
337
332
|
class HttpService {
|
|
338
333
|
http;
|
|
339
334
|
tokenStorage;
|
|
335
|
+
coreConfig;
|
|
340
336
|
// @BlockUI() blockUI!: NgBlockUI;
|
|
341
|
-
apiUrl
|
|
342
|
-
|
|
337
|
+
get apiUrl() {
|
|
338
|
+
return this.coreConfig.apiUrl;
|
|
339
|
+
}
|
|
340
|
+
constructor(http, tokenStorage, coreConfig) {
|
|
343
341
|
this.http = http;
|
|
344
342
|
this.tokenStorage = tokenStorage;
|
|
345
|
-
this.
|
|
346
|
-
Logger.log('HttpService: Initialized'
|
|
343
|
+
this.coreConfig = coreConfig;
|
|
344
|
+
Logger.log('HttpService: Initialized');
|
|
347
345
|
}
|
|
348
346
|
get(url, param, nestedParam = false, showLoader = false, refresh = true, headers) {
|
|
349
347
|
// if (showLoader && !this.blockUI.isActive) {
|
|
@@ -420,7 +418,7 @@ class HttpService {
|
|
|
420
418
|
// }
|
|
421
419
|
return value;
|
|
422
420
|
}
|
|
423
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: HttpService, deps: [{ token: i1.HttpClient }, { token: StorageService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
421
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: HttpService, deps: [{ token: i1.HttpClient }, { token: StorageService }, { token: CoreConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
424
422
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: HttpService, providedIn: 'root' });
|
|
425
423
|
}
|
|
426
424
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: HttpService, decorators: [{
|
|
@@ -428,7 +426,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
428
426
|
args: [{
|
|
429
427
|
providedIn: 'root',
|
|
430
428
|
}]
|
|
431
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: StorageService }] });
|
|
429
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: StorageService }, { type: CoreConfigService }] });
|
|
432
430
|
|
|
433
431
|
class AccountService {
|
|
434
432
|
http;
|
|
@@ -520,12 +518,21 @@ class AuthService {
|
|
|
520
518
|
cryptoHelper;
|
|
521
519
|
tokenStorage;
|
|
522
520
|
router;
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
521
|
+
coreConfig;
|
|
522
|
+
get apiUrl() {
|
|
523
|
+
return this.coreConfig.apiUrl;
|
|
524
|
+
}
|
|
525
|
+
get storageKey() {
|
|
526
|
+
return this.coreConfig.storageKey;
|
|
527
|
+
}
|
|
528
|
+
get secretKey() {
|
|
529
|
+
return this.coreConfig.secretKey;
|
|
530
|
+
}
|
|
531
|
+
get companyCode() {
|
|
532
|
+
return this.coreConfig.companyCode;
|
|
533
|
+
}
|
|
527
534
|
jwtHelper = new JwtHelperService();
|
|
528
|
-
|
|
535
|
+
advancedConfig = inject(DOOHBOT_ADVANCED_CONFIG, { optional: true });
|
|
529
536
|
// Reactive Authentication State
|
|
530
537
|
authStatusSubject = new BehaviorSubject('unauthenticated');
|
|
531
538
|
authStatus$ = this.authStatusSubject.asObservable();
|
|
@@ -533,16 +540,22 @@ class AuthService {
|
|
|
533
540
|
isLoggingIn = signal(false, ...(ngDevMode ? [{ debugName: "isLoggingIn" }] : []));
|
|
534
541
|
authError = signal(null, ...(ngDevMode ? [{ debugName: "authError" }] : []));
|
|
535
542
|
authSuccess = signal(null, ...(ngDevMode ? [{ debugName: "authSuccess" }] : []));
|
|
536
|
-
constructor(accountService, cryptoHelper, tokenStorage, router) {
|
|
543
|
+
constructor(accountService, cryptoHelper, tokenStorage, router, coreConfig) {
|
|
537
544
|
this.accountService = accountService;
|
|
538
545
|
this.cryptoHelper = cryptoHelper;
|
|
539
546
|
this.tokenStorage = tokenStorage;
|
|
540
547
|
this.router = router;
|
|
541
|
-
this.
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
548
|
+
this.coreConfig = coreConfig;
|
|
549
|
+
// Properties are now derived from coreConfig
|
|
550
|
+
}
|
|
551
|
+
/**
|
|
552
|
+
* Updates the service configuration from the component input
|
|
553
|
+
*/
|
|
554
|
+
updateConfig(config) {
|
|
555
|
+
this.coreConfig.updateConfig(config);
|
|
556
|
+
if (config.secretKey) {
|
|
557
|
+
this.cryptoHelper.setSecretKey(config.secretKey);
|
|
558
|
+
}
|
|
546
559
|
}
|
|
547
560
|
getLoggedInUserName() {
|
|
548
561
|
const username = this.tokenStorage.get('username');
|
|
@@ -567,32 +580,30 @@ class AuthService {
|
|
|
567
580
|
* Resolves a federated token from browser storage
|
|
568
581
|
*/
|
|
569
582
|
resolveSilentToken() {
|
|
570
|
-
const
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
Logger.
|
|
583
|
+
const config = this.coreConfig.config$();
|
|
584
|
+
const commonKeys = ['access_token', 'id_token', 'token', 'authToken'];
|
|
585
|
+
// 1. Try explicit authToken from config (Highest Priority)
|
|
586
|
+
if (config.authToken) {
|
|
587
|
+
Logger.info(`[Auth] Using explicit authToken from input`);
|
|
588
|
+
return config.authToken;
|
|
589
|
+
}
|
|
590
|
+
// 2. Try configured storage key from advanced config
|
|
591
|
+
if (this.advancedConfig?.autoConfigFromStorage) {
|
|
592
|
+
const key = this.advancedConfig.autoConfigFromStorage;
|
|
593
|
+
const token = localStorage.getItem(key) || sessionStorage.getItem(key);
|
|
594
|
+
if (token) {
|
|
595
|
+
Logger.debug(`[Auth] Resolved token from configured key: ${key}`);
|
|
596
|
+
return token;
|
|
583
597
|
}
|
|
584
598
|
}
|
|
585
|
-
//
|
|
586
|
-
|
|
587
|
-
const token = localStorage.getItem(
|
|
599
|
+
// 3. Try common fallback keys
|
|
600
|
+
for (const key of commonKeys) {
|
|
601
|
+
const token = localStorage.getItem(key) || sessionStorage.getItem(key);
|
|
588
602
|
if (token) {
|
|
589
|
-
Logger.
|
|
603
|
+
Logger.debug(`[Auth] Resolved token from fallback key: ${key}`);
|
|
590
604
|
return token;
|
|
591
605
|
}
|
|
592
|
-
Logger.debug(`[Auth] No token found at configured key: ${configuredKey}`);
|
|
593
606
|
}
|
|
594
|
-
// No token found
|
|
595
|
-
Logger.debug('[Auth] No token could be resolved from ABP or configured storage');
|
|
596
607
|
return null;
|
|
597
608
|
}
|
|
598
609
|
/**
|
|
@@ -832,7 +843,7 @@ class AuthService {
|
|
|
832
843
|
};
|
|
833
844
|
}
|
|
834
845
|
get licenseKey() {
|
|
835
|
-
return this.tokenStorage.get('license_key') ||
|
|
846
|
+
return this.tokenStorage.get('license_key') || this.coreConfig.licenseKey || '';
|
|
836
847
|
}
|
|
837
848
|
get isFederated() {
|
|
838
849
|
return this.licenseKey.startsWith('doohbot_lic_');
|
|
@@ -871,7 +882,7 @@ class AuthService {
|
|
|
871
882
|
clearCache() {
|
|
872
883
|
// this.cacheService.clear();
|
|
873
884
|
}
|
|
874
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AuthService, deps: [{ token: AccountService }, { token: CryptoHelperService }, { token: StorageService }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
885
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AuthService, deps: [{ token: AccountService }, { token: CryptoHelperService }, { token: StorageService }, { token: i4.Router }, { token: CoreConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
875
886
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AuthService, providedIn: 'root' });
|
|
876
887
|
}
|
|
877
888
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: AuthService, decorators: [{
|
|
@@ -879,7 +890,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
879
890
|
args: [{
|
|
880
891
|
providedIn: 'root',
|
|
881
892
|
}]
|
|
882
|
-
}], ctorParameters: () => [{ type: AccountService }, { type: CryptoHelperService }, { type: StorageService }, { type: i4.Router }] });
|
|
893
|
+
}], ctorParameters: () => [{ type: AccountService }, { type: CryptoHelperService }, { type: StorageService }, { type: i4.Router }, { type: CoreConfigService }] });
|
|
883
894
|
|
|
884
895
|
const BASE_STORAGE_KEY = 'app.personalization.v1';
|
|
885
896
|
const DEFAULT_SETTINGS = {
|
|
@@ -1251,16 +1262,6 @@ const SuggestedMessages = [
|
|
|
1251
1262
|
'Quick tips to start.',
|
|
1252
1263
|
];
|
|
1253
1264
|
|
|
1254
|
-
class DoohbotInput {
|
|
1255
|
-
username = '';
|
|
1256
|
-
password = '';
|
|
1257
|
-
authToken;
|
|
1258
|
-
license = '';
|
|
1259
|
-
licenseCode = '';
|
|
1260
|
-
licenseKey = '';
|
|
1261
|
-
buttonStyle;
|
|
1262
|
-
}
|
|
1263
|
-
|
|
1264
1265
|
class ChatButtonComponent {
|
|
1265
1266
|
buttonStyle = 'fab';
|
|
1266
1267
|
isChatOpen = false;
|
|
@@ -2188,12 +2189,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
2188
2189
|
class ChatApiService {
|
|
2189
2190
|
http;
|
|
2190
2191
|
httpStreamService;
|
|
2191
|
-
apiUrl
|
|
2192
|
+
get apiUrl() {
|
|
2193
|
+
return this.http.apiUrl;
|
|
2194
|
+
}
|
|
2192
2195
|
constructor(http, httpStreamService) {
|
|
2193
2196
|
this.http = http;
|
|
2194
2197
|
this.httpStreamService = httpStreamService;
|
|
2195
|
-
|
|
2196
|
-
Logger.log('ChatApiService: Initialized:', this.apiUrl);
|
|
2198
|
+
Logger.log('ChatApiService: Initialized');
|
|
2197
2199
|
}
|
|
2198
2200
|
/**
|
|
2199
2201
|
* Send chat message and get full response
|
|
@@ -4197,17 +4199,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
4197
4199
|
|
|
4198
4200
|
class LicenseService {
|
|
4199
4201
|
http = inject(HttpClient);
|
|
4202
|
+
coreConfig = inject(CoreConfigService);
|
|
4200
4203
|
registry = signal(null, ...(ngDevMode ? [{ debugName: "registry" }] : []));
|
|
4201
4204
|
/**
|
|
4202
4205
|
* Load the license configuration from a JSON file.
|
|
4203
4206
|
* Supports both Hierarchical (entitlements) and Flat-map (package:key) formats.
|
|
4204
4207
|
* @param filePath Path to the license JSON file
|
|
4205
4208
|
*/
|
|
4206
|
-
async loadLicenseFile(filePath
|
|
4209
|
+
async loadLicenseFile(filePath) {
|
|
4207
4210
|
try {
|
|
4208
|
-
|
|
4209
|
-
const configuredPath = AppConst.data?.licenseFile;
|
|
4210
|
-
const finalPath = configuredPath || filePath;
|
|
4211
|
+
const finalPath = filePath || this.coreConfig.licenseFilePath;
|
|
4211
4212
|
const data = await firstValueFrom(this.http.get(finalPath));
|
|
4212
4213
|
if (!data) {
|
|
4213
4214
|
throw new Error('Empty license file');
|
|
@@ -4292,31 +4293,31 @@ class LicenseService {
|
|
|
4292
4293
|
}
|
|
4293
4294
|
/**
|
|
4294
4295
|
* Resolves the license key for the current tenant.
|
|
4295
|
-
* Auto-discovers tenant from URL or optional appBaseUrl pattern.
|
|
4296
|
-
* Returns the key for 'doohbot' or null if not found.
|
|
4297
4296
|
*/
|
|
4298
|
-
resolveTenantLicenseKey(
|
|
4299
|
-
//
|
|
4300
|
-
|
|
4301
|
-
|
|
4302
|
-
|
|
4303
|
-
|
|
4304
|
-
null;
|
|
4297
|
+
resolveTenantLicenseKey(tenancyName) {
|
|
4298
|
+
// Explicit tenancy name (param or coreConfig)
|
|
4299
|
+
const finalTenancyName = tenancyName || this.coreConfig.tenancyName;
|
|
4300
|
+
if (finalTenancyName) {
|
|
4301
|
+
Logger.info(`[LicenseService] Using tenancy name: ${finalTenancyName}`);
|
|
4302
|
+
tenancyName = finalTenancyName;
|
|
4305
4303
|
}
|
|
4306
|
-
|
|
4307
|
-
Logger.error('[LicenseService] Error resolving tenancy name:'
|
|
4304
|
+
else {
|
|
4305
|
+
Logger.error('[LicenseService] Error resolving tenancy name from globals:');
|
|
4308
4306
|
}
|
|
4309
|
-
Logger.info('[LicenseService] Detected tenancy name:', tenancyName);
|
|
4310
4307
|
if (!tenancyName) {
|
|
4311
|
-
Logger.
|
|
4308
|
+
Logger.warn('[LicenseService] Could not resolve tenancy name.');
|
|
4312
4309
|
return null;
|
|
4313
4310
|
}
|
|
4314
|
-
Logger.
|
|
4311
|
+
Logger.debug(`[LicenseService] Resolving license for tenant: ${tenancyName}`);
|
|
4315
4312
|
// Lookup license key in registry
|
|
4316
|
-
const
|
|
4313
|
+
const reg = this.registry();
|
|
4314
|
+
if (!reg)
|
|
4315
|
+
return null;
|
|
4316
|
+
const tenantLicenses = reg.subjectLicenses.get(`tenant:${tenancyName}`);
|
|
4317
4317
|
const licenseKey = tenantLicenses?.['doohbot'] || null;
|
|
4318
|
-
if (licenseKey)
|
|
4319
|
-
Logger.
|
|
4318
|
+
if (licenseKey) {
|
|
4319
|
+
Logger.info(`[LicenseService] Found Doohbot license for tenant: ${tenancyName}`);
|
|
4320
|
+
}
|
|
4320
4321
|
return licenseKey;
|
|
4321
4322
|
}
|
|
4322
4323
|
/**
|
|
@@ -4335,93 +4336,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
4335
4336
|
}]
|
|
4336
4337
|
}] });
|
|
4337
4338
|
|
|
4338
|
-
class EnvironmentDiagnosticService {
|
|
4339
|
-
/**
|
|
4340
|
-
* Collects all diagnostic information from the environment.
|
|
4341
|
-
*/
|
|
4342
|
-
getDiagnosticReport() {
|
|
4343
|
-
const report = {
|
|
4344
|
-
timestamp: new Date().toISOString(),
|
|
4345
|
-
url: window.location.href,
|
|
4346
|
-
storage: {
|
|
4347
|
-
localStorage: this.getLocalStorage(),
|
|
4348
|
-
sessionStorage: this.getSessionStorage(),
|
|
4349
|
-
},
|
|
4350
|
-
cookies: this.getCookies(),
|
|
4351
|
-
abpContext: this.getAbpContext(),
|
|
4352
|
-
};
|
|
4353
|
-
Logger.info('[EnvironmentDiagnostic] Full Diagnostic Report:', report);
|
|
4354
|
-
return report;
|
|
4355
|
-
}
|
|
4356
|
-
/**
|
|
4357
|
-
* Retrieves all items from localStorage.
|
|
4358
|
-
*/
|
|
4359
|
-
getLocalStorage() {
|
|
4360
|
-
const result = {};
|
|
4361
|
-
for (let i = 0; i < localStorage.length; i++) {
|
|
4362
|
-
const key = localStorage.key(i);
|
|
4363
|
-
if (key) {
|
|
4364
|
-
result[key] = localStorage.getItem(key) || '';
|
|
4365
|
-
}
|
|
4366
|
-
}
|
|
4367
|
-
Logger.info('[EnvironmentDiagnostic] LocalStorage:', result);
|
|
4368
|
-
return result;
|
|
4369
|
-
}
|
|
4370
|
-
/**
|
|
4371
|
-
* Retrieves all items from sessionStorage.
|
|
4372
|
-
*/
|
|
4373
|
-
getSessionStorage() {
|
|
4374
|
-
const result = {};
|
|
4375
|
-
for (let i = 0; i < sessionStorage.length; i++) {
|
|
4376
|
-
const key = sessionStorage.key(i);
|
|
4377
|
-
if (key) {
|
|
4378
|
-
result[key] = sessionStorage.getItem(key) || '';
|
|
4379
|
-
}
|
|
4380
|
-
}
|
|
4381
|
-
Logger.info('[EnvironmentDiagnostic] SessionStorage:', result);
|
|
4382
|
-
return result;
|
|
4383
|
-
}
|
|
4384
|
-
/**
|
|
4385
|
-
* Parses and retrieves all cookies.
|
|
4386
|
-
*/
|
|
4387
|
-
getCookies() {
|
|
4388
|
-
const result = {};
|
|
4389
|
-
const cookies = document.cookie.split(';');
|
|
4390
|
-
for (let cookie of cookies) {
|
|
4391
|
-
const [key, value] = cookie.trim().split('=');
|
|
4392
|
-
if (key) {
|
|
4393
|
-
result[key] = decodeURIComponent(value || '');
|
|
4394
|
-
}
|
|
4395
|
-
}
|
|
4396
|
-
Logger.info('[EnvironmentDiagnostic] Cookies:', result);
|
|
4397
|
-
return result;
|
|
4398
|
-
}
|
|
4399
|
-
/**
|
|
4400
|
-
* Checks for ABP-specific global variables.
|
|
4401
|
-
*/
|
|
4402
|
-
getAbpContext() {
|
|
4403
|
-
const win = window;
|
|
4404
|
-
const context = {
|
|
4405
|
-
hasAbp: !!win.abp,
|
|
4406
|
-
hasAppPreBootstrap: !!win.AppPreBootstrap,
|
|
4407
|
-
hasAppConsts: !!win.AppConsts,
|
|
4408
|
-
abpAuthToken: win.abp?.auth?.getToken ? 'FUNCTION_EXISTS' : 'NOT_FOUND',
|
|
4409
|
-
appConstsAppBaseUrl: win.AppConsts?.appBaseUrl || 'NOT_FOUND',
|
|
4410
|
-
tenancyName: win.AppPreBootstrap?.resolveTenancyName ? 'RESOLVER_EXISTS' : 'NOT_FOUND',
|
|
4411
|
-
};
|
|
4412
|
-
Logger.info('[EnvironmentDiagnostic] ABP Context:', context);
|
|
4413
|
-
return context;
|
|
4414
|
-
}
|
|
4415
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: EnvironmentDiagnosticService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4416
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: EnvironmentDiagnosticService, providedIn: 'root' });
|
|
4417
|
-
}
|
|
4418
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImport: i0, type: EnvironmentDiagnosticService, decorators: [{
|
|
4419
|
-
type: Injectable,
|
|
4420
|
-
args: [{
|
|
4421
|
-
providedIn: 'root',
|
|
4422
|
-
}]
|
|
4423
|
-
}] });
|
|
4424
|
-
|
|
4425
4339
|
class Doohbot extends DoohbotInput {
|
|
4426
4340
|
elementRef;
|
|
4427
4341
|
renderer;
|
|
@@ -4442,7 +4356,6 @@ class Doohbot extends DoohbotInput {
|
|
|
4442
4356
|
snackbarService = inject(SnackbarService);
|
|
4443
4357
|
personalization = inject(PersonalizationService);
|
|
4444
4358
|
licenseService = inject(LicenseService);
|
|
4445
|
-
diagnosticService = inject(EnvironmentDiagnosticService);
|
|
4446
4359
|
//! ========================= EXPOSED STATE FROM SERVICES ============================
|
|
4447
4360
|
// UI State signals
|
|
4448
4361
|
isChatOpen = this.uiState.isChatOpen;
|
|
@@ -4502,8 +4415,6 @@ class Doohbot extends DoohbotInput {
|
|
|
4502
4415
|
// Corrected structural integrity.
|
|
4503
4416
|
ngOnInit() {
|
|
4504
4417
|
Logger.log('Initializing Doohbot component...');
|
|
4505
|
-
// Run diagnostics
|
|
4506
|
-
this.diagnosticService.getDiagnosticReport();
|
|
4507
4418
|
// Run validation once on startup
|
|
4508
4419
|
this.authService.validateStoredToken().subscribe();
|
|
4509
4420
|
// React to auth status changes
|
|
@@ -4548,6 +4459,7 @@ class Doohbot extends DoohbotInput {
|
|
|
4548
4459
|
}
|
|
4549
4460
|
// Handle config changes
|
|
4550
4461
|
if (changes['config']) {
|
|
4462
|
+
this.authService.updateConfig(this.config);
|
|
4551
4463
|
this.userAvatarUrl();
|
|
4552
4464
|
this.updateUserName();
|
|
4553
4465
|
if (this.config.licenseKey) {
|
|
@@ -4560,7 +4472,10 @@ class Doohbot extends DoohbotInput {
|
|
|
4560
4472
|
}
|
|
4561
4473
|
// Handle dynamic config updates for authentication
|
|
4562
4474
|
if (!this.isAuthenticated()) {
|
|
4563
|
-
this.
|
|
4475
|
+
const token = this.config.authToken;
|
|
4476
|
+
if (token) {
|
|
4477
|
+
this.onFederatedLogin(token);
|
|
4478
|
+
}
|
|
4564
4479
|
}
|
|
4565
4480
|
}
|
|
4566
4481
|
if (changes['buttonStyle'] && this.buttonStyle) {
|
|
@@ -4576,12 +4491,14 @@ class Doohbot extends DoohbotInput {
|
|
|
4576
4491
|
//! ====================== AUTHENTICATION ==================
|
|
4577
4492
|
// Logic moved to ChatFacadeService.initialize()
|
|
4578
4493
|
onNormalLogin(credentials) {
|
|
4579
|
-
// Try
|
|
4580
|
-
let
|
|
4581
|
-
//
|
|
4582
|
-
if (!
|
|
4583
|
-
|
|
4584
|
-
}
|
|
4494
|
+
// Try Tenancy Name from Config Input
|
|
4495
|
+
let tenancy = this.config.tenancyName;
|
|
4496
|
+
// fallback: Try to resolve from global utility (Auto-detect)
|
|
4497
|
+
if (!tenancy) {
|
|
4498
|
+
tenancy = window.AppPreBootstrap?.resolveTenancyName(window.AppConsts?.appBaseUrl);
|
|
4499
|
+
}
|
|
4500
|
+
// Resolve key from whatever tenancy we found
|
|
4501
|
+
let autoKey = this.licenseService.resolveTenantLicenseKey(tenancy || undefined);
|
|
4585
4502
|
// Inject for strict validation
|
|
4586
4503
|
if (autoKey) {
|
|
4587
4504
|
credentials.license = autoKey;
|
|
@@ -4781,11 +4698,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
4781
4698
|
type: ViewChild,
|
|
4782
4699
|
args: [FullscreenDirective]
|
|
4783
4700
|
}] } });
|
|
4784
|
-
//! ================== INITIALIZATION =======================
|
|
4785
|
-
function initializeApp() {
|
|
4786
|
-
const appConst = inject(AppConst);
|
|
4787
|
-
return () => appConst.load(); // Returns a function that returns a Promise
|
|
4788
|
-
}
|
|
4789
4701
|
|
|
4790
4702
|
/**
|
|
4791
4703
|
* Injection token for providing Doohbot API configuration
|
|
@@ -4959,10 +4871,8 @@ class LicenseInterceptor {
|
|
|
4959
4871
|
return next.handle(req);
|
|
4960
4872
|
}
|
|
4961
4873
|
// Determine if this is an internal API request
|
|
4962
|
-
const
|
|
4963
|
-
const
|
|
4964
|
-
const isInternalApi = req.url.includes(apiSegment) ||
|
|
4965
|
-
(apiBaseUrl && req.url.startsWith(apiBaseUrl)) ||
|
|
4874
|
+
const apiUrl = authService.apiUrl;
|
|
4875
|
+
const isInternalApi = (apiUrl && req.url.startsWith(apiUrl)) ||
|
|
4966
4876
|
(!req.url.startsWith('http') && !req.url.startsWith('assets/'));
|
|
4967
4877
|
if (!isInternalApi) {
|
|
4968
4878
|
return next.handle(req);
|
|
@@ -4986,20 +4896,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.14", ngImpo
|
|
|
4986
4896
|
type: Injectable
|
|
4987
4897
|
}], ctorParameters: () => [{ type: i0.Injector }] });
|
|
4988
4898
|
|
|
4989
|
-
function initializeDoohbotApp() {
|
|
4990
|
-
return () => {
|
|
4991
|
-
const appConst = inject(AppConst);
|
|
4992
|
-
return appConst.load();
|
|
4993
|
-
};
|
|
4994
|
-
}
|
|
4995
4899
|
function provideDoohbot() {
|
|
4996
4900
|
return makeEnvironmentProviders([
|
|
4997
|
-
AppConst,
|
|
4998
|
-
{
|
|
4999
|
-
provide: APP_INITIALIZER,
|
|
5000
|
-
useFactory: initializeDoohbotApp,
|
|
5001
|
-
multi: true,
|
|
5002
|
-
},
|
|
5003
4901
|
provideHttpClient(withInterceptorsFromDi()),
|
|
5004
4902
|
{
|
|
5005
4903
|
provide: HTTP_INTERCEPTORS,
|
|
@@ -5044,5 +4942,5 @@ function provideDoohbot() {
|
|
|
5044
4942
|
* Generated bundle index. Do not edit.
|
|
5045
4943
|
*/
|
|
5046
4944
|
|
|
5047
|
-
export { Chips, DOOHBOT_API_CONFIG, DialogComponent, DialogService, Doohbot, DoohbotConst, DoohbotInput, DropdownMenu,
|
|
4945
|
+
export { Chips, DOOHBOT_API_CONFIG, DialogComponent, DialogService, Doohbot, DoohbotConst, DoohbotInput, DropdownMenu, MenuItem, SnackBar, provideDoohbot };
|
|
5048
4946
|
//# sourceMappingURL=aakash58-chatbot.mjs.map
|