solver-sdk 1.8.0 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (181) hide show
  1. package/README.md +176 -468
  2. package/dist/cjs/api/{chat-api.js → chat-api/index.js} +77 -125
  3. package/dist/cjs/api/chat-api/index.js.map +1 -0
  4. package/dist/cjs/api/chat-api/interfaces.js +3 -0
  5. package/dist/cjs/api/chat-api/interfaces.js.map +1 -0
  6. package/dist/cjs/api/chat-api/models.js +6 -0
  7. package/dist/cjs/api/chat-api/models.js.map +1 -0
  8. package/dist/cjs/api/chat-api/stream-utils.js +192 -0
  9. package/dist/cjs/api/chat-api/stream-utils.js.map +1 -0
  10. package/dist/cjs/api/chat-api/websocket-helpers.js +211 -0
  11. package/dist/cjs/api/chat-api/websocket-helpers.js.map +1 -0
  12. package/dist/cjs/api/projects-api.js +275 -3
  13. package/dist/cjs/api/projects-api.js.map +1 -1
  14. package/dist/cjs/code-solver-sdk.js +21 -23
  15. package/dist/cjs/code-solver-sdk.js.map +1 -1
  16. package/dist/cjs/constants/websocket-events.constants.js +90 -52
  17. package/dist/cjs/constants/websocket-events.constants.js.map +1 -1
  18. package/dist/cjs/constants/websocket-namespaces.constants.js +18 -0
  19. package/dist/cjs/constants/websocket-namespaces.constants.js.map +1 -0
  20. package/dist/cjs/interfaces/websocket/callbacks.interfaces.js +3 -0
  21. package/dist/cjs/interfaces/websocket/callbacks.interfaces.js.map +1 -0
  22. package/dist/cjs/interfaces/websocket/client-options.interfaces.js +3 -0
  23. package/dist/cjs/interfaces/websocket/client-options.interfaces.js.map +1 -0
  24. package/dist/cjs/interfaces/websocket/events.interfaces.js +3 -0
  25. package/dist/cjs/interfaces/websocket/events.interfaces.js.map +1 -0
  26. package/dist/cjs/interfaces/websocket/stats.interfaces.js +3 -0
  27. package/dist/cjs/interfaces/websocket/stats.interfaces.js.map +1 -0
  28. package/dist/cjs/utils/code-solver-websocket-client.js +383 -1473
  29. package/dist/cjs/utils/code-solver-websocket-client.js.map +1 -1
  30. package/dist/cjs/utils/connection-state-manager.js +133 -0
  31. package/dist/cjs/utils/connection-state-manager.js.map +1 -0
  32. package/dist/cjs/utils/http-client.js +7 -0
  33. package/dist/cjs/utils/http-client.js.map +1 -1
  34. package/dist/cjs/utils/logger.js +106 -0
  35. package/dist/cjs/utils/logger.js.map +1 -0
  36. package/dist/cjs/utils/ping-pong-manager.js +306 -0
  37. package/dist/cjs/utils/ping-pong-manager.js.map +1 -0
  38. package/dist/cjs/utils/reasoning-auth-helper.js +58 -0
  39. package/dist/cjs/utils/reasoning-auth-helper.js.map +1 -0
  40. package/dist/cjs/utils/session-manager.js +114 -0
  41. package/dist/cjs/utils/session-manager.js.map +1 -0
  42. package/dist/cjs/utils/websocket-client.js +37 -10
  43. package/dist/cjs/utils/websocket-client.js.map +1 -1
  44. package/dist/cjs/ws/base-ws-client.js +286 -0
  45. package/dist/cjs/ws/base-ws-client.js.map +1 -0
  46. package/dist/cjs/ws/dependencies-ws-client.js +11 -0
  47. package/dist/cjs/ws/dependencies-ws-client.js.map +1 -0
  48. package/dist/cjs/ws/diagnostics-service.js +170 -0
  49. package/dist/cjs/ws/diagnostics-service.js.map +1 -0
  50. package/dist/cjs/ws/indexing-ws-client.js +223 -0
  51. package/dist/cjs/ws/indexing-ws-client.js.map +1 -0
  52. package/dist/cjs/ws/notifications-ws-client.js +12 -0
  53. package/dist/cjs/ws/notifications-ws-client.js.map +1 -0
  54. package/dist/cjs/ws/reasoning-ws-client.js +330 -0
  55. package/dist/cjs/ws/reasoning-ws-client.js.map +1 -0
  56. package/dist/esm/api/{chat-api.js → chat-api/index.js} +74 -125
  57. package/dist/esm/api/chat-api/index.js.map +1 -0
  58. package/dist/esm/api/chat-api/interfaces.js +2 -0
  59. package/dist/esm/api/chat-api/interfaces.js.map +1 -0
  60. package/dist/esm/api/chat-api/models.js +5 -0
  61. package/dist/esm/api/chat-api/models.js.map +1 -0
  62. package/dist/esm/api/chat-api/stream-utils.js +188 -0
  63. package/dist/esm/api/chat-api/stream-utils.js.map +1 -0
  64. package/dist/esm/api/chat-api/websocket-helpers.js +205 -0
  65. package/dist/esm/api/chat-api/websocket-helpers.js.map +1 -0
  66. package/dist/esm/api/projects-api.js +275 -3
  67. package/dist/esm/api/projects-api.js.map +1 -1
  68. package/dist/esm/code-solver-sdk.js +13 -15
  69. package/dist/esm/code-solver-sdk.js.map +1 -1
  70. package/dist/esm/constants/websocket-events.constants.js +89 -51
  71. package/dist/esm/constants/websocket-events.constants.js.map +1 -1
  72. package/dist/esm/constants/websocket-namespaces.constants.js +15 -0
  73. package/dist/esm/constants/websocket-namespaces.constants.js.map +1 -0
  74. package/dist/esm/interfaces/websocket/callbacks.interfaces.js +2 -0
  75. package/dist/esm/interfaces/websocket/callbacks.interfaces.js.map +1 -0
  76. package/dist/esm/interfaces/websocket/client-options.interfaces.js +2 -0
  77. package/dist/esm/interfaces/websocket/client-options.interfaces.js.map +1 -0
  78. package/dist/esm/interfaces/websocket/events.interfaces.js +2 -0
  79. package/dist/esm/interfaces/websocket/events.interfaces.js.map +1 -0
  80. package/dist/esm/interfaces/websocket/stats.interfaces.js +2 -0
  81. package/dist/esm/interfaces/websocket/stats.interfaces.js.map +1 -0
  82. package/dist/esm/utils/code-solver-websocket-client.js +382 -1473
  83. package/dist/esm/utils/code-solver-websocket-client.js.map +1 -1
  84. package/dist/esm/utils/connection-state-manager.js +129 -0
  85. package/dist/esm/utils/connection-state-manager.js.map +1 -0
  86. package/dist/esm/utils/http-client.js +7 -0
  87. package/dist/esm/utils/http-client.js.map +1 -1
  88. package/dist/esm/utils/logger.js +101 -0
  89. package/dist/esm/utils/logger.js.map +1 -0
  90. package/dist/esm/utils/ping-pong-manager.js +302 -0
  91. package/dist/esm/utils/ping-pong-manager.js.map +1 -0
  92. package/dist/esm/utils/reasoning-auth-helper.js +54 -0
  93. package/dist/esm/utils/reasoning-auth-helper.js.map +1 -0
  94. package/dist/esm/utils/session-manager.js +109 -0
  95. package/dist/esm/utils/session-manager.js.map +1 -0
  96. package/dist/esm/utils/websocket-client.js +37 -10
  97. package/dist/esm/utils/websocket-client.js.map +1 -1
  98. package/dist/esm/ws/base-ws-client.js +282 -0
  99. package/dist/esm/ws/base-ws-client.js.map +1 -0
  100. package/dist/esm/ws/dependencies-ws-client.js +7 -0
  101. package/dist/esm/ws/dependencies-ws-client.js.map +1 -0
  102. package/dist/esm/ws/diagnostics-service.js +166 -0
  103. package/dist/esm/ws/diagnostics-service.js.map +1 -0
  104. package/dist/esm/ws/indexing-ws-client.js +219 -0
  105. package/dist/esm/ws/indexing-ws-client.js.map +1 -0
  106. package/dist/esm/ws/notifications-ws-client.js +8 -0
  107. package/dist/esm/ws/notifications-ws-client.js.map +1 -0
  108. package/dist/esm/ws/reasoning-ws-client.js +326 -0
  109. package/dist/esm/ws/reasoning-ws-client.js.map +1 -0
  110. package/dist/types/api/chat-api/index.d.ts +81 -0
  111. package/dist/types/api/chat-api/index.d.ts.map +1 -0
  112. package/dist/types/api/chat-api/interfaces.d.ts +47 -0
  113. package/dist/types/api/chat-api/interfaces.d.ts.map +1 -0
  114. package/dist/types/api/{chat-api.d.ts → chat-api/models.d.ts} +10 -73
  115. package/dist/types/api/chat-api/models.d.ts.map +1 -0
  116. package/dist/types/api/chat-api/stream-utils.d.ts +31 -0
  117. package/dist/types/api/chat-api/stream-utils.d.ts.map +1 -0
  118. package/dist/types/api/chat-api/websocket-helpers.d.ts +40 -0
  119. package/dist/types/api/chat-api/websocket-helpers.d.ts.map +1 -0
  120. package/dist/types/api/projects-api.d.ts +114 -1
  121. package/dist/types/api/projects-api.d.ts.map +1 -1
  122. package/dist/types/code-solver-sdk.d.ts +3 -2
  123. package/dist/types/code-solver-sdk.d.ts.map +1 -1
  124. package/dist/types/constants/websocket-events.constants.d.ts +77 -36
  125. package/dist/types/constants/websocket-events.constants.d.ts.map +1 -1
  126. package/dist/types/constants/websocket-namespaces.constants.d.ts +14 -0
  127. package/dist/types/constants/websocket-namespaces.constants.d.ts.map +1 -0
  128. package/dist/types/interfaces/http-client.d.ts +1 -1
  129. package/dist/types/interfaces/http-client.d.ts.map +1 -1
  130. package/dist/types/interfaces/websocket/callbacks.interfaces.d.ts +30 -0
  131. package/dist/types/interfaces/websocket/callbacks.interfaces.d.ts.map +1 -0
  132. package/dist/types/interfaces/websocket/client-options.interfaces.d.ts +51 -0
  133. package/dist/types/interfaces/websocket/client-options.interfaces.d.ts.map +1 -0
  134. package/dist/types/interfaces/websocket/events.interfaces.d.ts +165 -0
  135. package/dist/types/interfaces/websocket/events.interfaces.d.ts.map +1 -0
  136. package/dist/types/interfaces/websocket/stats.interfaces.d.ts +72 -0
  137. package/dist/types/interfaces/websocket/stats.interfaces.d.ts.map +1 -0
  138. package/dist/types/types/index.d.ts +8 -0
  139. package/dist/types/types/index.d.ts.map +1 -1
  140. package/dist/types/utils/code-solver-websocket-client.d.ts +67 -612
  141. package/dist/types/utils/code-solver-websocket-client.d.ts.map +1 -1
  142. package/dist/types/utils/connection-state-manager.d.ts +94 -0
  143. package/dist/types/utils/connection-state-manager.d.ts.map +1 -0
  144. package/dist/types/utils/http-client.d.ts +5 -0
  145. package/dist/types/utils/http-client.d.ts.map +1 -1
  146. package/dist/types/utils/logger.d.ts +62 -0
  147. package/dist/types/utils/logger.d.ts.map +1 -0
  148. package/dist/types/utils/ping-pong-manager.d.ts +118 -0
  149. package/dist/types/utils/ping-pong-manager.d.ts.map +1 -0
  150. package/dist/types/utils/reasoning-auth-helper.d.ts +24 -0
  151. package/dist/types/utils/reasoning-auth-helper.d.ts.map +1 -0
  152. package/dist/types/utils/session-manager.d.ts +98 -0
  153. package/dist/types/utils/session-manager.d.ts.map +1 -0
  154. package/dist/types/utils/websocket-client.d.ts +6 -0
  155. package/dist/types/utils/websocket-client.d.ts.map +1 -1
  156. package/dist/types/ws/base-ws-client.d.ts +119 -0
  157. package/dist/types/ws/base-ws-client.d.ts.map +1 -0
  158. package/dist/types/ws/dependencies-ws-client.d.ts +6 -0
  159. package/dist/types/ws/dependencies-ws-client.d.ts.map +1 -0
  160. package/dist/types/ws/diagnostics-service.d.ts +93 -0
  161. package/dist/types/ws/diagnostics-service.d.ts.map +1 -0
  162. package/dist/types/ws/indexing-ws-client.d.ts +78 -0
  163. package/dist/types/ws/indexing-ws-client.d.ts.map +1 -0
  164. package/dist/types/ws/notifications-ws-client.d.ts +5 -0
  165. package/dist/types/ws/notifications-ws-client.d.ts.map +1 -0
  166. package/dist/types/ws/reasoning-ws-client.d.ts +87 -0
  167. package/dist/types/ws/reasoning-ws-client.d.ts.map +1 -0
  168. package/docs/API_REFERENCE.md +432 -0
  169. package/docs/AUTHENTICATION.md +83 -0
  170. package/docs/ERROR_HANDLING.md +240 -0
  171. package/docs/INTEGRATION_EXAMPLES.md +342 -0
  172. package/docs/PING_PONG.md +212 -0
  173. package/docs/README.md +102 -0
  174. package/docs/WEBSOCKET.md +139 -0
  175. package/docs/advanced/PING_PONG.md +212 -0
  176. package/docs/features/THINKING.md +158 -0
  177. package/docs/indexing/INDEXING.md +231 -0
  178. package/package.json +4 -3
  179. package/dist/cjs/api/chat-api.js.map +0 -1
  180. package/dist/esm/api/chat-api.js.map +0 -1
  181. package/dist/types/api/chat-api.d.ts.map +0 -1
