@sinequa/assistant 3.8.0 → 3.9.0
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/chat/charts/chart/chart.component.d.ts +13 -13
- package/chat/chat-message/chat-message.component.d.ts +85 -81
- package/chat/chat-message/i18n/en.json +11 -0
- package/chat/chat-message/i18n/fr.json +11 -0
- package/chat/chat-reference/chat-reference.component.d.ts +14 -14
- package/chat/chat-reference/i18n/en.json +4 -0
- package/chat/chat-reference/i18n/fr.json +4 -0
- package/chat/chat-settings-v3/chat-settings-v3.component.d.ts +48 -50
- package/chat/chat-settings-v3/i18n/en.json +14 -0
- package/chat/chat-settings-v3/i18n/fr.json +14 -0
- package/chat/chat.component.d.ts +388 -1405
- package/chat/chat.service.d.ts +247 -228
- package/chat/debug-message/debug-message.component.d.ts +17 -17
- package/chat/debug-message/i18n/en.json +3 -0
- package/chat/debug-message/i18n/fr.json +3 -0
- package/chat/dialogs/delete-saved-chat.component.d.ts +22 -0
- package/chat/dialogs/i18n/en.json +19 -0
- package/chat/dialogs/i18n/fr.json +19 -0
- package/chat/dialogs/rename-saved-chat.component.d.ts +21 -0
- package/chat/dialogs/updates.component.d.ts +15 -0
- package/chat/documents-upload/document-list/document-list.component.d.ts +68 -77
- package/chat/documents-upload/document-overview/document-overview.component.d.ts +31 -41
- package/chat/documents-upload/document-upload/document-upload.component.d.ts +96 -98
- package/chat/documents-upload/documents-upload.model.d.ts +66 -66
- package/chat/documents-upload/documents-upload.service.d.ts +170 -174
- package/chat/documents-upload/i18n/en.json +24 -0
- package/chat/documents-upload/i18n/fr.json +24 -0
- package/chat/format-icon/format-icon.component.d.ts +10 -10
- package/chat/format-icon/icons.d.ts +5 -5
- package/chat/i18n/en.json +42 -0
- package/chat/i18n/fr.json +42 -0
- package/chat/index.d.ts +5 -5
- package/chat/initials-avatar/initials-avatar.component.d.ts +35 -35
- package/chat/instance-manager.service.d.ts +28 -28
- package/chat/pipes/message-content.pipe.d.ts +16 -0
- package/chat/prompt.component.d.ts +25 -21
- package/chat/public-api.d.ts +17 -17
- package/chat/references/i18n/en.json +6 -0
- package/chat/references/i18n/fr.json +6 -0
- package/chat/references/inline-image-reference.d.ts +21 -0
- package/chat/references/inline-page-reference.d.ts +21 -0
- package/chat/rest-chat.service.d.ts +31 -33
- package/chat/saved-chats/i18n/en.json +4 -0
- package/chat/saved-chats/i18n/fr.json +4 -0
- package/chat/saved-chats/saved-chats.component.d.ts +30 -36
- package/chat/services/app.service.d.ts +8 -0
- package/chat/services/dialog.service.d.ts +12 -0
- package/chat/services/notification.service.d.ts +10 -0
- package/chat/services/principal.service.d.ts +7 -0
- package/chat/services/search.service.d.ts +7 -0
- package/chat/services/signalR.web.service.d.ts +45 -0
- package/chat/services/ui.service.d.ts +13 -0
- package/chat/services/user-settings.service.d.ts +7 -0
- package/chat/token-progress-bar/i18n/en.json +4 -0
- package/chat/token-progress-bar/i18n/fr.json +4 -0
- package/chat/token-progress-bar/token-progress-bar.component.d.ts +24 -27
- package/chat/tooltip/tooltip.component.d.ts +12 -0
- package/chat/tooltip/tooltip.directive.d.ts +81 -0
- package/chat/types/message-content.types.d.ts +54 -0
- package/chat/types/message-reference.types.d.ts +11 -0
- package/chat/types.d.ts +913 -873
- package/chat/unified-plugins/embedded-image-reference.plugin.d.ts +3 -0
- package/chat/unified-plugins/embedded-page-reference.plugin.d.ts +3 -0
- package/chat/utils/assistant-json.d.ts +2 -0
- package/chat/websocket-chat.service.d.ts +102 -103
- package/esm2022/chat/charts/chart/chart.component.mjs +40 -0
- package/esm2022/chat/chat-message/chat-message.component.mjs +351 -0
- package/esm2022/chat/chat-reference/chat-reference.component.mjs +40 -0
- package/esm2022/chat/chat-settings-v3/chat-settings-v3.component.mjs +118 -0
- package/esm2022/chat/chat.component.mjs +1090 -0
- package/esm2022/chat/chat.service.mjs +417 -0
- package/esm2022/chat/debug-message/debug-message.component.mjs +43 -0
- package/esm2022/chat/dialogs/delete-saved-chat.component.mjs +81 -0
- package/esm2022/chat/dialogs/rename-saved-chat.component.mjs +84 -0
- package/esm2022/chat/dialogs/updates.component.mjs +61 -0
- package/esm2022/chat/documents-upload/document-list/document-list.component.mjs +140 -0
- package/esm2022/chat/documents-upload/document-overview/document-overview.component.mjs +65 -0
- package/esm2022/chat/documents-upload/document-upload/document-upload.component.mjs +256 -0
- package/{esm2020 → esm2022}/chat/documents-upload/documents-upload.model.mjs +1 -1
- package/esm2022/chat/documents-upload/documents-upload.service.mjs +291 -0
- package/{esm2020 → esm2022}/chat/format-icon/format-icon.component.mjs +23 -23
- package/{esm2020 → esm2022}/chat/format-icon/icons.mjs +137 -137
- package/{esm2020 → esm2022}/chat/initials-avatar/initials-avatar.component.mjs +60 -60
- package/esm2022/chat/instance-manager.service.mjs +46 -0
- package/esm2022/chat/pipes/message-content.pipe.mjs +34 -0
- package/esm2022/chat/prompt.component.mjs +88 -0
- package/{esm2020 → esm2022}/chat/public-api.mjs +18 -18
- package/esm2022/chat/references/inline-image-reference.mjs +110 -0
- package/esm2022/chat/references/inline-page-reference.mjs +110 -0
- package/esm2022/chat/rest-chat.service.mjs +296 -0
- package/esm2022/chat/saved-chats/saved-chats.component.mjs +82 -0
- package/esm2022/chat/services/app.service.mjs +19 -0
- package/esm2022/chat/services/dialog.service.mjs +40 -0
- package/esm2022/chat/services/notification.service.mjs +25 -0
- package/esm2022/chat/services/principal.service.mjs +16 -0
- package/esm2022/chat/services/search.service.mjs +13 -0
- package/esm2022/chat/services/signalR.web.service.mjs +79 -0
- package/esm2022/chat/services/ui.service.mjs +61 -0
- package/esm2022/chat/services/user-settings.service.mjs +22 -0
- package/{esm2020 → esm2022}/chat/sinequa-assistant-chat.mjs +4 -4
- package/esm2022/chat/token-progress-bar/token-progress-bar.component.mjs +52 -0
- package/esm2022/chat/tooltip/tooltip.component.mjs +44 -0
- package/esm2022/chat/tooltip/tooltip.directive.mjs +203 -0
- package/esm2022/chat/types/message-content.types.mjs +2 -0
- package/esm2022/chat/types/message-reference.types.mjs +2 -0
- package/esm2022/chat/types.mjs +130 -0
- package/esm2022/chat/unified-plugins/embedded-image-reference.plugin.mjs +57 -0
- package/esm2022/chat/unified-plugins/embedded-page-reference.plugin.mjs +57 -0
- package/esm2022/chat/utils/assistant-json.mjs +12 -0
- package/esm2022/chat/websocket-chat.service.mjs +654 -0
- package/{esm2020 → esm2022}/public-api.mjs +2 -2
- package/{esm2020 → esm2022}/sinequa-assistant.mjs +4 -4
- package/fesm2022/sinequa-assistant-chat.mjs +5340 -0
- package/fesm2022/sinequa-assistant-chat.mjs.map +1 -0
- package/{fesm2015 → fesm2022}/sinequa-assistant.mjs +3 -3
- package/index.d.ts +5 -5
- package/package.json +52 -25
- package/public-api.d.ts +1 -1
- package/chat/messages/de.d.ts +0 -4
- package/chat/messages/en.d.ts +0 -4
- package/chat/messages/fr.d.ts +0 -4
- package/chat/messages/index.d.ts +0 -4
- package/esm2020/chat/charts/chart/chart.component.mjs +0 -40
- package/esm2020/chat/chat-message/chat-message.component.mjs +0 -263
- package/esm2020/chat/chat-reference/chat-reference.component.mjs +0 -40
- package/esm2020/chat/chat-settings-v3/chat-settings-v3.component.mjs +0 -117
- package/esm2020/chat/chat.component.mjs +0 -1069
- package/esm2020/chat/chat.service.mjs +0 -333
- package/esm2020/chat/debug-message/debug-message.component.mjs +0 -43
- package/esm2020/chat/documents-upload/document-list/document-list.component.mjs +0 -191
- package/esm2020/chat/documents-upload/document-overview/document-overview.component.mjs +0 -80
- package/esm2020/chat/documents-upload/document-upload/document-upload.component.mjs +0 -258
- package/esm2020/chat/documents-upload/documents-upload.service.mjs +0 -289
- package/esm2020/chat/instance-manager.service.mjs +0 -46
- package/esm2020/chat/messages/de.mjs +0 -4
- package/esm2020/chat/messages/en.mjs +0 -4
- package/esm2020/chat/messages/fr.mjs +0 -4
- package/esm2020/chat/messages/index.mjs +0 -9
- package/esm2020/chat/prompt.component.mjs +0 -88
- package/esm2020/chat/rest-chat.service.mjs +0 -241
- package/esm2020/chat/saved-chats/saved-chats.component.mjs +0 -175
- package/esm2020/chat/token-progress-bar/token-progress-bar.component.mjs +0 -54
- package/esm2020/chat/types.mjs +0 -112
- package/esm2020/chat/websocket-chat.service.mjs +0 -641
- package/fesm2015/sinequa-assistant-chat.mjs +0 -4200
- package/fesm2015/sinequa-assistant-chat.mjs.map +0 -1
- package/fesm2020/sinequa-assistant-chat.mjs +0 -4171
- package/fesm2020/sinequa-assistant-chat.mjs.map +0 -1
- package/fesm2020/sinequa-assistant.mjs +0 -9
- package/fesm2020/sinequa-assistant.mjs.map +0 -1
- /package/{fesm2015 → fesm2022}/sinequa-assistant.mjs.map +0 -0
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
import { Injectable, inject } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, catchError, filter, from, map, take } from 'rxjs';
|
|
3
|
+
import { HttpClient, HttpEventType, HttpHeaders } from '@angular/common/http';
|
|
4
|
+
import { AppService } from '../services/app.service';
|
|
5
|
+
import { getToken, globalConfig, post } from '@sinequa/atomic';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class DocumentsUploadService {
|
|
8
|
+
constructor() {
|
|
9
|
+
/** Documents' upload configuration. */
|
|
10
|
+
this.uploadConfig$ = new BehaviorSubject(undefined);
|
|
11
|
+
this.appService = inject(AppService);
|
|
12
|
+
this.http = inject(HttpClient);
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Initializes the file upload service with the provided chat service instance.
|
|
16
|
+
*
|
|
17
|
+
* @param chatService - An instance of ChatService. If not provided, an error is thrown.
|
|
18
|
+
* @throws {Error} If the chatService instance is not provided or if there is an error during initialization.
|
|
19
|
+
*/
|
|
20
|
+
init(chatService) {
|
|
21
|
+
if (!chatService)
|
|
22
|
+
throw new Error('A chatService instance must be provided');
|
|
23
|
+
this.chatService = chatService;
|
|
24
|
+
try {
|
|
25
|
+
this.getRequestsUrl();
|
|
26
|
+
this.getUploadConfig();
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
throw new Error(error);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Fetch the endpoint to use for the file upload related requests
|
|
34
|
+
* @throws {Error} If the property 'restEndpoint' is not provided in the assistant configuration
|
|
35
|
+
*/
|
|
36
|
+
getRequestsUrl() {
|
|
37
|
+
if (!!this.chatService.assistantConfig$.value.connectionSettings.restEndpoint) {
|
|
38
|
+
this.REQUEST_URL = this.chatService.assistantConfig$.value.connectionSettings.restEndpoint;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
throw new Error(`The property 'restEndpoint' must be provided when attempting to use 'REST' in assistant instance`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Retrieves the upload configuration for documents.
|
|
46
|
+
* The response, which contains the upload configuration, is emitted to the `uploadConfig$` observable.
|
|
47
|
+
*
|
|
48
|
+
* @throws {Error} If there is an error invoking the `documentsUploadConfigGet` action.
|
|
49
|
+
*/
|
|
50
|
+
getUploadConfig() {
|
|
51
|
+
const data = {
|
|
52
|
+
action: "documentsUploadConfigGet",
|
|
53
|
+
appName: this.appService.appName,
|
|
54
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
55
|
+
};
|
|
56
|
+
from(post(`plugin/${this.REQUEST_URL}`, data)).pipe(take(1), catchError((error) => {
|
|
57
|
+
throw new Error(`Error invoking documentsUploadConfigGet: ${error}`);
|
|
58
|
+
})).subscribe((res) => this.uploadConfig$.next(res));
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Uploads documents to the server.
|
|
62
|
+
*
|
|
63
|
+
* This method takes a FormData object which should contain all files to be uploaded.
|
|
64
|
+
* Each file should be appended to the FormData object with its original name.
|
|
65
|
+
*
|
|
66
|
+
* For example:
|
|
67
|
+
* ```typescript
|
|
68
|
+
* const formData = new FormData();
|
|
69
|
+
* formData.append(file.name, file.file);
|
|
70
|
+
* ```
|
|
71
|
+
*
|
|
72
|
+
* @param formData - The FormData object containing the files to be uploaded.
|
|
73
|
+
* - Each file should be appended to the FormData object with its original name.
|
|
74
|
+
* For example:
|
|
75
|
+
* ```typescript
|
|
76
|
+
* const formData = new FormData();
|
|
77
|
+
* formData.append(file.name, file.file);
|
|
78
|
+
* ```
|
|
79
|
+
*
|
|
80
|
+
* @param enableProgress - (Optional) A boolean parameter that controls whether progress reporting is enabled.
|
|
81
|
+
* - Defaults to `true`.
|
|
82
|
+
* - If `true`, the `reportProgress` option is set in the request options, enabling the track of upload progress based on the underlying browser's progress events.
|
|
83
|
+
* - If `false`, progress events are not reported.
|
|
84
|
+
*
|
|
85
|
+
* @returns An Observable that emits events of type `UploadEvent`:
|
|
86
|
+
* - `UploadProgressEvent`: Emitted during the upload process, containing:
|
|
87
|
+
* - * `type`: "uploadProgress" - The type of the event.
|
|
88
|
+
* - * `loaded`: number - The number of bytes uploaded so far.
|
|
89
|
+
* - * `total`: number - The total number of bytes to be uploaded (if available).
|
|
90
|
+
* - * `progress`: number - The percentage of upload progress (calculated as `(loaded / total) * 100`).
|
|
91
|
+
* - `UploadResponseEvent`: Emitted when the upload is complete, containing:
|
|
92
|
+
* - * `type`: "response" - The type of the event.
|
|
93
|
+
* - * `body`: `UploadResponse` - The server's response, including:
|
|
94
|
+
* - * - * `statusToken`: string - A token to track the status of the indexing process.
|
|
95
|
+
* - * - * `executionTime`: string - The time taken to execute the upload.
|
|
96
|
+
* - * - * `connectorResponse` (optional): Additional response data from the connector, containing:
|
|
97
|
+
* - * - * - * `collection`: string - The collection name.
|
|
98
|
+
* - * - * - * `action`: string - The action performed.
|
|
99
|
+
* - * - * - * `stats`: object - Statistics about the upload, including:
|
|
100
|
+
* - * - * - * - * `nbDocUpdated`: number - The number of documents updated.
|
|
101
|
+
*
|
|
102
|
+
* @throws {Error} If there is an error invoking the `documentsupload` action.
|
|
103
|
+
*
|
|
104
|
+
* Example usage:
|
|
105
|
+
* ```typescript
|
|
106
|
+
* const formData = new FormData();
|
|
107
|
+
* formData.append(file.name, file.file);
|
|
108
|
+
* this.documentsUploadService.uploadDocuments(formData).subscribe(event => {
|
|
109
|
+
* if (event.type === 'uploadProgress') {
|
|
110
|
+
* console.log(`Progress: ${event.progress}%`);
|
|
111
|
+
* } else if (event.type === 'response') {
|
|
112
|
+
* console.log('Upload complete:', event.body);
|
|
113
|
+
* }
|
|
114
|
+
* });
|
|
115
|
+
* ```
|
|
116
|
+
*/
|
|
117
|
+
uploadDocuments(formData, enableProgress = true) {
|
|
118
|
+
// Add the required "data" field as a JSON string
|
|
119
|
+
const data = {
|
|
120
|
+
action: "documentsupload",
|
|
121
|
+
appName: this.appService.appName,
|
|
122
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
123
|
+
};
|
|
124
|
+
formData.append('data', JSON.stringify(data));
|
|
125
|
+
let headers = new HttpHeaders({ 'Accept': 'application/json' });
|
|
126
|
+
const token = getToken();
|
|
127
|
+
if (token) {
|
|
128
|
+
headers = headers.append('sinequa-csrf-token', token);
|
|
129
|
+
}
|
|
130
|
+
const options = {
|
|
131
|
+
headers: headers,
|
|
132
|
+
observe: 'events',
|
|
133
|
+
};
|
|
134
|
+
if (enableProgress)
|
|
135
|
+
options['reportProgress'] = true;
|
|
136
|
+
const url = `${globalConfig.backendUrl}/${globalConfig.apiPath}/plugin/${this.REQUEST_URL}`;
|
|
137
|
+
/**
|
|
138
|
+
* Need to use the HttpClient directly to avoid the JSONMethodPluginService's behavior
|
|
139
|
+
* because it is altering the request and thus making it unable to properly set the Content-Type header with the boundary
|
|
140
|
+
*/
|
|
141
|
+
return this.http.post(url, formData, options).pipe(filter((event) => event.type === HttpEventType.Response || (enableProgress && event.type === HttpEventType.UploadProgress)), map((event) => {
|
|
142
|
+
switch (event.type) {
|
|
143
|
+
case HttpEventType.UploadProgress: {
|
|
144
|
+
const { loaded = 0, total = 0 } = event;
|
|
145
|
+
return { type: 'uploadProgress', loaded, total, progress: total > 0 ? Math.round((loaded / total) * 100) : 0 };
|
|
146
|
+
}
|
|
147
|
+
case HttpEventType.Response:
|
|
148
|
+
return { type: 'response', body: event.body };
|
|
149
|
+
default:
|
|
150
|
+
throw new Error("Unexpected event type"); // Should not reach here, but for typescript sake.
|
|
151
|
+
}
|
|
152
|
+
}), catchError((error) => {
|
|
153
|
+
throw new Error(`Error invoking documentsupload: ${error}`);
|
|
154
|
+
}));
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Retrieves the indexing status of a predefined uploaded document(s)
|
|
158
|
+
* based on the provided status token returned from the upload process.
|
|
159
|
+
*
|
|
160
|
+
* @param token - The status token used to track the indexing process.
|
|
161
|
+
* @returns An Observable that emits the server response of type `IndexingResponse`.
|
|
162
|
+
* The `IndexingResponse` object contains:
|
|
163
|
+
* - `docs`: array - An array of document status objects, each containing:
|
|
164
|
+
* - * `id`: string - The document ID.
|
|
165
|
+
* - * `fileName`: string - The name of the file.
|
|
166
|
+
* - * `operation`: "Add" | "Update" - The operation performed on the document.
|
|
167
|
+
* - * `status`: "Indexing" | "Indexed" | "Error" - The status of the document.
|
|
168
|
+
* - * `previousIndexationTime`: string | null - The previous indexation time.
|
|
169
|
+
* - * `currentIndexationTime`: string | null - The current indexation time.
|
|
170
|
+
* - `executionTime`: string - The time taken to retrieve the indexing status.
|
|
171
|
+
* @throws {Error} If there is an error invoking the `documentsUploadStatus` action.
|
|
172
|
+
*/
|
|
173
|
+
getIndexingStatus(token) {
|
|
174
|
+
const data = {
|
|
175
|
+
action: "documentsUploadStatus",
|
|
176
|
+
appName: this.appService.appName,
|
|
177
|
+
statusToken: token,
|
|
178
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
179
|
+
};
|
|
180
|
+
return from(post(`plugin/${this.REQUEST_URL}`, data)).pipe(catchError((error) => {
|
|
181
|
+
throw new Error(`Error invoking documentsUploadStatus: ${error}`);
|
|
182
|
+
}));
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Retrieves a list of uploaded documents.
|
|
186
|
+
*
|
|
187
|
+
* @param {string[]} [columns] - Optional array of additional index columns to include for each document.
|
|
188
|
+
* @param {number} [skip] - Optional number of documents to skip for pagination. If set, count also needs to be set. No skip if not set.
|
|
189
|
+
* @param {number} [count] - Optional number of documents to take for pagination (unlimited if not set).
|
|
190
|
+
* @returns {Observable<UploadedDocuments>} An observable that emits the list of uploaded documents.
|
|
191
|
+
* The `UploadedDocuments` object contains:
|
|
192
|
+
* - `docs`: array - An array of objects representing a single document with the following properties:
|
|
193
|
+
* - * `id`: string - A unique identifier for the document.
|
|
194
|
+
* - * `fileName`: string - The name of the file.
|
|
195
|
+
* - * `title`: string - The title of the document.
|
|
196
|
+
* - * `fileExt`: string - The file extension of the document.
|
|
197
|
+
* - * `indexationTime`: string - The time when the document was indexed.
|
|
198
|
+
* - * `size`: number - The size of the document.
|
|
199
|
+
* - * `sizeDisplay`: string - A human-readable representation of the document size.
|
|
200
|
+
* - * `[key: string]`: any - Additional columns asked in the request, value of the column for the document.
|
|
201
|
+
* - `count`: number - The count of documents in the current batch or subset.
|
|
202
|
+
* - `totalCount`: number - The total count of documents available.
|
|
203
|
+
* - `executionTime`: string - The time taken to process the documents.
|
|
204
|
+
* @throws {Error} Throws an error if the request fails.
|
|
205
|
+
*/
|
|
206
|
+
getDocumentsList(columns, skip, count) {
|
|
207
|
+
const data = {
|
|
208
|
+
action: "documentsList",
|
|
209
|
+
appName: this.appService.appName,
|
|
210
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
211
|
+
};
|
|
212
|
+
if (columns)
|
|
213
|
+
data["columns"] = columns;
|
|
214
|
+
if (skip)
|
|
215
|
+
data["skip"] = skip;
|
|
216
|
+
if (count)
|
|
217
|
+
data["count"] = count;
|
|
218
|
+
return from(post(`plugin/${this.REQUEST_URL}`, data)).pipe(catchError((error) => {
|
|
219
|
+
throw new Error(`Error invoking documentsList: ${error}`);
|
|
220
|
+
}));
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Deletes the uploaded documents with the specified IDs.
|
|
224
|
+
*
|
|
225
|
+
* @param docIds - An array of document IDs to delete.
|
|
226
|
+
* @returns An observable that emits the server response of type `deleteDocumentsResponse`.
|
|
227
|
+
* The `deleteDocumentsResponse` object contains:
|
|
228
|
+
* - `deletedCount`: number - The number of deleted documents.
|
|
229
|
+
* - `executionTime`: string - The time taken to delete the documents.
|
|
230
|
+
* @throws {Error} If there is an error invoking the `documentsDelete` action.
|
|
231
|
+
*/
|
|
232
|
+
deleteDocuments(docIds) {
|
|
233
|
+
const data = {
|
|
234
|
+
action: "documentsDelete",
|
|
235
|
+
docIds,
|
|
236
|
+
appName: this.appService.appName,
|
|
237
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
238
|
+
};
|
|
239
|
+
return from(post(`plugin/${this.REQUEST_URL}`, data)).pipe(catchError((error) => {
|
|
240
|
+
throw new Error(`Error invoking documentsDelete: ${error}`);
|
|
241
|
+
}));
|
|
242
|
+
}
|
|
243
|
+
/**
|
|
244
|
+
* Deletes all uploaded documents.
|
|
245
|
+
*
|
|
246
|
+
* @returns An observable that emits the server response of type `deleteDocumentsResponse`.
|
|
247
|
+
* The `deleteDocumentsResponse` object contains:
|
|
248
|
+
* - `deletedCount`: number - The number of deleted documents.
|
|
249
|
+
* - `executionTime`: string - The time taken to delete the documents.
|
|
250
|
+
* @throws {Error} If there is an error invoking the `documentsDeleteAll` action.
|
|
251
|
+
*/
|
|
252
|
+
deleteAllDocuments() {
|
|
253
|
+
const data = {
|
|
254
|
+
action: "documentsDeleteAll",
|
|
255
|
+
appName: this.appService.appName,
|
|
256
|
+
debug: this.chatService.assistantConfig$.value.defaultValues.debug
|
|
257
|
+
};
|
|
258
|
+
return from(post(`plugin/${this.REQUEST_URL}`, data)).pipe(catchError((error) => {
|
|
259
|
+
throw new Error(`Error invoking documentsDeleteAll: ${error}`);
|
|
260
|
+
}));
|
|
261
|
+
}
|
|
262
|
+
/**
|
|
263
|
+
* Formats the given file size in bytes into a human-readable string.
|
|
264
|
+
*
|
|
265
|
+
* @param bytes - The size of the file in bytes.
|
|
266
|
+
* @returns A string representing the file size in a human-readable format (e.g., "10.24 KB", "1.00 MB").
|
|
267
|
+
*/
|
|
268
|
+
formatFileSize(bytes) {
|
|
269
|
+
if (bytes === 0)
|
|
270
|
+
return "0 Bytes";
|
|
271
|
+
const k = 1024;
|
|
272
|
+
const sizes = ["Bytes", "KB", "MB", "GB", "TB"];
|
|
273
|
+
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
274
|
+
return (Number.parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + " " + sizes[i]);
|
|
275
|
+
}
|
|
276
|
+
/**
|
|
277
|
+
* Converts the given file size in bytes into megabytes.
|
|
278
|
+
*
|
|
279
|
+
* @param bytes - The size of the file in bytes.
|
|
280
|
+
* @returns The size of the file in megabytes.
|
|
281
|
+
*/
|
|
282
|
+
convertBytesToMB(bytes) {
|
|
283
|
+
return bytes / (1024 * 1024);
|
|
284
|
+
}
|
|
285
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DocumentsUploadService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
286
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DocumentsUploadService }); }
|
|
287
|
+
}
|
|
288
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DocumentsUploadService, decorators: [{
|
|
289
|
+
type: Injectable
|
|
290
|
+
}] });
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documents-upload.service.js","sourceRoot":"","sources":["../../../../../projects/assistant/chat/documents-upload/documents-upload.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { ChatService } from '../chat.service';\nimport { BehaviorSubject, catchError, filter, from, map, Observable, take } from 'rxjs';\nimport { deleteDocumentsResponse, IndexingInfos, UploadConfig, UploadedDocuments, UploadEvent } from './documents-upload.model';\nimport { HttpClient, HttpEventType, HttpHeaders, HttpResponse, HttpUploadProgressEvent } from '@angular/common/http';\nimport { AppService } from '../services/app.service';\nimport { getToken, globalConfig, post } from '@sinequa/atomic';\n\n@Injectable()\nexport class DocumentsUploadService {\n\n  /** Name of the assistant plugin. */\n  public REQUEST_URL: string;\n  /** Documents' upload configuration. */\n  uploadConfig$ = new BehaviorSubject<UploadConfig | undefined>(undefined);\n  public chatService: ChatService;\n\n  public appService = inject(AppService);\n  public http = inject(HttpClient);\n\n  /**\n   * Initializes the file upload service with the provided chat service instance.\n   *\n   * @param chatService - An instance of ChatService. If not provided, an error is thrown.\n   * @throws {Error} If the chatService instance is not provided or if there is an error during initialization.\n   */\n  init(chatService: ChatService | undefined): void {\n    if (!chatService) throw new Error('A chatService instance must be provided');\n\n    this.chatService = chatService;\n    try {\n      this.getRequestsUrl();\n      this.getUploadConfig();\n    } catch (error) {\n      throw new Error(error);\n    }\n  }\n\n  /**\n   * Fetch the endpoint to use for the file upload related requests\n   * @throws {Error} If the property 'restEndpoint' is not provided in the assistant configuration\n   */\n  getRequestsUrl() {\n    if (!!this.chatService.assistantConfig$.value!.connectionSettings.restEndpoint) {\n      this.REQUEST_URL = this.chatService.assistantConfig$.value!.connectionSettings.restEndpoint;\n    } else {\n      throw new Error(`The property 'restEndpoint' must be provided when attempting to use 'REST' in assistant instance`);\n    }\n  }\n\n  /**\n   * Retrieves the upload configuration for documents.\n   * The response, which contains the upload configuration, is emitted to the `uploadConfig$` observable.\n   *\n   * @throws {Error} If there is an error invoking the `documentsUploadConfigGet` action.\n   */\n  public getUploadConfig(): void {\n    const data = {\n      action: \"documentsUploadConfigGet\",\n      appName: this.appService.appName,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n\n    from(post<UploadConfig>(`plugin/${this.REQUEST_URL}`, data)).pipe(\n      take(1),\n      catchError((error) => {\n        throw new Error(`Error invoking documentsUploadConfigGet: ${error}`);\n      })\n    ).subscribe((res: UploadConfig) => this.uploadConfig$.next(res));\n  }\n\n  /**\n   * Uploads documents to the server.\n   *\n   * This method takes a FormData object which should contain all files to be uploaded.\n   * Each file should be appended to the FormData object with its original name.\n   *\n   * For example:\n   * ```typescript\n   * const formData = new FormData();\n   * formData.append(file.name, file.file);\n   * ```\n   *\n   * @param formData - The FormData object containing the files to be uploaded.\n   * - Each file should be appended to the FormData object with its original name.\n   * For example:\n   * ```typescript\n   * const formData = new FormData();\n   * formData.append(file.name, file.file);\n   * ```\n   *\n   * @param enableProgress - (Optional) A boolean parameter that controls whether progress reporting is enabled.\n   * - Defaults to `true`.\n   * - If `true`, the `reportProgress` option is set in the request options, enabling the track of upload progress based on the underlying browser's progress events.\n   * - If `false`, progress events are not reported.\n   *\n   * @returns An Observable that emits events of type `UploadEvent`:\n   * - `UploadProgressEvent`: Emitted during the upload process, containing:\n   *   - *  `type`: \"uploadProgress\" - The type of the event.\n   *   - *  `loaded`: number - The number of bytes uploaded so far.\n   *   - *  `total`: number - The total number of bytes to be uploaded (if available).\n   *   - *  `progress`: number - The percentage of upload progress (calculated as `(loaded / total) * 100`).\n   * - `UploadResponseEvent`: Emitted when the upload is complete, containing:\n   *   - *  `type`: \"response\" - The type of the event.\n   *   - *  `body`: `UploadResponse` - The server's response, including:\n   *     - * - * `statusToken`: string - A token to track the status of the indexing process.\n   *     - * - *  `executionTime`: string - The time taken to execute the upload.\n   *     - * - *  `connectorResponse` (optional): Additional response data from the connector, containing:\n   *       - * - * - *  `collection`: string - The collection name.\n   *       - * - * - *  `action`: string - The action performed.\n   *       - * - * - *  `stats`: object - Statistics about the upload, including:\n   *         - * - * - * - * `nbDocUpdated`: number - The number of documents updated.\n   *\n   * @throws {Error} If there is an error invoking the `documentsupload` action.\n   *\n   * Example usage:\n   * ```typescript\n   * const formData = new FormData();\n   * formData.append(file.name, file.file);\n   * this.documentsUploadService.uploadDocuments(formData).subscribe(event => {\n   *   if (event.type === 'uploadProgress') {\n   *     console.log(`Progress: ${event.progress}%`);\n   *   } else if (event.type === 'response') {\n   *     console.log('Upload complete:', event.body);\n   *   }\n   * });\n   * ```\n   */\n  public uploadDocuments(formData: FormData, enableProgress: boolean = true): Observable<UploadEvent> {\n    // Add the required \"data\" field as a JSON string\n    const data = {\n      action: \"documentsupload\",\n      appName: this.appService.appName,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n    formData.append('data', JSON.stringify(data));\n\n    let headers = new HttpHeaders({ 'Accept': 'application/json' });\n    const token = getToken();\n    if(token){\n      headers = headers.append('sinequa-csrf-token',token);\n    }\n    const options: any  = {\n      headers: headers,\n      observe: 'events',\n    };\n    if (enableProgress) options['reportProgress'] = true;\n\n    const url = `${globalConfig.backendUrl}/${globalConfig.apiPath}/plugin/${this.REQUEST_URL}`;\n    /**\n     * Need to use the HttpClient directly to avoid the JSONMethodPluginService's behavior\n     * because it is altering the request and thus making it unable to properly set the Content-Type header with the boundary\n     */\n    return this.http.post<any>(url, formData, options).pipe(\n      filter((event): event is HttpUploadProgressEvent | HttpResponse<any> =>\n        event.type === HttpEventType.Response || (enableProgress && event.type === HttpEventType.UploadProgress)\n      ),\n      map((event): UploadEvent => {\n        switch (event.type) {\n          case HttpEventType.UploadProgress: {\n            const { loaded = 0, total = 0 } = event;\n            return { type: 'uploadProgress', loaded, total, progress: total > 0 ? Math.round((loaded / total) * 100) : 0 };\n          }\n          case HttpEventType.Response:\n            return { type: 'response', body: event.body };\n          default:\n            throw new Error(\"Unexpected event type\"); // Should not reach here, but for typescript sake.\n        }\n      }),\n      catchError((error) => {\n        throw new Error(`Error invoking documentsupload: ${error}`);\n      })\n    );\n  }\n\n  /**\n   * Retrieves the indexing status of a predefined uploaded document(s)\n   * based on the provided status token returned from the upload process.\n   *\n   * @param token - The status token used to track the indexing process.\n   * @returns An Observable that emits the server response of type `IndexingResponse`.\n   * The `IndexingResponse` object contains:\n   * - `docs`: array - An array of document status objects, each containing:\n   *   - * `id`: string - The document ID.\n   *   - * `fileName`: string - The name of the file.\n   *   - * `operation`: \"Add\" | \"Update\" - The operation performed on the document.\n   *   - * `status`: \"Indexing\" | \"Indexed\" | \"Error\" - The status of the document.\n   *   - * `previousIndexationTime`: string | null - The previous indexation time.\n   *   - * `currentIndexationTime`: string | null - The current indexation time.\n   * - `executionTime`: string - The time taken to retrieve the indexing status.\n   * @throws {Error} If there is an error invoking the `documentsUploadStatus` action.\n   */\n  public getIndexingStatus(token: string): Observable<IndexingInfos> {\n    const data = {\n      action: \"documentsUploadStatus\",\n      appName: this.appService.appName,\n      statusToken: token,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n\n    return from(post<IndexingInfos>(`plugin/${this.REQUEST_URL}`, data)).pipe(\n      catchError((error) => {\n        throw new Error(`Error invoking documentsUploadStatus: ${error}`);\n      })\n    );\n  }\n\n  /**\n   * Retrieves a list of uploaded documents.\n   *\n   * @param {string[]} [columns] - Optional array of additional index columns to include for each document.\n   * @param {number} [skip] - Optional number of documents to skip for pagination. If set, count also needs to be set. No skip if not set.\n   * @param {number} [count] - Optional number of documents to take for pagination (unlimited if not set).\n   * @returns {Observable<UploadedDocuments>} An observable that emits the list of uploaded documents.\n   * The `UploadedDocuments` object contains:\n   * - `docs`: array - An array of objects representing a single document with the following properties:\n   *   - * `id`: string - A unique identifier for the document.\n   *   - * `fileName`: string - The name of the file.\n   *   - * `title`: string - The title of the document.\n   *   - * `fileExt`: string - The file extension of the document.\n   *   - * `indexationTime`: string - The time when the document was indexed.\n   *   - * `size`: number - The size of the document.\n   *   - * `sizeDisplay`: string - A human-readable representation of the document size.\n   *   - * `[key: string]`: any - Additional columns asked in the request, value of the column for the document.\n   * - `count`: number - The count of documents in the current batch or subset.\n   * - `totalCount`: number - The total count of documents available.\n   * - `executionTime`: string - The time taken to process the documents.\n   * @throws {Error} Throws an error if the request fails.\n   */\n  public getDocumentsList(columns?: string[], skip?: number, count?: number): Observable<UploadedDocuments> {\n    const data = {\n      action: \"documentsList\",\n      appName: this.appService.appName,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n\n    if (columns) data[\"columns\"] = columns;\n    if (skip) data[\"skip\"] = skip;\n    if (count) data[\"count\"] = count;\n\n    return from(post<UploadedDocuments>(`plugin/${this.REQUEST_URL}`, data)).pipe(\n      catchError((error) => {\n        throw new Error(`Error invoking documentsList: ${error}`);\n      })\n    );\n  }\n\n  /**\n   * Deletes the uploaded documents with the specified IDs.\n   *\n   * @param docIds - An array of document IDs to delete.\n   * @returns An observable that emits the server response of type `deleteDocumentsResponse`.\n   * The `deleteDocumentsResponse` object contains:\n   * - `deletedCount`: number - The number of deleted documents.\n   * - `executionTime`: string - The time taken to delete the documents.\n   * @throws {Error} If there is an error invoking the `documentsDelete` action.\n   */\n  public deleteDocuments(docIds: string[]): Observable<deleteDocumentsResponse> {\n    const data = {\n      action: \"documentsDelete\",\n      docIds,\n      appName: this.appService.appName,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n\n    return from(post<deleteDocumentsResponse>(`plugin/${this.REQUEST_URL}`, data)).pipe(\n      catchError((error) => {\n        throw new Error(`Error invoking documentsDelete: ${error}`);\n      })\n    );\n  }\n\n  /**\n   * Deletes all uploaded documents.\n   *\n   * @returns An observable that emits the server response of type `deleteDocumentsResponse`.\n   * The `deleteDocumentsResponse` object contains:\n   * - `deletedCount`: number - The number of deleted documents.\n   * - `executionTime`: string - The time taken to delete the documents.\n   * @throws {Error} If there is an error invoking the `documentsDeleteAll` action.\n   */\n  public deleteAllDocuments(): Observable<deleteDocumentsResponse> {\n    const data = {\n      action: \"documentsDeleteAll\",\n      appName: this.appService.appName,\n      debug: this.chatService.assistantConfig$.value!.defaultValues.debug\n    };\n\n    return from(post<deleteDocumentsResponse>(`plugin/${this.REQUEST_URL}`, data)).pipe(\n      catchError((error) => {\n        throw new Error(`Error invoking documentsDeleteAll: ${error}`);\n      })\n    );\n  }\n\n  /**\n   * Formats the given file size in bytes into a human-readable string.\n   *\n   * @param bytes - The size of the file in bytes.\n   * @returns A string representing the file size in a human-readable format (e.g., \"10.24 KB\", \"1.00 MB\").\n   */\n  public formatFileSize(bytes: number): string {\n    if (bytes === 0) return \"0 Bytes\";\n    const k = 1024;\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\"];\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\n    return (\n      Number.parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + \" \" + sizes[i]\n    );\n  }\n\n  /**\n   * Converts the given file size in bytes into megabytes.\n   *\n   * @param bytes - The size of the file in bytes.\n   * @returns The size of the file in megabytes.\n   */\n  public convertBytesToMB(bytes: number): number {\n    return bytes / (1024 * 1024);\n  }\n\n}\n"]}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
-
import { defaultFormatIcons } from './icons';
|
|
3
|
-
import { CommonModule } from '@angular/common';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common";
|
|
6
|
-
export class FormatIconComponent {
|
|
7
|
-
constructor() {
|
|
8
|
-
this._formatIcons = defaultFormatIcons;
|
|
9
|
-
}
|
|
10
|
-
ngOnChanges() {
|
|
11
|
-
const icon = this.extension ? this._formatIcons[this.extension] : undefined;
|
|
12
|
-
this.icon = icon?.icon || this._formatIcons.file.icon;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
18
|
-
type: Component,
|
|
19
|
-
args: [{ selector: 'sq-format-icon', encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule], template: "<span *ngIf=\"icon\" class=\"{{icon}}\"></span>" }]
|
|
20
|
-
}], propDecorators: { extension: [{
|
|
21
|
-
type: Input
|
|
22
|
-
}] } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { defaultFormatIcons } from './icons';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
export class FormatIconComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this._formatIcons = defaultFormatIcons;
|
|
9
|
+
}
|
|
10
|
+
ngOnChanges() {
|
|
11
|
+
const icon = this.extension ? this._formatIcons[this.extension] : undefined;
|
|
12
|
+
this.icon = icon?.icon || this._formatIcons.file.icon;
|
|
13
|
+
}
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormatIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
15
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormatIconComponent, isStandalone: true, selector: "sq-format-icon", inputs: { extension: "extension" }, usesOnChanges: true, ngImport: i0, template: "<span *ngIf=\"icon\" class=\"{{icon}}\"></span>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormatIconComponent, decorators: [{
|
|
18
|
+
type: Component,
|
|
19
|
+
args: [{ selector: 'sq-format-icon', encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule], template: "<span *ngIf=\"icon\" class=\"{{icon}}\"></span>" }]
|
|
20
|
+
}], propDecorators: { extension: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0LWljb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXNzaXN0YW50L2NoYXQvZm9ybWF0LWljb24vZm9ybWF0LWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXNzaXN0YW50L2NoYXQvZm9ybWF0LWljb24vZm9ybWF0LWljb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBUy9DLE1BQU0sT0FBTyxtQkFBbUI7SUFQaEM7UUFXVSxpQkFBWSxHQUFHLGtCQUFrQixDQUFDO0tBUzNDO0lBTEMsV0FBVztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDNUUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLEVBQUUsSUFBSSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztJQUN4RCxDQUFDOytHQVhVLG1CQUFtQjttR0FBbkIsbUJBQW1CLG1JQ1hoQyxpREFBMkMsMkNEUy9CLFlBQVk7OzRGQUVYLG1CQUFtQjtrQkFQL0IsU0FBUzsrQkFDRSxnQkFBZ0IsaUJBRVgsaUJBQWlCLENBQUMsSUFBSSxjQUN6QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUM7OEJBSWQsU0FBUztzQkFBakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGRlZmF1bHRGb3JtYXRJY29ucyB9IGZyb20gJy4vaWNvbnMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc3EtZm9ybWF0LWljb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybWF0LWljb24uY29tcG9uZW50Lmh0bWwnLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBGb3JtYXRJY29uQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcblxuICBASW5wdXQoKSBleHRlbnNpb246IHN0cmluZztcblxuICBwcml2YXRlIF9mb3JtYXRJY29ucyA9IGRlZmF1bHRGb3JtYXRJY29ucztcbiAgXG4gIGljb246IHN0cmluZztcblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICBjb25zdCBpY29uID0gdGhpcy5leHRlbnNpb24gPyB0aGlzLl9mb3JtYXRJY29uc1t0aGlzLmV4dGVuc2lvbl0gOiB1bmRlZmluZWQ7XG4gICAgdGhpcy5pY29uID0gaWNvbj8uaWNvbiB8fCB0aGlzLl9mb3JtYXRJY29ucy5maWxlLmljb247XG4gIH1cblxufVxuIiwiPHNwYW4gKm5nSWY9XCJpY29uXCIgY2xhc3M9XCJ7e2ljb259fVwiPjwvc3Bhbj4iXX0=
|