solver-sdk 1.0.2 → 1.0.5

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.
Files changed (89) hide show
  1. package/README.md +80 -75
  2. package/dist/cjs/api/projects-api.js +25 -20
  3. package/dist/cjs/api/projects-api.js.map +1 -1
  4. package/dist/cjs/api/reasoning-api.js +28 -20
  5. package/dist/cjs/api/reasoning-api.js.map +1 -1
  6. package/dist/cjs/api/search-api.js +2 -2
  7. package/dist/cjs/api/search-api.js.map +1 -1
  8. package/dist/esm/api/projects-api.js +25 -20
  9. package/dist/esm/api/projects-api.js.map +1 -1
  10. package/dist/esm/api/reasoning-api.js +28 -20
  11. package/dist/esm/api/reasoning-api.js.map +1 -1
  12. package/dist/esm/api/search-api.js +2 -2
  13. package/dist/esm/api/search-api.js.map +1 -1
  14. package/dist/esm/index.js +21 -1816
  15. package/dist/esm/index.js.map +1 -1
  16. package/dist/types/api/projects-api.d.ts +70 -28
  17. package/dist/types/api/projects-api.d.ts.map +1 -1
  18. package/dist/types/api/reasoning-api.d.ts +73 -15
  19. package/dist/types/api/reasoning-api.d.ts.map +1 -1
  20. package/package.json +21 -10
  21. package/dist/esm/types/api/agents-api.d.ts +0 -141
  22. package/dist/esm/types/api/agents-api.d.ts.map +0 -1
  23. package/dist/esm/types/api/code-modification-api.d.ts +0 -104
  24. package/dist/esm/types/api/code-modification-api.d.ts.map +0 -1
  25. package/dist/esm/types/api/context-api.d.ts +0 -86
  26. package/dist/esm/types/api/context-api.d.ts.map +0 -1
  27. package/dist/esm/types/api/projects-api.d.ts +0 -89
  28. package/dist/esm/types/api/projects-api.d.ts.map +0 -1
  29. package/dist/esm/types/api/reasoning-api.d.ts +0 -130
  30. package/dist/esm/types/api/reasoning-api.d.ts.map +0 -1
  31. package/dist/esm/types/api/search-api.d.ts +0 -92
  32. package/dist/esm/types/api/search-api.d.ts.map +0 -1
  33. package/dist/esm/types/code-solver-sdk.d.ts +0 -145
  34. package/dist/esm/types/code-solver-sdk.d.ts.map +0 -1
  35. package/dist/esm/types/index.d.ts +0 -81
  36. package/dist/esm/types/index.d.ts.map +0 -1
  37. package/dist/esm/types/interfaces/http-client.d.ts +0 -110
  38. package/dist/esm/types/interfaces/http-client.d.ts.map +0 -1
  39. package/dist/esm/types/interfaces/sdk-options.d.ts +0 -34
  40. package/dist/esm/types/interfaces/sdk-options.d.ts.map +0 -1
  41. package/dist/esm/types/models/types.d.ts +0 -139
  42. package/dist/esm/types/models/types.d.ts.map +0 -1
  43. package/dist/esm/types/utils/code-solver-websocket-client.d.ts +0 -138
  44. package/dist/esm/types/utils/code-solver-websocket-client.d.ts.map +0 -1
  45. package/dist/esm/types/utils/http-client.d.ts +0 -85
  46. package/dist/esm/types/utils/http-client.d.ts.map +0 -1
  47. package/dist/esm/types/utils/indexing-websocket-client.d.ts +0 -123
  48. package/dist/esm/types/utils/indexing-websocket-client.d.ts.map +0 -1
  49. package/dist/esm/types/utils/sse-client.d.ts +0 -92
  50. package/dist/esm/types/utils/sse-client.d.ts.map +0 -1
  51. package/dist/esm/types/utils/websocket-client.d.ts +0 -118
  52. package/dist/esm/types/utils/websocket-client.d.ts.map +0 -1
  53. package/dist/index.d.ts +0 -1599
  54. package/dist/umd/code-solver-sdk.js +0 -1902
  55. package/dist/umd/code-solver-sdk.js.map +0 -1
  56. package/dist/umd/code-solver-sdk.min.js +0 -2
  57. package/dist/umd/code-solver-sdk.min.js.map +0 -1
  58. package/dist/umd/types/api/agents-api.d.ts +0 -141
  59. package/dist/umd/types/api/agents-api.d.ts.map +0 -1
  60. package/dist/umd/types/api/code-modification-api.d.ts +0 -104
  61. package/dist/umd/types/api/code-modification-api.d.ts.map +0 -1
  62. package/dist/umd/types/api/context-api.d.ts +0 -86
  63. package/dist/umd/types/api/context-api.d.ts.map +0 -1
  64. package/dist/umd/types/api/projects-api.d.ts +0 -89
  65. package/dist/umd/types/api/projects-api.d.ts.map +0 -1
  66. package/dist/umd/types/api/reasoning-api.d.ts +0 -130
  67. package/dist/umd/types/api/reasoning-api.d.ts.map +0 -1
  68. package/dist/umd/types/api/search-api.d.ts +0 -92
  69. package/dist/umd/types/api/search-api.d.ts.map +0 -1
  70. package/dist/umd/types/code-solver-sdk.d.ts +0 -145
  71. package/dist/umd/types/code-solver-sdk.d.ts.map +0 -1
  72. package/dist/umd/types/index.d.ts +0 -81
  73. package/dist/umd/types/index.d.ts.map +0 -1
  74. package/dist/umd/types/interfaces/http-client.d.ts +0 -110
  75. package/dist/umd/types/interfaces/http-client.d.ts.map +0 -1
  76. package/dist/umd/types/interfaces/sdk-options.d.ts +0 -34
  77. package/dist/umd/types/interfaces/sdk-options.d.ts.map +0 -1
  78. package/dist/umd/types/models/types.d.ts +0 -139
  79. package/dist/umd/types/models/types.d.ts.map +0 -1
  80. package/dist/umd/types/utils/code-solver-websocket-client.d.ts +0 -138
  81. package/dist/umd/types/utils/code-solver-websocket-client.d.ts.map +0 -1
  82. package/dist/umd/types/utils/http-client.d.ts +0 -85
  83. package/dist/umd/types/utils/http-client.d.ts.map +0 -1
  84. package/dist/umd/types/utils/indexing-websocket-client.d.ts +0 -123
  85. package/dist/umd/types/utils/indexing-websocket-client.d.ts.map +0 -1
  86. package/dist/umd/types/utils/sse-client.d.ts +0 -92
  87. package/dist/umd/types/utils/sse-client.d.ts.map +0 -1
  88. package/dist/umd/types/utils/websocket-client.d.ts +0 -118
  89. package/dist/umd/types/utils/websocket-client.d.ts.map +0 -1