@@ -0,0 +1,212 @@
1
+ # WebSocket Ping/Pong механизм
2
+
3
+ Данный документ описывает механизм поддержания WebSocket соединений и мониторинга их состояния через ping/pong обмен.
4
+
5
+ ## Обзор функциональности
6
+
7
+ SDK поддерживает автоматический механизм отправки ping-сообщений и обработки pong-ответов для:
8
+
9
+ 1. **Проверки активности соединения** - обнаружение разрывов соединения даже в отсутствие активности
10
+ 2. **Измерения времени отклика (Round Trip Time, RTT)** - мониторинг качества соединения
11
+ 3. **Сбора статистики соединения** - для диагностики и отладки
12
+ 4. **Автоматического обнаружения проблем** - уведомление о потере соединения
13
+
14
+ ## Включение механизма ping/pong
15
+
16
+ ```typescript
17
+ import { CodeSolverSDK, WebSocketNamespace } from 'solver-sdk';
18
+
19
+ // Создаем экземпляр SDK
20
+ const sdk = new CodeSolverSDK({
21
+ baseURL: 'https://api.example.com',
22
+ apiKey: 'your-api-key'
23
+ });
24
+
25
+ // Получаем WebSocket клиент
26
+ const wsClient = sdk.getWebSocketClient();
27
+
28
+ // Подключаемся к пространствам имен
29
+ await wsClient.connectToReasoning();
30
+ await wsClient.connectToDependencies();
31
+ await wsClient.connectToIndexing();
32
+
33
+ // Включаем автоматический механизм ping/pong
34
+ // параметры: интервал отправки в мс (по умолчанию 30000) и порог таймаута (по умолчанию 3)
35
+ wsClient.enablePingPong(10000, 3);
36
+
37
+ // Регистрируем обработчик для события таймаута соединения
38
+ wsClient.onPingPongEvent('connection_timeout', (data) => {
39
+ console.log(`Соединение потеряно для namespace ${data.namespace}`);
40
+ console.log(`Socket ID: ${data.socketId}`);
41
+ console.log(`Количество пропущенных pong: ${data.timeouts}`);
42
+
43
+ // Здесь можно добавить логику переподключения или уведомления пользователя
44
+ });
45
+ ```
46
+
47
+ ## Отключение механизма ping/pong
48
+
49
+ ```typescript
50
+ // Отключение для всех пространств имен
51
+ wsClient.disablePingPong();
52
+
53
+ // Отключение для конкретного пространства имен
54
+ wsClient.disablePingPong(WebSocketNamespace.REASONING);
55
+ ```
56
+
57
+ ## Получение статистики ping/pong
58
+
59
+ ```typescript
60
+ // Получение статистики для всех пространств имен
61
+ const allStats = wsClient.getPingStats();
62
+ console.log('Статистика для всех соединений:', allStats);
63
+
64
+ // Получение статистики для конкретного пространства имен
65
+ const reasoningStats = wsClient.getPingStats(WebSocketNamespace.REASONING);
66
+ console.log('Статистика для reasoning:', reasoningStats);
67
+
68
+ // Пример содержимого статистики:
69
+ // {
70
+ // namespace: '/reasoning',
71
+ // socketId: 'socket-id-123',
72
+ // pingSent: 10, // Количество отправленных ping
73
+ // pongReceived: 10, // Количество полученных pong
74
+ // averageRtt: 15.5, // Среднее время отклика (мс)
75
+ // minRtt: 5, // Минимальное время отклика (мс)
76
+ // maxRtt: 45, // Максимальное время отклика (мс)
77
+ // lastRtt: 12, // Последнее измеренное время отклика (мс)
78
+ // lastPongTimestamp: 1712345678901, // Timestamp последнего полученного pong
79
+ // isConnected: true // Текущий статус соединения
80
+ // }
81
+ ```
82
+
83
+ ## Ручная отправка ping/pong
84
+
85
+ Хотя SDK обеспечивает автоматический механизм ping/pong, вы также можете вручную отправлять ping-сообщения:
86
+
87
+ ```typescript
88
+ // Отправка ping и получение pong
89
+ wsClient.send(WebSocketNamespace.REASONING, 'connection_ping', {
90
+ timestamp: Date.now()
91
+ });
92
+
93
+ // Добавление обработчика для pong-ответов
94
+ wsClient.on('connection_pong', (data) => {
95
+ const rtt = Date.now() - data.echo;
96
+ console.log(`Получен pong, RTT: ${rtt}ms`);
97
+ });
98
+
99
+ // Альтернативно, можно использовать готовый обработчик
100
+ wsClient.on('connection_pong', wsClient.getPongHandler());
101
+ ```
102
+
103
+ ## Обработка отключений и переподключение
104
+
105
+ ```typescript
106
+ // Обработка события таймаута соединения
107
+ wsClient.onPingPongEvent('connection_timeout', async (data) => {
108
+ console.log(`Соединение потеряно для ${data.namespace}`);
109
+
110
+ // Попытка переподключения
111
+ try {
112
+ // Отключаемся от проблемного пространства имен
113
+ wsClient.disconnect(data.namespace);
114
+
115
+ // Пауза перед повторным подключением
116
+ await new Promise(resolve => setTimeout(resolve, 1000));
117
+
118
+ // Переподключаемся
119
+ switch (data.namespace) {
120
+ case WebSocketNamespace.REASONING:
121
+ await wsClient.connectToReasoning();
122
+ break;
123
+ case WebSocketNamespace.DEPENDENCIES:
124
+ await wsClient.connectToDependencies();
125
+ break;
126
+ case WebSocketNamespace.INDEXING:
127
+ await wsClient.connectToIndexing();
128
+ break;
129
+ }
130
+
131
+ console.log(`Успешно переподключились к ${data.namespace}`);
132
+ } catch (error) {
133
+ console.error(`Ошибка при переподключении к ${data.namespace}:`, error);
134
+ }
135
+ });
136
+ ```
137
+
138
+ ## Рекомендации по использованию
139
+
140
+ 1. **Интервал ping/pong**: Рекомендуемый интервал - 30 секунд для продакшн и 5-10 секунд для отладки.
141
+
142
+ 2. **Порог таймаута**: Значение 2-3 пропущенных ping/pong позволяет избежать ложных срабатываний при временных задержках сети.
143
+
144
+ 3. **Экономия трафика**: При частой передаче данных через WebSocket можно увеличить интервал ping/pong, так как регулярный обмен данными уже поддерживает соединение активным.
145
+
146
+ 4. **Мониторинг RTT**: Используйте statsPingStats для мониторинга задержек сети и раннего обнаружения проблем с соединением.
147
+
148
+ 5. **Отключение перед закрытием приложения**: Вызывайте disablePingPong() и затем disconnectAll() при закрытии приложения для корректного освобождения ресурсов.
149
+
150
+ ## Пример комплексного использования
151
+
152
+ ```typescript
153
+ async function setupWebSocketWithHealthMonitoring() {
154
+ const sdk = new CodeSolverSDK({
155
+ baseURL: 'https://api.example.com',
156
+ apiKey: 'your-api-key',
157
+ websocket: {
158
+ reconnect: true,
159
+ reconnectAttempts: 5,
160
+ reconnectDelay: 2000
161
+ }
162
+ });
163
+
164
+ const wsClient = sdk.getWebSocketClient();
165
+
166
+ // Подключаемся ко всем пространствам имен
167
+ await wsClient.connectToReasoning();
168
+ await wsClient.connectToDependencies();
169
+ await wsClient.connectToIndexing();
170
+
171
+ // Включаем механизм ping/pong для всех соединений
172
+ wsClient.enablePingPong(20000, 3);
173
+
174
+ // Регистрируем обработчик для события таймаута
175
+ wsClient.onPingPongEvent('connection_timeout', handleConnectionTimeout);
176
+
177
+ // Периодически проверяем статистику соединений
178
+ const statsInterval = setInterval(() => {
179
+ const stats = wsClient.getPingStats();
180
+
181
+ // Анализируем статистику
182
+ for (const stat of stats) {
183
+ if (stat.averageRtt > 500) {
184
+ console.warn(`Высокая задержка для ${stat.namespace}: ${stat.averageRtt}ms`);
185
+ }
186
+ }
187
+ }, 60000); // Проверка каждую минуту
188
+
189
+ // Функция для обработки таймаута соединения
190
+ async function handleConnectionTimeout(data) {
191
+ console.error(`Соединение потеряно для ${data.namespace}`);
192
+
193
+ // Логика переподключения...
194
+ }
195
+
196
+ // Функция для корректного закрытия соединений
197
+ function cleanup() {
198
+ clearInterval(statsInterval);
199
+ wsClient.disablePingPong();
200
+ wsClient.disconnectAll();
201
+ }
202
+
203
+ // Возвращаем функцию очистки
204
+ return cleanup;
205
+ }
206
+
207
+ // Использование
208
+ const cleanup = await setupWebSocketWithHealthMonitoring();
209
+
210
+ // При закрытии приложения
211
+ window.addEventListener('beforeunload', cleanup);
212
+ ```
package/docs/README.md ADDED
@@ -0,0 +1,102 @@
1
+ 23# Code Solver SDK
2
+
3
+ JavaScript/TypeScript SDK для взаимодействия с API Code Solver, предназначенного для умной работы с кодом, семантического поиска и AI-ассистентов.
4
+
5
+ ## Установка
6
+
7
+ ```bash
8
+ npm install @code-solver/sdk
9
+ ```
10
+
11
+ ## Основные возможности
12
+
13
+ - **Работа с проектами**: создание, индексация и управление проектами
14
+ - **Семантический поиск**: поиск по смыслу в коде проекта
15
+ - **AI-чат с контекстом**: взаимодействие с AI-моделями в контексте проекта
16
+ - **Работа с WebSocket**: потоковая обработка событий и ответов
17
+ - **Мультиплатформенность**: поддержка как браузеров, так и Node.js
18
+
19
+ ## Быстрый старт
20
+
21
+ ```javascript
22
+ import { CodeSolverSDK } from '@code-solver/sdk';
23
+
24
+ // Инициализация SDK
25
+ const sdk = new CodeSolverSDK({
26
+ baseURL: 'https://api.code-solver.com',
27
+ apiKey: 'ваш-api-ключ',
28
+ websocket: {
29
+ reconnect: true,
30
+ reconnectAttempts: 5
31
+ }
32
+ });
33
+
34
+ // Проверка доступности API
35
+ const isAvailable = await sdk.checkHealth();
36
+ if (!isAvailable) {
37
+ console.error('API недоступен');
38
+ return;
39
+ }
40
+
41
+ // Создание проекта
42
+ const project = await sdk.projects.createProject(
43
+ 'Мой проект',
44
+ '/путь/к/проекту',
45
+ {
46
+ excludePatterns: ['node_modules', '.git', 'dist']
47
+ }
48
+ );
49
+
50
+ // Индексация проекта
51
+ await sdk.projects.indexProject(project.id);
52
+
53
+ // Отслеживание прогресса индексации через WebSocket
54
+ sdk.projects.on('indexing_progress', (data) => {
55
+ console.log(`Прогресс индексации: ${data.progress}%`);
56
+ });
57
+
58
+ sdk.projects.on('indexing_complete', (data) => {
59
+ console.log('Индексация завершена!');
60
+ });
61
+
62
+ // Семантический поиск
63
+ const searchResults = await sdk.search.semanticSearch(project.id, {
64
+ query: 'функция для обработки HTTP запросов',
65
+ limit: 10
66
+ });
67
+
68
+ // Взаимодействие с AI-ассистентом
69
+ const chatResponse = await sdk.chat.chat([
70
+ {
71
+ role: 'system',
72
+ content: 'Ты опытный программист, помогающий разработчику.'
73
+ },
74
+ {
75
+ role: 'user',
76
+ content: 'Объясни, как работает функция getUserProfile в моем проекте.'
77
+ }
78
+ ], {
79
+ projectId: project.id,
80
+ model: 'claude-3-7-sonnet-20240229'
81
+ });
82
+
83
+ console.log(chatResponse.answer);
84
+ ```
85
+
86
+ ## Документация
87
+
88
+ Подробная документация доступна в следующих файлах:
89
+
90
+ - [API Reference](./API_REFERENCE.md) - подробное описание всех методов SDK
91
+ - [Authentication](./AUTHENTICATION.md) - информация по аутентификации
92
+ - [Работа с WebSocket](./WEBSOCKET.md) - примеры работы с WebSocket соединениями
93
+ - [Примеры интеграции](./INTEGRATION_EXAMPLES.md) - примеры интеграции с VS Code/Cursor
94
+
95
+ ## Поддерживаемые платформы
96
+
97
+ - **Браузеры**: Chrome, Firefox, Safari, Edge
98
+ - **Node.js**: 14.x и выше
99
+
100
+ ## Лицензия
101
+
102
+ MIT
@@ -0,0 +1,139 @@
1
+ # Работа с WebSocket в Solver SDK
2
+
3
+ Эта документация описывает, как использовать WebSocket соединения через Solver SDK для работы в реальном времени.
4
+
5
+ ## Инициализация SDK
6
+
7
+ ```javascript
8
+ const { CodeSolverSDK } = require('solver-sdk');
9
+
10
+ // Создаем экземпляр SDK с настройками
11
+ const sdk = new CodeSolverSDK({
12
+ baseURL: 'https://api.example.com',
13
+ apiKey: 'your-api-key'
14
+ });
15
+ ```
16
+
17
+ ## Работа с рассуждениями (Reasoning)
18
+
19
+ ### Создание рассуждения и получение результатов в реальном времени
20
+
21
+ ```javascript
22
+ // Создание рассуждения
23
+ const reasoning = await sdk.reasoning.createReasoning({
24
+ projectId: 'project-id',
25
+ query: 'Объясни этот проект'
26
+ });
27
+
28
+ // Подключение к WebSocket
29
+ await sdk.reasoning.connectWebSocket(reasoning.id);
30
+
31
+ // Подписка на события
32
+ sdk.reasoning.on('thinking', (data) => {
33
+ console.log('Мышление:', data.content);
34
+ });
35
+
36
+ sdk.reasoning.on('complete', (data) => {
37
+ console.log('Результат:', data.content);
38
+ // Отключение после завершения
39
+ sdk.reasoning.disconnectWebSocket();
40
+ });
41
+
42
+ // Запуск рассуждения
43
+ await sdk.reasoning.startReasoning(reasoning.id);
44
+ ```
45
+
46
+ ## Потоковый чат с мышлением AI
47
+
48
+ ```javascript
49
+ // Обработчик событий для потокового получения ответа и мышления
50
+ const handleEvent = (eventType, data) => {
51
+ if (eventType === 'thinking_delta' && data.thinking) {
52
+ console.log('Мышление:', data.thinking);
53
+ } else if (eventType === 'text_delta' && data.text) {
54
+ process.stdout.write(data.text);
55
+ } else if (eventType === 'message_stop') {
56
+ console.log('\nОтвет завершен');
57
+ }
58
+ };
59
+
60
+ // Отправка запроса
61
+ const messages = [
62
+ { role: 'user', content: 'Расскажи о JavaScript' }
63
+ ];
64
+
65
+ const options = {
66
+ model: 'claude-3-7-sonnet-20240229',
67
+ thinking: true,
68
+ temperature: 0.7
69
+ };
70
+
71
+ // Отправка с потоковым получением ответа
72
+ const response = await sdk.chat.streamChatWithThinking(
73
+ messages,
74
+ options,
75
+ handleEvent
76
+ );
77
+ ```
78
+
79
+ ## Мониторинг индексации проектов
80
+
81
+ ```javascript
82
+ // Подключение к WebSocket для проектов
83
+ await sdk.projects.connectWebSocket();
84
+
85
+ // Отслеживание прогресса индексации
86
+ sdk.projects.on('indexing_progress', (data) => {
87
+ console.log(`Прогресс индексации: ${data.progress}%`);
88
+ console.log(`Обработано файлов: ${data.processedFiles} из ${data.totalFiles}`);
89
+ });
90
+
91
+ // Завершение индексации
92
+ sdk.projects.on('indexing_complete', (data) => {
93
+ console.log('Индексация завершена!', data.success ? 'Успешно' : 'С ошибками');
94
+
95
+ // Отключение после завершения
96
+ sdk.projects.disconnectWebSocket();
97
+ });
98
+ ```
99
+
100
+ ## Работа с зависимостями
101
+
102
+ ```javascript
103
+ // Подключение к пространству имен зависимостей
104
+ await sdk.dependencies.connectWebSocket(projectId);
105
+
106
+ // Подписка на события зависимостей
107
+ sdk.dependencies.on('dependency_update', (data) => {
108
+ console.log('Обновление зависимостей:', data);
109
+ });
110
+
111
+ // Отключение
112
+ await sdk.dependencies.disconnectWebSocket();
113
+ ```
114
+
115
+ ## Обработка ошибок
116
+
117
+ ```javascript
118
+ try {
119
+ await sdk.chat.streamChatWithThinking(
120
+ messages,
121
+ options,
122
+ handleEvent
123
+ );
124
+ } catch (error) {
125
+ console.error('Произошла ошибка:', error.message);
126
+ }
127
+ ```
128
+
129
+ ## Основные события
130
+
131
+ | Событие | Описание |
132
+ |---------|----------|
133
+ | `message_start` | Начало сообщения |
134
+ | `thinking_delta` | Обновление мышления AI |
135
+ | `text_delta` | Часть текстового ответа |
136
+ | `message_stop` | Конец сообщения |
137
+ | `indexing_progress` | Прогресс индексации |
138
+ | `indexing_complete` | Завершение индексации |
139
+ | `error` | Уведомление об ошибке |
@@ -0,0 +1,212 @@
1
+ # WebSocket Ping/Pong механизм
2
+
3
+ Данный документ описывает механизм поддержания WebSocket соединений и мониторинга их состояния через ping/pong обмен.
4
+
5
+ ## Обзор функциональности
6
+
7
+ SDK поддерживает автоматический механизм отправки ping-сообщений и обработки pong-ответов для:
8
+
9
+ 1. **Проверки активности соединения** - обнаружение разрывов соединения даже в отсутствие активности
10
+ 2. **Измерения времени отклика (Round Trip Time, RTT)** - мониторинг качества соединения
11
+ 3. **Сбора статистики соединения** - для диагностики и отладки
12
+ 4. **Автоматического обнаружения проблем** - уведомление о потере соединения
13
+
14
+ ## Включение механизма ping/pong
15
+
16
+ ```typescript
17
+ import { CodeSolverSDK, WebSocketNamespace } from 'solver-sdk';
18
+
19
+ // Создаем экземпляр SDK
20
+ const sdk = new CodeSolverSDK({
21
+ baseURL: 'https://api.example.com',
22
+ apiKey: 'your-api-key'
23
+ });
24
+
25
+ // Получаем WebSocket клиент
26
+ const wsClient = sdk.getWebSocketClient();
27
+
28
+ // Подключаемся к пространствам имен
29
+ await wsClient.connectToReasoning();
30
+ await wsClient.connectToDependencies();
31
+ await wsClient.connectToIndexing();
32
+
33
+ // Включаем автоматический механизм ping/pong
34
+ // параметры: интервал отправки в мс (по умолчанию 30000) и порог таймаута (по умолчанию 3)
35
+ wsClient.enablePingPong(10000, 3);
36
+
37
+ // Регистрируем обработчик для события таймаута соединения
38
+ wsClient.onPingPongEvent('connection_timeout', (data) => {
39
+ console.log(`Соединение потеряно для namespace ${data.namespace}`);
40
+ console.log(`Socket ID: ${data.socketId}`);
41
+ console.log(`Количество пропущенных pong: ${data.timeouts}`);
42
+
43
+ // Здесь можно добавить логику переподключения или уведомления пользователя
44
+ });
45
+ ```
46
+
47
+ ## Отключение механизма ping/pong
48
+
49
+ ```typescript
50
+ // Отключение для всех пространств имен
51
+ wsClient.disablePingPong();
52
+
53
+ // Отключение для конкретного пространства имен
54
+ wsClient.disablePingPong(WebSocketNamespace.REASONING);
55
+ ```
56
+
57
+ ## Получение статистики ping/pong
58
+
59
+ ```typescript
60
+ // Получение статистики для всех пространств имен
61
+ const allStats = wsClient.getPingStats();
62
+ console.log('Статистика для всех соединений:', allStats);
63
+
64
+ // Получение статистики для конкретного пространства имен
65
+ const reasoningStats = wsClient.getPingStats(WebSocketNamespace.REASONING);
66
+ console.log('Статистика для reasoning:', reasoningStats);
67
+
68
+ // Пример содержимого статистики:
69
+ // {
70
+ // namespace: '/reasoning',
71
+ // socketId: 'socket-id-123',
72
+ // pingSent: 10, // Количество отправленных ping
73
+ // pongReceived: 10, // Количество полученных pong
74
+ // averageRtt: 15.5, // Среднее время отклика (мс)
75
+ // minRtt: 5, // Минимальное время отклика (мс)
76
+ // maxRtt: 45, // Максимальное время отклика (мс)
77
+ // lastRtt: 12, // Последнее измеренное время отклика (мс)
78
+ // lastPongTimestamp: 1712345678901, // Timestamp последнего полученного pong
79
+ // isConnected: true // Текущий статус соединения
80
+ // }
81
+ ```
82
+
83
+ ## Ручная отправка ping/pong
84
+
85
+ Хотя SDK обеспечивает автоматический механизм ping/pong, вы также можете вручную отправлять ping-сообщения:
86
+
87
+ ```typescript
88
+ // Отправка ping и получение pong
89
+ wsClient.send(WebSocketNamespace.REASONING, 'connection_ping', {
90
+ timestamp: Date.now()
91
+ });
92
+
93
+ // Добавление обработчика для pong-ответов
94
+ wsClient.on('connection_pong', (data) => {
95
+ const rtt = Date.now() - data.echo;
96
+ console.log(`Получен pong, RTT: ${rtt}ms`);
97
+ });
98
+
99
+ // Альтернативно, можно использовать готовый обработчик
100
+ wsClient.on('connection_pong', wsClient.getPongHandler());
101
+ ```
102
+
103
+ ## Обработка отключений и переподключение
104
+
105
+ ```typescript
106
+ // Обработка события таймаута соединения
107
+ wsClient.onPingPongEvent('connection_timeout', async (data) => {
108
+ console.log(`Соединение потеряно для ${data.namespace}`);
109
+
110
+ // Попытка переподключения
111
+ try {
112
+ // Отключаемся от проблемного пространства имен
113
+ wsClient.disconnect(data.namespace);
114
+
115
+ // Пауза перед повторным подключением
116
+ await new Promise(resolve => setTimeout(resolve, 1000));
117
+
118
+ // Переподключаемся
119
+ switch (data.namespace) {
120
+ case WebSocketNamespace.REASONING:
121
+ await wsClient.connectToReasoning();
122
+ break;
123
+ case WebSocketNamespace.DEPENDENCIES:
124
+ await wsClient.connectToDependencies();
125
+ break;
126
+ case WebSocketNamespace.INDEXING:
127
+ await wsClient.connectToIndexing();
128
+ break;
129
+ }
130
+
131
+ console.log(`Успешно переподключились к ${data.namespace}`);
132
+ } catch (error) {
133
+ console.error(`Ошибка при переподключении к ${data.namespace}:`, error);
134
+ }
135
+ });
136
+ ```
137
+
138
+ ## Рекомендации по использованию
139
+
140
+ 1. **Интервал ping/pong**: Рекомендуемый интервал - 30 секунд для продакшн и 5-10 секунд для отладки.
141
+
142
+ 2. **Порог таймаута**: Значение 2-3 пропущенных ping/pong позволяет избежать ложных срабатываний при временных задержках сети.
143
+
144
+ 3. **Экономия трафика**: При частой передаче данных через WebSocket можно увеличить интервал ping/pong, так как регулярный обмен данными уже поддерживает соединение активным.
145
+
146
+ 4. **Мониторинг RTT**: Используйте statsPingStats для мониторинга задержек сети и раннего обнаружения проблем с соединением.
147
+
148
+ 5. **Отключение перед закрытием приложения**: Вызывайте disablePingPong() и затем disconnectAll() при закрытии приложения для корректного освобождения ресурсов.
149
+
150
+ ## Пример комплексного использования
151
+
152
+ ```typescript
153
+ async function setupWebSocketWithHealthMonitoring() {
154
+ const sdk = new CodeSolverSDK({
155
+ baseURL: 'https://api.example.com',
156
+ apiKey: 'your-api-key',
157
+ websocket: {
158
+ reconnect: true,
159
+ reconnectAttempts: 5,
160
+ reconnectDelay: 2000
161
+ }
162
+ });
163
+
164
+ const wsClient = sdk.getWebSocketClient();
165
+
166
+ // Подключаемся ко всем пространствам имен
167
+ await wsClient.connectToReasoning();
168
+ await wsClient.connectToDependencies();
169
+ await wsClient.connectToIndexing();
170
+
171
+ // Включаем механизм ping/pong для всех соединений
172
+ wsClient.enablePingPong(20000, 3);
173
+
174
+ // Регистрируем обработчик для события таймаута
175
+ wsClient.onPingPongEvent('connection_timeout', handleConnectionTimeout);
176
+
177
+ // Периодически проверяем статистику соединений
178
+ const statsInterval = setInterval(() => {
179
+ const stats = wsClient.getPingStats();
180
+
181
+ // Анализируем статистику
182
+ for (const stat of stats) {
183
+ if (stat.averageRtt > 500) {
184
+ console.warn(`Высокая задержка для ${stat.namespace}: ${stat.averageRtt}ms`);
185
+ }
186
+ }
187
+ }, 60000); // Проверка каждую минуту
188
+
189
+ // Функция для обработки таймаута соединения
190
+ async function handleConnectionTimeout(data) {
191
+ console.error(`Соединение потеряно для ${data.namespace}`);
192
+
193
+ // Логика переподключения...
194
+ }
195
+
196
+ // Функция для корректного закрытия соединений
197
+ function cleanup() {
198
+ clearInterval(statsInterval);
199
+ wsClient.disablePingPong();
200
+ wsClient.disconnectAll();
201
+ }
202
+
203
+ // Возвращаем функцию очистки
204
+ return cleanup;
205
+ }
206
+
207
+ // Использование
208
+ const cleanup = await setupWebSocketWithHealthMonitoring();
209
+
210
+ // При закрытии приложения
211
+ window.addEventListener('beforeunload', cleanup);
212
+ ```