@hivegpt/hiveai-angular 0.0.304 → 0.0.306
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 +24 -24
- package/bundles/hivegpt-hiveai-angular.umd.js +2653 -2648
- package/bundles/hivegpt-hiveai-angular.umd.js.map +1 -1
- package/bundles/hivegpt-hiveai-angular.umd.min.js +1 -1
- package/bundles/hivegpt-hiveai-angular.umd.min.js.map +1 -1
- package/environments/environment.d.ts +14 -14
- package/environments/environment.d.ts.map +1 -1
- package/esm2015/environments/environment.js +15 -15
- package/esm2015/hivegpt-hiveai-angular.js +12 -12
- package/esm2015/lib/components/NotificationSocket.js +39 -39
- package/esm2015/lib/components/bot-html-editor/bot-html-editor.component.js +112 -112
- package/esm2015/lib/components/bot.service.js +43 -43
- package/esm2015/lib/components/chat-drawer/chat-drawer.component.js +1628 -1623
- package/esm2015/lib/components/chatbot/chatbot.component.js +50 -50
- package/esm2015/lib/components/conversation.service.js +40 -40
- package/esm2015/lib/components/socket-service.service.js +72 -72
- package/esm2015/lib/components/video-player/video-player.component.js +123 -123
- package/esm2015/lib/hivegpt.module.js +21 -21
- package/esm2015/lib/models/video.js +2 -2
- package/esm2015/lib/pipes/safe-html.pipe.js +19 -19
- package/esm2015/lib/utils/utils.js +36 -36
- package/esm2015/public-api.js +7 -7
- package/fesm2015/hivegpt-hiveai-angular.js +2125 -2120
- package/fesm2015/hivegpt-hiveai-angular.js.map +1 -1
- package/hivegpt-hiveai-angular.d.ts +11 -11
- package/hivegpt-hiveai-angular.d.ts.map +1 -1
- package/hivegpt-hiveai-angular.metadata.json +1 -1
- package/lib/components/NotificationSocket.d.ts +4 -4
- package/lib/components/NotificationSocket.d.ts.map +1 -1
- package/lib/components/bot-html-editor/bot-html-editor.component.d.ts +35 -35
- package/lib/components/bot-html-editor/bot-html-editor.component.d.ts.map +1 -1
- package/lib/components/bot.service.d.ts +11 -11
- package/lib/components/bot.service.d.ts.map +1 -1
- package/lib/components/chat-drawer/chat-drawer.component.d.ts +244 -244
- package/lib/components/chat-drawer/chat-drawer.component.d.ts.map +1 -1
- package/lib/components/chatbot/chatbot.component.d.ts +35 -35
- package/lib/components/chatbot/chatbot.component.d.ts.map +1 -1
- package/lib/components/conversation.service.d.ts +10 -10
- package/lib/components/conversation.service.d.ts.map +1 -1
- package/lib/components/socket-service.service.d.ts +19 -19
- package/lib/components/socket-service.service.d.ts.map +1 -1
- package/lib/components/video-player/video-player.component.d.ts +35 -35
- package/lib/components/video-player/video-player.component.d.ts.map +1 -1
- package/lib/hivegpt.module.d.ts +2 -2
- package/lib/hivegpt.module.d.ts.map +1 -1
- package/lib/models/video.d.ts +34 -34
- package/lib/models/video.d.ts.map +1 -1
- package/lib/pipes/safe-html.pipe.d.ts +7 -7
- package/lib/pipes/safe-html.pipe.d.ts.map +1 -1
- package/lib/utils/utils.d.ts +2 -2
- package/lib/utils/utils.d.ts.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +3 -3
- package/public-api.d.ts.map +1 -1
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
export class ChatBotComponent {
|
|
3
|
-
constructor() {
|
|
4
|
-
this.visible = false;
|
|
5
|
-
}
|
|
6
|
-
toggle() {
|
|
7
|
-
this.visible = !this.visible;
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
ChatBotComponent.decorators = [
|
|
11
|
-
{ type: Component, args: [{
|
|
12
|
-
selector: 'hivegpt-chatbot',
|
|
13
|
-
template: "<button mat-icon-button class=\"chat-button\" color=\"primary\" (click)=\"toggle()\">\n <mat-icon>chat</mat-icon>\n</button>\n\n<ng-container *ngIf=\"visible\">\n <hivegpt-chat-drawer\n [apiKey]=\"apiKey\"\n [bgBubbleAi]=\"bgBubbleAi\"\n [bgBubbleUser]=\"bgBubbleUser\"\n [bgGradient]=\"bgGradient\"\n [botName]=\"botName\"\n [closeButtonbgColor]=\"closeButtonbgColor\"\n [closeButtonColor]=\"closeButtonColor\"\n [credentials]=\"credentials\"\n [dateTextColor]=\"dateTextColor\"\n [dateTimeColor]=\"dateTimeColor\"\n [eventId]=\"eventId\"\n [eventName]=\"eventName\"\n [formFieldBgColor]=\"formFieldBgColor\"\n [formFieldTextColor]=\"formFieldTextColor\"\n [fullView]=\"fullView\"\n [greeting]=\"greeting\"\n [gradientColors]=\"gradientColors\"\n [messageTextColorAi]=\"messageTextColorAi\"\n [messageTextColorUser]=\"messageTextColorUser\"\n [sendButtonColor]=\"sendButtonColor\"\n [sendButtonTextColor]=\"sendButtonTextColor\"\n [showClose]=\"showClose\"\n [thumbsDownMessages]=\"thumbsDownMessages\"\n [thumbsUpMessage]=\"thumbsUpMessage\"\n [unknownResponses]=\"unknownResponses\"\n [useOpenAi]=\"useOpenAi\"\n [userId]=\"userId\"\n [botId]=\"botId\"\n >\n </hivegpt-chat-drawer>\n</ng-container>\n",
|
|
14
|
-
styles: ["::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#e5ccbc}.spinner{align-items:center;display:flex;gap:2px;justify-content:center}.spinner>div{animation:bouncedelay 1.4s ease-in-out infinite;animation-fill-mode:both;background-color:#173330;border-radius:100%;display:inline-block;height:5px;width:5px}.spinner .bounce1{animation-delay:-.32s}.spinner .bounce2{animation-delay:-.16s}@keyframes bouncedelay{0%,80%,to{-webkit-transform:scale(0);transform:scale(0)}40%{-webkit-transform:scale(1);transform:scale(1)}}.chat-button{align-items:center;background:#17235b;border:#17235b;border-radius:50%;bottom:20px;color:#fff;display:inline-flex;font-size:24px;height:50px;justify-content:center;position:fixed;right:20px;width:50px}"]
|
|
15
|
-
},] }
|
|
16
|
-
];
|
|
17
|
-
ChatBotComponent.propDecorators = {
|
|
18
|
-
userId: [{ type: Input }],
|
|
19
|
-
apiKey: [{ type: Input }],
|
|
20
|
-
botName: [{ type: Input }],
|
|
21
|
-
botSkills: [{ type: Input }],
|
|
22
|
-
botId: [{ type: Input }],
|
|
23
|
-
closeButtonColor: [{ type: Input }],
|
|
24
|
-
gradientColors: [{ type: Input }],
|
|
25
|
-
greeting: [{ type: Input }],
|
|
26
|
-
sendButtonColor: [{ type: Input }],
|
|
27
|
-
useOpenAi: [{ type: Input }],
|
|
28
|
-
showClose: [{ type: Input }],
|
|
29
|
-
bgGradient: [{ type: Input }],
|
|
30
|
-
sendButtonTextColor: [{ type: Input }],
|
|
31
|
-
fullView: [{ type: Input }],
|
|
32
|
-
bgBubbleAi: [{ type: Input }],
|
|
33
|
-
bgBubbleUser: [{ type: Input }],
|
|
34
|
-
closeButtonbgColor: [{ type: Input }],
|
|
35
|
-
messageTextColorAi: [{ type: Input }],
|
|
36
|
-
messageTextColorUser: [{ type: Input }],
|
|
37
|
-
dateTimeColor: [{ type: Input }],
|
|
38
|
-
dateTextColor: [{ type: Input }],
|
|
39
|
-
formFieldBgColor: [{ type: Input }],
|
|
40
|
-
formFieldTextColor: [{ type: Input }],
|
|
41
|
-
thumbsUpMessage: [{ type: Input }],
|
|
42
|
-
thumbsDownMessages: [{ type: Input }],
|
|
43
|
-
timezone: [{ type: Input }],
|
|
44
|
-
eventName: [{ type: Input }],
|
|
45
|
-
credentials: [{ type: Input }],
|
|
46
|
-
unknownResponses: [{ type: Input }],
|
|
47
|
-
rules: [{ type: Input }],
|
|
48
|
-
eventId: [{ type: Input }]
|
|
49
|
-
};
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
export class ChatBotComponent {
|
|
3
|
+
constructor() {
|
|
4
|
+
this.visible = false;
|
|
5
|
+
}
|
|
6
|
+
toggle() {
|
|
7
|
+
this.visible = !this.visible;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
ChatBotComponent.decorators = [
|
|
11
|
+
{ type: Component, args: [{
|
|
12
|
+
selector: 'hivegpt-chatbot',
|
|
13
|
+
template: "<button mat-icon-button class=\"chat-button\" color=\"primary\" (click)=\"toggle()\">\r\n <mat-icon>chat</mat-icon>\r\n</button>\r\n\r\n<ng-container *ngIf=\"visible\">\r\n <hivegpt-chat-drawer\r\n [apiKey]=\"apiKey\"\r\n [bgBubbleAi]=\"bgBubbleAi\"\r\n [bgBubbleUser]=\"bgBubbleUser\"\r\n [bgGradient]=\"bgGradient\"\r\n [botName]=\"botName\"\r\n [closeButtonbgColor]=\"closeButtonbgColor\"\r\n [closeButtonColor]=\"closeButtonColor\"\r\n [credentials]=\"credentials\"\r\n [dateTextColor]=\"dateTextColor\"\r\n [dateTimeColor]=\"dateTimeColor\"\r\n [eventId]=\"eventId\"\r\n [eventName]=\"eventName\"\r\n [formFieldBgColor]=\"formFieldBgColor\"\r\n [formFieldTextColor]=\"formFieldTextColor\"\r\n [fullView]=\"fullView\"\r\n [greeting]=\"greeting\"\r\n [gradientColors]=\"gradientColors\"\r\n [messageTextColorAi]=\"messageTextColorAi\"\r\n [messageTextColorUser]=\"messageTextColorUser\"\r\n [sendButtonColor]=\"sendButtonColor\"\r\n [sendButtonTextColor]=\"sendButtonTextColor\"\r\n [showClose]=\"showClose\"\r\n [thumbsDownMessages]=\"thumbsDownMessages\"\r\n [thumbsUpMessage]=\"thumbsUpMessage\"\r\n [unknownResponses]=\"unknownResponses\"\r\n [useOpenAi]=\"useOpenAi\"\r\n [userId]=\"userId\"\r\n [botId]=\"botId\"\r\n >\r\n </hivegpt-chat-drawer>\r\n</ng-container>\r\n",
|
|
14
|
+
styles: ["::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#e5ccbc}.spinner{align-items:center;display:flex;gap:2px;justify-content:center}.spinner>div{animation:bouncedelay 1.4s ease-in-out infinite;animation-fill-mode:both;background-color:#173330;border-radius:100%;display:inline-block;height:5px;width:5px}.spinner .bounce1{animation-delay:-.32s}.spinner .bounce2{animation-delay:-.16s}@keyframes bouncedelay{0%,80%,to{-webkit-transform:scale(0);transform:scale(0)}40%{-webkit-transform:scale(1);transform:scale(1)}}.chat-button{align-items:center;background:#17235b;border:#17235b;border-radius:50%;bottom:20px;color:#fff;display:inline-flex;font-size:24px;height:50px;justify-content:center;position:fixed;right:20px;width:50px}"]
|
|
15
|
+
},] }
|
|
16
|
+
];
|
|
17
|
+
ChatBotComponent.propDecorators = {
|
|
18
|
+
userId: [{ type: Input }],
|
|
19
|
+
apiKey: [{ type: Input }],
|
|
20
|
+
botName: [{ type: Input }],
|
|
21
|
+
botSkills: [{ type: Input }],
|
|
22
|
+
botId: [{ type: Input }],
|
|
23
|
+
closeButtonColor: [{ type: Input }],
|
|
24
|
+
gradientColors: [{ type: Input }],
|
|
25
|
+
greeting: [{ type: Input }],
|
|
26
|
+
sendButtonColor: [{ type: Input }],
|
|
27
|
+
useOpenAi: [{ type: Input }],
|
|
28
|
+
showClose: [{ type: Input }],
|
|
29
|
+
bgGradient: [{ type: Input }],
|
|
30
|
+
sendButtonTextColor: [{ type: Input }],
|
|
31
|
+
fullView: [{ type: Input }],
|
|
32
|
+
bgBubbleAi: [{ type: Input }],
|
|
33
|
+
bgBubbleUser: [{ type: Input }],
|
|
34
|
+
closeButtonbgColor: [{ type: Input }],
|
|
35
|
+
messageTextColorAi: [{ type: Input }],
|
|
36
|
+
messageTextColorUser: [{ type: Input }],
|
|
37
|
+
dateTimeColor: [{ type: Input }],
|
|
38
|
+
dateTextColor: [{ type: Input }],
|
|
39
|
+
formFieldBgColor: [{ type: Input }],
|
|
40
|
+
formFieldTextColor: [{ type: Input }],
|
|
41
|
+
thumbsUpMessage: [{ type: Input }],
|
|
42
|
+
thumbsDownMessages: [{ type: Input }],
|
|
43
|
+
timezone: [{ type: Input }],
|
|
44
|
+
eventName: [{ type: Input }],
|
|
45
|
+
credentials: [{ type: Input }],
|
|
46
|
+
unknownResponses: [{ type: Input }],
|
|
47
|
+
rules: [{ type: Input }],
|
|
48
|
+
eventId: [{ type: Input }]
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdGJvdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiRDovaGl2ZUdQVC1BSS1wYWNrYWdlcy9IaXZlQUktUGFja2FnZXMvcHJvamVjdHMvaGl2ZWdwdC9ldmVudHNncHQtYW5ndWxhci9zcmMvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jaGF0Ym90L2NoYXRib3QuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBTWpELE1BQU0sT0FBTyxnQkFBZ0I7SUFMN0I7UUFxQ0UsWUFBTyxHQUFHLEtBQUssQ0FBQztJQUtsQixDQUFDO0lBSEMsTUFBTTtRQUNKLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQy9CLENBQUM7OztZQXpDRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtnQkFDM0IseXlDQUF1Qzs7YUFFeEM7OztxQkFFRSxLQUFLO3FCQUNMLEtBQUs7c0JBQ0wsS0FBSzt3QkFDTCxLQUFLO29CQUNMLEtBQUs7K0JBQ0wsS0FBSzs2QkFDTCxLQUFLO3VCQUNMLEtBQUs7OEJBQ0wsS0FBSzt3QkFDTCxLQUFLO3dCQUNMLEtBQUs7eUJBQ0wsS0FBSztrQ0FDTCxLQUFLO3VCQUNMLEtBQUs7eUJBQ0wsS0FBSzsyQkFDTCxLQUFLO2lDQUNMLEtBQUs7aUNBQ0wsS0FBSzttQ0FDTCxLQUFLOzRCQUNMLEtBQUs7NEJBQ0wsS0FBSzsrQkFDTCxLQUFLO2lDQUNMLEtBQUs7OEJBQ0wsS0FBSztpQ0FDTCxLQUFLO3VCQUNMLEtBQUs7d0JBQ0wsS0FBSzswQkFDTCxLQUFLOytCQUNMLEtBQUs7b0JBQ0wsS0FBSztzQkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2hpdmVncHQtY2hhdGJvdCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NoYXRib3QuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NoYXRib3QuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENoYXRCb3RDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHVzZXJJZCE6IHN0cmluZztcclxuICBASW5wdXQoKSBhcGlLZXkhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgYm90TmFtZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBib3RTa2lsbHMhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgYm90SWQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgY2xvc2VCdXR0b25Db2xvciE6IHN0cmluZztcclxuICBASW5wdXQoKSBncmFkaWVudENvbG9ycyE6IHN0cmluZ1tdO1xyXG4gIEBJbnB1dCgpIGdyZWV0aW5nITogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIHNlbmRCdXR0b25Db2xvciE6IHN0cmluZztcclxuICBASW5wdXQoKSB1c2VPcGVuQWkhOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIHNob3dDbG9zZSE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgYmdHcmFkaWVudCE6IHN0cmluZ1tdO1xyXG4gIEBJbnB1dCgpIHNlbmRCdXR0b25UZXh0Q29sb3IhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgZnVsbFZpZXchOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIGJnQnViYmxlQWkhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgYmdCdWJibGVVc2VyITogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGNsb3NlQnV0dG9uYmdDb2xvciE6IHN0cmluZztcclxuICBASW5wdXQoKSBtZXNzYWdlVGV4dENvbG9yQWkhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbWVzc2FnZVRleHRDb2xvclVzZXIhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgZGF0ZVRpbWVDb2xvciE6IHN0cmluZztcclxuICBASW5wdXQoKSBkYXRlVGV4dENvbG9yITogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGZvcm1GaWVsZEJnQ29sb3IhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgZm9ybUZpZWxkVGV4dENvbG9yITogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIHRodW1ic1VwTWVzc2FnZSE6IHN0cmluZztcclxuICBASW5wdXQoKSB0aHVtYnNEb3duTWVzc2FnZXMhOiBzdHJpbmdbXTtcclxuICBASW5wdXQoKSB0aW1lem9uZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBldmVudE5hbWUhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgY3JlZGVudGlhbHMhOiBbXTtcclxuICBASW5wdXQoKSB1bmtub3duUmVzcG9uc2VzITogW107XHJcbiAgQElucHV0KCkgcnVsZXMhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgZXZlbnRJZCE6IHN0cmluZztcclxuICB2aXNpYmxlID0gZmFsc2U7XHJcblxyXG4gIHRvZ2dsZSgpIHtcclxuICAgIHRoaXMudmlzaWJsZSA9ICF0aGlzLnZpc2libGU7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class ConversationService {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.storageKey = 'conversationKey';
|
|
7
|
-
this.userSepecificNotification = new Subject();
|
|
8
|
-
}
|
|
9
|
-
generateKey() {
|
|
10
|
-
const timestamp = Math.floor(new Date().getTime() / 1000).toString(16);
|
|
11
|
-
const randomHex = 'xxxxxxxxxxxxxxxx'.replace(/[x]/g, () => {
|
|
12
|
-
return Math.floor(Math.random() * 16).toString(16);
|
|
13
|
-
});
|
|
14
|
-
return timestamp + randomHex;
|
|
15
|
-
}
|
|
16
|
-
getKey(botId, resetKey = false) {
|
|
17
|
-
const storageKey = `conversationKey_${botId}`;
|
|
18
|
-
var value = localStorage.getItem(storageKey);
|
|
19
|
-
if (!value || resetKey) {
|
|
20
|
-
value = this.generateKey();
|
|
21
|
-
localStorage.setItem(storageKey, value);
|
|
22
|
-
}
|
|
23
|
-
return value;
|
|
24
|
-
}
|
|
25
|
-
sendValidatedUserData(message) {
|
|
26
|
-
//console.log('lgging messages', message, new Date());\
|
|
27
|
-
this.userSepecificNotification.next(message);
|
|
28
|
-
}
|
|
29
|
-
getUserSpecificNotification() {
|
|
30
|
-
return this.userSepecificNotification.asObservable();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
ConversationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ConversationService_Factory() { return new ConversationService(); }, token: ConversationService, providedIn: "root" });
|
|
34
|
-
ConversationService.decorators = [
|
|
35
|
-
{ type: Injectable, args: [{
|
|
36
|
-
providedIn: 'root',
|
|
37
|
-
},] }
|
|
38
|
-
];
|
|
39
|
-
ConversationService.ctorParameters = () => [];
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ConversationService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.storageKey = 'conversationKey';
|
|
7
|
+
this.userSepecificNotification = new Subject();
|
|
8
|
+
}
|
|
9
|
+
generateKey() {
|
|
10
|
+
const timestamp = Math.floor(new Date().getTime() / 1000).toString(16);
|
|
11
|
+
const randomHex = 'xxxxxxxxxxxxxxxx'.replace(/[x]/g, () => {
|
|
12
|
+
return Math.floor(Math.random() * 16).toString(16);
|
|
13
|
+
});
|
|
14
|
+
return timestamp + randomHex;
|
|
15
|
+
}
|
|
16
|
+
getKey(botId, resetKey = false) {
|
|
17
|
+
const storageKey = `conversationKey_${botId}`;
|
|
18
|
+
var value = localStorage.getItem(storageKey);
|
|
19
|
+
if (!value || resetKey) {
|
|
20
|
+
value = this.generateKey();
|
|
21
|
+
localStorage.setItem(storageKey, value);
|
|
22
|
+
}
|
|
23
|
+
return value;
|
|
24
|
+
}
|
|
25
|
+
sendValidatedUserData(message) {
|
|
26
|
+
//console.log('lgging messages', message, new Date());\
|
|
27
|
+
this.userSepecificNotification.next(message);
|
|
28
|
+
}
|
|
29
|
+
getUserSpecificNotification() {
|
|
30
|
+
return this.userSepecificNotification.asObservable();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ConversationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ConversationService_Factory() { return new ConversationService(); }, token: ConversationService, providedIn: "root" });
|
|
34
|
+
ConversationService.decorators = [
|
|
35
|
+
{ type: Injectable, args: [{
|
|
36
|
+
providedIn: 'root',
|
|
37
|
+
},] }
|
|
38
|
+
];
|
|
39
|
+
ConversationService.ctorParameters = () => [];
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVyc2F0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiRDovaGl2ZUdQVC1BSS1wYWNrYWdlcy9IaXZlQUktUGFja2FnZXMvcHJvamVjdHMvaGl2ZWdwdC9ldmVudHNncHQtYW5ndWxhci9zcmMvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9jb252ZXJzYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFHOUI7UUFGUSxlQUFVLEdBQUcsaUJBQWlCLENBQUM7UUF1Qi9CLDhCQUF5QixHQUFpQixJQUFJLE9BQU8sRUFBTyxDQUFDO0lBckJyRCxDQUFDO0lBQ2pCLFdBQVc7UUFDVCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLE1BQU0sU0FBUyxHQUFHLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFO1lBQ3hELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3JELENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBYSxFQUFFLFdBQW9CLEtBQUs7UUFDN0MsTUFBTSxVQUFVLEdBQUcsbUJBQW1CLEtBQUssRUFBRSxDQUFDO1FBQzlDLElBQUksS0FBSyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFN0MsSUFBSSxDQUFDLEtBQUssSUFBSSxRQUFRLEVBQUU7WUFDdEIsS0FBSyxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUMzQixZQUFZLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztTQUN6QztRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUdELHFCQUFxQixDQUFDLE9BQVk7UUFDaEMsdURBQXVEO1FBRXZELElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUNELDJCQUEyQjtRQUN6QixPQUFPLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN2RCxDQUFDOzs7O1lBbkNGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvbnZlcnNhdGlvblNlcnZpY2Uge1xyXG4gIHByaXZhdGUgc3RvcmFnZUtleSA9ICdjb252ZXJzYXRpb25LZXknO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG4gIGdlbmVyYXRlS2V5KCk6IHN0cmluZyB7XHJcbiAgICBjb25zdCB0aW1lc3RhbXAgPSBNYXRoLmZsb29yKG5ldyBEYXRlKCkuZ2V0VGltZSgpIC8gMTAwMCkudG9TdHJpbmcoMTYpO1xyXG4gICAgY29uc3QgcmFuZG9tSGV4ID0gJ3h4eHh4eHh4eHh4eHh4eHgnLnJlcGxhY2UoL1t4XS9nLCAoKSA9PiB7XHJcbiAgICAgIHJldHVybiBNYXRoLmZsb29yKE1hdGgucmFuZG9tKCkgKiAxNikudG9TdHJpbmcoMTYpO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gdGltZXN0YW1wICsgcmFuZG9tSGV4O1xyXG4gIH1cclxuXHJcbiAgZ2V0S2V5KGJvdElkOiBzdHJpbmcsIHJlc2V0S2V5OiBib29sZWFuID0gZmFsc2UpOiBzdHJpbmcge1xyXG4gICAgY29uc3Qgc3RvcmFnZUtleSA9IGBjb252ZXJzYXRpb25LZXlfJHtib3RJZH1gO1xyXG4gICAgdmFyIHZhbHVlID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oc3RvcmFnZUtleSk7XHJcblxyXG4gICAgaWYgKCF2YWx1ZSB8fCByZXNldEtleSkge1xyXG4gICAgICB2YWx1ZSA9IHRoaXMuZ2VuZXJhdGVLZXkoKTtcclxuICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oc3RvcmFnZUtleSwgdmFsdWUpO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgdXNlclNlcGVjaWZpY05vdGlmaWNhdGlvbjogU3ViamVjdDxhbnk+ID0gbmV3IFN1YmplY3Q8YW55PigpO1xyXG4gIHNlbmRWYWxpZGF0ZWRVc2VyRGF0YShtZXNzYWdlOiBhbnkpIHtcclxuICAgIC8vY29uc29sZS5sb2coJ2xnZ2luZyBtZXNzYWdlcycsIG1lc3NhZ2UsIG5ldyBEYXRlKCkpO1xcXHJcblxyXG4gICAgdGhpcy51c2VyU2VwZWNpZmljTm90aWZpY2F0aW9uLm5leHQobWVzc2FnZSk7XHJcbiAgfVxyXG4gIGdldFVzZXJTcGVjaWZpY05vdGlmaWNhdGlvbigpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgcmV0dXJuIHRoaXMudXNlclNlcGVjaWZpY05vdGlmaWNhdGlvbi5hc09ic2VydmFibGUoKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,72 +1,72 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { ConversationService } from './conversation.service';
|
|
3
|
-
import { NotificationSocket } from './NotificationSocket';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "./conversation.service";
|
|
6
|
-
import * as i2 from "./NotificationSocket";
|
|
7
|
-
export class SocketService {
|
|
8
|
-
constructor(conversationService, notificationSocket) {
|
|
9
|
-
this.conversationService = conversationService;
|
|
10
|
-
this.notificationSocket = notificationSocket;
|
|
11
|
-
this.isCommonSocketInitialized = false;
|
|
12
|
-
this.isUserSpecificSocketInitialized = false;
|
|
13
|
-
this.isUserSpecificEventReleased = true;
|
|
14
|
-
this.messageQueue = [];
|
|
15
|
-
this.releaseInterval = 1000;
|
|
16
|
-
this.intervalSetup = false;
|
|
17
|
-
this.startReleasingMessages();
|
|
18
|
-
}
|
|
19
|
-
isSocketInitialized(isCommon) {
|
|
20
|
-
return isCommon
|
|
21
|
-
? this.isCommonSocketInitialized
|
|
22
|
-
: this.isUserSpecificSocketInitialized &&
|
|
23
|
-
!this.isUserSpecificEventReleased;
|
|
24
|
-
}
|
|
25
|
-
disconnectSocketConnection() {
|
|
26
|
-
this.notificationSocket.disconnect();
|
|
27
|
-
}
|
|
28
|
-
connectSocketConnection() {
|
|
29
|
-
this.notificationSocket.connect();
|
|
30
|
-
}
|
|
31
|
-
registerUserSpecificHiveSocket(botId, conversation_id, org_id) {
|
|
32
|
-
const commonNotification = 'commonNotification';
|
|
33
|
-
const groupId = `Hive_AI_Notifs_${botId}_${conversation_id}`;
|
|
34
|
-
const groupId_org = `Hive_AI_Notifs_${org_id}`;
|
|
35
|
-
// Remove any pre-existing listeners for commonNotification
|
|
36
|
-
// this.notificationSocket.removeAllListeners(commonNotification);
|
|
37
|
-
// Join the group again with updated botId and conversation_id
|
|
38
|
-
this.notificationSocket.emit('joinData', { groupId });
|
|
39
|
-
this.notificationSocket.emit('joinData', { groupId: groupId_org });
|
|
40
|
-
// Re-register for common notifications
|
|
41
|
-
this.notificationSocket.fromEvent(commonNotification).subscribe((res) => {
|
|
42
|
-
console.log('Received commonNotification:', res);
|
|
43
|
-
this.conversationService.sendValidatedUserData(res);
|
|
44
|
-
}, (error) => {
|
|
45
|
-
console.error('Error receiving commonNotification:', error);
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
startReleasingMessages() {
|
|
49
|
-
if (!this.intervalSetup) {
|
|
50
|
-
setInterval(() => {
|
|
51
|
-
if (this.messageQueue.length > 0) {
|
|
52
|
-
const message = this.messageQueue.shift(); // Remove the first message from the queue
|
|
53
|
-
// Handle the message here, e.g., send it to the server or process it
|
|
54
|
-
console.log('Releasing message from queue:', message);
|
|
55
|
-
// this.campaignService.sendValidatedUserData(message);
|
|
56
|
-
}
|
|
57
|
-
}, this.releaseInterval);
|
|
58
|
-
this.intervalSetup = true; // Prevents multiple intervals
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
SocketService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SocketService_Factory() { return new SocketService(i0.ɵɵinject(i1.ConversationService), i0.ɵɵinject(i2.NotificationSocket)); }, token: SocketService, providedIn: "root" });
|
|
63
|
-
SocketService.decorators = [
|
|
64
|
-
{ type: Injectable, args: [{
|
|
65
|
-
providedIn: 'root',
|
|
66
|
-
},] }
|
|
67
|
-
];
|
|
68
|
-
SocketService.ctorParameters = () => [
|
|
69
|
-
{ type: ConversationService },
|
|
70
|
-
{ type: NotificationSocket }
|
|
71
|
-
];
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { ConversationService } from './conversation.service';
|
|
3
|
+
import { NotificationSocket } from './NotificationSocket';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./conversation.service";
|
|
6
|
+
import * as i2 from "./NotificationSocket";
|
|
7
|
+
export class SocketService {
|
|
8
|
+
constructor(conversationService, notificationSocket) {
|
|
9
|
+
this.conversationService = conversationService;
|
|
10
|
+
this.notificationSocket = notificationSocket;
|
|
11
|
+
this.isCommonSocketInitialized = false;
|
|
12
|
+
this.isUserSpecificSocketInitialized = false;
|
|
13
|
+
this.isUserSpecificEventReleased = true;
|
|
14
|
+
this.messageQueue = [];
|
|
15
|
+
this.releaseInterval = 1000;
|
|
16
|
+
this.intervalSetup = false;
|
|
17
|
+
this.startReleasingMessages();
|
|
18
|
+
}
|
|
19
|
+
isSocketInitialized(isCommon) {
|
|
20
|
+
return isCommon
|
|
21
|
+
? this.isCommonSocketInitialized
|
|
22
|
+
: this.isUserSpecificSocketInitialized &&
|
|
23
|
+
!this.isUserSpecificEventReleased;
|
|
24
|
+
}
|
|
25
|
+
disconnectSocketConnection() {
|
|
26
|
+
this.notificationSocket.disconnect();
|
|
27
|
+
}
|
|
28
|
+
connectSocketConnection() {
|
|
29
|
+
this.notificationSocket.connect();
|
|
30
|
+
}
|
|
31
|
+
registerUserSpecificHiveSocket(botId, conversation_id, org_id) {
|
|
32
|
+
const commonNotification = 'commonNotification';
|
|
33
|
+
const groupId = `Hive_AI_Notifs_${botId}_${conversation_id}`;
|
|
34
|
+
const groupId_org = `Hive_AI_Notifs_${org_id}`;
|
|
35
|
+
// Remove any pre-existing listeners for commonNotification
|
|
36
|
+
// this.notificationSocket.removeAllListeners(commonNotification);
|
|
37
|
+
// Join the group again with updated botId and conversation_id
|
|
38
|
+
this.notificationSocket.emit('joinData', { groupId });
|
|
39
|
+
this.notificationSocket.emit('joinData', { groupId: groupId_org });
|
|
40
|
+
// Re-register for common notifications
|
|
41
|
+
this.notificationSocket.fromEvent(commonNotification).subscribe((res) => {
|
|
42
|
+
console.log('Received commonNotification:', res);
|
|
43
|
+
this.conversationService.sendValidatedUserData(res);
|
|
44
|
+
}, (error) => {
|
|
45
|
+
console.error('Error receiving commonNotification:', error);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
startReleasingMessages() {
|
|
49
|
+
if (!this.intervalSetup) {
|
|
50
|
+
setInterval(() => {
|
|
51
|
+
if (this.messageQueue.length > 0) {
|
|
52
|
+
const message = this.messageQueue.shift(); // Remove the first message from the queue
|
|
53
|
+
// Handle the message here, e.g., send it to the server or process it
|
|
54
|
+
console.log('Releasing message from queue:', message);
|
|
55
|
+
// this.campaignService.sendValidatedUserData(message);
|
|
56
|
+
}
|
|
57
|
+
}, this.releaseInterval);
|
|
58
|
+
this.intervalSetup = true; // Prevents multiple intervals
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
SocketService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SocketService_Factory() { return new SocketService(i0.ɵɵinject(i1.ConversationService), i0.ɵɵinject(i2.NotificationSocket)); }, token: SocketService, providedIn: "root" });
|
|
63
|
+
SocketService.decorators = [
|
|
64
|
+
{ type: Injectable, args: [{
|
|
65
|
+
providedIn: 'root',
|
|
66
|
+
},] }
|
|
67
|
+
];
|
|
68
|
+
SocketService.ctorParameters = () => [
|
|
69
|
+
{ type: ConversationService },
|
|
70
|
+
{ type: NotificationSocket }
|
|
71
|
+
];
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ja2V0LXNlcnZpY2Uuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJEOi9oaXZlR1BULUFJLXBhY2thZ2VzL0hpdmVBSS1QYWNrYWdlcy9wcm9qZWN0cy9oaXZlZ3B0L2V2ZW50c2dwdC1hbmd1bGFyL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3NvY2tldC1zZXJ2aWNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUkzQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7OztBQUsxRCxNQUFNLE9BQU8sYUFBYTtJQVN4QixZQUNVLG1CQUF3QyxFQUN4QyxrQkFBc0M7UUFEdEMsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtRQUN4Qyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBVHhDLDhCQUF5QixHQUFHLEtBQUssQ0FBQztRQUNsQyxvQ0FBK0IsR0FBRyxLQUFLLENBQUM7UUFDeEMsZ0NBQTJCLEdBQUcsSUFBSSxDQUFDO1FBQ25DLGlCQUFZLEdBQVUsRUFBRSxDQUFDO1FBQ3pCLG9CQUFlLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLGtCQUFhLEdBQVksS0FBSyxDQUFDO1FBTXJDLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxRQUFpQjtRQUNuQyxPQUFPLFFBQVE7WUFDYixDQUFDLENBQUMsSUFBSSxDQUFDLHlCQUF5QjtZQUNoQyxDQUFDLENBQUMsSUFBSSxDQUFDLCtCQUErQjtnQkFDdEMsQ0FBQyxJQUFJLENBQUMsMkJBQTJCLENBQUM7SUFDdEMsQ0FBQztJQUVELDBCQUEwQjtRQUN4QixJQUFJLENBQUMsa0JBQWtCLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUNELHVCQUF1QjtRQUNyQixJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUNELDhCQUE4QixDQUFDLEtBQWEsRUFBRSxlQUF1QixFQUFFLE1BQWM7UUFDbkYsTUFBTSxrQkFBa0IsR0FBRyxvQkFBb0IsQ0FBQztRQUNoRCxNQUFNLE9BQU8sR0FBRyxrQkFBa0IsS0FBSyxJQUFJLGVBQWUsRUFBRSxDQUFDO1FBQzdELE1BQU0sV0FBVyxHQUFHLGtCQUFrQixNQUFNLEVBQUUsQ0FBQztRQUUvQywyREFBMkQ7UUFDM0Qsa0VBQWtFO1FBRWxFLDhEQUE4RDtRQUM5RCxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUVuRSx1Q0FBdUM7UUFDdkMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLFNBQVMsQ0FDN0QsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNOLE9BQU8sQ0FBQyxHQUFHLENBQUMsOEJBQThCLEVBQUUsR0FBRyxDQUFDLENBQUM7WUFDakQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RELENBQUMsRUFDRCxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ1IsT0FBTyxDQUFDLEtBQUssQ0FBQyxxQ0FBcUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUM5RCxDQUFDLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTyxzQkFBc0I7UUFDNUIsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDdkIsV0FBVyxDQUFDLEdBQUcsRUFBRTtnQkFDZixJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtvQkFDaEMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLDBDQUEwQztvQkFDckYscUVBQXFFO29CQUNyRSxPQUFPLENBQUMsR0FBRyxDQUFDLCtCQUErQixFQUFFLE9BQU8sQ0FBQyxDQUFDO29CQUN0RCx1REFBdUQ7aUJBQ3hEO1lBQ0gsQ0FBQyxFQUFFLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztZQUN6QixJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxDQUFDLDhCQUE4QjtTQUMxRDtJQUNILENBQUM7Ozs7WUFwRUYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUFMUSxtQkFBbUI7WUFDbkIsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyB3ZWJTb2NrZXQsIFdlYlNvY2tldFN1YmplY3QgfSBmcm9tICdyeGpzL3dlYlNvY2tldCc7XHJcbmltcG9ydCB7IENvbnZlcnNhdGlvblNlcnZpY2UgfSBmcm9tICcuL2NvbnZlcnNhdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTm90aWZpY2F0aW9uU29ja2V0IH0gZnJvbSAnLi9Ob3RpZmljYXRpb25Tb2NrZXQnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNvY2tldFNlcnZpY2Uge1xyXG4gIHB1YmxpYyB0ZXN0TWVzc2FnZTogc3RyaW5nO1xyXG4gIHByaXZhdGUgaXNDb21tb25Tb2NrZXRJbml0aWFsaXplZCA9IGZhbHNlO1xyXG4gIHByaXZhdGUgaXNVc2VyU3BlY2lmaWNTb2NrZXRJbml0aWFsaXplZCA9IGZhbHNlO1xyXG4gIHByaXZhdGUgaXNVc2VyU3BlY2lmaWNFdmVudFJlbGVhc2VkID0gdHJ1ZTtcclxuICBwcml2YXRlIG1lc3NhZ2VRdWV1ZTogYW55W10gPSBbXTtcclxuICBwcml2YXRlIHJlbGVhc2VJbnRlcnZhbCA9IDEwMDA7XHJcbiAgcHJpdmF0ZSBpbnRlcnZhbFNldHVwOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBjb252ZXJzYXRpb25TZXJ2aWNlOiBDb252ZXJzYXRpb25TZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBub3RpZmljYXRpb25Tb2NrZXQ6IE5vdGlmaWNhdGlvblNvY2tldFxyXG4gICkge1xyXG4gICAgdGhpcy5zdGFydFJlbGVhc2luZ01lc3NhZ2VzKCk7XHJcbiAgfVxyXG5cclxuICBpc1NvY2tldEluaXRpYWxpemVkKGlzQ29tbW9uOiBib29sZWFuKSB7XHJcbiAgICByZXR1cm4gaXNDb21tb25cclxuICAgICAgPyB0aGlzLmlzQ29tbW9uU29ja2V0SW5pdGlhbGl6ZWRcclxuICAgICAgOiB0aGlzLmlzVXNlclNwZWNpZmljU29ja2V0SW5pdGlhbGl6ZWQgJiZcclxuICAgICAgIXRoaXMuaXNVc2VyU3BlY2lmaWNFdmVudFJlbGVhc2VkO1xyXG4gIH1cclxuXHJcbiAgZGlzY29ubmVjdFNvY2tldENvbm5lY3Rpb24oKSB7XHJcbiAgICB0aGlzLm5vdGlmaWNhdGlvblNvY2tldC5kaXNjb25uZWN0KCk7XHJcbiAgfVxyXG4gIGNvbm5lY3RTb2NrZXRDb25uZWN0aW9uKCkge1xyXG4gICAgdGhpcy5ub3RpZmljYXRpb25Tb2NrZXQuY29ubmVjdCgpO1xyXG4gIH1cclxuICByZWdpc3RlclVzZXJTcGVjaWZpY0hpdmVTb2NrZXQoYm90SWQ6IHN0cmluZywgY29udmVyc2F0aW9uX2lkOiBzdHJpbmcsIG9yZ19pZDogc3RyaW5nKSB7XHJcbiAgICBjb25zdCBjb21tb25Ob3RpZmljYXRpb24gPSAnY29tbW9uTm90aWZpY2F0aW9uJztcclxuICAgIGNvbnN0IGdyb3VwSWQgPSBgSGl2ZV9BSV9Ob3RpZnNfJHtib3RJZH1fJHtjb252ZXJzYXRpb25faWR9YDtcclxuICAgIGNvbnN0IGdyb3VwSWRfb3JnID0gYEhpdmVfQUlfTm90aWZzXyR7b3JnX2lkfWA7XHJcblxyXG4gICAgLy8gUmVtb3ZlIGFueSBwcmUtZXhpc3RpbmcgbGlzdGVuZXJzIGZvciBjb21tb25Ob3RpZmljYXRpb25cclxuICAgIC8vIHRoaXMubm90aWZpY2F0aW9uU29ja2V0LnJlbW92ZUFsbExpc3RlbmVycyhjb21tb25Ob3RpZmljYXRpb24pO1xyXG5cclxuICAgIC8vIEpvaW4gdGhlIGdyb3VwIGFnYWluIHdpdGggdXBkYXRlZCBib3RJZCBhbmQgY29udmVyc2F0aW9uX2lkXHJcbiAgICB0aGlzLm5vdGlmaWNhdGlvblNvY2tldC5lbWl0KCdqb2luRGF0YScsIHsgZ3JvdXBJZCB9KTtcclxuICAgIHRoaXMubm90aWZpY2F0aW9uU29ja2V0LmVtaXQoJ2pvaW5EYXRhJywgeyBncm91cElkOiBncm91cElkX29yZyB9KTtcclxuXHJcbiAgICAvLyBSZS1yZWdpc3RlciBmb3IgY29tbW9uIG5vdGlmaWNhdGlvbnNcclxuICAgIHRoaXMubm90aWZpY2F0aW9uU29ja2V0LmZyb21FdmVudChjb21tb25Ob3RpZmljYXRpb24pLnN1YnNjcmliZShcclxuICAgICAgKHJlcykgPT4ge1xyXG4gICAgICAgIGNvbnNvbGUubG9nKCdSZWNlaXZlZCBjb21tb25Ob3RpZmljYXRpb246JywgcmVzKTtcclxuICAgICAgICB0aGlzLmNvbnZlcnNhdGlvblNlcnZpY2Uuc2VuZFZhbGlkYXRlZFVzZXJEYXRhKHJlcyk7XHJcbiAgICAgIH0sXHJcbiAgICAgIChlcnJvcikgPT4ge1xyXG4gICAgICAgIGNvbnNvbGUuZXJyb3IoJ0Vycm9yIHJlY2VpdmluZyBjb21tb25Ob3RpZmljYXRpb246JywgZXJyb3IpO1xyXG4gICAgICB9XHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzdGFydFJlbGVhc2luZ01lc3NhZ2VzKCkge1xyXG4gICAgaWYgKCF0aGlzLmludGVydmFsU2V0dXApIHtcclxuICAgICAgc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICAgIGlmICh0aGlzLm1lc3NhZ2VRdWV1ZS5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICBjb25zdCBtZXNzYWdlID0gdGhpcy5tZXNzYWdlUXVldWUuc2hpZnQoKTsgLy8gUmVtb3ZlIHRoZSBmaXJzdCBtZXNzYWdlIGZyb20gdGhlIHF1ZXVlXHJcbiAgICAgICAgICAvLyBIYW5kbGUgdGhlIG1lc3NhZ2UgaGVyZSwgZS5nLiwgc2VuZCBpdCB0byB0aGUgc2VydmVyIG9yIHByb2Nlc3MgaXRcclxuICAgICAgICAgIGNvbnNvbGUubG9nKCdSZWxlYXNpbmcgbWVzc2FnZSBmcm9tIHF1ZXVlOicsIG1lc3NhZ2UpO1xyXG4gICAgICAgICAgLy8gdGhpcy5jYW1wYWlnblNlcnZpY2Uuc2VuZFZhbGlkYXRlZFVzZXJEYXRhKG1lc3NhZ2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgfSwgdGhpcy5yZWxlYXNlSW50ZXJ2YWwpO1xyXG4gICAgICB0aGlzLmludGVydmFsU2V0dXAgPSB0cnVlOyAvLyBQcmV2ZW50cyBtdWx0aXBsZSBpbnRlcnZhbHNcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
|