@@ -1,1902 +0,0 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('axios'), require('event-source-polyfill')) :
3
- typeof define === 'function' && define.amd ? define(['exports', 'axios', 'event-source-polyfill'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.CodeSolverSDK = {}, global.axios, global.EventSourcePolyfill));
5
- })(this, (function (exports, axios, eventSourcePolyfill) { 'use strict';
6
-
7
- /**
8
- * Определение типа среды выполнения
9
- * @returns 'browser' | 'node'
10
- */
11
- function getEnvironment$1() {
12
- return (typeof window !== 'undefined' && typeof window.document !== 'undefined')
13
- ? 'browser'
14
- : 'node';
15
- }
16
- /**
17
- * HTTP клиент для выполнения запросов к API
18
- *
19
- * Предоставляет методы для работы с REST API, включая обработку ошибок,
20
- * повторные попытки и таймауты.
21
- */
22
- class HttpClient {
23
- /**
24
- * Создает новый HTTP клиент
25
- * @param {string} baseURL Базовый URL для запросов
26
- * @param {HttpClientOptions} [options] Опции для HTTP клиента
27
- */
28
- constructor(baseURL, options = {}) {
29
- this.baseURL = baseURL;
30
- this.options = {
31
- headers: {
32
- 'Content-Type': 'application/json',
33
- 'Accept': 'application/json',
34
- ...(options.headers || {})
35
- },
36
- timeout: options.timeout || 30000,
37
- retry: options.retry || {
38
- maxRetries: 3,
39
- retryDelay: 1000,
40
- maxRetryDelay: 10000,
41
- retryStatusCodes: [408, 429, 500, 502, 503, 504]
42
- },
43
- httpsAgent: options.httpsAgent
44
- };
45
- this.environment = getEnvironment$1();
46
- // Создаем Axios инстанс с базовыми настройками
47
- this.axiosInstance = axios.create({
48
- baseURL: this.baseURL,
49
- timeout: this.options.timeout,
50
- headers: this.options.headers,
51
- ...(this.environment === 'node' && this.options.httpsAgent ? { httpsAgent: this.options.httpsAgent } : {})
52
- });
53
- // Добавляем интерцептор для обработки ошибок и повторных попыток
54
- this.setupInterceptors();
55
- }
56
- /**
57
- * Настраивает интерцепторы Axios
58
- */
59
- setupInterceptors() {
60
- // Интерцептор для ответов
61
- this.axiosInstance.interceptors.response.use((response) => response.data, async (error) => {
62
- const { config, response } = error;
63
- // Если нет конфига запроса или это уже повторный запрос, или skipRetry установлен, возвращаем ошибку
64
- if (!config || config._retryCount || config.skipRetry) {
65
- return Promise.reject(error);
66
- }
67
- config._retryCount = config._retryCount || 0;
68
- const retryConfig = this.options.retry;
69
- // Проверяем, нужно ли делать повторную попытку для данного статуса
70
- const shouldRetry = response &&
71
- retryConfig.retryStatusCodes?.includes(response.status) &&
72
- config._retryCount < (retryConfig.maxRetries || 3);
73
- if (shouldRetry) {
74
- config._retryCount += 1;
75
- // Вычисляем время задержки перед повторной попыткой
76
- const delay = Math.min((retryConfig.retryDelay || 1000) * Math.pow(2, config._retryCount - 1), retryConfig.maxRetryDelay || 10000);
77
- // Ждем перед повторной попыткой
78
- await new Promise(resolve => setTimeout(resolve, delay));
79
- // Делаем повторную попытку
80
- return this.axiosInstance(config);
81
- }
82
- // Если не нужно делать повторную попытку, возвращаем ошибку
83
- return Promise.reject(error);
84
- });
85
- }
86
- /**
87
- * Выполняет HTTP запрос
88
- * @param {RequestOptions} options Опции запроса
89
- * @returns {Promise<T>} Ответ от API
90
- */
91
- async request(options) {
92
- const axiosConfig = {
93
- url: options.url,
94
- method: options.method,
95
- data: options.data,
96
- params: options.params,
97
- headers: {
98
- ...this.options.headers,
99
- ...(options.headers || {})
100
- },
101
- timeout: options.timeout || this.options.timeout
102
- };
103
- // Если указано не делать повторные попытки, добавляем специальный флаг
104
- if (options.noRetry) {
105
- axiosConfig.skipRetry = true;
106
- }
107
- try {
108
- return await this.axiosInstance.request(axiosConfig);
109
- }
110
- catch (error) {
111
- throw this.handleError(error);
112
- }
113
- }
114
- /**
115
- * Выполняет GET запрос
116
- * @param {string} url URL для запроса
117
- * @param {Record<string, any>} [params] Query параметры
118
- * @param {Record<string, string>} [headers] HTTP заголовки
119
- * @returns {Promise<T>} Ответ от API
120
- */
121
- async get(url, params, headers) {
122
- return this.request({
123
- url,
124
- method: 'GET',
125
- params,
126
- headers
127
- });
128
- }
129
- /**
130
- * Выполняет POST запрос
131
- * @param {string} url URL для запроса
132
- * @param {any} [data] Данные для отправки
133
- * @param {Record<string, string>} [headers] HTTP заголовки
134
- * @returns {Promise<T>} Ответ от API
135
- */
136
- async post(url, data, headers) {
137
- return this.request({
138
- url,
139
- method: 'POST',
140
- data,
141
- headers
142
- });
143
- }
144
- /**
145
- * Выполняет PUT запрос
146
- * @param {string} url URL для запроса
147
- * @param {any} [data] Данные для отправки
148
- * @param {Record<string, string>} [headers] HTTP заголовки
149
- * @returns {Promise<T>} Ответ от API
150
- */
151
- async put(url, data, headers) {
152
- return this.request({
153
- url,
154
- method: 'PUT',
155
- data,
156
- headers
157
- });
158
- }
159
- /**
160
- * Выполняет DELETE запрос
161
- * @param {string} url URL для запроса
162
- * @param {Record<string, any>} [params] Query параметры
163
- * @param {Record<string, string>} [headers] HTTP заголовки
164
- * @returns {Promise<T>} Ответ от API
165
- */
166
- async delete(url, params, headers) {
167
- return this.request({
168
- url,
169
- method: 'DELETE',
170
- params,
171
- headers
172
- });
173
- }
174
- /**
175
- * Выполняет PATCH запрос
176
- * @param {string} url URL для запроса
177
- * @param {any} [data] Данные для отправки
178
- * @param {Record<string, string>} [headers] HTTP заголовки
179
- * @returns {Promise<T>} Ответ от API
180
- */
181
- async patch(url, data, headers) {
182
- return this.request({
183
- url,
184
- method: 'PATCH',
185
- data,
186
- headers
187
- });
188
- }
189
- /**
190
- * Обрабатывает ошибки от Axios
191
- * @param {any} error Ошибка от Axios
192
- * @returns {Error} Обработанная ошибка
193
- */
194
- handleError(error) {
195
- let enhancedError;
196
- if (error.response) {
197
- // Ошибка от сервера с кодом ответа
198
- const { status, data } = error.response;
199
- const message = data?.message || data?.error || `HTTP ошибка ${status}`;
200
- enhancedError = new Error(message);
201
- enhancedError.status = status;
202
- enhancedError.data = data;
203
- enhancedError.isApiError = true;
204
- }
205
- else if (error.request) {
206
- // Запрос был сделан, но ответ не получен
207
- enhancedError = new Error('Нет ответа от сервера. Проверьте подключение к интернету.');
208
- enhancedError.request = error.request;
209
- enhancedError.isNetworkError = true;
210
- }
211
- else {
212
- // Произошла ошибка при настройке запроса
213
- enhancedError = new Error(error.message || 'Произошла неизвестная ошибка');
214
- enhancedError.isUnknownError = true;
215
- }
216
- // Сохраняем оригинальную ошибку для отладки
217
- enhancedError.originalError = error;
218
- // Пытаемся обработать ошибку через глобальный обработчик
219
- try {
220
- // eslint-disable-next-line @typescript-eslint/no-var-requires
221
- const { CodeSolverSDK } = require('../code-solver-sdk.js');
222
- if (typeof CodeSolverSDK.handleError === 'function') {
223
- CodeSolverSDK.handleError(enhancedError);
224
- }
225
- }
226
- catch (e) {
227
- // Игнорируем ошибки при импорте или вызове обработчика
228
- }
229
- return enhancedError;
230
- }
231
- }
232
-
233
- /**
234
- * API для работы с проектами
235
- */
236
- class ProjectsApi {
237
- /**
238
- * Создает новый экземпляр API для работы с проектами
239
- * @param {HttpClient} httpClient HTTP клиент
240
- */
241
- constructor(httpClient) {
242
- this.httpClient = httpClient;
243
- }
244
- /**
245
- * Получает список всех проектов
246
- * @returns {Promise<Project[]>} Список проектов
247
- */
248
- async getAllProjects() {
249
- return this.httpClient.get('/api/projects');
250
- }
251
- /**
252
- * Получает проект по идентификатору
253
- * @param {string} projectId Идентификатор проекта
254
- * @returns {Promise<Project>} Проект
255
- */
256
- async getProject(projectId) {
257
- return this.httpClient.get(`/api/projects/${projectId}`);
258
- }
259
- /**
260
- * Создает новый проект
261
- * @param {string} name Название проекта
262
- * @param {string} path Путь к проекту
263
- * @returns {Promise<Project>} Созданный проект
264
- */
265
- async createProject(name, path) {
266
- return this.httpClient.post('/api/projects', { name, path });
267
- }
268
- /**
269
- * Обновляет проект
270
- * @param {string} projectId Идентификатор проекта
271
- * @param {Partial<Pick<Project, 'name' | 'path'>>} data Данные для обновления
272
- * @returns {Promise<Project>} Обновленный проект
273
- */
274
- async updateProject(projectId, data) {
275
- return this.httpClient.put(`/api/projects/${projectId}`, data);
276
- }
277
- /**
278
- * Удаляет проект
279
- * @param {string} projectId Идентификатор проекта
280
- * @returns {Promise<void>}
281
- */
282
- async deleteProject(projectId) {
283
- return this.httpClient.delete(`/api/projects/${projectId}`);
284
- }
285
- /**
286
- * Запускает индексацию проекта
287
- * @param {string} projectId Идентификатор проекта
288
- * @returns {Promise<Project>} Обновленный проект
289
- */
290
- async indexProject(projectId) {
291
- return this.httpClient.post(`/api/projects/${projectId}/index`);
292
- }
293
- /**
294
- * Останавливает индексацию проекта
295
- * @param {string} projectId Идентификатор проекта
296
- * @returns {Promise<Project>} Обновленный проект
297
- */
298
- async stopIndexing(projectId) {
299
- return this.httpClient.post(`/api/projects/${projectId}/stop-indexing`);
300
- }
301
- /**
302
- * Получает статус индексации проекта
303
- * @param {string} projectId Идентификатор проекта
304
- * @returns {Promise<Project>} Проект с обновленным статусом индексации
305
- */
306
- async getIndexingStatus(projectId) {
307
- return this.httpClient.get(`/api/projects/${projectId}/indexing-status`);
308
- }
309
- }
310
-
311
- /**
312
- * API для поиска кода
313
- */
314
- class SearchApi {
315
- /**
316
- * Создает новый экземпляр API для поиска кода
317
- * @param {HttpClient} httpClient HTTP клиент
318
- */
319
- constructor(httpClient) {
320
- this.httpClient = httpClient;
321
- }
322
- /**
323
- * Выполняет поиск кода в проекте
324
- * @param {string} projectId Идентификатор проекта
325
- * @param {SearchCodeParams} params Параметры поиска
326
- * @returns {Promise<SearchResults>} Результаты поиска
327
- */
328
- async searchCode(projectId, params) {
329
- return this.httpClient.post(`/api/projects/${projectId}/search`, params);
330
- }
331
- /**
332
- * Выполняет семантический поиск кода в проекте
333
- * @param {string} projectId Идентификатор проекта
334
- * @param {SearchCodeParams} params Параметры поиска
335
- * @returns {Promise<SearchResults>} Результаты поиска
336
- */
337
- async semanticSearch(projectId, params) {
338
- return this.httpClient.post(`/api/projects/${projectId}/semantic-search`, params);
339
- }
340
- /**
341
- * Получает популярные поисковые запросы
342
- * @param {string} projectId Идентификатор проекта
343
- * @param {number} [limit=10] Лимит результатов
344
- * @returns {Promise<string[]>} Популярные поисковые запросы
345
- */
346
- async getPopularQueries(projectId, limit = 10) {
347
- return this.httpClient.get(`/api/projects/${projectId}/popular-queries`, { limit });
348
- }
349
- /**
350
- * Получает подсказки для автозаполнения поискового запроса
351
- * @param {string} projectId Идентификатор проекта
352
- * @param {string} query Начало поискового запроса
353
- * @param {number} [limit=5] Лимит результатов
354
- * @returns {Promise<string[]>} Подсказки для автозаполнения
355
- */
356
- async getQuerySuggestions(projectId, query, limit = 5) {
357
- return this.httpClient.get(`/api/projects/${projectId}/query-suggestions`, { query, limit });
358
- }
359
- }
360
-
361
- /**
362
- * API для работы с контекстом
363
- */
364
- class ContextApi {
365
- /**
366
- * Создает новый экземпляр API для работы с контекстом
367
- * @param {HttpClient} httpClient HTTP клиент
368
- */
369
- constructor(httpClient) {
370
- this.httpClient = httpClient;
371
- }
372
- /**
373
- * Определяет контекст для запроса
374
- * @param {DetectContextParams} params Параметры определения контекста
375
- * @returns {Promise<AutoContext>} Определенный контекст
376
- */
377
- async detectContext(params) {
378
- return this.httpClient.post('/api/context/detect', params);
379
- }
380
- /**
381
- * Получает содержимое файла
382
- * @param {string} projectId Идентификатор проекта
383
- * @param {string} filePath Путь к файлу
384
- * @returns {Promise<string>} Содержимое файла
385
- */
386
- async getFileContent(projectId, filePath) {
387
- return this.httpClient.get(`/api/projects/${projectId}/files`, { path: filePath });
388
- }
389
- /**
390
- * Получает содержимое фрагмента файла
391
- * @param {string} projectId Идентификатор проекта
392
- * @param {string} filePath Путь к файлу
393
- * @param {number} startLine Начальная строка
394
- * @param {number} endLine Конечная строка
395
- * @returns {Promise<CodeSnippet>} Фрагмент кода
396
- */
397
- async getFileSnippet(projectId, filePath, startLine, endLine) {
398
- return this.httpClient.get(`/api/projects/${projectId}/snippets`, {
399
- path: filePath,
400
- startLine,
401
- endLine
402
- });
403
- }
404
- /**
405
- * Получает структуру директории
406
- * @param {string} projectId Идентификатор проекта
407
- * @param {string} [dirPath='/'] Путь к директории
408
- * @returns {Promise<Array<{name: string, type: 'file' | 'directory', path: string}>>} Структура директории
409
- */
410
- async getDirectoryStructure(projectId, dirPath = '/') {
411
- return this.httpClient.get(`/api/projects/${projectId}/directory`, { path: dirPath });
412
- }
413
- }
414
-
415
- /**
416
- * API для работы с рассуждениями
417
- */
418
- class ReasoningApi {
419
- /**
420
- * Создает новый экземпляр API для работы с рассуждениями
421
- * @param {HttpClient} httpClient HTTP клиент
422
- */
423
- constructor(httpClient) {
424
- this.httpClient = httpClient;
425
- }
426
- /**
427
- * Получает список рассуждений
428
- * @param {GetReasoningsParams} [params] Параметры для получения списка
429
- * @returns {Promise<Reasoning[]>} Список рассуждений
430
- */
431
- async getReasonings(params) {
432
- return this.httpClient.get('/api/reasonings', params);
433
- }
434
- /**
435
- * Получает рассуждение по идентификатору
436
- * @param {string} reasoningId Идентификатор рассуждения
437
- * @returns {Promise<Reasoning>} Рассуждение
438
- */
439
- async getReasoning(reasoningId) {
440
- return this.httpClient.get(`/api/reasonings/${reasoningId}`);
441
- }
442
- /**
443
- * Создает новое рассуждение
444
- * @param {CreateReasoningParams} params Параметры рассуждения
445
- * @returns {Promise<Reasoning>} Созданное рассуждение
446
- */
447
- async createReasoning(params) {
448
- return this.httpClient.post('/api/reasonings', params);
449
- }
450
- /**
451
- * Запускает процесс рассуждения
452
- * @param {string} reasoningId Идентификатор рассуждения
453
- * @returns {Promise<Reasoning>} Рассуждение
454
- */
455
- async startReasoning(reasoningId) {
456
- return this.httpClient.post(`/api/reasonings/${reasoningId}/start`);
457
- }
458
- /**
459
- * Останавливает процесс рассуждения
460
- * @param {string} reasoningId Идентификатор рассуждения
461
- * @returns {Promise<Reasoning>} Рассуждение
462
- */
463
- async stopReasoning(reasoningId) {
464
- return this.httpClient.post(`/api/reasonings/${reasoningId}/stop`);
465
- }
466
- /**
467
- * Удаляет рассуждение
468
- * @param {string} reasoningId Идентификатор рассуждения
469
- * @returns {Promise<void>}
470
- */
471
- async deleteReasoning(reasoningId) {
472
- return this.httpClient.delete(`/api/reasonings/${reasoningId}`);
473
- }
474
- /**
475
- * Получает промежуточные мысли рассуждения
476
- * @param {string} reasoningId Идентификатор рассуждения
477
- * @returns {Promise<string[]>} Промежуточные мысли
478
- */
479
- async getThinking(reasoningId) {
480
- return this.httpClient.get(`/api/reasonings/${reasoningId}/thinking`);
481
- }
482
- }
483
-
484
- /**
485
- * API для модификации кода
486
- */
487
- class CodeModificationApi {
488
- /**
489
- * Создает новый экземпляр API для модификации кода
490
- * @param {HttpClient} httpClient HTTP клиент
491
- */
492
- constructor(httpClient) {
493
- this.httpClient = httpClient;
494
- }
495
- /**
496
- * Выполняет модификацию кода
497
- * @param {CodeModificationParams} params Параметры модификации
498
- * @returns {Promise<CodeModificationResult>} Результат модификации
499
- */
500
- async modifyCode(params) {
501
- return this.httpClient.post('/api/code-modifications', params);
502
- }
503
- /**
504
- * Применяет результат модификации к файлу
505
- * @param {string} modificationId Идентификатор модификации
506
- * @returns {Promise<CodeModificationResult>} Обновленный результат модификации
507
- */
508
- async applyModification(modificationId) {
509
- return this.httpClient.post(`/api/code-modifications/${modificationId}/apply`);
510
- }
511
- /**
512
- * Отменяет применение модификации
513
- * @param {string} modificationId Идентификатор модификации
514
- * @returns {Promise<CodeModificationResult>} Обновленный результат модификации
515
- */
516
- async revertModification(modificationId) {
517
- return this.httpClient.post(`/api/code-modifications/${modificationId}/revert`);
518
- }
519
- /**
520
- * Получает модификацию по идентификатору
521
- * @param {string} modificationId Идентификатор модификации
522
- * @returns {Promise<CodeModificationResult>} Результат модификации
523
- */
524
- async getModification(modificationId) {
525
- return this.httpClient.get(`/api/code-modifications/${modificationId}`);
526
- }
527
- /**
528
- * Получает список модификаций для проекта
529
- * @param {string} projectId Идентификатор проекта
530
- * @param {object} [params] Параметры запроса
531
- * @param {number} [params.limit] Лимит результатов
532
- * @param {number} [params.offset] Смещение для пагинации
533
- * @returns {Promise<CodeModificationResult[]>} Список результатов модификации
534
- */
535
- async getModifications(projectId, params) {
536
- return this.httpClient.get(`/api/projects/${projectId}/code-modifications`, params);
537
- }
538
- }
539
-
540
- /**
541
- * Базовый класс для WebSocket клиентов
542
- */
543
- class WebSocketClient {
544
- /**
545
- * Создает новый WebSocket клиент
546
- * @param {string} url URL для подключения
547
- * @param {WebSocketClientOptions} [options] Опции клиента
548
- */
549
- constructor(url, options = {}) {
550
- /** Экземпляр WebSocket */
551
- this.webSocket = null;
552
- /** Счетчик попыток переподключения */
553
- this.retryCount = 0;
554
- /** Флаг, указывающий, что соединение было закрыто намеренно */
555
- this.intentionallyClosed = false;
556
- /** Таймер переподключения */
557
- this.reconnectTimer = null;
558
- /** Таймер таймаута соединения */
559
- this.connectionTimeoutTimer = null;
560
- /** Обработчики событий */
561
- this.eventHandlers = {};
562
- /** Очередь сообщений для отправки после подключения */
563
- this.messageQueue = [];
564
- /** Состояние соединения */
565
- this.connected = false;
566
- this.url = url;
567
- this.options = {
568
- headers: options.headers || {},
569
- connectionTimeout: options.connectionTimeout || 30000,
570
- protocols: options.protocols || [],
571
- maxRetries: options.maxRetries || 5,
572
- retryDelay: options.retryDelay || 1000,
573
- maxRetryDelay: options.maxRetryDelay || 30000,
574
- autoReconnect: options.autoReconnect !== undefined ? options.autoReconnect : true
575
- };
576
- // Определяем среду выполнения
577
- this.isBrowser = typeof window !== 'undefined' && typeof window.document !== 'undefined';
578
- }
579
- /**
580
- * Подключается к WebSocket серверу
581
- * @returns {Promise<void>}
582
- */
583
- connect() {
584
- // Если соединение уже установлено, возвращаем Promise.resolve
585
- if (this.webSocket && this.webSocket.readyState === WebSocket.OPEN) {
586
- return Promise.resolve();
587
- }
588
- // Сбрасываем флаг намеренного закрытия
589
- this.intentionallyClosed = false;
590
- return new Promise((resolve, reject) => {
591
- try {
592
- // Создаем новый экземпляр WebSocket
593
- if (this.isBrowser) {
594
- // Браузерное окружение
595
- this.webSocket = new WebSocket(this.url, this.options.protocols);
596
- }
597
- else {
598
- // Node.js окружение
599
- try {
600
- // Динамически импортируем ws модуль в Node.js
601
- const WebSocketImpl = require('ws');
602
- this.webSocket = new WebSocketImpl(this.url, {
603
- headers: this.options.headers,
604
- protocol: this.options.protocols
605
- });
606
- }
607
- catch (error) {
608
- reject(new Error('Не удалось загрузить модуль ws в Node.js: ' + error.message));
609
- return;
610
- }
611
- }
612
- // Устанавливаем таймаут соединения
613
- this.connectionTimeoutTimer = setTimeout(() => {
614
- if (this.webSocket && this.webSocket.readyState !== WebSocket.OPEN) {
615
- reject(new Error('Таймаут подключения WebSocket'));
616
- this.close();
617
- }
618
- }, this.options.connectionTimeout);
619
- // Обработчик открытия соединения
620
- this.webSocket.onopen = () => {
621
- clearTimeout(this.connectionTimeoutTimer);
622
- this.retryCount = 0;
623
- this.connected = true;
624
- // Отправляем сообщения из очереди
625
- while (this.messageQueue.length > 0) {
626
- const message = this.messageQueue.shift();
627
- if (message && this.webSocket && this.webSocket.readyState === WebSocket.OPEN) {
628
- this.webSocket.send(message);
629
- }
630
- }
631
- resolve();
632
- this.dispatchEvent('open', {});
633
- };
634
- // Обработчик сообщений
635
- this.webSocket.onmessage = (event) => {
636
- try {
637
- // Пытаемся распарсить сообщение как JSON
638
- let data = event.data;
639
- if (typeof data === 'string') {
640
- try {
641
- data = JSON.parse(data);
642
- }
643
- catch (e) {
644
- // Если не удалось распарсить, оставляем как есть
645
- }
646
- }
647
- this.dispatchEvent('message', data);
648
- }
649
- catch (e) {
650
- console.error('Ошибка при обработке сообщения WebSocket:', e);
651
- }
652
- };
653
- // Обработчик закрытия соединения
654
- this.webSocket.onclose = (event) => {
655
- clearTimeout(this.connectionTimeoutTimer);
656
- this.connected = false;
657
- this.dispatchEvent('close', { code: event.code, reason: event.reason });
658
- // Если соединение было закрыто намеренно, не пытаемся переподключиться
659
- if (this.intentionallyClosed) {
660
- return;
661
- }
662
- // Если включено автоматическое переподключение, пытаемся переподключиться
663
- if (this.options.autoReconnect) {
664
- this.reconnect();
665
- }
666
- };
667
- // Обработчик ошибок
668
- this.webSocket.onerror = (error) => {
669
- this.dispatchEvent('error', error);
670
- // Если соединение не установлено и это первая попытка, отклоняем Promise
671
- if (!this.connected && this.retryCount === 0) {
672
- clearTimeout(this.connectionTimeoutTimer);
673
- reject(new Error('Ошибка подключения WebSocket'));
674
- }
675
- };
676
- }
677
- catch (error) {
678
- reject(error);
679
- }
680
- });
681
- }
682
- /**
683
- * Переподключается к WebSocket серверу
684
- * @private
685
- */
686
- reconnect() {
687
- // Увеличиваем счетчик попыток
688
- this.retryCount++;
689
- // Если превышено максимальное количество попыток, не пытаемся переподключиться
690
- if (this.retryCount > (this.options.maxRetries || 5)) {
691
- this.dispatchEvent('maxRetries', { retries: this.retryCount });
692
- return;
693
- }
694
- // Вычисляем задержку перед переподключением с экспоненциальным ростом
695
- const delay = Math.min((this.options.retryDelay || 1000) * Math.pow(2, this.retryCount - 1), this.options.maxRetryDelay || 30000);
696
- // Пытаемся переподключиться после задержки
697
- this.reconnectTimer = setTimeout(() => {
698
- this.dispatchEvent('reconnect', { attempt: this.retryCount });
699
- this.connect().catch(() => { });
700
- }, delay);
701
- }
702
- /**
703
- * Закрывает WebSocket соединение
704
- * @param {number} [code=1000] Код закрытия
705
- * @param {string} [reason] Причина закрытия
706
- */
707
- close(code = 1000, reason) {
708
- this.intentionallyClosed = true;
709
- // Очищаем таймеры
710
- clearTimeout(this.reconnectTimer);
711
- clearTimeout(this.connectionTimeoutTimer);
712
- // Очищаем очередь сообщений
713
- this.messageQueue = [];
714
- // Закрываем соединение
715
- if (this.webSocket) {
716
- if (this.webSocket.readyState === WebSocket.OPEN) {
717
- this.webSocket.close(code, reason);
718
- }
719
- this.webSocket = null;
720
- }
721
- this.connected = false;
722
- }
723
- /**
724
- * Отправляет сообщение через WebSocket
725
- * @param {string | object} message Сообщение для отправки
726
- * @returns {boolean} Успешно ли отправлено сообщение
727
- */
728
- send(message) {
729
- const data = typeof message === 'string' ? message : JSON.stringify(message);
730
- if (this.webSocket && this.webSocket.readyState === WebSocket.OPEN) {
731
- this.webSocket.send(data);
732
- return true;
733
- }
734
- else {
735
- // Если соединение не установлено, добавляем сообщение в очередь
736
- this.messageQueue.push(data);
737
- // Если соединение не установлено и не закрыто намеренно, пытаемся подключиться
738
- if ((!this.webSocket || this.webSocket.readyState === WebSocket.CLOSED) && !this.intentionallyClosed) {
739
- this.connect().catch(() => { });
740
- }
741
- return false;
742
- }
743
- }
744
- /**
745
- * Проверяет, установлено ли соединение
746
- * @returns {boolean} Установлено ли соединение
747
- */
748
- isConnected() {
749
- return this.webSocket !== null && this.webSocket.readyState === WebSocket.OPEN;
750
- }
751
- /**
752
- * Добавляет обработчик события
753
- * @param {string} eventType Тип события
754
- * @param {WebSocketEventHandler} handler Обработчик события
755
- */
756
- on(eventType, handler) {
757
- if (!this.eventHandlers[eventType]) {
758
- this.eventHandlers[eventType] = [];
759
- }
760
- this.eventHandlers[eventType].push(handler);
761
- }
762
- /**
763
- * Удаляет обработчик события
764
- * @param {string} eventType Тип события
765
- * @param {WebSocketEventHandler} [handler] Обработчик события (если не указан, удаляются все обработчики)
766
- */
767
- off(eventType, handler) {
768
- if (!this.eventHandlers[eventType]) {
769
- return;
770
- }
771
- if (!handler) {
772
- // Если обработчик не указан, удаляем все обработчики для данного события
773
- delete this.eventHandlers[eventType];
774
- }
775
- else {
776
- // Если обработчик указан, удаляем только его
777
- this.eventHandlers[eventType] = this.eventHandlers[eventType].filter(h => h !== handler);
778
- // Если обработчиков больше нет, удаляем массив
779
- if (this.eventHandlers[eventType].length === 0) {
780
- delete this.eventHandlers[eventType];
781
- }
782
- }
783
- }
784
- /**
785
- * Вызывает обработчики для указанного события
786
- * @param {string} eventType Тип события
787
- * @param {any} data Данные события
788
- */
789
- dispatchEvent(eventType, data) {
790
- if (!this.eventHandlers[eventType]) {
791
- return;
792
- }
793
- for (const handler of this.eventHandlers[eventType]) {
794
- try {
795
- handler(data);
796
- }
797
- catch (e) {
798
- console.error(`Ошибка в обработчике события ${eventType}:`, e);
799
- }
800
- }
801
- }
802
- }
803
-
804
- /**
805
- * Пространства имен для WebSocket
806
- */
807
- exports.WebSocketNamespace = void 0;
808
- (function (WebSocketNamespace) {
809
- /** Пространство имен для рассуждений */
810
- WebSocketNamespace["REASONING"] = "reasoning";
811
- /** Пространство имен для индексации */
812
- WebSocketNamespace["INDEXING"] = "indexing";
813
- /** Пространство имен для уведомлений */
814
- WebSocketNamespace["NOTIFICATIONS"] = "notifications";
815
- })(exports.WebSocketNamespace || (exports.WebSocketNamespace = {}));
816
- /**
817
- * WebSocket клиент для работы с Code Solver API
818
- */
819
- class CodeSolverWebSocketClient {
820
- /**
821
- * Создает новый WebSocket клиент для Code Solver API
822
- * @param {string} baseURL Базовый URL API
823
- * @param {CodeSolverWebSocketOptions} [options] Опции клиента
824
- */
825
- constructor(baseURL, options = {}) {
826
- /** WebSocket клиенты для разных пространств имен */
827
- this.clients = new Map();
828
- /** Активная сессия рассуждения */
829
- this.activeReasoningId = null;
830
- /** Активная сессия индексации */
831
- this.activeProjectId = null;
832
- this.baseURL = baseURL.replace(/^http/, 'ws');
833
- this.options = {
834
- ...options,
835
- headers: {
836
- ...(options.headers || {}),
837
- ...(options.apiKey ? { 'Authorization': `Bearer ${options.apiKey}` } : {})
838
- }
839
- };
840
- }
841
- /**
842
- * Подключается к пространству имен WebSocket
843
- * @param {WebSocketNamespace} namespace Пространство имен
844
- * @param {Record<string, any>} [params] Параметры подключения
845
- * @returns {Promise<WebSocketClient>} WebSocket клиент
846
- */
847
- async connect(namespace, params = {}) {
848
- // Если клиент уже существует, возвращаем его
849
- if (this.clients.has(namespace)) {
850
- const client = this.clients.get(namespace);
851
- // Если клиент уже подключен, возвращаем его
852
- if (client.isConnected()) {
853
- return client;
854
- }
855
- }
856
- // Формируем URL для подключения
857
- const url = new URL(`${this.baseURL}/${namespace}`);
858
- // Добавляем параметры к URL
859
- Object.entries(params).forEach(([key, value]) => {
860
- url.searchParams.append(key, String(value));
861
- });
862
- // Создаем новый WebSocket клиент
863
- const client = new WebSocketClient(url.toString(), this.options);
864
- // Подключаемся к серверу
865
- await client.connect();
866
- // Сохраняем клиент
867
- this.clients.set(namespace, client);
868
- return client;
869
- }
870
- /**
871
- * Подключается к сессии рассуждения
872
- * @param {string} [reasoningId] Идентификатор рассуждения
873
- * @returns {Promise<void>}
874
- */
875
- async connectToReasoning(reasoningId) {
876
- // Если reasoningId не указан, используем активный
877
- const id = reasoningId || this.activeReasoningId;
878
- if (!id) {
879
- throw new Error('Необходимо указать идентификатор рассуждения');
880
- }
881
- // Сохраняем активный идентификатор рассуждения
882
- this.activeReasoningId = id;
883
- // Подключаемся к пространству имен
884
- await this.connect(exports.WebSocketNamespace.REASONING, { reasoningId: id });
885
- }
886
- /**
887
- * Подключается к сессии индексации проекта
888
- * @param {string} [projectId] Идентификатор проекта
889
- * @returns {Promise<void>}
890
- */
891
- async connectToIndexing(projectId) {
892
- // Если projectId не указан, используем активный
893
- const id = projectId || this.activeProjectId;
894
- if (!id) {
895
- throw new Error('Необходимо указать идентификатор проекта');
896
- }
897
- // Сохраняем активный идентификатор проекта
898
- this.activeProjectId = id;
899
- // Подключаемся к пространству имен
900
- await this.connect(exports.WebSocketNamespace.INDEXING, { projectId: id });
901
- }
902
- /**
903
- * Подключается к уведомлениям
904
- * @returns {Promise<void>}
905
- */
906
- async connectToNotifications() {
907
- // Подключаемся к пространству имен
908
- await this.connect(exports.WebSocketNamespace.NOTIFICATIONS);
909
- }
910
- /**
911
- * Отключается от пространства имен
912
- * @param {WebSocketNamespace} namespace Пространство имен
913
- */
914
- disconnect(namespace) {
915
- const client = this.clients.get(namespace);
916
- if (client) {
917
- client.close();
918
- this.clients.delete(namespace);
919
- }
920
- // Сбрасываем активные сессии
921
- if (namespace === exports.WebSocketNamespace.REASONING) {
922
- this.activeReasoningId = null;
923
- }
924
- else if (namespace === exports.WebSocketNamespace.INDEXING) {
925
- this.activeProjectId = null;
926
- }
927
- }
928
- /**
929
- * Отключается от всех пространств имен
930
- */
931
- disconnectAll() {
932
- for (const [namespace, client] of this.clients.entries()) {
933
- client.close();
934
- this.clients.delete(namespace);
935
- }
936
- // Сбрасываем активные сессии
937
- this.activeReasoningId = null;
938
- this.activeProjectId = null;
939
- }
940
- /**
941
- * Добавляет обработчик события для пространства имен
942
- * @param {string} eventType Тип события
943
- * @param {Function} handler Обработчик события
944
- * @param {WebSocketNamespace} [namespace] Пространство имен (если не указано, добавляется ко всем активным)
945
- */
946
- on(eventType, handler, namespace) {
947
- if (namespace) {
948
- // Если указано пространство имен, добавляем обработчик только к нему
949
- const client = this.clients.get(namespace);
950
- if (!client) {
951
- throw new Error(`Не подключен к пространству имен ${namespace}`);
952
- }
953
- client.on(eventType, handler);
954
- }
955
- else {
956
- // Если пространство имен не указано, добавляем обработчик ко всем активным пространствам
957
- for (const client of this.clients.values()) {
958
- client.on(eventType, handler);
959
- }
960
- }
961
- }
962
- /**
963
- * Удаляет обработчик события для пространства имен
964
- * @param {string} eventType Тип события
965
- * @param {Function} [handler] Обработчик события (если не указан, удаляются все обработчики)
966
- * @param {WebSocketNamespace} [namespace] Пространство имен (если не указано, удаляется из всех активных)
967
- */
968
- off(eventType, handler, namespace) {
969
- if (namespace) {
970
- // Если указано пространство имен, удаляем обработчик только из него
971
- const client = this.clients.get(namespace);
972
- if (!client) {
973
- return;
974
- }
975
- client.off(eventType, handler);
976
- }
977
- else {
978
- // Если пространство имен не указано, удаляем обработчик из всех активных пространств
979
- for (const client of this.clients.values()) {
980
- client.off(eventType, handler);
981
- }
982
- }
983
- }
984
- /**
985
- * Отправляет сообщение в пространство имен
986
- * @param {WebSocketNamespace} namespace Пространство имен
987
- * @param {string} eventType Тип события
988
- * @param {any} [data] Данные сообщения
989
- * @returns {boolean} Успешно ли отправлено сообщение
990
- */
991
- send(namespace, eventType, data) {
992
- const client = this.clients.get(namespace);
993
- if (!client) {
994
- throw new Error(`Не подключен к пространству имен ${namespace}`);
995
- }
996
- return client.send({
997
- event: eventType,
998
- data
999
- });
1000
- }
1001
- /**
1002
- * Отправляет сообщение в активную сессию рассуждения
1003
- * @param {string} eventType Тип события
1004
- * @param {any} [data] Данные сообщения
1005
- * @returns {boolean} Успешно ли отправлено сообщение
1006
- */
1007
- sendToReasoning(eventType, data) {
1008
- if (!this.activeReasoningId) {
1009
- throw new Error('Не подключен к сессии рассуждения');
1010
- }
1011
- return this.send(exports.WebSocketNamespace.REASONING, eventType, data);
1012
- }
1013
- /**
1014
- * Отправляет сообщение в активную сессию индексации
1015
- * @param {string} eventType Тип события
1016
- * @param {any} [data] Данные сообщения
1017
- * @returns {boolean} Успешно ли отправлено сообщение
1018
- */
1019
- sendToIndexing(eventType, data) {
1020
- if (!this.activeProjectId) {
1021
- throw new Error('Не подключен к сессии индексации');
1022
- }
1023
- return this.send(exports.WebSocketNamespace.INDEXING, eventType, data);
1024
- }
1025
- /**
1026
- * Отправляет сообщение в уведомления
1027
- * @param {string} eventType Тип события
1028
- * @param {any} [data] Данные сообщения
1029
- * @returns {boolean} Успешно ли отправлено сообщение
1030
- */
1031
- sendToNotifications(eventType, data) {
1032
- return this.send(exports.WebSocketNamespace.NOTIFICATIONS, eventType, data);
1033
- }
1034
- /**
1035
- * Проверяет, подключен ли клиент к указанному пространству имен
1036
- * @param {WebSocketNamespace} namespace Пространство имен
1037
- * @returns {boolean} Статус подключения
1038
- */
1039
- isConnected(namespace) {
1040
- const client = this.clients.get(namespace);
1041
- return client ? client.isConnected() : false;
1042
- }
1043
- /**
1044
- * Проверяет, подключен ли клиент к пространству имен рассуждений
1045
- * @returns {boolean} Статус подключения
1046
- */
1047
- isConnectedToReasoning() {
1048
- return this.isConnected(exports.WebSocketNamespace.REASONING);
1049
- }
1050
- /**
1051
- * Проверяет, подключен ли клиент к пространству имен индексации
1052
- * @returns {boolean} Статус подключения
1053
- */
1054
- isConnectedToIndexing() {
1055
- return this.isConnected(exports.WebSocketNamespace.INDEXING);
1056
- }
1057
- /**
1058
- * Проверяет, подключен ли клиент к пространству имен уведомлений
1059
- * @returns {boolean} Статус подключения
1060
- */
1061
- isConnectedToNotifications() {
1062
- return this.isConnected(exports.WebSocketNamespace.NOTIFICATIONS);
1063
- }
1064
- }
1065
-
1066
- /**
1067
- * API для работы с агентами
1068
- */
1069
- class AgentsApi {
1070
- /**
1071
- * Создает новый экземпляр API для работы с агентами
1072
- * @param {HttpClient} httpClient HTTP клиент
1073
- */
1074
- constructor(httpClient) {
1075
- this.httpClient = httpClient;
1076
- }
1077
- /**
1078
- * Получает список всех агентов проекта
1079
- * @param {string} projectId Идентификатор проекта
1080
- * @returns {Promise<Agent[]>} Список агентов
1081
- */
1082
- async getAgents(projectId) {
1083
- return this.httpClient.get(`/api/projects/${projectId}/agents`);
1084
- }
1085
- /**
1086
- * Получает агента по идентификатору
1087
- * @param {string} agentId Идентификатор агента
1088
- * @returns {Promise<Agent>} Агент
1089
- */
1090
- async getAgent(agentId) {
1091
- return this.httpClient.get(`/api/agents/${agentId}`);
1092
- }
1093
- /**
1094
- * Создает нового агента
1095
- * @param {CreateAgentParams} params Параметры создания агента
1096
- * @returns {Promise<Agent>} Созданный агент
1097
- */
1098
- async createAgent(params) {
1099
- return this.httpClient.post('/api/agents', params);
1100
- }
1101
- /**
1102
- * Обновляет агента
1103
- * @param {string} agentId Идентификатор агента
1104
- * @param {Partial<Pick<Agent, 'name' | 'description' | 'settings'>>} data Данные для обновления
1105
- * @returns {Promise<Agent>} Обновленный агент
1106
- */
1107
- async updateAgent(agentId, data) {
1108
- return this.httpClient.put(`/api/agents/${agentId}`, data);
1109
- }
1110
- /**
1111
- * Удаляет агента
1112
- * @param {string} agentId Идентификатор агента
1113
- * @returns {Promise<void>}
1114
- */
1115
- async deleteAgent(agentId) {
1116
- return this.httpClient.delete(`/api/agents/${agentId}`);
1117
- }
1118
- /**
1119
- * Запускает агента
1120
- * @param {string} agentId Идентификатор агента
1121
- * @param {object} [params] Параметры запуска
1122
- * @returns {Promise<Agent>} Обновленный агент
1123
- */
1124
- async startAgent(agentId, params) {
1125
- return this.httpClient.post(`/api/agents/${agentId}/start`, params);
1126
- }
1127
- /**
1128
- * Останавливает агента
1129
- * @param {string} agentId Идентификатор агента
1130
- * @returns {Promise<Agent>} Обновленный агент
1131
- */
1132
- async stopAgent(agentId) {
1133
- return this.httpClient.post(`/api/agents/${agentId}/stop`);
1134
- }
1135
- /**
1136
- * Получает задачи агента
1137
- * @param {string} agentId Идентификатор агента
1138
- * @returns {Promise<AgentTask[]>} Список задач
1139
- */
1140
- async getAgentTasks(agentId) {
1141
- return this.httpClient.get(`/api/agents/${agentId}/tasks`);
1142
- }
1143
- /**
1144
- * Создает новую задачу для агента
1145
- * @param {string} agentId Идентификатор агента
1146
- * @param {object} params Параметры задачи
1147
- * @param {string} params.description Описание задачи
1148
- * @param {object} [params.context] Контекст задачи
1149
- * @returns {Promise<AgentTask>} Созданная задача
1150
- */
1151
- async createAgentTask(agentId, params) {
1152
- return this.httpClient.post(`/api/agents/${agentId}/tasks`, params);
1153
- }
1154
- }
1155
-
1156
- // Версия SDK
1157
- const SDK_VERSION = '1.0.0';
1158
- /**
1159
- * Определение типа среды выполнения
1160
- * @returns 'browser' | 'node' | 'unknown'
1161
- */
1162
- function getEnvironment() {
1163
- if (typeof window !== 'undefined' && typeof window.document !== 'undefined') {
1164
- return 'browser';
1165
- }
1166
- else if (typeof process !== 'undefined' && process.versions && process.versions.node) {
1167
- return 'node';
1168
- }
1169
- return 'unknown';
1170
- }
1171
- /**
1172
- * Основной класс SDK для работы с Code Solver API
1173
- * Поддерживает работу как в браузере, так и в Node.js
1174
- */
1175
- class CodeSolverSDK {
1176
- /**
1177
- * Создает новый экземпляр SDK
1178
- * @param {CodeSolverSDKOptions} options Опции SDK
1179
- */
1180
- constructor(options) {
1181
- /** WebSocket клиент для работы с реалтайм API */
1182
- this.wsClient = null;
1183
- this._options = {
1184
- ...options,
1185
- mode: options.mode || 'auto'
1186
- };
1187
- // Определяем среду выполнения
1188
- this.environment = this._options.mode === 'auto'
1189
- ? getEnvironment()
1190
- : this._options.mode === 'browser' ? 'browser' : 'node';
1191
- // Инициализируем HTTP клиент
1192
- this.httpClient = new HttpClient(this._options.baseURL, {
1193
- headers: {
1194
- ...(this._options.apiKey ? { 'Authorization': `Bearer ${this._options.apiKey}` } : {}),
1195
- ...(this._options.headers || {})
1196
- },
1197
- timeout: this._options.timeout,
1198
- httpsAgent: this.environment === 'node' ? this._options.httpsAgent : undefined
1199
- });
1200
- // Инициализируем API клиенты
1201
- this._agents = new AgentsApi(this.httpClient);
1202
- this._context = new ContextApi(this.httpClient);
1203
- this._projects = new ProjectsApi(this.httpClient);
1204
- this._search = new SearchApi(this.httpClient);
1205
- this._reasoning = new ReasoningApi(this.httpClient);
1206
- this._codeModification = new CodeModificationApi(this.httpClient);
1207
- }
1208
- /**
1209
- * Проверяет доступность API
1210
- * @returns {Promise<boolean>} Доступен ли API
1211
- */
1212
- async checkHealth() {
1213
- try {
1214
- await this.httpClient.get('/health');
1215
- return true;
1216
- }
1217
- catch (error) {
1218
- return false;
1219
- }
1220
- }
1221
- /**
1222
- * Получает WebSocket клиент
1223
- * @returns {CodeSolverWebSocketClient} WebSocket клиент
1224
- */
1225
- getWebSocketClient() {
1226
- if (!this.wsClient) {
1227
- this.wsClient = new CodeSolverWebSocketClient(this._options.baseURL, {
1228
- apiKey: this._options.apiKey,
1229
- headers: this._options.headers
1230
- });
1231
- }
1232
- return this.wsClient;
1233
- }
1234
- /**
1235
- * API для работы с агентами
1236
- */
1237
- get agents() {
1238
- return this._agents;
1239
- }
1240
- /**
1241
- * API для работы с контекстом
1242
- */
1243
- get context() {
1244
- return this._context;
1245
- }
1246
- /**
1247
- * API для работы с проектами
1248
- */
1249
- get projects() {
1250
- return this._projects;
1251
- }
1252
- /**
1253
- * API для поиска кода
1254
- */
1255
- get search() {
1256
- return this._search;
1257
- }
1258
- /**
1259
- * API для работы с рассуждениями
1260
- */
1261
- get reasoning() {
1262
- return this._reasoning;
1263
- }
1264
- /**
1265
- * API для модификации кода
1266
- */
1267
- get codeModification() {
1268
- return this._codeModification;
1269
- }
1270
- /**
1271
- * Опции SDK
1272
- */
1273
- get options() {
1274
- return this._options;
1275
- }
1276
- /**
1277
- * Получает текущую среду выполнения
1278
- * @returns {string} Среда выполнения ('browser', 'node', 'unknown')
1279
- */
1280
- getEnvironment() {
1281
- return this.environment;
1282
- }
1283
- /**
1284
- * Закрывает все соединения и освобождает ресурсы
1285
- */
1286
- dispose() {
1287
- if (this.wsClient) {
1288
- this.wsClient.disconnectAll();
1289
- this.wsClient = null;
1290
- }
1291
- }
1292
- /**
1293
- * Устанавливает глобальный обработчик ошибок SDK
1294
- * @param {(error: Error) => void} handler Функция-обработчик ошибок
1295
- */
1296
- static setErrorHandler(handler) {
1297
- CodeSolverSDK.errorHandler = handler;
1298
- }
1299
- /**
1300
- * Обрабатывает ошибку через глобальный обработчик, если он установлен
1301
- * @param {Error} error Ошибка для обработки
1302
- */
1303
- static handleError(error) {
1304
- if (CodeSolverSDK.errorHandler) {
1305
- CodeSolverSDK.errorHandler(error);
1306
- }
1307
- else {
1308
- console.error('[CodeSolverSDK]', error);
1309
- }
1310
- }
1311
- /**
1312
- * Возвращает текущую версию SDK
1313
- * @returns {string} Версия SDK
1314
- */
1315
- static getVersion() {
1316
- return SDK_VERSION;
1317
- }
1318
- /**
1319
- * Возвращает текущую версию SDK
1320
- * @returns {string} Версия SDK
1321
- */
1322
- getVersion() {
1323
- return SDK_VERSION;
1324
- }
1325
- /**
1326
- * Устанавливает новый API ключ для SDK
1327
- * @param {string} apiKey Новый API ключ
1328
- */
1329
- setApiKey(apiKey) {
1330
- if (!apiKey) {
1331
- throw new Error('API ключ не может быть пустым');
1332
- }
1333
- // Обновляем опции
1334
- this._options.apiKey = apiKey;
1335
- // Пересоздаем HTTP клиент с новым API ключом
1336
- const newHttpClient = new HttpClient(this._options.baseURL, {
1337
- headers: {
1338
- ...this._options.headers,
1339
- 'Authorization': `Bearer ${apiKey}`
1340
- },
1341
- timeout: this._options.timeout,
1342
- httpsAgent: this.environment === 'node' ? this._options.httpsAgent : undefined
1343
- });
1344
- // Обновляем ссылки на клиент и API
1345
- this.httpClient = newHttpClient;
1346
- this._agents = new AgentsApi(newHttpClient);
1347
- this._context = new ContextApi(newHttpClient);
1348
- this._projects = new ProjectsApi(newHttpClient);
1349
- this._search = new SearchApi(newHttpClient);
1350
- this._reasoning = new ReasoningApi(newHttpClient);
1351
- this._codeModification = new CodeModificationApi(newHttpClient);
1352
- // Если есть WebSocket клиент, пересоздаем его
1353
- if (this.wsClient) {
1354
- const isConnected = this.wsClient.isConnectedToReasoning() || this.wsClient.isConnectedToIndexing();
1355
- this.wsClient.disconnectAll();
1356
- this.wsClient = new CodeSolverWebSocketClient(this._options.baseURL, {
1357
- apiKey,
1358
- headers: this._options.headers
1359
- });
1360
- // Если был подключен, восстанавливаем соединение
1361
- if (isConnected) {
1362
- this.connect().catch(() => { });
1363
- }
1364
- }
1365
- }
1366
- /**
1367
- * Подключается к WebSocket серверу
1368
- * @returns {Promise<boolean>} Promise с результатом подключения
1369
- */
1370
- async connect() {
1371
- try {
1372
- const wsClient = this.getWebSocketClient();
1373
- // Подключаемся к обоим пространствам имен
1374
- await wsClient.connectToReasoning();
1375
- await wsClient.connectToIndexing();
1376
- return true;
1377
- }
1378
- catch (error) {
1379
- CodeSolverSDK.handleError(error);
1380
- return false;
1381
- }
1382
- }
1383
- /**
1384
- * Отключается от WebSocket сервера
1385
- * @returns {Promise<void>} Promise без результата
1386
- */
1387
- async disconnect() {
1388
- if (this.wsClient) {
1389
- await this.wsClient.disconnectAll();
1390
- }
1391
- }
1392
- /**
1393
- * Проверяет, подключен ли SDK к WebSocket серверу
1394
- * @returns {boolean} Статус подключения
1395
- */
1396
- isConnected() {
1397
- if (!this.wsClient)
1398
- return false;
1399
- return this.wsClient.isConnectedToReasoning() || this.wsClient.isConnectedToIndexing();
1400
- }
1401
- /**
1402
- * Проверяет доступность API (алиас для checkHealth)
1403
- * @returns {Promise<boolean>} Promise с результатом проверки
1404
- */
1405
- async isHealthy() {
1406
- return this.checkHealth();
1407
- }
1408
- /**
1409
- * Проверяет доступность всех сервисов API
1410
- * @returns {Promise<{[key: string]: boolean}>} Статус каждого сервиса
1411
- */
1412
- async checkServices() {
1413
- try {
1414
- const results = {
1415
- api: false,
1416
- websocket: false,
1417
- database: false,
1418
- search: false
1419
- };
1420
- try {
1421
- // Проверка API
1422
- results.api = await this.checkHealth();
1423
- // Проверка других компонентов через запрос статуса
1424
- const response = await this.httpClient.get('/api/v1/status');
1425
- if (response && typeof response === 'object') {
1426
- results.database = Boolean(response.database?.connected);
1427
- results.search = Boolean(response.search?.connected);
1428
- // Проверка WebSocket соединения
1429
- if (this.wsClient) {
1430
- results.websocket = this.wsClient.isConnectedToReasoning() ||
1431
- this.wsClient.isConnectedToIndexing();
1432
- }
1433
- else {
1434
- try {
1435
- const wsClient = this.getWebSocketClient();
1436
- await wsClient.connectToReasoning();
1437
- results.websocket = true;
1438
- await wsClient.disconnect(exports.WebSocketNamespace.REASONING);
1439
- }
1440
- catch (e) {
1441
- results.websocket = false;
1442
- }
1443
- }
1444
- }
1445
- }
1446
- catch (error) {
1447
- // Игнорируем ошибки при проверке
1448
- }
1449
- return results;
1450
- }
1451
- catch (error) {
1452
- return {
1453
- api: false,
1454
- websocket: false,
1455
- database: false,
1456
- search: false
1457
- };
1458
- }
1459
- }
1460
- /**
1461
- * Закрывает соединение с сервером (алиас для dispose)
1462
- */
1463
- close() {
1464
- this.dispose();
1465
- return Promise.resolve();
1466
- }
1467
- }
1468
- /** Глобальный обработчик ошибок */
1469
- CodeSolverSDK.errorHandler = null;
1470
-
1471
- // В браузере будем использовать нативный EventSource или полифилл
1472
- const BrowserEventSource = typeof EventSource !== 'undefined' ? EventSource : eventSourcePolyfill.EventSourcePolyfill;
1473
- // Проверяем, находимся ли мы в браузере
1474
- const isBrowser = typeof window !== 'undefined' && typeof window.document !== 'undefined';
1475
- /**
1476
- * Клиент для работы с Server-Sent Events (SSE)
1477
- * Поддерживает работу как в браузере, так и в Node.js
1478
- */
1479
- class SseClient {
1480
- /**
1481
- * Создает новый SSE клиент
1482
- * @param {string} url URL для подключения
1483
- * @param {SseClientOptions} [options] Опции клиента
1484
- */
1485
- constructor(url, options = {}) {
1486
- /** Экземпляр EventSource */
1487
- this.eventSource = null;
1488
- /** Счетчик попыток переподключения */
1489
- this.retryCount = 0;
1490
- /** Флаг, указывающий, что соединение было закрыто намеренно */
1491
- this.intentionallyClosed = false;
1492
- /** Таймер переподключения */
1493
- this.reconnectTimer = null;
1494
- /** Таймер таймаута соединения */
1495
- this.connectionTimeoutTimer = null;
1496
- /** Обработчики событий */
1497
- this.eventHandlers = {};
1498
- this.url = url;
1499
- this.options = {
1500
- headers: options.headers || {},
1501
- connectionTimeout: options.connectionTimeout || 30000,
1502
- maxRetries: options.maxRetries || 5,
1503
- retryDelay: options.retryDelay || 1000,
1504
- maxRetryDelay: options.maxRetryDelay || 30000
1505
- };
1506
- }
1507
- /**
1508
- * Подключается к SSE эндпоинту
1509
- * @returns {Promise<void>}
1510
- */
1511
- connect() {
1512
- // Если соединение уже установлено, возвращаем Promise.resolve
1513
- if (this.eventSource && this.eventSource.readyState === 1) {
1514
- return Promise.resolve();
1515
- }
1516
- // Сбрасываем флаг намеренного закрытия
1517
- this.intentionallyClosed = false;
1518
- return new Promise((resolve, reject) => {
1519
- try {
1520
- // Создаем новый экземпляр EventSource
1521
- const EventSourceImpl = isBrowser ? BrowserEventSource : require('eventsource');
1522
- this.eventSource = new EventSourceImpl(this.url, {
1523
- headers: this.options.headers,
1524
- withCredentials: true
1525
- });
1526
- // Устанавливаем таймаут соединения
1527
- this.connectionTimeoutTimer = setTimeout(() => {
1528
- if (this.eventSource && this.eventSource.readyState !== 1) {
1529
- reject(new Error('Таймаут подключения SSE'));
1530
- this.close();
1531
- }
1532
- }, this.options.connectionTimeout);
1533
- // Проверяем, что this.eventSource не null
1534
- if (!this.eventSource) {
1535
- reject(new Error('Не удалось создать EventSource'));
1536
- return;
1537
- }
1538
- // Обработчик открытия соединения
1539
- this.eventSource.onopen = () => {
1540
- clearTimeout(this.connectionTimeoutTimer);
1541
- this.retryCount = 0;
1542
- resolve();
1543
- this.dispatchEvent('open', {});
1544
- };
1545
- // Обработчик сообщений
1546
- this.eventSource.onmessage = (event) => {
1547
- try {
1548
- const data = JSON.parse(event.data);
1549
- this.dispatchEvent('message', data);
1550
- // Также вызываем специальный обработчик для конкретного типа события,
1551
- // если такой тип указан в данных
1552
- if (data && data.type) {
1553
- this.dispatchEvent(data.type, data);
1554
- }
1555
- }
1556
- catch (error) {
1557
- this.dispatchEvent('error', { error, message: 'Ошибка при обработке сообщения SSE' });
1558
- }
1559
- };
1560
- // Обработчик ошибок
1561
- this.eventSource.onerror = (error) => {
1562
- clearTimeout(this.connectionTimeoutTimer);
1563
- if (this.intentionallyClosed) {
1564
- return;
1565
- }
1566
- // Если соединение уже установлено и произошла ошибка, просто сообщаем об ошибке
1567
- if (this.eventSource && this.eventSource.readyState === 1) {
1568
- this.dispatchEvent('error', { error, message: 'Ошибка SSE соединения' });
1569
- return;
1570
- }
1571
- // Если это первая попытка подключения, отклоняем Promise
1572
- if (this.retryCount === 0) {
1573
- reject(new Error('Ошибка подключения SSE'));
1574
- }
1575
- // Запускаем процесс переподключения
1576
- this.reconnect();
1577
- };
1578
- // Настраиваем обработчики для всех добавленных событий
1579
- for (const eventType in this.eventHandlers) {
1580
- if (eventType !== 'message' && eventType !== 'open' && eventType !== 'error') {
1581
- this.eventSource.addEventListener(eventType, (event) => {
1582
- try {
1583
- const data = JSON.parse(event.data);
1584
- this.dispatchEvent(eventType, data);
1585
- }
1586
- catch (e) {
1587
- this.dispatchEvent(eventType, event.data);
1588
- }
1589
- });
1590
- }
1591
- }
1592
- }
1593
- catch (error) {
1594
- reject(error);
1595
- }
1596
- });
1597
- }
1598
- /**
1599
- * Закрывает SSE соединение
1600
- */
1601
- close() {
1602
- this.intentionallyClosed = true;
1603
- // Очищаем таймеры
1604
- clearTimeout(this.reconnectTimer);
1605
- clearTimeout(this.connectionTimeoutTimer);
1606
- // Закрываем соединение
1607
- if (this.eventSource) {
1608
- this.eventSource.close();
1609
- this.eventSource = null;
1610
- }
1611
- this.dispatchEvent('close', {});
1612
- }
1613
- /**
1614
- * Добавляет обработчик события
1615
- * @param {string} eventType Тип события
1616
- * @param {SseEventHandler} handler Обработчик события
1617
- */
1618
- on(eventType, handler) {
1619
- if (!this.eventHandlers[eventType]) {
1620
- this.eventHandlers[eventType] = [];
1621
- // Если соединение уже установлено, добавляем обработчик события
1622
- if (this.eventSource && this.eventSource.readyState === 1 &&
1623
- eventType !== 'message' && eventType !== 'open' && eventType !== 'error') {
1624
- this.eventSource.addEventListener(eventType, (event) => {
1625
- try {
1626
- const data = JSON.parse(event.data);
1627
- this.dispatchEvent(eventType, data);
1628
- }
1629
- catch (e) {
1630
- this.dispatchEvent(eventType, event.data);
1631
- }
1632
- });
1633
- }
1634
- }
1635
- this.eventHandlers[eventType].push(handler);
1636
- }
1637
- /**
1638
- * Удаляет обработчик события
1639
- * @param {string} eventType Тип события
1640
- * @param {SseEventHandler} [handler] Обработчик события (если не указан, удаляются все обработчики)
1641
- */
1642
- off(eventType, handler) {
1643
- if (!this.eventHandlers[eventType]) {
1644
- return;
1645
- }
1646
- if (!handler) {
1647
- // Если обработчик не указан, удаляем все обработчики для данного события
1648
- delete this.eventHandlers[eventType];
1649
- }
1650
- else {
1651
- // Если обработчик указан, удаляем только его
1652
- this.eventHandlers[eventType] = this.eventHandlers[eventType].filter(h => h !== handler);
1653
- // Если обработчиков больше нет, удаляем массив
1654
- if (this.eventHandlers[eventType].length === 0) {
1655
- delete this.eventHandlers[eventType];
1656
- }
1657
- }
1658
- }
1659
- /**
1660
- * Вызывает обработчики для указанного события
1661
- * @param {string} eventType Тип события
1662
- * @param {any} data Данные события
1663
- */
1664
- dispatchEvent(eventType, data) {
1665
- if (!this.eventHandlers[eventType]) {
1666
- return;
1667
- }
1668
- for (const handler of this.eventHandlers[eventType]) {
1669
- try {
1670
- handler(data);
1671
- }
1672
- catch (e) {
1673
- console.error(`Ошибка в обработчике события ${eventType}:`, e);
1674
- }
1675
- }
1676
- }
1677
- /**
1678
- * Переподключается к SSE эндпоинту с экспоненциальной задержкой
1679
- * @private
1680
- */
1681
- reconnect() {
1682
- // Увеличиваем счетчик попыток
1683
- this.retryCount++;
1684
- // Если превышено максимальное количество попыток, прекращаем
1685
- if (this.retryCount > (this.options.maxRetries || 5)) {
1686
- this.dispatchEvent('maxRetries', { retries: this.retryCount });
1687
- return;
1688
- }
1689
- // Вычисляем задержку перед переподключением с экспоненциальным ростом
1690
- const delay = Math.min((this.options.retryDelay || 1000) * Math.pow(2, this.retryCount - 1), this.options.maxRetryDelay || 30000);
1691
- // Пытаемся переподключиться после задержки
1692
- this.reconnectTimer = setTimeout(() => {
1693
- this.dispatchEvent('reconnect', { attempt: this.retryCount });
1694
- this.connect().catch(() => { });
1695
- }, delay);
1696
- }
1697
- }
1698
-
1699
- /**
1700
- * События индексации
1701
- */
1702
- var IndexingEvent;
1703
- (function (IndexingEvent) {
1704
- /** Начало индексации */
1705
- IndexingEvent["START"] = "indexing_start";
1706
- /** Прогресс индексации */
1707
- IndexingEvent["PROGRESS"] = "indexing_progress";
1708
- /** Завершение индексации */
1709
- IndexingEvent["COMPLETE"] = "indexing_complete";
1710
- /** Ошибка индексации */
1711
- IndexingEvent["ERROR"] = "indexing_error";
1712
- })(IndexingEvent || (IndexingEvent = {}));
1713
- /**
1714
- * WebSocket клиент для работы с индексацией
1715
- */
1716
- class IndexingWebSocketClient extends WebSocketClient {
1717
- /**
1718
- * Создает новый WebSocket клиент для индексации
1719
- * @param {string} url URL для подключения
1720
- * @param {IndexingWebSocketOptions} [options] Опции клиента
1721
- */
1722
- constructor(url, options = {}) {
1723
- // Сохраняем базовый URL
1724
- const baseUrl = url;
1725
- // Формируем URL с параметрами для проекта если он указан
1726
- let targetUrl = url;
1727
- if (options.projectId) {
1728
- const urlWithParams = new URL(url);
1729
- urlWithParams.searchParams.append('projectId', options.projectId);
1730
- urlWithParams.searchParams.append('type', 'indexing');
1731
- targetUrl = urlWithParams.toString();
1732
- }
1733
- super(targetUrl, {
1734
- ...options,
1735
- headers: {
1736
- ...(options.headers || {}),
1737
- ...(options.apiKey ? { 'Authorization': `Bearer ${options.apiKey}` } : {})
1738
- }
1739
- });
1740
- /** Идентификатор проекта */
1741
- this.projectId = null;
1742
- this.baseUrl = baseUrl;
1743
- this.projectId = options.projectId || null;
1744
- }
1745
- /**
1746
- * Устанавливает идентификатор проекта
1747
- * @param {string} projectId Идентификатор проекта
1748
- */
1749
- setProjectId(projectId) {
1750
- this.projectId = projectId;
1751
- }
1752
- /**
1753
- * Подключается к WebSocket для отслеживания индексации
1754
- * @param {string} [projectId] Идентификатор проекта (если не был указан в конструкторе)
1755
- * @returns {Promise<void>}
1756
- */
1757
- async connect(projectId) {
1758
- const targetProjectId = projectId || this.projectId;
1759
- if (!targetProjectId) {
1760
- throw new Error('Project ID is required for indexing WebSocket connection');
1761
- }
1762
- // Сохраняем ID проекта
1763
- this.projectId = targetProjectId;
1764
- // Если проект изменился и клиент уже подключен, отключаемся
1765
- if (projectId && this.isConnected()) {
1766
- this.close();
1767
- }
1768
- // Выполняем соединение
1769
- await super.connect();
1770
- }
1771
- /**
1772
- * Подписывается на события начала индексации
1773
- * @param {(data: {projectId: string}) => void} handler Обработчик события
1774
- */
1775
- onStart(handler) {
1776
- this.on(IndexingEvent.START, handler);
1777
- }
1778
- /**
1779
- * Подписывается на события прогресса индексации
1780
- * @param {(data: IndexingProgressData) => void} handler Обработчик события
1781
- */
1782
- onProgress(handler) {
1783
- this.on(IndexingEvent.PROGRESS, handler);
1784
- }
1785
- /**
1786
- * Подписывается на события завершения индексации
1787
- * @param {(data: IndexingCompleteData) => void} handler Обработчик события
1788
- */
1789
- onComplete(handler) {
1790
- this.on(IndexingEvent.COMPLETE, handler);
1791
- }
1792
- /**
1793
- * Подписывается на события ошибок индексации
1794
- * @param {(data: IndexingErrorData) => void} handler Обработчик события
1795
- */
1796
- onError(handler) {
1797
- this.on(IndexingEvent.ERROR, handler);
1798
- }
1799
- }
1800
-
1801
- /**
1802
- * Общие типы данных для SDK
1803
- */
1804
- /**
1805
- * Уровень логирования
1806
- */
1807
- exports.LogLevel = void 0;
1808
- (function (LogLevel) {
1809
- LogLevel["DEBUG"] = "debug";
1810
- LogLevel["INFO"] = "info";
1811
- LogLevel["WARN"] = "warn";
1812
- LogLevel["ERROR"] = "error";
1813
- })(exports.LogLevel || (exports.LogLevel = {}));
1814
-
1815
- // Экспорт основного класса SDK
1816
- // Версия SDK
1817
- const VERSION = '1.0.0';
1818
- // Простой пример использования SDK
1819
- /**
1820
- * Пример использования SDK:
1821
- *
1822
- * ```typescript
1823
- * // ESM импорт (браузер, современный Node.js)
1824
- * import { CodeSolverSDK } from 'code-solver-sdk';
1825
- *
1826
- * // CommonJS импорт (Node.js)
1827
- * // const { CodeSolverSDK } = require('code-solver-sdk');
1828
- *
1829
- * const sdk = new CodeSolverSDK({
1830
- * baseURL: 'https://api.example.com',
1831
- * apiKey: 'your-api-key' // если требуется
1832
- * });
1833
- *
1834
- * // Пример работы с проектами
1835
- * async function example() {
1836
- * // Проверка доступности API
1837
- * const isHealthy = await sdk.checkHealth();
1838
- * console.log('API доступен:', isHealthy);
1839
- *
1840
- * // Получение списка проектов
1841
- * const projects = await sdk.projects.getAllProjects();
1842
- * console.log('Проекты:', projects);
1843
- *
1844
- * // Создание нового проекта
1845
- * const newProject = await sdk.projects.createProject('Мой проект', '/path/to/project');
1846
- * console.log('Новый проект:', newProject);
1847
- *
1848
- * // Запуск индексации
1849
- * await sdk.projects.indexProject(newProject.id);
1850
- *
1851
- * // Поиск кода
1852
- * const searchResults = await sdk.search.searchCode(newProject.id, {
1853
- * query: 'function example',
1854
- * limit: 10
1855
- * });
1856
- * console.log('Результаты поиска:', searchResults);
1857
- *
1858
- * // Работа с рассуждениями
1859
- * const reasoning = await sdk.reasoning.createReasoning({
1860
- * projectId: newProject.id,
1861
- * query: 'Объясни, как работает этот проект'
1862
- * });
1863
- *
1864
- * // Запуск процесса рассуждения
1865
- * await sdk.reasoning.startReasoning(reasoning.id);
1866
- *
1867
- * // Подключение через WebSocket
1868
- * const wsClient = sdk.getWebSocketClient();
1869
- * await wsClient.connectToReasoning();
1870
- *
1871
- * // Обработка событий
1872
- * wsClient.on('thinking', (data) => {
1873
- * console.log('Размышление:', data.content);
1874
- * });
1875
- *
1876
- * wsClient.on('complete', (data) => {
1877
- * console.log('Завершено:', data.content);
1878
- * wsClient.disconnectAll();
1879
- * });
1880
- * }
1881
- * ```
1882
- */
1883
-
1884
- exports.AgentsApi = AgentsApi;
1885
- exports.CodeModificationApi = CodeModificationApi;
1886
- exports.CodeSolverSDK = CodeSolverSDK;
1887
- exports.CodeSolverWebSocketClient = CodeSolverWebSocketClient;
1888
- exports.ContextApi = ContextApi;
1889
- exports.HttpClient = HttpClient;
1890
- exports.IndexingWebSocketClient = IndexingWebSocketClient;
1891
- exports.ProjectsApi = ProjectsApi;
1892
- exports.ReasoningApi = ReasoningApi;
1893
- exports.SearchApi = SearchApi;
1894
- exports.SseClient = SseClient;
1895
- exports.VERSION = VERSION;
1896
- exports.WebSocketClient = WebSocketClient;
1897
- exports.default = CodeSolverSDK;
1898
-
1899
- Object.defineProperty(exports, '__esModule', { value: true });
1900
-
1901
- }));
1902
- //# sourceMappingURL=code-solver-sdk.js.map