solver-sdk 1.0.3 → 1.0.6

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