@didim365/agent-cli-core 0.1.1 → 0.1.3

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 (1081) hide show
  1. package/dist/src/core/apiKeyCredentialStorage.d.ts +23 -3
  2. package/dist/src/core/apiKeyCredentialStorage.js +56 -16
  3. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -1
  4. package/dist/src/generated/git-commit.d.ts +1 -1
  5. package/dist/src/generated/git-commit.js +1 -1
  6. package/package.json +6 -2
  7. package/dist/docs/00_project/ai_adapter/01-overview.md +0 -172
  8. package/dist/docs/00_project/ai_adapter/02-architecture.md +0 -448
  9. package/dist/docs/00_project/ai_adapter/03-technical-design.md +0 -1470
  10. package/dist/docs/00_project/ai_adapter/04-integration-design.md +0 -1934
  11. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +0 -336
  12. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +0 -559
  13. package/dist/docs/00_project/ai_adapter/README.md +0 -145
  14. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +0 -1
  15. package/dist/docs/00_project/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  16. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +0 -148
  17. package/dist/docs/00_project/ai_adapter/migration-plan.md +0 -205
  18. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +0 -627
  19. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +0 -436
  20. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +0 -248
  21. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +0 -133
  22. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +0 -472
  23. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +0 -123
  24. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  25. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  26. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  27. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +0 -203
  28. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  29. package/dist/docs/00_project/ai_adapter/utility-migration.md +0 -237
  30. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  31. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -197
  32. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  33. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  35. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  36. package/dist/docs/00_project/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  37. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  38. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  41. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  42. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  43. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  44. package/dist/docs/00_project/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -470
  45. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  46. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  47. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  48. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  49. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  50. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  52. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  53. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  57. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  59. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  60. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  61. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  62. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  63. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  64. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  65. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +0 -627
  66. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +0 -400
  67. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +0 -248
  68. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +0 -133
  69. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +0 -472
  70. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +0 -123
  71. package/dist/docs/00_project/white_labeling/todolist/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_todolist.md +0 -431
  72. package/dist/docs/00_project/white_labeling/working_history/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_20260214.md +0 -238
  73. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +0 -310
  74. package/dist/docs/CONTRIBUTING.md +0 -554
  75. package/dist/docs/ai_adapter/01-overview.md +0 -155
  76. package/dist/docs/ai_adapter/02-architecture.md +0 -452
  77. package/dist/docs/ai_adapter/03-technical-design.md +0 -1470
  78. package/dist/docs/ai_adapter/04-integration-design.md +0 -1904
  79. package/dist/docs/ai_adapter/05-implementation-plan.md +0 -312
  80. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +0 -559
  81. package/dist/docs/ai_adapter/README.md +0 -118
  82. package/dist/docs/ai_adapter/agent_service_openapi.json +0 -1
  83. package/dist/docs/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  84. package/dist/docs/ai_adapter/event-mapping-matrix.md +0 -140
  85. package/dist/docs/ai_adapter/migration-plan.md +0 -205
  86. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +0 -636
  87. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +0 -372
  88. package/dist/docs/ai_adapter/template/02_code_review_template.md +0 -220
  89. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +0 -120
  90. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +0 -453
  91. package/dist/docs/ai_adapter/template/99_TDD_plan.md +0 -111
  92. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +0 -433
  93. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +0 -726
  94. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +0 -974
  95. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +0 -203
  96. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +0 -1382
  97. package/dist/docs/ai_adapter/utility-migration.md +0 -237
  98. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  99. package/dist/docs/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +0 -185
  100. package/dist/docs/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +0 -185
  101. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +0 -378
  102. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +0 -269
  103. package/dist/docs/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +0 -86
  104. package/dist/docs/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +0 -157
  105. package/dist/docs/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +0 -107
  106. package/dist/docs/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +0 -630
  107. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +0 -372
  108. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +0 -205
  109. package/dist/docs/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +0 -275
  110. package/dist/docs/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +0 -239
  111. package/dist/docs/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +0 -228
  112. package/dist/docs/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +0 -367
  113. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +0 -271
  114. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +0 -330
  115. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +0 -251
  116. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +0 -136
  117. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +0 -232
  118. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +0 -191
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +0 -225
  120. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +0 -171
  121. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +0 -198
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +0 -98
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +0 -264
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +0 -204
  125. package/dist/docs/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +0 -106
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +0 -251
  127. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +0 -264
  128. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +0 -176
  129. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +0 -204
  130. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +0 -316
  131. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +0 -262
  132. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +0 -286
  133. package/dist/docs/api/index.md +0 -5
  134. package/dist/docs/api/providers.md +0 -56
  135. package/dist/docs/architecture.md +0 -80
  136. package/dist/docs/assets/connected_devtools.png +0 -0
  137. package/dist/docs/assets/gemini-screenshot.png +0 -0
  138. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  139. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  140. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  141. package/dist/docs/assets/release_patch.png +0 -0
  142. package/dist/docs/assets/theme-ansi-light.png +0 -0
  143. package/dist/docs/assets/theme-ansi.png +0 -0
  144. package/dist/docs/assets/theme-atom-one.png +0 -0
  145. package/dist/docs/assets/theme-ayu-light.png +0 -0
  146. package/dist/docs/assets/theme-ayu.png +0 -0
  147. package/dist/docs/assets/theme-custom.png +0 -0
  148. package/dist/docs/assets/theme-default-light.png +0 -0
  149. package/dist/docs/assets/theme-default.png +0 -0
  150. package/dist/docs/assets/theme-dracula.png +0 -0
  151. package/dist/docs/assets/theme-github-light.png +0 -0
  152. package/dist/docs/assets/theme-github.png +0 -0
  153. package/dist/docs/assets/theme-google-light.png +0 -0
  154. package/dist/docs/assets/theme-xcode-light.png +0 -0
  155. package/dist/docs/change_model/model_command_multi_provider_plan.md +0 -221
  156. package/dist/docs/change_model/model_command_multi_provider_todolist.md +0 -206
  157. package/dist/docs/changelogs/index.md +0 -726
  158. package/dist/docs/changelogs/latest.md +0 -370
  159. package/dist/docs/changelogs/preview.md +0 -332
  160. package/dist/docs/cli/authentication.md +0 -3
  161. package/dist/docs/cli/checkpointing.md +0 -94
  162. package/dist/docs/cli/commands.md +0 -375
  163. package/dist/docs/cli/custom-commands.md +0 -315
  164. package/dist/docs/cli/enterprise.md +0 -565
  165. package/dist/docs/cli/gemini-ignore.md +0 -71
  166. package/dist/docs/cli/gemini-md.md +0 -108
  167. package/dist/docs/cli/generation-settings.md +0 -210
  168. package/dist/docs/cli/headless.md +0 -388
  169. package/dist/docs/cli/index.md +0 -65
  170. package/dist/docs/cli/keyboard-shortcuts.md +0 -129
  171. package/dist/docs/cli/model-routing.md +0 -42
  172. package/dist/docs/cli/model.md +0 -62
  173. package/dist/docs/cli/sandbox.md +0 -171
  174. package/dist/docs/cli/session-management.md +0 -158
  175. package/dist/docs/cli/settings.md +0 -130
  176. package/dist/docs/cli/skills.md +0 -188
  177. package/dist/docs/cli/system-prompt.md +0 -125
  178. package/dist/docs/cli/telemetry.md +0 -826
  179. package/dist/docs/cli/themes.md +0 -235
  180. package/dist/docs/cli/token-caching.md +0 -20
  181. package/dist/docs/cli/trusted-folders.md +0 -95
  182. package/dist/docs/cli/tutorials/skills-getting-started.md +0 -124
  183. package/dist/docs/cli/tutorials.md +0 -87
  184. package/dist/docs/cli/uninstall.md +0 -65
  185. package/dist/docs/configuration.md +0 -108
  186. package/dist/docs/core/index.md +0 -105
  187. package/dist/docs/core/long-term-memory-design.md +0 -254
  188. package/dist/docs/core/long-term-memory-proposal.md +0 -112
  189. package/dist/docs/core/memport.md +0 -246
  190. package/dist/docs/core/policy-engine.md +0 -300
  191. package/dist/docs/core/tools-api.md +0 -131
  192. package/dist/docs/examples/proxy-script.md +0 -83
  193. package/dist/docs/extensions/best-practices.md +0 -139
  194. package/dist/docs/extensions/index.md +0 -44
  195. package/dist/docs/extensions/reference.md +0 -312
  196. package/dist/docs/extensions/releasing.md +0 -183
  197. package/dist/docs/extensions/writing-extensions.md +0 -283
  198. package/dist/docs/faq.md +0 -154
  199. package/dist/docs/get-started/authentication.md +0 -321
  200. package/dist/docs/get-started/configuration-v1.md +0 -888
  201. package/dist/docs/get-started/configuration.md +0 -1567
  202. package/dist/docs/get-started/examples.md +0 -219
  203. package/dist/docs/get-started/gemini-3.md +0 -101
  204. package/dist/docs/get-started/index.md +0 -71
  205. package/dist/docs/get-started/installation.md +0 -141
  206. package/dist/docs/hooks/best-practices.md +0 -677
  207. package/dist/docs/hooks/index.md +0 -178
  208. package/dist/docs/hooks/reference.md +0 -322
  209. package/dist/docs/hooks/writing-hooks.md +0 -450
  210. package/dist/docs/ide-integration/ide-companion-spec.md +0 -267
  211. package/dist/docs/ide-integration/index.md +0 -202
  212. package/dist/docs/index.md +0 -153
  213. package/dist/docs/integration-tests.md +0 -211
  214. package/dist/docs/issue-and-pr-automation.md +0 -134
  215. package/dist/docs/local-development.md +0 -128
  216. package/dist/docs/mermaid/context.mmd +0 -103
  217. package/dist/docs/mermaid/render-path.mmd +0 -64
  218. package/dist/docs/migration.md +0 -78
  219. package/dist/docs/npm.md +0 -62
  220. package/dist/docs/providers.md +0 -136
  221. package/dist/docs/quota-and-pricing.md +0 -158
  222. package/dist/docs/release-confidence.md +0 -164
  223. package/dist/docs/releases.md +0 -539
  224. package/dist/docs/sidebar.json +0 -140
  225. package/dist/docs/tools/file-system.md +0 -217
  226. package/dist/docs/tools/index.md +0 -98
  227. package/dist/docs/tools/mcp-server.md +0 -1068
  228. package/dist/docs/tools/memory.md +0 -54
  229. package/dist/docs/tools/shell.md +0 -260
  230. package/dist/docs/tools/todos.md +0 -57
  231. package/dist/docs/tools/web-fetch.md +0 -59
  232. package/dist/docs/tools/web-search.md +0 -42
  233. package/dist/docs/tos-privacy.md +0 -96
  234. package/dist/docs/troubleshooting.md +0 -173
  235. package/dist/src/agents/a2a-client-manager.test.d.ts +0 -6
  236. package/dist/src/agents/a2a-client-manager.test.js +0 -220
  237. package/dist/src/agents/a2a-client-manager.test.js.map +0 -1
  238. package/dist/src/agents/a2aUtils.test.d.ts +0 -6
  239. package/dist/src/agents/a2aUtils.test.js +0 -147
  240. package/dist/src/agents/a2aUtils.test.js.map +0 -1
  241. package/dist/src/agents/acknowledgedAgents.test.d.ts +0 -6
  242. package/dist/src/agents/acknowledgedAgents.test.js +0 -70
  243. package/dist/src/agents/acknowledgedAgents.test.js.map +0 -1
  244. package/dist/src/agents/agent-scheduler.test.d.ts +0 -6
  245. package/dist/src/agents/agent-scheduler.test.js +0 -56
  246. package/dist/src/agents/agent-scheduler.test.js.map +0 -1
  247. package/dist/src/agents/agentLoader.test.d.ts +0 -6
  248. package/dist/src/agents/agentLoader.test.js +0 -304
  249. package/dist/src/agents/agentLoader.test.js.map +0 -1
  250. package/dist/src/agents/cli-help-agent.test.d.ts +0 -6
  251. package/dist/src/agents/cli-help-agent.test.js +0 -67
  252. package/dist/src/agents/cli-help-agent.test.js.map +0 -1
  253. package/dist/src/agents/codebase-investigator.test.d.ts +0 -6
  254. package/dist/src/agents/codebase-investigator.test.js +0 -42
  255. package/dist/src/agents/codebase-investigator.test.js.map +0 -1
  256. package/dist/src/agents/generalist-agent.test.d.ts +0 -6
  257. package/dist/src/agents/generalist-agent.test.js +0 -31
  258. package/dist/src/agents/generalist-agent.test.js.map +0 -1
  259. package/dist/src/agents/local-executor.test.d.ts +0 -6
  260. package/dist/src/agents/local-executor.test.js +0 -1577
  261. package/dist/src/agents/local-executor.test.js.map +0 -1
  262. package/dist/src/agents/local-invocation.test.d.ts +0 -6
  263. package/dist/src/agents/local-invocation.test.js +0 -228
  264. package/dist/src/agents/local-invocation.test.js.map +0 -1
  265. package/dist/src/agents/registry.test.d.ts +0 -6
  266. package/dist/src/agents/registry.test.js +0 -773
  267. package/dist/src/agents/registry.test.js.map +0 -1
  268. package/dist/src/agents/registry_acknowledgement.test.d.ts +0 -6
  269. package/dist/src/agents/registry_acknowledgement.test.js +0 -130
  270. package/dist/src/agents/registry_acknowledgement.test.js.map +0 -1
  271. package/dist/src/agents/remote-invocation.test.d.ts +0 -6
  272. package/dist/src/agents/remote-invocation.test.js +0 -213
  273. package/dist/src/agents/remote-invocation.test.js.map +0 -1
  274. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +0 -6
  275. package/dist/src/agents/subagent-tool-wrapper.test.js +0 -109
  276. package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
  277. package/dist/src/agents/utils.test.d.ts +0 -6
  278. package/dist/src/agents/utils.test.js +0 -87
  279. package/dist/src/agents/utils.test.js.map +0 -1
  280. package/dist/src/availability/fallbackIntegration.test.d.ts +0 -6
  281. package/dist/src/availability/fallbackIntegration.test.js +0 -58
  282. package/dist/src/availability/fallbackIntegration.test.js.map +0 -1
  283. package/dist/src/availability/modelAvailabilityService.test.d.ts +0 -6
  284. package/dist/src/availability/modelAvailabilityService.test.js +0 -140
  285. package/dist/src/availability/modelAvailabilityService.test.js.map +0 -1
  286. package/dist/src/availability/policyCatalog.test.d.ts +0 -6
  287. package/dist/src/availability/policyCatalog.test.js +0 -70
  288. package/dist/src/availability/policyCatalog.test.js.map +0 -1
  289. package/dist/src/availability/policyHelpers.test.d.ts +0 -6
  290. package/dist/src/availability/policyHelpers.test.js +0 -220
  291. package/dist/src/availability/policyHelpers.test.js.map +0 -1
  292. package/dist/src/code_assist/admin/admin_controls.test.d.ts +0 -6
  293. package/dist/src/code_assist/admin/admin_controls.test.js +0 -200
  294. package/dist/src/code_assist/admin/admin_controls.test.js.map +0 -1
  295. package/dist/src/code_assist/codeAssist.test.d.ts +0 -6
  296. package/dist/src/code_assist/codeAssist.test.js +0 -102
  297. package/dist/src/code_assist/codeAssist.test.js.map +0 -1
  298. package/dist/src/code_assist/converter.test.d.ts +0 -6
  299. package/dist/src/code_assist/converter.test.js +0 -391
  300. package/dist/src/code_assist/converter.test.js.map +0 -1
  301. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +0 -6
  302. package/dist/src/code_assist/experiments/client_metadata.test.js +0 -96
  303. package/dist/src/code_assist/experiments/client_metadata.test.js.map +0 -1
  304. package/dist/src/code_assist/experiments/experiments.test.d.ts +0 -6
  305. package/dist/src/code_assist/experiments/experiments.test.js +0 -93
  306. package/dist/src/code_assist/experiments/experiments.test.js.map +0 -1
  307. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +0 -6
  308. package/dist/src/code_assist/experiments/experiments_local.test.js +0 -115
  309. package/dist/src/code_assist/experiments/experiments_local.test.js.map +0 -1
  310. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +0 -6
  311. package/dist/src/code_assist/oauth-credential-storage.test.js +0 -198
  312. package/dist/src/code_assist/oauth-credential-storage.test.js.map +0 -1
  313. package/dist/src/code_assist/oauth2.test.d.ts +0 -6
  314. package/dist/src/code_assist/oauth2.test.js +0 -1065
  315. package/dist/src/code_assist/oauth2.test.js.map +0 -1
  316. package/dist/src/code_assist/server.test.d.ts +0 -6
  317. package/dist/src/code_assist/server.test.js +0 -453
  318. package/dist/src/code_assist/server.test.js.map +0 -1
  319. package/dist/src/code_assist/setup.test.d.ts +0 -6
  320. package/dist/src/code_assist/setup.test.js +0 -517
  321. package/dist/src/code_assist/setup.test.js.map +0 -1
  322. package/dist/src/code_assist/telemetry.test.d.ts +0 -6
  323. package/dist/src/code_assist/telemetry.test.js +0 -301
  324. package/dist/src/code_assist/telemetry.test.js.map +0 -1
  325. package/dist/src/commands/extensions.test.d.ts +0 -6
  326. package/dist/src/commands/extensions.test.js +0 -19
  327. package/dist/src/commands/extensions.test.js.map +0 -1
  328. package/dist/src/commands/init.test.d.ts +0 -6
  329. package/dist/src/commands/init.test.js +0 -25
  330. package/dist/src/commands/init.test.js.map +0 -1
  331. package/dist/src/commands/memory.test.d.ts +0 -6
  332. package/dist/src/commands/memory.test.js +0 -182
  333. package/dist/src/commands/memory.test.js.map +0 -1
  334. package/dist/src/commands/restore.test.d.ts +0 -6
  335. package/dist/src/commands/restore.test.js +0 -137
  336. package/dist/src/commands/restore.test.js.map +0 -1
  337. package/dist/src/config/config.test.d.ts +0 -6
  338. package/dist/src/config/config.test.js +0 -1811
  339. package/dist/src/config/config.test.js.map +0 -1
  340. package/dist/src/config/flashFallback.test.d.ts +0 -6
  341. package/dist/src/config/flashFallback.test.js +0 -63
  342. package/dist/src/config/flashFallback.test.js.map +0 -1
  343. package/dist/src/config/models.test.d.ts +0 -6
  344. package/dist/src/config/models.test.js +0 -146
  345. package/dist/src/config/models.test.js.map +0 -1
  346. package/dist/src/config/storage.test.d.ts +0 -6
  347. package/dist/src/config/storage.test.js +0 -115
  348. package/dist/src/config/storage.test.js.map +0 -1
  349. package/dist/src/confirmation-bus/message-bus.test.d.ts +0 -6
  350. package/dist/src/confirmation-bus/message-bus.test.js +0 -170
  351. package/dist/src/confirmation-bus/message-bus.test.js.map +0 -1
  352. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +0 -6
  353. package/dist/src/core/apiKeyCredentialStorage.test.js +0 -71
  354. package/dist/src/core/apiKeyCredentialStorage.test.js.map +0 -1
  355. package/dist/src/core/baseLlmClient.test.d.ts +0 -6
  356. package/dist/src/core/baseLlmClient.test.js +0 -569
  357. package/dist/src/core/baseLlmClient.test.js.map +0 -1
  358. package/dist/src/core/baseLlmClient_new_types.test.d.ts +0 -1
  359. package/dist/src/core/baseLlmClient_new_types.test.js +0 -387
  360. package/dist/src/core/baseLlmClient_new_types.test.js.map +0 -1
  361. package/dist/src/core/client.test.d.ts +0 -6
  362. package/dist/src/core/client.test.js +0 -2654
  363. package/dist/src/core/client.test.js.map +0 -1
  364. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +0 -6
  365. package/dist/src/core/contentGenerator.multiProvider.test.js +0 -314
  366. package/dist/src/core/contentGenerator.multiProvider.test.js.map +0 -1
  367. package/dist/src/core/contentGenerator.test.d.ts +0 -6
  368. package/dist/src/core/contentGenerator.test.js +0 -299
  369. package/dist/src/core/contentGenerator.test.js.map +0 -1
  370. package/dist/src/core/contentGenerator_new_types.test.d.ts +0 -6
  371. package/dist/src/core/contentGenerator_new_types.test.js +0 -292
  372. package/dist/src/core/contentGenerator_new_types.test.js.map +0 -1
  373. package/dist/src/core/coreToolHookTriggers.test.d.ts +0 -6
  374. package/dist/src/core/coreToolHookTriggers.test.js +0 -159
  375. package/dist/src/core/coreToolHookTriggers.test.js.map +0 -1
  376. package/dist/src/core/coreToolScheduler.test.d.ts +0 -6
  377. package/dist/src/core/coreToolScheduler.test.js +0 -1684
  378. package/dist/src/core/coreToolScheduler.test.js.map +0 -1
  379. package/dist/src/core/fakeContentGenerator.test.d.ts +0 -6
  380. package/dist/src/core/fakeContentGenerator.test.js +0 -127
  381. package/dist/src/core/fakeContentGenerator.test.js.map +0 -1
  382. package/dist/src/core/geminiChat.test.d.ts +0 -6
  383. package/dist/src/core/geminiChat.test.js +0 -1773
  384. package/dist/src/core/geminiChat.test.js.map +0 -1
  385. package/dist/src/core/geminiChat_network_retry.test.d.ts +0 -6
  386. package/dist/src/core/geminiChat_network_retry.test.js +0 -201
  387. package/dist/src/core/geminiChat_network_retry.test.js.map +0 -1
  388. package/dist/src/core/logger.test.d.ts +0 -6
  389. package/dist/src/core/logger.test.js +0 -550
  390. package/dist/src/core/logger.test.js.map +0 -1
  391. package/dist/src/core/loggingContentGenerator.test.d.ts +0 -6
  392. package/dist/src/core/loggingContentGenerator.test.js +0 -221
  393. package/dist/src/core/loggingContentGenerator.test.js.map +0 -1
  394. package/dist/src/core/prompts-substitution.test.d.ts +0 -6
  395. package/dist/src/core/prompts-substitution.test.js +0 -101
  396. package/dist/src/core/prompts-substitution.test.js.map +0 -1
  397. package/dist/src/core/prompts.test.d.ts +0 -6
  398. package/dist/src/core/prompts.test.js +0 -391
  399. package/dist/src/core/prompts.test.js.map +0 -1
  400. package/dist/src/core/recordingContentGenerator.test.d.ts +0 -6
  401. package/dist/src/core/recordingContentGenerator.test.js +0 -101
  402. package/dist/src/core/recordingContentGenerator.test.js.map +0 -1
  403. package/dist/src/core/tokenLimits.test.d.ts +0 -6
  404. package/dist/src/core/tokenLimits.test.js +0 -30
  405. package/dist/src/core/tokenLimits.test.js.map +0 -1
  406. package/dist/src/core/turn.test.d.ts +0 -6
  407. package/dist/src/core/turn.test.js +0 -739
  408. package/dist/src/core/turn.test.js.map +0 -1
  409. package/dist/src/fallback/handler.test.d.ts +0 -6
  410. package/dist/src/fallback/handler.test.js +0 -242
  411. package/dist/src/fallback/handler.test.js.map +0 -1
  412. package/dist/src/hooks/hookAggregator.test.d.ts +0 -6
  413. package/dist/src/hooks/hookAggregator.test.js +0 -387
  414. package/dist/src/hooks/hookAggregator.test.js.map +0 -1
  415. package/dist/src/hooks/hookEventHandler.test.d.ts +0 -6
  416. package/dist/src/hooks/hookEventHandler.test.js +0 -603
  417. package/dist/src/hooks/hookEventHandler.test.js.map +0 -1
  418. package/dist/src/hooks/hookPlanner.test.d.ts +0 -6
  419. package/dist/src/hooks/hookPlanner.test.js +0 -315
  420. package/dist/src/hooks/hookPlanner.test.js.map +0 -1
  421. package/dist/src/hooks/hookRegistry.test.d.ts +0 -6
  422. package/dist/src/hooks/hookRegistry.test.js +0 -529
  423. package/dist/src/hooks/hookRegistry.test.js.map +0 -1
  424. package/dist/src/hooks/hookRunner.test.d.ts +0 -6
  425. package/dist/src/hooks/hookRunner.test.js +0 -606
  426. package/dist/src/hooks/hookRunner.test.js.map +0 -1
  427. package/dist/src/hooks/hookSystem.test.d.ts +0 -6
  428. package/dist/src/hooks/hookSystem.test.js +0 -330
  429. package/dist/src/hooks/hookSystem.test.js.map +0 -1
  430. package/dist/src/hooks/hookSystem_new_types.test.d.ts +0 -6
  431. package/dist/src/hooks/hookSystem_new_types.test.js +0 -243
  432. package/dist/src/hooks/hookSystem_new_types.test.js.map +0 -1
  433. package/dist/src/hooks/hookTranslator.test.d.ts +0 -6
  434. package/dist/src/hooks/hookTranslator.test.js +0 -192
  435. package/dist/src/hooks/hookTranslator.test.js.map +0 -1
  436. package/dist/src/hooks/trustedHooks.test.d.ts +0 -6
  437. package/dist/src/hooks/trustedHooks.test.js +0 -154
  438. package/dist/src/hooks/trustedHooks.test.js.map +0 -1
  439. package/dist/src/hooks/types.test.d.ts +0 -6
  440. package/dist/src/hooks/types.test.js +0 -278
  441. package/dist/src/hooks/types.test.js.map +0 -1
  442. package/dist/src/ide/detect-ide.test.d.ts +0 -6
  443. package/dist/src/ide/detect-ide.test.js +0 -195
  444. package/dist/src/ide/detect-ide.test.js.map +0 -1
  445. package/dist/src/ide/ide-client.test.d.ts +0 -6
  446. package/dist/src/ide/ide-client.test.js +0 -753
  447. package/dist/src/ide/ide-client.test.js.map +0 -1
  448. package/dist/src/ide/ide-installer.test.d.ts +0 -6
  449. package/dist/src/ide/ide-installer.test.js +0 -193
  450. package/dist/src/ide/ide-installer.test.js.map +0 -1
  451. package/dist/src/ide/ideContext.test.d.ts +0 -6
  452. package/dist/src/ide/ideContext.test.js +0 -393
  453. package/dist/src/ide/ideContext.test.js.map +0 -1
  454. package/dist/src/ide/process-utils.test.d.ts +0 -6
  455. package/dist/src/ide/process-utils.test.js +0 -151
  456. package/dist/src/ide/process-utils.test.js.map +0 -1
  457. package/dist/src/index.test.d.ts +0 -6
  458. package/dist/src/index.test.js +0 -53
  459. package/dist/src/index.test.js.map +0 -1
  460. package/dist/src/mcp/google-auth-provider.test.d.ts +0 -6
  461. package/dist/src/mcp/google-auth-provider.test.js +0 -167
  462. package/dist/src/mcp/google-auth-provider.test.js.map +0 -1
  463. package/dist/src/mcp/oauth-provider.test.d.ts +0 -6
  464. package/dist/src/mcp/oauth-provider.test.js +0 -1355
  465. package/dist/src/mcp/oauth-provider.test.js.map +0 -1
  466. package/dist/src/mcp/oauth-token-storage.test.d.ts +0 -6
  467. package/dist/src/mcp/oauth-token-storage.test.js +0 -305
  468. package/dist/src/mcp/oauth-token-storage.test.js.map +0 -1
  469. package/dist/src/mcp/oauth-utils.test.d.ts +0 -6
  470. package/dist/src/mcp/oauth-utils.test.js +0 -289
  471. package/dist/src/mcp/oauth-utils.test.js.map +0 -1
  472. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +0 -6
  473. package/dist/src/mcp/sa-impersonation-provider.test.js +0 -117
  474. package/dist/src/mcp/sa-impersonation-provider.test.js.map +0 -1
  475. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +0 -6
  476. package/dist/src/mcp/token-storage/base-token-storage.test.js +0 -151
  477. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +0 -1
  478. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +0 -6
  479. package/dist/src/mcp/token-storage/file-token-storage.test.js +0 -238
  480. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +0 -1
  481. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +0 -6
  482. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +0 -193
  483. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +0 -1
  484. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +0 -6
  485. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +0 -305
  486. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +0 -1
  487. package/dist/src/output/json-formatter.test.d.ts +0 -6
  488. package/dist/src/output/json-formatter.test.js +0 -294
  489. package/dist/src/output/json-formatter.test.js.map +0 -1
  490. package/dist/src/output/stream-json-formatter.test.d.ts +0 -6
  491. package/dist/src/output/stream-json-formatter.test.js +0 -477
  492. package/dist/src/output/stream-json-formatter.test.js.map +0 -1
  493. package/dist/src/policy/config.test.d.ts +0 -6
  494. package/dist/src/policy/config.test.js +0 -598
  495. package/dist/src/policy/config.test.js.map +0 -1
  496. package/dist/src/policy/persistence.test.d.ts +0 -6
  497. package/dist/src/policy/persistence.test.js +0 -154
  498. package/dist/src/policy/persistence.test.js.map +0 -1
  499. package/dist/src/policy/policy-engine.test.d.ts +0 -6
  500. package/dist/src/policy/policy-engine.test.js +0 -1299
  501. package/dist/src/policy/policy-engine.test.js.map +0 -1
  502. package/dist/src/policy/policy-updater.test.d.ts +0 -6
  503. package/dist/src/policy/policy-updater.test.js +0 -116
  504. package/dist/src/policy/policy-updater.test.js.map +0 -1
  505. package/dist/src/policy/shell-safety.test.d.ts +0 -6
  506. package/dist/src/policy/shell-safety.test.js +0 -438
  507. package/dist/src/policy/shell-safety.test.js.map +0 -1
  508. package/dist/src/policy/toml-loader.test.d.ts +0 -6
  509. package/dist/src/policy/toml-loader.test.js +0 -409
  510. package/dist/src/policy/toml-loader.test.js.map +0 -1
  511. package/dist/src/policy/utils.test.d.ts +0 -6
  512. package/dist/src/policy/utils.test.js +0 -92
  513. package/dist/src/policy/utils.test.js.map +0 -1
  514. package/dist/src/prompts/mcp-prompts.test.d.ts +0 -6
  515. package/dist/src/prompts/mcp-prompts.test.js +0 -39
  516. package/dist/src/prompts/mcp-prompts.test.js.map +0 -1
  517. package/dist/src/prompts/prompt-registry.test.d.ts +0 -6
  518. package/dist/src/prompts/prompt-registry.test.js +0 -96
  519. package/dist/src/prompts/prompt-registry.test.js.map +0 -1
  520. package/dist/src/providers/__tests__/bundleSize.test.d.ts +0 -6
  521. package/dist/src/providers/__tests__/bundleSize.test.js +0 -75
  522. package/dist/src/providers/__tests__/bundleSize.test.js.map +0 -1
  523. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +0 -6
  524. package/dist/src/providers/__tests__/errorHandling.integration.test.js +0 -339
  525. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +0 -1
  526. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +0 -6
  527. package/dist/src/providers/__tests__/multiProvider.integration.test.js +0 -419
  528. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +0 -1
  529. package/dist/src/providers/__tests__/performance.test.d.ts +0 -6
  530. package/dist/src/providers/__tests__/performance.test.js +0 -270
  531. package/dist/src/providers/__tests__/performance.test.js.map +0 -1
  532. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +0 -6
  533. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +0 -245
  534. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +0 -1
  535. package/dist/src/providers/baseAdapter.test.d.ts +0 -1
  536. package/dist/src/providers/baseAdapter.test.js +0 -142
  537. package/dist/src/providers/baseAdapter.test.js.map +0 -1
  538. package/dist/src/providers/claude/adapter.test.d.ts +0 -6
  539. package/dist/src/providers/claude/adapter.test.js +0 -628
  540. package/dist/src/providers/claude/adapter.test.js.map +0 -1
  541. package/dist/src/providers/claude/bootstrap.test.d.ts +0 -6
  542. package/dist/src/providers/claude/bootstrap.test.js +0 -74
  543. package/dist/src/providers/claude/bootstrap.test.js.map +0 -1
  544. package/dist/src/providers/claude/converter.test.d.ts +0 -6
  545. package/dist/src/providers/claude/converter.test.js +0 -1002
  546. package/dist/src/providers/claude/converter.test.js.map +0 -1
  547. package/dist/src/providers/claude/exports.test.d.ts +0 -6
  548. package/dist/src/providers/claude/exports.test.js +0 -40
  549. package/dist/src/providers/claude/exports.test.js.map +0 -1
  550. package/dist/src/providers/configAdapter.test.d.ts +0 -1
  551. package/dist/src/providers/configAdapter.test.js +0 -150
  552. package/dist/src/providers/configAdapter.test.js.map +0 -1
  553. package/dist/src/providers/contentResolver.test.d.ts +0 -1
  554. package/dist/src/providers/contentResolver.test.js +0 -89
  555. package/dist/src/providers/contentResolver.test.js.map +0 -1
  556. package/dist/src/providers/factory.test.d.ts +0 -1
  557. package/dist/src/providers/factory.test.js +0 -151
  558. package/dist/src/providers/factory.test.js.map +0 -1
  559. package/dist/src/providers/gemini/adapterBridge.test.d.ts +0 -6
  560. package/dist/src/providers/gemini/adapterBridge.test.js +0 -164
  561. package/dist/src/providers/gemini/adapterBridge.test.js.map +0 -1
  562. package/dist/src/providers/gemini/bootstrap.test.d.ts +0 -6
  563. package/dist/src/providers/gemini/bootstrap.test.js +0 -72
  564. package/dist/src/providers/gemini/bootstrap.test.js.map +0 -1
  565. package/dist/src/providers/gemini/configConverter.test.d.ts +0 -6
  566. package/dist/src/providers/gemini/configConverter.test.js +0 -218
  567. package/dist/src/providers/gemini/configConverter.test.js.map +0 -1
  568. package/dist/src/providers/gemini/errorClassifier.test.d.ts +0 -6
  569. package/dist/src/providers/gemini/errorClassifier.test.js +0 -83
  570. package/dist/src/providers/gemini/errorClassifier.test.js.map +0 -1
  571. package/dist/src/providers/gemini/eventMapper.test.d.ts +0 -6
  572. package/dist/src/providers/gemini/eventMapper.test.js +0 -502
  573. package/dist/src/providers/gemini/eventMapper.test.js.map +0 -1
  574. package/dist/src/providers/gemini/exports.test.d.ts +0 -6
  575. package/dist/src/providers/gemini/exports.test.js +0 -90
  576. package/dist/src/providers/gemini/exports.test.js.map +0 -1
  577. package/dist/src/providers/gemini/featureFlag.test.d.ts +0 -6
  578. package/dist/src/providers/gemini/featureFlag.test.js +0 -139
  579. package/dist/src/providers/gemini/featureFlag.test.js.map +0 -1
  580. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +0 -6
  581. package/dist/src/providers/gemini/geminiAdapter.test.js +0 -279
  582. package/dist/src/providers/gemini/geminiAdapter.test.js.map +0 -1
  583. package/dist/src/providers/gemini/geminiConverter.test.d.ts +0 -6
  584. package/dist/src/providers/gemini/geminiConverter.test.js +0 -474
  585. package/dist/src/providers/gemini/geminiConverter.test.js.map +0 -1
  586. package/dist/src/providers/gemini/geminiParity.test.d.ts +0 -6
  587. package/dist/src/providers/gemini/geminiParity.test.js +0 -754
  588. package/dist/src/providers/gemini/geminiParity.test.js.map +0 -1
  589. package/dist/src/providers/gemini/geminiStream.test.d.ts +0 -6
  590. package/dist/src/providers/gemini/geminiStream.test.js +0 -391
  591. package/dist/src/providers/gemini/geminiStream.test.js.map +0 -1
  592. package/dist/src/providers/gemini/historyBuilder.test.d.ts +0 -6
  593. package/dist/src/providers/gemini/historyBuilder.test.js +0 -207
  594. package/dist/src/providers/gemini/historyBuilder.test.js.map +0 -1
  595. package/dist/src/providers/gemini/requestBuilder.test.d.ts +0 -6
  596. package/dist/src/providers/gemini/requestBuilder.test.js +0 -358
  597. package/dist/src/providers/gemini/requestBuilder.test.js.map +0 -1
  598. package/dist/src/providers/gemini/streamConverter.test.d.ts +0 -6
  599. package/dist/src/providers/gemini/streamConverter.test.js +0 -131
  600. package/dist/src/providers/gemini/streamConverter.test.js.map +0 -1
  601. package/dist/src/providers/modelSpec.test.d.ts +0 -1
  602. package/dist/src/providers/modelSpec.test.js +0 -119
  603. package/dist/src/providers/modelSpec.test.js.map +0 -1
  604. package/dist/src/providers/openai/adapter.test.d.ts +0 -6
  605. package/dist/src/providers/openai/adapter.test.js +0 -274
  606. package/dist/src/providers/openai/adapter.test.js.map +0 -1
  607. package/dist/src/providers/openai/bootstrap.test.d.ts +0 -6
  608. package/dist/src/providers/openai/bootstrap.test.js +0 -76
  609. package/dist/src/providers/openai/bootstrap.test.js.map +0 -1
  610. package/dist/src/providers/openai/converter.test.d.ts +0 -6
  611. package/dist/src/providers/openai/converter.test.js +0 -1133
  612. package/dist/src/providers/openai/converter.test.js.map +0 -1
  613. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +0 -6
  614. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +0 -356
  615. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +0 -1
  616. package/dist/src/providers/openai-compatible/adapter.test.d.ts +0 -6
  617. package/dist/src/providers/openai-compatible/adapter.test.js +0 -240
  618. package/dist/src/providers/openai-compatible/adapter.test.js.map +0 -1
  619. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +0 -6
  620. package/dist/src/providers/openai-compatible/bootstrap.test.js +0 -145
  621. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +0 -1
  622. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +0 -6
  623. package/dist/src/providers/openai-compatible/promptBuilder.test.js +0 -154
  624. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +0 -1
  625. package/dist/src/providers/providerConfig.test.d.ts +0 -1
  626. package/dist/src/providers/providerConfig.test.js +0 -145
  627. package/dist/src/providers/providerConfig.test.js.map +0 -1
  628. package/dist/src/providers/providerConfigIntegration.test.d.ts +0 -6
  629. package/dist/src/providers/providerConfigIntegration.test.js +0 -187
  630. package/dist/src/providers/providerConfigIntegration.test.js.map +0 -1
  631. package/dist/src/providers/providerSelector.test.d.ts +0 -1
  632. package/dist/src/providers/providerSelector.test.js +0 -199
  633. package/dist/src/providers/providerSelector.test.js.map +0 -1
  634. package/dist/src/providers/providerTypes.test.d.ts +0 -1
  635. package/dist/src/providers/providerTypes.test.js +0 -95
  636. package/dist/src/providers/providerTypes.test.js.map +0 -1
  637. package/dist/src/providers/registry.test.d.ts +0 -1
  638. package/dist/src/providers/registry.test.js +0 -207
  639. package/dist/src/providers/registry.test.js.map +0 -1
  640. package/dist/src/providers/streamAssembler.test.d.ts +0 -1
  641. package/dist/src/providers/streamAssembler.test.js +0 -247
  642. package/dist/src/providers/streamAssembler.test.js.map +0 -1
  643. package/dist/src/providers/telemetryBridge.test.d.ts +0 -6
  644. package/dist/src/providers/telemetryBridge.test.js +0 -235
  645. package/dist/src/providers/telemetryBridge.test.js.map +0 -1
  646. package/dist/src/providers/types.test.d.ts +0 -6
  647. package/dist/src/providers/types.test.js +0 -253
  648. package/dist/src/providers/types.test.js.map +0 -1
  649. package/dist/src/resources/resource-registry.test.d.ts +0 -6
  650. package/dist/src/resources/resource-registry.test.js +0 -54
  651. package/dist/src/resources/resource-registry.test.js.map +0 -1
  652. package/dist/src/routing/modelRouterService.test.d.ts +0 -6
  653. package/dist/src/routing/modelRouterService.test.js +0 -106
  654. package/dist/src/routing/modelRouterService.test.js.map +0 -1
  655. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +0 -6
  656. package/dist/src/routing/strategies/classifierStrategy.test.js +0 -249
  657. package/dist/src/routing/strategies/classifierStrategy.test.js.map +0 -1
  658. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +0 -6
  659. package/dist/src/routing/strategies/compositeStrategy.test.js +0 -124
  660. package/dist/src/routing/strategies/compositeStrategy.test.js.map +0 -1
  661. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +0 -6
  662. package/dist/src/routing/strategies/defaultStrategy.test.js +0 -102
  663. package/dist/src/routing/strategies/defaultStrategy.test.js.map +0 -1
  664. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +0 -6
  665. package/dist/src/routing/strategies/fallbackStrategy.test.js +0 -96
  666. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +0 -1
  667. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +0 -6
  668. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +0 -367
  669. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +0 -1
  670. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +0 -6
  671. package/dist/src/routing/strategies/overrideStrategy.test.js +0 -59
  672. package/dist/src/routing/strategies/overrideStrategy.test.js.map +0 -1
  673. package/dist/src/safety/built-in.test.d.ts +0 -6
  674. package/dist/src/safety/built-in.test.js +0 -199
  675. package/dist/src/safety/built-in.test.js.map +0 -1
  676. package/dist/src/safety/checker-runner.test.d.ts +0 -6
  677. package/dist/src/safety/checker-runner.test.js +0 -238
  678. package/dist/src/safety/checker-runner.test.js.map +0 -1
  679. package/dist/src/safety/context-builder.test.d.ts +0 -6
  680. package/dist/src/safety/context-builder.test.js +0 -49
  681. package/dist/src/safety/context-builder.test.js.map +0 -1
  682. package/dist/src/safety/registry.test.d.ts +0 -6
  683. package/dist/src/safety/registry.test.js +0 -31
  684. package/dist/src/safety/registry.test.js.map +0 -1
  685. package/dist/src/scheduler/confirmation.test.d.ts +0 -6
  686. package/dist/src/scheduler/confirmation.test.js +0 -325
  687. package/dist/src/scheduler/confirmation.test.js.map +0 -1
  688. package/dist/src/scheduler/policy.test.d.ts +0 -6
  689. package/dist/src/scheduler/policy.test.js +0 -299
  690. package/dist/src/scheduler/policy.test.js.map +0 -1
  691. package/dist/src/scheduler/scheduler.test.d.ts +0 -6
  692. package/dist/src/scheduler/scheduler.test.js +0 -822
  693. package/dist/src/scheduler/scheduler.test.js.map +0 -1
  694. package/dist/src/scheduler/state-manager.test.d.ts +0 -6
  695. package/dist/src/scheduler/state-manager.test.js +0 -429
  696. package/dist/src/scheduler/state-manager.test.js.map +0 -1
  697. package/dist/src/scheduler/tool-executor.test.d.ts +0 -6
  698. package/dist/src/scheduler/tool-executor.test.js +0 -232
  699. package/dist/src/scheduler/tool-executor.test.js.map +0 -1
  700. package/dist/src/scheduler/tool-modifier.test.d.ts +0 -6
  701. package/dist/src/scheduler/tool-modifier.test.js +0 -159
  702. package/dist/src/scheduler/tool-modifier.test.js.map +0 -1
  703. package/dist/src/services/chatCompressionService.test.d.ts +0 -6
  704. package/dist/src/services/chatCompressionService.test.js +0 -573
  705. package/dist/src/services/chatCompressionService.test.js.map +0 -1
  706. package/dist/src/services/chatRecordingService.test.d.ts +0 -6
  707. package/dist/src/services/chatRecordingService.test.js +0 -486
  708. package/dist/src/services/chatRecordingService.test.js.map +0 -1
  709. package/dist/src/services/contextManager.test.d.ts +0 -6
  710. package/dist/src/services/contextManager.test.js +0 -104
  711. package/dist/src/services/contextManager.test.js.map +0 -1
  712. package/dist/src/services/environmentSanitization.test.d.ts +0 -6
  713. package/dist/src/services/environmentSanitization.test.js +0 -284
  714. package/dist/src/services/environmentSanitization.test.js.map +0 -1
  715. package/dist/src/services/fileDiscoveryService.test.d.ts +0 -6
  716. package/dist/src/services/fileDiscoveryService.test.js +0 -223
  717. package/dist/src/services/fileDiscoveryService.test.js.map +0 -1
  718. package/dist/src/services/fileSystemService.test.d.ts +0 -6
  719. package/dist/src/services/fileSystemService.test.js +0 -41
  720. package/dist/src/services/fileSystemService.test.js.map +0 -1
  721. package/dist/src/services/gitService.test.d.ts +0 -6
  722. package/dist/src/services/gitService.test.js +0 -264
  723. package/dist/src/services/gitService.test.js.map +0 -1
  724. package/dist/src/services/loopDetectionService.test.d.ts +0 -6
  725. package/dist/src/services/loopDetectionService.test.js +0 -881
  726. package/dist/src/services/loopDetectionService.test.js.map +0 -1
  727. package/dist/src/services/modelConfig.golden.test.d.ts +0 -6
  728. package/dist/src/services/modelConfig.golden.test.js +0 -74
  729. package/dist/src/services/modelConfig.golden.test.js.map +0 -1
  730. package/dist/src/services/modelConfig.integration.test.d.ts +0 -6
  731. package/dist/src/services/modelConfig.integration.test.js +0 -247
  732. package/dist/src/services/modelConfig.integration.test.js.map +0 -1
  733. package/dist/src/services/modelConfigBridge.test.d.ts +0 -6
  734. package/dist/src/services/modelConfigBridge.test.js +0 -410
  735. package/dist/src/services/modelConfigBridge.test.js.map +0 -1
  736. package/dist/src/services/modelConfigService.test.d.ts +0 -6
  737. package/dist/src/services/modelConfigService.test.js +0 -868
  738. package/dist/src/services/modelConfigService.test.js.map +0 -1
  739. package/dist/src/services/sessionSummaryService.test.d.ts +0 -6
  740. package/dist/src/services/sessionSummaryService.test.js +0 -785
  741. package/dist/src/services/sessionSummaryService.test.js.map +0 -1
  742. package/dist/src/services/sessionSummaryUtils.test.d.ts +0 -6
  743. package/dist/src/services/sessionSummaryUtils.test.js +0 -160
  744. package/dist/src/services/sessionSummaryUtils.test.js.map +0 -1
  745. package/dist/src/services/shellExecutionService.test.d.ts +0 -6
  746. package/dist/src/services/shellExecutionService.test.js +0 -1080
  747. package/dist/src/services/shellExecutionService.test.js.map +0 -1
  748. package/dist/src/skills/skillLoader.test.d.ts +0 -6
  749. package/dist/src/skills/skillLoader.test.js +0 -185
  750. package/dist/src/skills/skillLoader.test.js.map +0 -1
  751. package/dist/src/skills/skillManager.test.d.ts +0 -6
  752. package/dist/src/skills/skillManager.test.js +0 -297
  753. package/dist/src/skills/skillManager.test.js.map +0 -1
  754. package/dist/src/telemetry/activity-detector.test.d.ts +0 -6
  755. package/dist/src/telemetry/activity-detector.test.js +0 -136
  756. package/dist/src/telemetry/activity-detector.test.js.map +0 -1
  757. package/dist/src/telemetry/activity-monitor.test.d.ts +0 -6
  758. package/dist/src/telemetry/activity-monitor.test.js +0 -251
  759. package/dist/src/telemetry/activity-monitor.test.js.map +0 -1
  760. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -19
  761. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +0 -964
  762. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +0 -1
  763. package/dist/src/telemetry/config.test.d.ts +0 -6
  764. package/dist/src/telemetry/config.test.js +0 -149
  765. package/dist/src/telemetry/config.test.js.map +0 -1
  766. package/dist/src/telemetry/gcp-exporters.test.d.ts +0 -6
  767. package/dist/src/telemetry/gcp-exporters.test.js +0 -318
  768. package/dist/src/telemetry/gcp-exporters.test.js.map +0 -1
  769. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +0 -6
  770. package/dist/src/telemetry/high-water-mark-tracker.test.js +0 -152
  771. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +0 -1
  772. package/dist/src/telemetry/integration.test.circular.d.ts +0 -6
  773. package/dist/src/telemetry/integration.test.circular.js +0 -54
  774. package/dist/src/telemetry/integration.test.circular.js.map +0 -1
  775. package/dist/src/telemetry/loggers.test.circular.d.ts +0 -6
  776. package/dist/src/telemetry/loggers.test.circular.js +0 -107
  777. package/dist/src/telemetry/loggers.test.circular.js.map +0 -1
  778. package/dist/src/telemetry/loggers.test.d.ts +0 -6
  779. package/dist/src/telemetry/loggers.test.js +0 -1618
  780. package/dist/src/telemetry/loggers.test.js.map +0 -1
  781. package/dist/src/telemetry/memory-monitor.test.d.ts +0 -6
  782. package/dist/src/telemetry/memory-monitor.test.js +0 -472
  783. package/dist/src/telemetry/memory-monitor.test.js.map +0 -1
  784. package/dist/src/telemetry/metrics.test.d.ts +0 -6
  785. package/dist/src/telemetry/metrics.test.js +0 -1176
  786. package/dist/src/telemetry/metrics.test.js.map +0 -1
  787. package/dist/src/telemetry/rate-limiter.test.d.ts +0 -6
  788. package/dist/src/telemetry/rate-limiter.test.js +0 -207
  789. package/dist/src/telemetry/rate-limiter.test.js.map +0 -1
  790. package/dist/src/telemetry/sanitize.test.d.ts +0 -6
  791. package/dist/src/telemetry/sanitize.test.js +0 -279
  792. package/dist/src/telemetry/sanitize.test.js.map +0 -1
  793. package/dist/src/telemetry/sdk.test.d.ts +0 -6
  794. package/dist/src/telemetry/sdk.test.js +0 -360
  795. package/dist/src/telemetry/sdk.test.js.map +0 -1
  796. package/dist/src/telemetry/semantic.test.d.ts +0 -6
  797. package/dist/src/telemetry/semantic.test.js +0 -387
  798. package/dist/src/telemetry/semantic.test.js.map +0 -1
  799. package/dist/src/telemetry/semantic.truncation.test.d.ts +0 -1
  800. package/dist/src/telemetry/semantic.truncation.test.js +0 -92
  801. package/dist/src/telemetry/semantic.truncation.test.js.map +0 -1
  802. package/dist/src/telemetry/startupProfiler.test.d.ts +0 -6
  803. package/dist/src/telemetry/startupProfiler.test.js +0 -285
  804. package/dist/src/telemetry/startupProfiler.test.js.map +0 -1
  805. package/dist/src/telemetry/telemetry-utils.test.d.ts +0 -6
  806. package/dist/src/telemetry/telemetry-utils.test.js +0 -41
  807. package/dist/src/telemetry/telemetry-utils.test.js.map +0 -1
  808. package/dist/src/telemetry/telemetry.test.d.ts +0 -6
  809. package/dist/src/telemetry/telemetry.test.js +0 -57
  810. package/dist/src/telemetry/telemetry.test.js.map +0 -1
  811. package/dist/src/telemetry/uiTelemetry.test.d.ts +0 -6
  812. package/dist/src/telemetry/uiTelemetry.test.js +0 -584
  813. package/dist/src/telemetry/uiTelemetry.test.js.map +0 -1
  814. package/dist/src/tools/activate-skill.test.d.ts +0 -6
  815. package/dist/src/tools/activate-skill.test.js +0 -113
  816. package/dist/src/tools/activate-skill.test.js.map +0 -1
  817. package/dist/src/tools/ask-user.test.d.ts +0 -6
  818. package/dist/src/tools/ask-user.test.js +0 -187
  819. package/dist/src/tools/ask-user.test.js.map +0 -1
  820. package/dist/src/tools/base-tool-invocation.test.d.ts +0 -6
  821. package/dist/src/tools/base-tool-invocation.test.js +0 -85
  822. package/dist/src/tools/base-tool-invocation.test.js.map +0 -1
  823. package/dist/src/tools/confirmation-policy.test.d.ts +0 -6
  824. package/dist/src/tools/confirmation-policy.test.js +0 -143
  825. package/dist/src/tools/confirmation-policy.test.js.map +0 -1
  826. package/dist/src/tools/diffOptions.test.d.ts +0 -6
  827. package/dist/src/tools/diffOptions.test.js +0 -172
  828. package/dist/src/tools/diffOptions.test.js.map +0 -1
  829. package/dist/src/tools/edit.test.d.ts +0 -6
  830. package/dist/src/tools/edit.test.js +0 -729
  831. package/dist/src/tools/edit.test.js.map +0 -1
  832. package/dist/src/tools/get-internal-docs.test.d.ts +0 -6
  833. package/dist/src/tools/get-internal-docs.test.js +0 -57
  834. package/dist/src/tools/get-internal-docs.test.js.map +0 -1
  835. package/dist/src/tools/glob.test.d.ts +0 -6
  836. package/dist/src/tools/glob.test.js +0 -433
  837. package/dist/src/tools/glob.test.js.map +0 -1
  838. package/dist/src/tools/grep.test.d.ts +0 -6
  839. package/dist/src/tools/grep.test.js +0 -328
  840. package/dist/src/tools/grep.test.js.map +0 -1
  841. package/dist/src/tools/ls.test.d.ts +0 -6
  842. package/dist/src/tools/ls.test.js +0 -242
  843. package/dist/src/tools/ls.test.js.map +0 -1
  844. package/dist/src/tools/mcp-client-manager.test.d.ts +0 -6
  845. package/dist/src/tools/mcp-client-manager.test.js +0 -251
  846. package/dist/src/tools/mcp-client-manager.test.js.map +0 -1
  847. package/dist/src/tools/mcp-client.test.d.ts +0 -6
  848. package/dist/src/tools/mcp-client.test.js +0 -1346
  849. package/dist/src/tools/mcp-client.test.js.map +0 -1
  850. package/dist/src/tools/mcp-tool.test.d.ts +0 -6
  851. package/dist/src/tools/mcp-tool.test.js +0 -657
  852. package/dist/src/tools/mcp-tool.test.js.map +0 -1
  853. package/dist/src/tools/memoryTool.test.d.ts +0 -6
  854. package/dist/src/tools/memoryTool.test.js +0 -302
  855. package/dist/src/tools/memoryTool.test.js.map +0 -1
  856. package/dist/src/tools/message-bus-integration.test.d.ts +0 -6
  857. package/dist/src/tools/message-bus-integration.test.js +0 -169
  858. package/dist/src/tools/message-bus-integration.test.js.map +0 -1
  859. package/dist/src/tools/modifiable-tool.test.d.ts +0 -6
  860. package/dist/src/tools/modifiable-tool.test.js +0 -237
  861. package/dist/src/tools/modifiable-tool.test.js.map +0 -1
  862. package/dist/src/tools/read-file.test.d.ts +0 -6
  863. package/dist/src/tools/read-file.test.js +0 -376
  864. package/dist/src/tools/read-file.test.js.map +0 -1
  865. package/dist/src/tools/read-many-files.test.d.ts +0 -6
  866. package/dist/src/tools/read-many-files.test.js +0 -567
  867. package/dist/src/tools/read-many-files.test.js.map +0 -1
  868. package/dist/src/tools/ripGrep.test.d.ts +0 -6
  869. package/dist/src/tools/ripGrep.test.js +0 -1139
  870. package/dist/src/tools/ripGrep.test.js.map +0 -1
  871. package/dist/src/tools/shell.test.d.ts +0 -6
  872. package/dist/src/tools/shell.test.js +0 -526
  873. package/dist/src/tools/shell.test.js.map +0 -1
  874. package/dist/src/tools/tool-names.test.d.ts +0 -6
  875. package/dist/src/tools/tool-names.test.js +0 -43
  876. package/dist/src/tools/tool-names.test.js.map +0 -1
  877. package/dist/src/tools/tool-registry.test.d.ts +0 -6
  878. package/dist/src/tools/tool-registry.test.js +0 -461
  879. package/dist/src/tools/tool-registry.test.js.map +0 -1
  880. package/dist/src/tools/tools.test.d.ts +0 -6
  881. package/dist/src/tools/tools.test.js +0 -207
  882. package/dist/src/tools/tools.test.js.map +0 -1
  883. package/dist/src/tools/web-fetch.test.d.ts +0 -6
  884. package/dist/src/tools/web-fetch.test.js +0 -442
  885. package/dist/src/tools/web-fetch.test.js.map +0 -1
  886. package/dist/src/tools/web-search.test.d.ts +0 -6
  887. package/dist/src/tools/web-search.test.js +0 -214
  888. package/dist/src/tools/web-search.test.js.map +0 -1
  889. package/dist/src/tools/write-file.test.d.ts +0 -6
  890. package/dist/src/tools/write-file.test.js +0 -681
  891. package/dist/src/tools/write-file.test.js.map +0 -1
  892. package/dist/src/tools/write-todos.test.d.ts +0 -6
  893. package/dist/src/tools/write-todos.test.js +0 -90
  894. package/dist/src/tools/write-todos.test.js.map +0 -1
  895. package/dist/src/utils/apiConversionUtils.test.d.ts +0 -6
  896. package/dist/src/utils/apiConversionUtils.test.js +0 -150
  897. package/dist/src/utils/apiConversionUtils.test.js.map +0 -1
  898. package/dist/src/utils/bfsFileSearch.test.d.ts +0 -6
  899. package/dist/src/utils/bfsFileSearch.test.js +0 -227
  900. package/dist/src/utils/bfsFileSearch.test.js.map +0 -1
  901. package/dist/src/utils/channel.test.d.ts +0 -6
  902. package/dist/src/utils/channel.test.js +0 -170
  903. package/dist/src/utils/channel.test.js.map +0 -1
  904. package/dist/src/utils/checkpointUtils.test.d.ts +0 -6
  905. package/dist/src/utils/checkpointUtils.test.js +0 -229
  906. package/dist/src/utils/checkpointUtils.test.js.map +0 -1
  907. package/dist/src/utils/customHeaderUtils.test.d.ts +0 -6
  908. package/dist/src/utils/customHeaderUtils.test.js +0 -77
  909. package/dist/src/utils/customHeaderUtils.test.js.map +0 -1
  910. package/dist/src/utils/debugLogger.test.d.ts +0 -6
  911. package/dist/src/utils/debugLogger.test.js +0 -69
  912. package/dist/src/utils/debugLogger.test.js.map +0 -1
  913. package/dist/src/utils/delay.test.d.ts +0 -6
  914. package/dist/src/utils/delay.test.js +0 -88
  915. package/dist/src/utils/delay.test.js.map +0 -1
  916. package/dist/src/utils/editCorrector.test.d.ts +0 -6
  917. package/dist/src/utils/editCorrector.test.js +0 -533
  918. package/dist/src/utils/editCorrector.test.js.map +0 -1
  919. package/dist/src/utils/editor.test.d.ts +0 -6
  920. package/dist/src/utils/editor.test.js +0 -429
  921. package/dist/src/utils/editor.test.js.map +0 -1
  922. package/dist/src/utils/environmentContext.test.d.ts +0 -6
  923. package/dist/src/utils/environmentContext.test.js +0 -114
  924. package/dist/src/utils/environmentContext.test.js.map +0 -1
  925. package/dist/src/utils/errorParsing.test.d.ts +0 -6
  926. package/dist/src/utils/errorParsing.test.js +0 -84
  927. package/dist/src/utils/errorParsing.test.js.map +0 -1
  928. package/dist/src/utils/errorReporting.test.d.ts +0 -6
  929. package/dist/src/utils/errorReporting.test.js +0 -133
  930. package/dist/src/utils/errorReporting.test.js.map +0 -1
  931. package/dist/src/utils/errors.test.d.ts +0 -6
  932. package/dist/src/utils/errors.test.js +0 -155
  933. package/dist/src/utils/errors.test.js.map +0 -1
  934. package/dist/src/utils/events.test.d.ts +0 -6
  935. package/dist/src/utils/events.test.js +0 -237
  936. package/dist/src/utils/events.test.js.map +0 -1
  937. package/dist/src/utils/extensionLoader.test.d.ts +0 -6
  938. package/dist/src/utils/extensionLoader.test.js +0 -176
  939. package/dist/src/utils/extensionLoader.test.js.map +0 -1
  940. package/dist/src/utils/fileDiffUtils.test.d.ts +0 -6
  941. package/dist/src/utils/fileDiffUtils.test.js +0 -84
  942. package/dist/src/utils/fileDiffUtils.test.js.map +0 -1
  943. package/dist/src/utils/fileUtils.test.d.ts +0 -6
  944. package/dist/src/utils/fileUtils.test.js +0 -780
  945. package/dist/src/utils/fileUtils.test.js.map +0 -1
  946. package/dist/src/utils/filesearch/crawlCache.test.d.ts +0 -6
  947. package/dist/src/utils/filesearch/crawlCache.test.js +0 -103
  948. package/dist/src/utils/filesearch/crawlCache.test.js.map +0 -1
  949. package/dist/src/utils/filesearch/crawler.test.d.ts +0 -6
  950. package/dist/src/utils/filesearch/crawler.test.js +0 -495
  951. package/dist/src/utils/filesearch/crawler.test.js.map +0 -1
  952. package/dist/src/utils/filesearch/fileSearch.test.d.ts +0 -6
  953. package/dist/src/utils/filesearch/fileSearch.test.js +0 -663
  954. package/dist/src/utils/filesearch/fileSearch.test.js.map +0 -1
  955. package/dist/src/utils/filesearch/ignore.test.d.ts +0 -6
  956. package/dist/src/utils/filesearch/ignore.test.js +0 -144
  957. package/dist/src/utils/filesearch/ignore.test.js.map +0 -1
  958. package/dist/src/utils/filesearch/result-cache.test.d.ts +0 -6
  959. package/dist/src/utils/filesearch/result-cache.test.js +0 -46
  960. package/dist/src/utils/filesearch/result-cache.test.js.map +0 -1
  961. package/dist/src/utils/flashFallback.test.d.ts +0 -6
  962. package/dist/src/utils/flashFallback.test.js +0 -103
  963. package/dist/src/utils/flashFallback.test.js.map +0 -1
  964. package/dist/src/utils/formatters.test.d.ts +0 -6
  965. package/dist/src/utils/formatters.test.js +0 -26
  966. package/dist/src/utils/formatters.test.js.map +0 -1
  967. package/dist/src/utils/geminiIgnoreParser.test.d.ts +0 -6
  968. package/dist/src/utils/geminiIgnoreParser.test.js +0 -98
  969. package/dist/src/utils/geminiIgnoreParser.test.js.map +0 -1
  970. package/dist/src/utils/geminiTypeConversion.test.d.ts +0 -6
  971. package/dist/src/utils/geminiTypeConversion.test.js +0 -310
  972. package/dist/src/utils/geminiTypeConversion.test.js.map +0 -1
  973. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +0 -6
  974. package/dist/src/utils/generateContentResponseUtilities.test.js +0 -512
  975. package/dist/src/utils/generateContentResponseUtilities.test.js.map +0 -1
  976. package/dist/src/utils/getFolderStructure.test.d.ts +0 -6
  977. package/dist/src/utils/getFolderStructure.test.js +0 -283
  978. package/dist/src/utils/getFolderStructure.test.js.map +0 -1
  979. package/dist/src/utils/gitIgnoreParser.test.d.ts +0 -6
  980. package/dist/src/utils/gitIgnoreParser.test.js +0 -243
  981. package/dist/src/utils/gitIgnoreParser.test.js.map +0 -1
  982. package/dist/src/utils/googleErrors.test.d.ts +0 -6
  983. package/dist/src/utils/googleErrors.test.js +0 -309
  984. package/dist/src/utils/googleErrors.test.js.map +0 -1
  985. package/dist/src/utils/googleQuotaErrors.test.d.ts +0 -6
  986. package/dist/src/utils/googleQuotaErrors.test.js +0 -548
  987. package/dist/src/utils/googleQuotaErrors.test.js.map +0 -1
  988. package/dist/src/utils/ignorePatterns.test.d.ts +0 -6
  989. package/dist/src/utils/ignorePatterns.test.js +0 -246
  990. package/dist/src/utils/ignorePatterns.test.js.map +0 -1
  991. package/dist/src/utils/installationManager.test.d.ts +0 -6
  992. package/dist/src/utils/installationManager.test.js +0 -93
  993. package/dist/src/utils/installationManager.test.js.map +0 -1
  994. package/dist/src/utils/llm-edit-fixer.test.d.ts +0 -6
  995. package/dist/src/utils/llm-edit-fixer.test.js +0 -223
  996. package/dist/src/utils/llm-edit-fixer.test.js.map +0 -1
  997. package/dist/src/utils/llmUtils.test.d.ts +0 -6
  998. package/dist/src/utils/llmUtils.test.js +0 -196
  999. package/dist/src/utils/llmUtils.test.js.map +0 -1
  1000. package/dist/src/utils/memoryDiscovery.test.d.ts +0 -6
  1001. package/dist/src/utils/memoryDiscovery.test.js +0 -542
  1002. package/dist/src/utils/memoryDiscovery.test.js.map +0 -1
  1003. package/dist/src/utils/memoryImportProcessor.test.d.ts +0 -6
  1004. package/dist/src/utils/memoryImportProcessor.test.js +0 -581
  1005. package/dist/src/utils/memoryImportProcessor.test.js.map +0 -1
  1006. package/dist/src/utils/nextSpeakerChecker.test.d.ts +0 -6
  1007. package/dist/src/utils/nextSpeakerChecker.test.js +0 -191
  1008. package/dist/src/utils/nextSpeakerChecker.test.js.map +0 -1
  1009. package/dist/src/utils/partUtils.test.d.ts +0 -6
  1010. package/dist/src/utils/partUtils.test.js +0 -397
  1011. package/dist/src/utils/partUtils.test.js.map +0 -1
  1012. package/dist/src/utils/pathCorrector.test.d.ts +0 -6
  1013. package/dist/src/utils/pathCorrector.test.js +0 -87
  1014. package/dist/src/utils/pathCorrector.test.js.map +0 -1
  1015. package/dist/src/utils/pathReader.test.d.ts +0 -6
  1016. package/dist/src/utils/pathReader.test.js +0 -406
  1017. package/dist/src/utils/pathReader.test.js.map +0 -1
  1018. package/dist/src/utils/paths.test.d.ts +0 -6
  1019. package/dist/src/utils/paths.test.js +0 -402
  1020. package/dist/src/utils/paths.test.js.map +0 -1
  1021. package/dist/src/utils/retry.test.d.ts +0 -6
  1022. package/dist/src/utils/retry.test.js +0 -548
  1023. package/dist/src/utils/retry.test.js.map +0 -1
  1024. package/dist/src/utils/retry_llm_error.test.d.ts +0 -6
  1025. package/dist/src/utils/retry_llm_error.test.js +0 -280
  1026. package/dist/src/utils/retry_llm_error.test.js.map +0 -1
  1027. package/dist/src/utils/safeJsonStringify.test.d.ts +0 -6
  1028. package/dist/src/utils/safeJsonStringify.test.js +0 -61
  1029. package/dist/src/utils/safeJsonStringify.test.js.map +0 -1
  1030. package/dist/src/utils/schemaValidator.test.d.ts +0 -6
  1031. package/dist/src/utils/schemaValidator.test.js +0 -113
  1032. package/dist/src/utils/schemaValidator.test.js.map +0 -1
  1033. package/dist/src/utils/secure-browser-launcher.test.d.ts +0 -6
  1034. package/dist/src/utils/secure-browser-launcher.test.js +0 -149
  1035. package/dist/src/utils/secure-browser-launcher.test.js.map +0 -1
  1036. package/dist/src/utils/security.test.d.ts +0 -1
  1037. package/dist/src/utils/security.test.js +0 -121
  1038. package/dist/src/utils/security.test.js.map +0 -1
  1039. package/dist/src/utils/shell-utils.integration.test.d.ts +0 -1
  1040. package/dist/src/utils/shell-utils.integration.test.js +0 -58
  1041. package/dist/src/utils/shell-utils.integration.test.js.map +0 -1
  1042. package/dist/src/utils/shell-utils.test.d.ts +0 -6
  1043. package/dist/src/utils/shell-utils.test.js +0 -437
  1044. package/dist/src/utils/shell-utils.test.js.map +0 -1
  1045. package/dist/src/utils/stdio.test.d.ts +0 -6
  1046. package/dist/src/utils/stdio.test.js +0 -47
  1047. package/dist/src/utils/stdio.test.js.map +0 -1
  1048. package/dist/src/utils/summarizer.test.d.ts +0 -6
  1049. package/dist/src/utils/summarizer.test.js +0 -152
  1050. package/dist/src/utils/summarizer.test.js.map +0 -1
  1051. package/dist/src/utils/systemEncoding.test.d.ts +0 -6
  1052. package/dist/src/utils/systemEncoding.test.js +0 -369
  1053. package/dist/src/utils/systemEncoding.test.js.map +0 -1
  1054. package/dist/src/utils/terminalSerializer.test.d.ts +0 -6
  1055. package/dist/src/utils/terminalSerializer.test.js +0 -193
  1056. package/dist/src/utils/terminalSerializer.test.js.map +0 -1
  1057. package/dist/src/utils/textUtils.test.d.ts +0 -6
  1058. package/dist/src/utils/textUtils.test.js +0 -76
  1059. package/dist/src/utils/textUtils.test.js.map +0 -1
  1060. package/dist/src/utils/thoughtUtils.test.d.ts +0 -6
  1061. package/dist/src/utils/thoughtUtils.test.js +0 -78
  1062. package/dist/src/utils/thoughtUtils.test.js.map +0 -1
  1063. package/dist/src/utils/tokenCalculation.test.d.ts +0 -6
  1064. package/dist/src/utils/tokenCalculation.test.js +0 -184
  1065. package/dist/src/utils/tokenCalculation.test.js.map +0 -1
  1066. package/dist/src/utils/tool-utils.test.d.ts +0 -6
  1067. package/dist/src/utils/tool-utils.test.js +0 -84
  1068. package/dist/src/utils/tool-utils.test.js.map +0 -1
  1069. package/dist/src/utils/toolCallContext.test.d.ts +0 -6
  1070. package/dist/src/utils/toolCallContext.test.js +0 -68
  1071. package/dist/src/utils/toolCallContext.test.js.map +0 -1
  1072. package/dist/src/utils/userAccountManager.test.d.ts +0 -6
  1073. package/dist/src/utils/userAccountManager.test.js +0 -225
  1074. package/dist/src/utils/userAccountManager.test.js.map +0 -1
  1075. package/dist/src/utils/version.test.d.ts +0 -6
  1076. package/dist/src/utils/version.test.js +0 -39
  1077. package/dist/src/utils/version.test.js.map +0 -1
  1078. package/dist/src/utils/workspaceContext.test.d.ts +0 -6
  1079. package/dist/src/utils/workspaceContext.test.js +0 -374
  1080. package/dist/src/utils/workspaceContext.test.js.map +0 -1
  1081. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,1904 +0,0 @@
1
- # 04. DidimAIStudio 연동 설계
2
-
3
- ## 4.1 개요
4
-
5
- ### 4.1.1 목적
6
-
7
- Gemini CLI의 Multi-LLM Provider Adapter 설계를 DidimAIStudio 솔루션과 연동하여 다음 목표를 달성합니다:
8
-
9
- 1. **프로바이더 통합**: 두 시스템의 LLM 프로바이더 지원을 통합
10
- 2. **설정 공유**: 모델 설정 및 API 키를 일관되게 관리
11
- 3. **기능 재사용**: DidimAIStudio의 13+ 프로바이더 지원을 gemini-cli에서 활용
12
- 4. **양방향 통신**: CLI ↔ 서버 간 원활한 데이터 교환
13
-
14
- ### 4.1.2 DidimAIStudio 솔루션 구조
15
-
16
- > **소스코드 경로**: `/DidimAIStudio`
17
- > **인프라 구성**: `/DidimAIStudio/infra/compose/docker-compose.base.yml`
18
-
19
- DidimAIStudio는 마이크로서비스 아키텍처로 구성되어 있으며, Gemini CLI 연동에 핵심적인 서비스는 다음과 같습니다:
20
-
21
- #### 핵심 서비스
22
-
23
- | 서비스 | 포트 | 역할 | 소스 경로 |
24
- |--------|------|------|-----------|
25
- | **scenario-gateway** | 8008 | API 게이트웨이, API-Key 인증, 요청 라우팅 | `/services/scenario-gateway` |
26
- | **agents** | 8003 | LLM 실행 엔진, 시나리오/워크플로우 처리 | `/services/agents` |
27
-
28
- #### 관련 서비스
29
-
30
- | 서비스 | 포트 | 역할 |
31
- |--------|------|------|
32
- | auth | 8000 | 사용자 인증/인가 |
33
- | models | 8001 | 모델 프로파일 관리 |
34
- | indexing | 8002 | 문서 인덱싱/RAG |
35
- | cloud-storage | 8006 | 파일 스토리지 |
36
- | mcp-tools | 8007 | MCP 도구 서버 |
37
-
38
- ### 4.1.3 시스템 비교
39
-
40
- | 구분 | Gemini CLI | DidimAIStudio |
41
- |------|------------|---------------------|
42
- | **역할** | 클라이언트 CLI | 서버 마이크로서비스 |
43
- | **언어** | TypeScript | Python |
44
- | **프레임워크** | Node.js + Ink | FastAPI + LangGraph |
45
- | **프로바이더** | Gemini (+ 어댑터 확장 예정) | 13+ (OpenAI, Claude, Gemini 등) |
46
- | **스트리밍** | AsyncGenerator | SSE (Server-Sent Events) |
47
- | **설정 저장** | 환경변수 + 로컬 파일 | Database + 환경변수 |
48
- | **게이트웨이** | - | scenario-gateway (API-Key 인증) |
49
-
50
- ### 4.1.4 연동 범위
51
-
52
- **In Scope (1차)**:
53
- - 공통 타입 시스템 정의
54
- - scenario-gateway를 통한 API 연동
55
- - 메시지 형식 변환
56
- - 프로바이더 설정 동기화
57
- - 토큰 사용량 추적 통합
58
-
59
- **Out of Scope (향후)**:
60
- - 실시간 양방향 동기화
61
- - 분산 트레이싱 통합
62
- - 공유 메모리 시스템
63
-
64
- ## 4.2 연동 아키텍처
65
-
66
- ### 4.2.1 전체 구조
67
-
68
- ```
69
- ┌─────────────────────────────────────────────────────────────────────────┐
70
- │ User │
71
- └─────────────────────────────────┬───────────────────────────────────────┘
72
-
73
- ┌─────────────┴─────────────┐
74
- │ │
75
- ▼ ▼
76
- ┌───────────────────────────────┐ ┌───────────────────────────────────┐
77
- │ Gemini CLI │ │ DidimAIStudio Web App │
78
- │ (Terminal Client) │ │ (Browser Client) │
79
- └───────────────┬───────────────┘ └─────────────────┬─────────────────┘
80
- │ │
81
- │ │
82
- ▼ │
83
- ┌───────────────────────────────────────────────────────────────────────┐
84
- │ Integration Layer │
85
- │ ┌─────────────────────────────────────────────────────────────────┐ │
86
- │ │ DidimAIStudioAdapter │ │
87
- │ │ (gemini-cli 내부) │ │
88
- │ │ │ │
89
- │ │ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │ │
90
- │ │ │ Request │ │ Response │ │ Stream │ │ │
91
- │ │ │ Converter │ │ Converter │ │ Adapter │ │ │
92
- │ │ └──────────────┘ └──────────────┘ └──────────────┘ │ │
93
- │ └─────────────────────────────────────────────────────────────────┘ │
94
- └───────────────────────────────────┬───────────────────────────────────┘
95
-
96
- │ HTTP/SSE
97
-
98
- ┌───────────────────────────────────────────────────────────────────────┐
99
- │ DidimAIStudio Solution (Microservices) │
100
- │ │
101
- │ ┌─────────────────────────────────────────────────────────────────┐ │
102
- │ │ scenario-gateway (Port 8008) │ │
103
- │ │ API-Key 인증 게이트웨이 │ │
104
- │ │ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │ │
105
- │ │ │ /invoke │ │ /invoke/sse │ │/invoke/sse/ │ │ │
106
- │ │ │ (REST) │ │ (Streaming) │ │ improved │ │ │
107
- │ │ └──────────────┘ └──────────────┘ └──────────────┘ │ │
108
- │ │ ↓ ↓ ↓ │ │
109
- │ │ ┌─────────────────────────────────────────────────┐ │ │
110
- │ │ │ - API-Key 검증 (ApiKeyAuthMiddleware) │ │ │
111
- │ │ │ - IP 검증, Rate Limiting │ │ │
112
- │ │ │ - x-thread-id 헤더 처리 (새 Thread vs 기존) │ │ │
113
- │ │ │ - WebSocket Key (qa_id) 발급 │ │ │
114
- │ │ └─────────────────────────────────────────────────┘ │ │
115
- │ └──────────────────────────────┬──────────────────────────────────┘ │
116
- │ │ HTTP/SSE │
117
- │ ▼ │
118
- │ ┌─────────────────────────────────────────────────────────────────┐ │
119
- │ │ agents (Port 8003) │ │
120
- │ │ LLM 실행 엔진 │ │
121
- │ │ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │ │
122
- │ │ │ /v1/invoke │ │/v1/invoke/sse│ │/v1/websocket │ │ │
123
- │ │ │ │ │ /improved │ │ -keys │ │ │
124
- │ │ └──────────────┘ └──────────────┘ └──────────────┘ │ │
125
- │ │ │ │ │
126
- │ │ ┌─────────────────────────────────▼───────────────────────────┐│ │
127
- │ │ │ LangGraph Runtime ││ │
128
- │ │ │ ┌────────┐ ┌────────┐ ┌────────┐ ┌────────┐ ┌────────┐ ││ │
129
- │ │ │ │ OpenAI │ │ Claude │ │ Gemini │ │Bedrock │ │ vLLM │... ││ │
130
- │ │ │ └────────┘ └────────┘ └────────┘ └────────┘ └────────┘ ││ │
131
- │ │ └─────────────────────────────────────────────────────────────┘│ │
132
- │ └─────────────────────────────────────────────────────────────────┘ │
133
- └───────────────────────────────────────────────────────────────────────┘
134
- ```
135
-
136
- ### 4.2.2 서비스 간 통신 흐름
137
-
138
- ```
139
- ┌──────────────────────────────────────────────────────────────────────────┐
140
- │ 요청 흐름 (Request Flow) │
141
- ├──────────────────────────────────────────────────────────────────────────┤
142
- │ │
143
- │ ┌─────────────┐ │
144
- │ │ Gemini CLI │ │
145
- │ │ (Request) │ │
146
- │ └──────┬──────┘ │
147
- │ │ │
148
- │ │ POST /api/v1/invoke/sse │
149
- │ │ Headers: Authorization: Bearer <API-KEY> │
150
- │ │ x-thread-id: <thread-id> (optional) │
151
- │ │ Body: { "chat": "사용자 메시지" } │
152
- │ ▼ │
153
- │ ┌─────────────────────────────────────────────────────────────────┐ │
154
- │ │ scenario-gateway (:8008) │ │
155
- │ │ │ │
156
- │ │ 1. API-Key 검증 (ApiKeyAuthMiddleware) │ │
157
- │ │ 2. passport_data 추출 (user_id, my_scenario_id) │ │
158
- │ │ 3. x-thread-id 헤더 확인: │ │
159
- │ │ - 없음: 새 Thread + qa_id 생성 (POST /v1/websocket-keys) │ │
160
- │ │ - 있음: 기존 Thread에 qa_id 발급 (/v1/websocket-keys/with-thread-id) │
161
- │ │ 4. AgentsInvokeRequest 구성 │ │
162
- │ └──────────────────────────────┬──────────────────────────────────┘ │
163
- │ │ │
164
- │ POST http://agents:8003/v1/invoke/sse │
165
- │ Body: { │
166
- │ "scenario_my_page_id": 123, │
167
- │ "user_id": "user-uuid", │
168
- │ "thread_id": "thread-uuid", │
169
- │ "qa_id": "qa-uuid", │
170
- │ "message": "사용자 메시지", │
171
- │ "attachments": null │
172
- │ } │
173
- │ ▼ │
174
- │ ┌─────────────────────────────────────────────────────────────────┐ │
175
- │ │ agents (:8003) │ │
176
- │ │ │ │
177
- │ │ 1. 시나리오 조회 (scenario_my_page_id) │ │
178
- │ │ 2. LangGraph 워크플로우 실행 │ │
179
- │ │ 3. SSE 스트리밍 응답 생성 │ │
180
- │ └─────────────────────────────────────────────────────────────────┘ │
181
- │ │
182
- └──────────────────────────────────────────────────────────────────────────┘
183
- ```
184
-
185
- ### 4.2.3 연동 모드
186
-
187
- #### 모드 A: Direct Provider (기본)
188
-
189
- gemini-cli가 직접 LLM API를 호출합니다.
190
-
191
- ```
192
- Gemini CLI ──► Provider Adapter ──► LLM API (OpenAI/Claude/Gemini)
193
- ```
194
-
195
- **사용 시나리오**: 단독 CLI 사용, 빠른 응답 필요
196
-
197
- **설정**:
198
- ```typescript
199
- // 환경변수 또는 config에서 설정
200
- LLM_PROVIDER=gemini // gemini | claude | openai | vllm
201
- GEMINI_API_KEY=...
202
- ```
203
-
204
- > ⚠️ **Direct 모드 구현 상태**: 현재 `03-technical-design.md`의 GeminiAdapter, ClaudeAdapter, OpenAIAdapter 설계에 해당합니다. DidimAIStudioAdapter와는 별개의 코드 경로입니다.
205
-
206
- #### 모드 B: Gateway Mode (DidimAIStudio 연동)
207
-
208
- gemini-cli가 DidimAIStudio를 통해 LLM API를 호출합니다.
209
-
210
- ```
211
- Gemini CLI ──► DidimAIStudioAdapter ──► scenario-gateway ──► agents ──► LLM API
212
- ```
213
-
214
- **사용 시나리오**:
215
- - DidimAIStudio의 고급 기능 활용 (에이전트 워크플로우, 메모리)
216
- - 중앙 집중식 API 키 관리
217
- - 사용량 추적 및 비용 관리
218
-
219
- **설정**:
220
- ```typescript
221
- // 환경변수 또는 config에서 설정
222
- LLM_PROVIDER=didim
223
- DIDIM_BASE_URL=http://localhost:8008
224
- DIDIM_API_KEY=...
225
- ```
226
-
227
- > ⚠️ **엔드포인트 선택 (M2 관련)**:
228
- > - `/api/v1/invoke/sse`: 기본 SSE 스트리밍
229
- > - `/api/v1/invoke/sse/improved`: LangGraph 세분화 SSE (권장)
230
- >
231
- > 현재 어댑터는 **`/api/v1/invoke/sse/improved`를 사용**합니다.
232
-
233
- ### 4.2.4 데이터 흐름
234
-
235
- ```
236
- ┌─────────────────────────────────────────────────────────────────────────┐
237
- │ Request Flow │
238
- ├─────────────────────────────────────────────────────────────────────────┤
239
- │ │
240
- │ ┌─────────────┐ ┌─────────────────┐ ┌─────────────────────┐ │
241
- │ │ User Input │────▶│ LlmGenerateReq │────▶│ ScenarioSSERequestDTO│ │
242
- │ │ (CLI) │ │ (gemini-cli) │ │ (scenario-gateway) │ │
243
- │ └─────────────┘ └─────────────────┘ └───────────┬─────────┘ │
244
- │ │ │
245
- │ ▼ │
246
- │ ┌─────────────────────┐ │
247
- │ │ AgentsInvokeRequest │ │
248
- │ │ (agents service) │ │
249
- │ └───────────┬─────────┘ │
250
- │ │ │
251
- │ ▼ │
252
- │ ┌─────────────────────┐ │
253
- │ │ LangGraph Runtime │ │
254
- │ │ Processing │ │
255
- │ └─────────────────────┘ │
256
- │ │ │
257
- ├─────────────────────────────────────────────────────────────────────────┤
258
- │ Response Flow │
259
- ├─────────────────────────────────────────────────────────────────────────┤
260
- │ │ │
261
- │ ▼ │
262
- │ ┌─────────────┐ ┌─────────────────┐ ┌─────────────────────┐ │
263
- │ │ CLI Output │◀────│ LlmStreamEvent │◀────│ SSE Events │ │
264
- │ │ (Stream) │ │ (gemini-cli) │ │ (message_partial, │ │
265
- │ └─────────────┘ └─────────────────┘ │ message_complete, │ │
266
- │ │ done, error) │ │
267
- │ └─────────────────────┘ │
268
- │ │
269
- └─────────────────────────────────────────────────────────────────────────┘
270
- ```
271
-
272
- ## 4.3 공통 타입 시스템
273
-
274
- ### 4.3.1 DidimAIStudio 실제 DTO 구조
275
-
276
- > **소스 참조**: `/services/scenario-gateway/app/dto/agents_dto.py`
277
-
278
- #### scenario-gateway 입력 DTO
279
-
280
- ```python
281
- # ScenarioSSERequestDTO - Gemini CLI → scenario-gateway
282
- class ScenarioSSERequestDTO(BaseModel):
283
- chat: str # 채팅 메시지 (1-10000자)
284
- ```
285
-
286
- #### agents 서비스 요청 DTO
287
-
288
- ```python
289
- # AgentsInvokeRequest - scenario-gateway → agents
290
- class AgentsInvokeRequest(BaseModel):
291
- scenario_my_page_id: int # 시나리오 마이페이지 ID
292
- user_id: str # 사용자 ID
293
- thread_id: str # 대화 흐름 구분 ID
294
- qa_id: str # 질문-응답 단위 ID
295
- message: str # 사용자 메시지 (1-50000자)
296
- attachments: Optional[List[str]] # 첨부파일 URL 목록
297
- ```
298
-
299
- #### agents 서비스 응답 DTO
300
-
301
- ```python
302
- # AgentsInvokeResponse - agents → scenario-gateway
303
- class AgentsInvokeResponse(BaseModel):
304
- qa_id: str # 질문-응답 단위 ID
305
- message: Optional[str] # 텍스트 응답
306
- attachments: Optional[List[str]] # 첨부파일 URL 목록
307
- status: Optional[str] # success|error|processing|timeout
308
- error_code: Optional[str] # 오류 코드
309
- ```
310
-
311
- ### 4.3.2 타입 매핑 테이블
312
-
313
- #### 메시지 타입
314
-
315
- | Gemini CLI | DidimAIStudio | 설명 |
316
- |------------|---------------|------|
317
- | `LlmMessage` | `BaseMessage` (LangChain) | 기본 메시지 |
318
- | `LlmTextContent` | `message: str` | 텍스트 내용 |
319
- | `LlmImageContent` | `attachments: List[str]` | 이미지 URL |
320
- | `LlmToolCallContent` | `ToolCall` (LangGraph) | 도구 호출 |
321
- | `LlmToolResultContent` | `ToolMessage` (LangGraph) | 도구 결과 |
322
-
323
- #### 요청/응답 타입
324
-
325
- | Gemini CLI | DidimAIStudio (scenario-gateway) | DidimAIStudio (agents) | 비고 |
326
- |------------|----------------------------------|------------------------|------|
327
- | `LlmGenerateRequest` | `ScenarioSSERequestDTO` | `AgentsInvokeRequest` | ⚠️ chat 필드만 전달됨 |
328
- | `LlmGenerateResponse` | SSE `done` event | `AgentsInvokeResponse` | |
329
- | `LlmStreamEvent` | SSE Events | SSE Events | |
330
- | `LlmTokenUsage` | `token_summary` | `total_tokens` | |
331
-
332
- > ⚠️ **제한사항**:
333
- > - `LlmGenerateRequest`의 `messages[]`, `tools[]`, `systemInstruction`은 현재 gateway API로 전달 불가
334
- > - Multi-turn 컨텍스트는 서버 측 thread 관리에 의존
335
-
336
- #### SSE 이벤트 타입 매핑
337
-
338
- | Gemini CLI `LlmStreamEvent.type` | DidimAIStudio SSE Event | 설명 | 비고 |
339
- |----------------------------------|-------------------------|------|------|
340
- | `content_delta` | `message`, `content` | 텍스트 청크 | |
341
- | `content_delta` | `message_partial` | 토큰 스트리밍 | improved SSE |
342
- | `content_delta` (metadata) | `message_metadata` | 실행 컨텍스트 | improved SSE |
343
- | `content_delta` (metadata) | `process` | 노드 진행 상황 | improved SSE |
344
- | `message_end` | `done` | 응답 완료 | threadId, qaId 포함 |
345
- | `error` | `error` | 에러 발생 | |
346
-
347
- > ⚠️ **tool_call_delta 미지원**: 현재 gateway API는 tool 정보를 입/출력하지 않으므로 `tool_call_delta` 이벤트는 발생하지 않습니다.
348
-
349
- #### 완료 상태 매핑
350
-
351
- | Gemini CLI `LlmStopReason` | DidimAIStudio SSE Event |
352
- |---------------------------|-------------------------|
353
- | `end_turn` | `done` event |
354
- | `max_tokens` | `done` with truncation |
355
- | `tool_use` | `process` (tool_start) |
356
- | `content_filter` | `error` (CONTENT_FILTER) |
357
- | `error` | `error` event |
358
-
359
- ### 4.3.3 공통 인터페이스 정의
360
-
361
- #### TypeScript (gemini-cli)
362
-
363
- ```typescript
364
- // packages/core/src/providers/didim/types.ts
365
-
366
- /**
367
- * DidimAIStudio 연동을 위한 공통 타입
368
- * 실제 DidimAIStudio DTO 구조 기반
369
- */
370
-
371
- // scenario-gateway 입력 (POST /api/v1/invoke/sse)
372
- export interface ScenarioSSERequestDTO {
373
- chat: string; // 채팅 메시지 (1-10000자)
374
- }
375
-
376
- // agents 서비스 요청 (내부 통신용, scenario-gateway → agents)
377
- export interface AgentsInvokeRequest {
378
- scenario_my_page_id: number; // 시나리오 마이페이지 ID
379
- user_id: string; // 사용자 ID
380
- thread_id: string; // 대화 흐름 구분 ID
381
- qa_id: string; // 질문-응답 단위 ID
382
- message: string; // 사용자 메시지
383
- attachments?: string[] | null; // 첨부파일 URL 목록
384
- }
385
-
386
- // agents 서비스 응답
387
- export interface AgentsInvokeResponse {
388
- qa_id: string;
389
- message?: string | null;
390
- attachments?: string[] | null;
391
- status?: 'success' | 'error' | 'processing' | 'timeout';
392
- error_code?: string | null;
393
- }
394
-
395
- // WebSocket Key 생성 DTO
396
- export interface WebSocketKeyCreateDTO {
397
- user_id: string;
398
- scenario_my_page_id?: number;
399
- }
400
-
401
- // WebSocket Key 응답 DTO
402
- export interface WebSocketKeyResponseDTO {
403
- id: number;
404
- user_id: string;
405
- scenario_my_page_id?: number;
406
- thread_id: string; // 스레드 ID
407
- qa_id: string; // QA ID
408
- created_at: string;
409
- updated_at: string;
410
- }
411
-
412
- // SSE 이벤트 타입
413
- export type DidimSSEEventType =
414
- | 'message' // 기본 메시지 청크
415
- | 'content' // 콘텐츠 청크
416
- | 'message_partial' // 토큰 스트리밍 (improved)
417
- | 'message_complete' // 메시지 완료 (improved)
418
- | 'message_metadata' // 실행 컨텍스트 (improved)
419
- | 'process' // 노드 진행 상황 (improved)
420
- | 'done' // 응답 완료
421
- | 'error'; // 에러
422
-
423
- // SSE 청크 데이터
424
- export interface SSEChatChunk {
425
- chunk?: string;
426
- scenario_id?: string;
427
- thread_id?: string;
428
- }
429
-
430
- // SSE 완료 데이터
431
- export interface SSEDoneData {
432
- message: string;
433
- scenario_id: string;
434
- thread_id: string;
435
- qa_id: string;
436
- }
437
-
438
- // SSE 에러 데이터
439
- export interface SSEErrorData {
440
- error: string;
441
- error_code?: string;
442
- }
443
-
444
- // 채팅 응답 (비스트리밍)
445
- export interface ChatResponse {
446
- response: string;
447
- scenario_id: string;
448
- thread_id: string;
449
- timestamp: string;
450
- }
451
- ```
452
-
453
- #### Python (DidimAIStudio) - 신규 연동 API용
454
-
455
- ```python
456
- # services/agents/app/schemas/integration/gemini_cli.py
457
-
458
- from pydantic import BaseModel
459
- from typing import Optional, Union, List, Dict, Any
460
- from enum import Enum
461
-
462
- class LlmStopReason(str, Enum):
463
- END_TURN = "end_turn"
464
- MAX_TOKENS = "max_tokens"
465
- STOP_SEQUENCE = "stop_sequence"
466
- TOOL_USE = "tool_use"
467
- CONTENT_FILTER = "content_filter"
468
- ERROR = "error"
469
-
470
- class LlmTextContent(BaseModel):
471
- type: str = "text"
472
- text: str
473
-
474
- class LlmImageContent(BaseModel):
475
- type: str = "image"
476
- source: Dict[str, str] # type, mediaType, data
477
-
478
- class LlmToolCallContent(BaseModel):
479
- type: str = "tool_call"
480
- id: str
481
- name: str
482
- arguments: Dict[str, Any]
483
-
484
- class LlmMessage(BaseModel):
485
- role: str # user, assistant, system, tool
486
- content: List[Union[LlmTextContent, LlmImageContent, LlmToolCallContent]]
487
- name: Optional[str] = None
488
- tool_call_id: Optional[str] = None
489
-
490
- class LlmGenerateRequest(BaseModel):
491
- """Gemini CLI 요청 형식"""
492
- model: str
493
- messages: List[LlmMessage]
494
- system_instruction: Optional[str] = None
495
- tools: Optional[List[Dict]] = None
496
- tool_choice: Optional[str] = None
497
- temperature: Optional[float] = None
498
- max_tokens: Optional[int] = None
499
- stop_sequences: Optional[List[str]] = None
500
- top_p: Optional[float] = None
501
- top_k: Optional[int] = None
502
-
503
- class LlmTokenUsage(BaseModel):
504
- prompt_tokens: int
505
- completion_tokens: int
506
- total_tokens: int
507
- cached_tokens: Optional[int] = None
508
-
509
- class LlmGenerateResponse(BaseModel):
510
- """Gemini CLI 응답 형식"""
511
- id: str
512
- content: List[Union[LlmTextContent, LlmToolCallContent]]
513
- model: str
514
- stop_reason: LlmStopReason
515
- usage: LlmTokenUsage
516
- raw_response: Optional[Dict] = None
517
- ```
518
-
519
- ## 4.4 어댑터 구현
520
-
521
- ### 4.4.1 DidimAIStudio 실제 API 엔드포인트
522
-
523
- > **소스 참조**:
524
- > - `/services/scenario-gateway/app/api/v1/endpoints/scenario_api.py`
525
- > - `/services/agents/app/api/v1/router.py`
526
-
527
- #### scenario-gateway 엔드포인트 (Port 8008)
528
-
529
- | 메서드 | 경로 | 설명 |
530
- |--------|------|------|
531
- | POST | `/api/v1/invoke` | 비스트리밍 채팅 요청 |
532
- | POST | `/api/v1/invoke/sse` | SSE 스트리밍 채팅 |
533
- | POST | `/api/v1/invoke/sse/improved` | LangGraph 호환 세분화 SSE |
534
- | GET | `/health` | 헬스 체크 |
535
- | GET | `/metrics` | Prometheus 메트릭 |
536
-
537
- #### agents 엔드포인트 (Port 8003) - 내부 통신
538
-
539
- | 메서드 | 경로 | 설명 |
540
- |--------|------|------|
541
- | POST | `/v1/invoke` | 비스트리밍 실행 |
542
- | POST | `/v1/invoke/sse` | SSE 스트리밍 실행 |
543
- | POST | `/v1/invoke/sse/improved` | 세분화 SSE 스트리밍 |
544
- | POST | `/v1/websocket-keys` | 새 Thread + qa_id 생성 |
545
- | POST | `/v1/websocket-keys/with-thread-id` | 기존 Thread에 qa_id 발급 |
546
- | POST | `/v1/chats` | 채팅 종료 (토큰 집계) |
547
- | GET | `/v1/scenarios` | 시나리오 조회 |
548
- | GET | `/v1/threads` | Thread 조회 |
549
-
550
- ### 4.4.2 DidimAIStudio 어댑터 (gemini-cli)
551
-
552
- ```typescript
553
- // packages/core/src/providers/didim/adapter.ts
554
-
555
- import { BaseAdapter, AdapterConfig } from '../baseAdapter';
556
- import {
557
- LlmGenerateRequest,
558
- LlmGenerateResponse,
559
- LlmStream,
560
- LlmStreamEvent,
561
- ProviderCapabilities,
562
- } from '../types';
563
- import {
564
- ScenarioSSERequestDTO,
565
- ChatResponse,
566
- SSEDoneData,
567
- SSEErrorData,
568
- DidimSSEEventType,
569
- } from './types';
570
- import { DidimTypeConverter } from './converter';
571
-
572
- export interface DidimAdapterConfig extends AdapterConfig {
573
- baseUrl: string; // scenario-gateway URL (예: http://localhost:8008)
574
- apiKey: string; // API Key (Bearer 토큰)
575
- threadId?: string; // 기존 대화 스레드 ID (선택적)
576
- }
577
-
578
- export class DidimAIStudioAdapter extends BaseAdapter {
579
- readonly providerName = 'didim-aistudio';
580
- /**
581
- * Capabilities - 실제 scenario-gateway API 지원 범위 기반
582
- *
583
- * ⚠️ 제한사항:
584
- * - Tool/Attachment는 현재 ScenarioSSERequestDTO(chat만 수신)로 전달 불가
585
- * - Embedding/TokenCount는 사후 추정값만 제공 (사전 API 없음)
586
- * - System message는 시나리오 설정에 포함되어야 함 (요청 시 전달 불가)
587
- */
588
- readonly capabilities: ProviderCapabilities = {
589
- supportsStreaming: true,
590
- supportsToolCalls: false, // ⚠️ 현재 gateway API로 tool 정보 전달 불가
591
- supportsImageInput: false, // ⚠️ attachments는 gateway 내부에서만 처리
592
- supportsImageGeneration: false,
593
- supportsEmbedding: false, // ⚠️ Didim API에 사전 embedding endpoint 없음
594
- supportsTokenCount: false, // ⚠️ 사전 token count API 없음 (추정값만 가능)
595
- supportsSystemMessage: false, // ⚠️ 시나리오 설정에 포함, 요청 시 전달 불가
596
- maxContextLength: 200_000, // 시나리오에 설정된 모델에 따라 다름
597
- maxOutputTokens: 32_768,
598
- };
599
-
600
- private converter: DidimTypeConverter;
601
- private config: DidimAdapterConfig;
602
- private currentThreadId?: string;
603
-
604
- constructor(config: DidimAdapterConfig) {
605
- super(config);
606
- this.config = config;
607
- this.converter = new DidimTypeConverter();
608
- this.currentThreadId = config.threadId;
609
- }
610
-
611
- /**
612
- * ⚠️ 알려진 제한사항 (H3):
613
- * - ScenarioSSERequestDTO가 "chat" 필드만 받으므로, 마지막 사용자 메시지만 전송됨
614
- * - 시스템 메시지, 이전 대화 히스토리, 도구 컨텍스트는 전달되지 않음
615
- * - Multi-turn 품질은 DidimAIStudio 서버 측 thread 관리에 의존
616
- *
617
- * TODO: 전용 API 확장 시 LlmGenerateRequest 전체를 전달하도록 개선
618
- */
619
- async generateContent(
620
- request: LlmGenerateRequest,
621
- options?: GenerateOptions
622
- ): Promise<LlmGenerateResponse> {
623
- // 마지막 사용자 메시지만 추출 (API 제약으로 인한 제한)
624
- const chatMessage = this.converter.extractLastUserMessage(request);
625
-
626
- const response = await fetch(`${this.config.baseUrl}/api/v1/invoke`, {
627
- method: 'POST',
628
- headers: {
629
- 'Content-Type': 'application/json',
630
- 'Authorization': `Bearer ${this.config.apiKey}`,
631
- ...(this.currentThreadId && { 'x-thread-id': this.currentThreadId }),
632
- },
633
- body: JSON.stringify({ chat: chatMessage }),
634
- signal: options?.signal,
635
- });
636
-
637
- if (!response.ok) {
638
- throw new Error(`Didim AI generation failed: ${response.statusText}`);
639
- }
640
-
641
- const data: ChatResponse = await response.json();
642
-
643
- // thread_id 저장 (다음 요청에 사용)
644
- this.currentThreadId = data.thread_id;
645
-
646
- return this.converter.toChatResponseToLlm(data, request.model);
647
- }
648
-
649
- async generateContentStream(
650
- request: LlmGenerateRequest,
651
- options?: GenerateOptions
652
- ): Promise<LlmStream> {
653
- this.validateRequest(request);
654
- return this.createSSEStream(request, options);
655
- }
656
-
657
- async countTokens(request: LlmGenerateRequest): Promise<LlmTokenCount> {
658
- // DidimAIStudio는 응답 시 토큰 정보 제공
659
- // 사전 카운트는 추정값 사용
660
- const text = this.converter.extractText(request);
661
- return { totalTokens: Math.ceil(text.length / 4) };
662
- }
663
-
664
- private async *createSSEStream(
665
- request: LlmGenerateRequest,
666
- options?: GenerateOptions
667
- ): LlmStream {
668
- const chatMessage = this.converter.extractLastUserMessage(request);
669
-
670
- const response = await fetch(`${this.config.baseUrl}/api/v1/invoke/sse/improved`, {
671
- method: 'POST',
672
- headers: {
673
- 'Content-Type': 'application/json',
674
- 'Authorization': `Bearer ${this.config.apiKey}`,
675
- 'Accept': 'text/event-stream',
676
- ...(this.currentThreadId && { 'x-thread-id': this.currentThreadId }),
677
- },
678
- body: JSON.stringify({ chat: chatMessage }),
679
- signal: options?.signal,
680
- });
681
-
682
- if (!response.ok) {
683
- throw new Error(`SSE connection failed: ${response.statusText}`);
684
- }
685
-
686
- const reader = response.body?.getReader();
687
- if (!reader) {
688
- throw new Error('No response body');
689
- }
690
-
691
- const decoder = new TextDecoder();
692
- let buffer = '';
693
-
694
- try {
695
- while (true) {
696
- const { done, value } = await reader.read();
697
- if (done) break;
698
-
699
- buffer += decoder.decode(value, { stream: true });
700
-
701
- // 완전한 SSE 이벤트 추출 (\n\n로 구분)
702
- while (buffer.includes('\n\n')) {
703
- const eventEnd = buffer.indexOf('\n\n');
704
- const completeEvent = buffer.substring(0, eventEnd);
705
- buffer = buffer.substring(eventEnd + 2);
706
-
707
- if (completeEvent.trim()) {
708
- const event = this.parseSSEEvent(completeEvent);
709
- if (event) {
710
- // thread_id 저장
711
- if (event.threadId) {
712
- this.currentThreadId = event.threadId;
713
- }
714
- yield this.converter.toStreamEvent(event);
715
- }
716
- }
717
- }
718
- }
719
- } finally {
720
- reader.releaseLock();
721
- }
722
- }
723
-
724
- /**
725
- * SSE 이벤트 파싱 (M1 개선)
726
- * - 다중 data: 라인 지원
727
- * - event: 없는 기본 이벤트 처리
728
- * - \r\n 및 \n 구분자 모두 처리
729
- */
730
- private parseSSEEvent(eventText: string): ParsedSSEEvent | null {
731
- // \r\n과 \n 모두 지원
732
- const lines = eventText.replace(/\r\n/g, '\n').split('\n');
733
- let eventType: string | null = null;
734
- const dataLines: string[] = [];
735
- let eventId: string | null = null;
736
-
737
- for (const line of lines) {
738
- if (line.startsWith('event:')) {
739
- eventType = line.substring(6).trim();
740
- } else if (line.startsWith('data:')) {
741
- // 다중 data: 라인 수집
742
- dataLines.push(line.substring(5).trim());
743
- } else if (line.startsWith('id:')) {
744
- eventId = line.substring(3).trim();
745
- }
746
- }
747
-
748
- // data 라인들을 줄바꿈으로 결합
749
- const data = dataLines.join('\n');
750
-
751
- // event: 없이 data:만 있는 SSE도 처리 (기본 이벤트)
752
- if (!data) return null;
753
- if (!eventType) eventType = 'message'; // 기본 이벤트 타입
754
-
755
- try {
756
- const parsed = JSON.parse(data);
757
- return {
758
- eventType,
759
- data: parsed,
760
- eventId,
761
- // H1 수정: data에서 threadId 추출
762
- threadId: parsed.thread_id || parsed.threadId,
763
- qaId: parsed.qa_id || parsed.qaId,
764
- };
765
- } catch {
766
- return { eventType, data: { chunk: data }, eventId };
767
- }
768
- }
769
- }
770
-
771
- interface ParsedSSEEvent {
772
- eventType: string;
773
- data: any;
774
- eventId: string | null;
775
- threadId?: string; // H1: data에서 추출된 threadId
776
- qaId?: string; // data에서 추출된 qaId
777
- }
778
- ```
779
-
780
- ### 4.4.3 타입 변환기 (gemini-cli)
781
-
782
- ```typescript
783
- // packages/core/src/providers/didim/converter.ts
784
-
785
- import {
786
- LlmGenerateRequest,
787
- LlmGenerateResponse,
788
- LlmMessage,
789
- LlmStreamEvent,
790
- LlmStopReason,
791
- LlmTextContent,
792
- LlmTokenUsage,
793
- } from '../types';
794
- import {
795
- ChatResponse,
796
- SSEDoneData,
797
- SSEErrorData,
798
- DidimSSEEventType,
799
- } from './types';
800
-
801
- export class DidimTypeConverter {
802
- /**
803
- * 마지막 사용자 메시지 추출
804
- */
805
- extractLastUserMessage(request: LlmGenerateRequest): string {
806
- const userMessages = request.messages.filter(m => m.role === 'user');
807
- if (userMessages.length === 0) return '';
808
-
809
- const lastMessage = userMessages[userMessages.length - 1];
810
- const texts = lastMessage.content
811
- .filter((c): c is LlmTextContent => c.type === 'text')
812
- .map(c => c.text);
813
-
814
- return texts.join('\n');
815
- }
816
-
817
- /**
818
- * 전체 텍스트 추출 (토큰 카운트용)
819
- */
820
- extractText(request: LlmGenerateRequest): string {
821
- const texts: string[] = [];
822
- for (const message of request.messages) {
823
- for (const content of message.content) {
824
- if (content.type === 'text') {
825
- texts.push((content as LlmTextContent).text);
826
- }
827
- }
828
- }
829
- return texts.join('\n');
830
- }
831
-
832
- /**
833
- * 첨부 파일 URL 추출
834
- */
835
- extractAttachments(messages: LlmMessage[]): string[] {
836
- const attachments: string[] = [];
837
- for (const message of messages) {
838
- for (const content of message.content) {
839
- if (content.type === 'image' && content.source?.type === 'url') {
840
- attachments.push(content.source.data);
841
- }
842
- }
843
- }
844
- return attachments;
845
- }
846
-
847
- /**
848
- * ChatResponse → LlmGenerateResponse 변환
849
- */
850
- toChatResponseToLlm(response: ChatResponse, model: string): LlmGenerateResponse {
851
- return {
852
- id: response.thread_id,
853
- content: [{ type: 'text', text: response.response }],
854
- model,
855
- stopReason: 'end_turn' as LlmStopReason,
856
- usage: {
857
- promptTokens: 0,
858
- completionTokens: 0,
859
- totalTokens: 0,
860
- },
861
- };
862
- }
863
-
864
- /**
865
- * SSE 이벤트 → LlmStreamEvent 변환
866
- */
867
- toStreamEvent(event: { eventType: string; data: any; eventId: string | null }): LlmStreamEvent {
868
- const { eventType, data } = event;
869
-
870
- switch (eventType) {
871
- case 'message':
872
- case 'content':
873
- case 'message_partial':
874
- // 텍스트 청크
875
- return {
876
- type: 'content_delta',
877
- delta: { text: data.chunk || data.message || '' },
878
- };
879
-
880
- case 'message_complete':
881
- // 도구 완료 또는 메시지 완료
882
- if (data.process_name) {
883
- return {
884
- type: 'tool_call_delta',
885
- delta: {
886
- toolCall: {
887
- type: 'tool_call',
888
- id: data.id || 'unknown',
889
- name: data.process_name,
890
- arguments: data.process_output || {},
891
- },
892
- },
893
- };
894
- }
895
- return {
896
- type: 'content_delta',
897
- delta: { text: data.message || '' },
898
- };
899
-
900
- case 'message_metadata':
901
- // 실행 컨텍스트 (improved SSE)
902
- return {
903
- type: 'content_delta',
904
- delta: {},
905
- metadata: {
906
- langgraphNode: data.langgraph_node,
907
- step: data.step,
908
- model: data.model,
909
- },
910
- };
911
-
912
- case 'process':
913
- // 노드 진행 상황
914
- return {
915
- type: 'content_delta',
916
- delta: {},
917
- metadata: {
918
- processName: data.process_name,
919
- processType: data.process_type,
920
- },
921
- };
922
-
923
- case 'done':
924
- // 응답 완료
925
- const doneData = data as SSEDoneData;
926
- return {
927
- type: 'message_end',
928
- usage: {
929
- promptTokens: 0,
930
- completionTokens: 0,
931
- totalTokens: 0,
932
- },
933
- threadId: doneData.thread_id,
934
- qaId: doneData.qa_id,
935
- };
936
-
937
- case 'error':
938
- // 에러
939
- const errorData = data as SSEErrorData;
940
- return {
941
- type: 'error',
942
- error: {
943
- type: errorData.error_code || 'unknown',
944
- message: errorData.error,
945
- },
946
- };
947
-
948
- default:
949
- return {
950
- type: 'content_delta',
951
- delta: {},
952
- };
953
- }
954
- }
955
- }
956
- ```
957
-
958
- ### 4.4.4 기존 API 활용 방안 (DidimAIStudio)
959
-
960
- > **핵심**: Gemini CLI는 scenario-gateway의 기존 API를 그대로 활용합니다.
961
- > 별도의 `/gemini-cli` 전용 API를 만들지 않고, 기존 `/api/v1/invoke/sse` 엔드포인트를 사용합니다.
962
-
963
- #### 기존 API 흐름 (scenario_api.py)
964
-
965
- ```python
966
- # /services/scenario-gateway/app/api/v1/endpoints/scenario_api.py
967
-
968
- # 현재 구조:
969
- # POST /api/v1/invoke/sse
970
- # 1. API-Key 인증 (ApiKeyAuthMiddleware)
971
- # 2. passport_data에서 user_id, my_scenario_id 추출
972
- # 3. x-thread-id 헤더 확인 → WebSocket Key 생성/조회
973
- # 4. AgentsInvokeRequest 구성
974
- # 5. agents 서비스 호출 (http://agents:8003/v1/invoke/sse)
975
- # 6. SSE 스트리밍 응답 전달
976
-
977
- @router.post("/invoke/sse")
978
- async def scenario_request_sse(
979
- request_data: ScenarioSSERequestDTO, # { "chat": "메시지" }
980
- request: Request,
981
- x_thread_id: str = Header(None, alias="x-thread-id"),
982
- x_dooray_info_key: str = Header(None, alias="x-dooray-info-key")
983
- ):
984
- # ... 기존 구현 활용
985
- ```
986
-
987
- #### Gemini CLI 연동 시 추가 고려사항
988
-
989
- 1. **API-Key 발급**: Gemini CLI 사용자에게 DidimAIStudio API-Key 발급
990
- 2. **시나리오 매핑**: 사용자별 기본 시나리오 설정 또는 CLI에서 지정
991
- 3. **응답 포맷**: 기존 SSE 응답을 그대로 사용하되, gemini-cli에서 파싱
992
-
993
- #### 옵션: Gemini CLI 전용 API (선택적 확장)
994
-
995
- ```python
996
- # /services/scenario-gateway/app/api/v1/endpoints/gemini_cli_api.py (선택적)
997
-
998
- from fastapi import APIRouter, Depends, HTTPException
999
- from fastapi.responses import StreamingResponse
1000
- from typing import AsyncGenerator
1001
- import json
1002
-
1003
- from app.schemas.integration.gemini_cli import (
1004
- LlmGenerateRequest,
1005
- LlmGenerateResponse,
1006
- LlmStreamEvent,
1007
- )
1008
- from app.service.integration.gemini_cli_service import GeminiCLIService
1009
- from app.core.auth import get_api_key_user
1010
-
1011
- router = APIRouter(prefix="/api/v1/gemini-cli", tags=["gemini-cli"])
1012
-
1013
- @router.post("/generate")
1014
- async def generate_content(
1015
- request: LlmGenerateRequest,
1016
- current_user = Depends(get_api_key_user),
1017
- service: GeminiCLIService = Depends()
1018
- ) -> LlmGenerateResponse:
1019
- """
1020
- Gemini CLI 호환 콘텐츠 생성 API (비스트리밍)
1021
- LlmGenerateRequest 형식을 직접 받아 처리
1022
- """
1023
- return await service.generate(request, current_user)
1024
-
1025
-
1026
- @router.post("/generate/stream")
1027
- async def generate_content_stream(
1028
- request: LlmGenerateRequest,
1029
- current_user = Depends(get_api_key_user),
1030
- service: GeminiCLIService = Depends()
1031
- ) -> StreamingResponse:
1032
- """
1033
- Gemini CLI 호환 콘텐츠 생성 API (스트리밍)
1034
- LlmStreamEvent 형식으로 응답
1035
- """
1036
- async def event_generator() -> AsyncGenerator[str, None]:
1037
- async for event in service.generate_stream(request, current_user):
1038
- yield f"data: {json.dumps(event.dict())}\n\n"
1039
- yield "data: [DONE]\n\n"
1040
-
1041
- return StreamingResponse(
1042
- event_generator(),
1043
- media_type="text/event-stream",
1044
- headers={
1045
- "Cache-Control": "no-cache",
1046
- "Connection": "keep-alive",
1047
- }
1048
- )
1049
- ```
1050
-
1051
- ### 4.4.5 연동 서비스 (DidimAIStudio - 선택적 확장용)
1052
-
1053
- ```python
1054
- # /services/scenario-gateway/app/service/integration/gemini_cli_service.py
1055
-
1056
- from typing import AsyncGenerator
1057
- import uuid
1058
- import httpx
1059
- import json
1060
-
1061
- from app.schemas.integration.gemini_cli import (
1062
- LlmGenerateRequest,
1063
- LlmGenerateResponse,
1064
- LlmStreamEvent,
1065
- LlmTokenUsage,
1066
- LlmTextContent,
1067
- LlmStopReason,
1068
- )
1069
- from app.dto.agents_dto import AgentsInvokeRequest, AgentsInvokeResponse
1070
- from app.service.integration.gemini_cli_converter import GeminiCLIConverter
1071
-
1072
- # 내부 agents 서비스 URL
1073
- AGENTS_URL_SSE = "http://agents:8003/v1/invoke/sse/improved"
1074
-
1075
-
1076
- class GeminiCLIService:
1077
- def __init__(self, converter: GeminiCLIConverter):
1078
- self.converter = converter
1079
-
1080
- async def generate(
1081
- self,
1082
- request: LlmGenerateRequest,
1083
- user
1084
- ) -> LlmGenerateResponse:
1085
- """비스트리밍 콘텐츠 생성"""
1086
- # 스트리밍으로 전체 응답 수집
1087
- full_content = ""
1088
- total_tokens = 0
1089
-
1090
- async for event in self.generate_stream(request, user):
1091
- if event.type == "content_delta" and event.delta:
1092
- full_content += event.delta.get("text", "")
1093
- if event.usage:
1094
- total_tokens = event.usage.total_tokens
1095
-
1096
- return LlmGenerateResponse(
1097
- id=str(uuid.uuid4()),
1098
- content=[LlmTextContent(type="text", text=full_content)],
1099
- model=request.model,
1100
- stop_reason=LlmStopReason.END_TURN,
1101
- usage=LlmTokenUsage(
1102
- prompt_tokens=0,
1103
- completion_tokens=0,
1104
- total_tokens=total_tokens
1105
- )
1106
- )
1107
-
1108
- async def generate_stream(
1109
- self,
1110
- request: LlmGenerateRequest,
1111
- user
1112
- ) -> AsyncGenerator[LlmStreamEvent, None]:
1113
- """스트리밍 콘텐츠 생성"""
1114
- # Gemini CLI 요청 → AgentsInvokeRequest 변환
1115
- agents_request = self.converter.to_agents_request(request, user)
1116
-
1117
- # agents 서비스 스트리밍 호출
1118
- async with httpx.AsyncClient(timeout=200.0) as client:
1119
- async with client.stream(
1120
- "POST",
1121
- AGENTS_URL_SSE,
1122
- json=agents_request.model_dump(),
1123
- headers={"Content-Type": "application/json"}
1124
- ) as response:
1125
- response.raise_for_status()
1126
-
1127
- buffer = ""
1128
- async for chunk in response.aiter_bytes():
1129
- buffer += chunk.decode('utf-8', errors='ignore')
1130
-
1131
- while '\n\n' in buffer:
1132
- event_end = buffer.find('\n\n')
1133
- complete_event = buffer[:event_end]
1134
- buffer = buffer[event_end + 2:]
1135
-
1136
- if complete_event.strip():
1137
- event = self._parse_sse_event(complete_event)
1138
- if event:
1139
- yield self.converter.to_stream_event(event)
1140
-
1141
- async def count_tokens(
1142
- self,
1143
- request: LlmGenerateRequest,
1144
- user
1145
- ) -> int:
1146
- """토큰 수 계산"""
1147
- text = self.converter.extract_text(request)
1148
- return len(text) // 4
1149
-
1150
- def _parse_sse_event(self, event_text: str) -> dict | None:
1151
- """SSE 이벤트 파싱"""
1152
- lines = event_text.split('\n')
1153
- event_type = None
1154
- data = None
1155
-
1156
- for line in lines:
1157
- if line.startswith('event: '):
1158
- event_type = line[7:]
1159
- elif line.startswith('data: '):
1160
- try:
1161
- data = json.loads(line[6:])
1162
- except json.JSONDecodeError:
1163
- data = {"chunk": line[6:]}
1164
-
1165
- if event_type and data:
1166
- return {"event_type": event_type, "data": data}
1167
- return None
1168
- ```
1169
-
1170
- ### 4.4.6 변환기 (DidimAIStudio - 선택적 확장용)
1171
-
1172
- ```python
1173
- # /services/scenario-gateway/app/service/integration/gemini_cli_converter.py
1174
-
1175
- from typing import List, Dict, Any, Optional
1176
- import uuid
1177
-
1178
- from app.schemas.integration.gemini_cli import (
1179
- LlmGenerateRequest,
1180
- LlmMessage,
1181
- LlmStreamEvent,
1182
- LlmStopReason,
1183
- )
1184
- from app.dto.agents_dto import AgentsInvokeRequest
1185
-
1186
-
1187
- class GeminiCLIConverter:
1188
- """Gemini CLI ↔ DidimAIStudio 형식 변환"""
1189
-
1190
- def to_agents_request(
1191
- self,
1192
- request: LlmGenerateRequest,
1193
- user
1194
- ) -> AgentsInvokeRequest:
1195
- """LlmGenerateRequest → AgentsInvokeRequest"""
1196
- # 마지막 사용자 메시지 추출
1197
- last_message = self._extract_last_user_message(request.messages)
1198
-
1199
- # 첨부 파일 추출
1200
- attachments = self._extract_attachments(request.messages)
1201
-
1202
- return AgentsInvokeRequest(
1203
- scenario_my_page_id=user.default_scenario_id,
1204
- user_id=str(user.id),
1205
- thread_id=str(uuid.uuid4()),
1206
- qa_id=str(uuid.uuid4()),
1207
- message=last_message,
1208
- attachments=attachments if attachments else None
1209
- )
1210
-
1211
- def to_stream_event(self, event: dict) -> LlmStreamEvent:
1212
- """SSE 이벤트 → LlmStreamEvent"""
1213
- event_type = event.get("event_type")
1214
- data = event.get("data", {})
1215
-
1216
- handlers = {
1217
- "message": self._handle_message,
1218
- "content": self._handle_message,
1219
- "message_partial": self._handle_partial,
1220
- "message_complete": self._handle_complete,
1221
- "message_metadata": self._handle_metadata,
1222
- "process": self._handle_process,
1223
- "done": self._handle_done,
1224
- "error": self._handle_error,
1225
- }
1226
-
1227
- handler = handlers.get(event_type, self._handle_unknown)
1228
- return handler(data)
1229
-
1230
- def extract_text(self, request: LlmGenerateRequest) -> str:
1231
- """요청에서 전체 텍스트 추출"""
1232
- texts = []
1233
- for message in request.messages:
1234
- for content in message.content:
1235
- if content.type == "text":
1236
- texts.append(content.text)
1237
- return "\n".join(texts)
1238
-
1239
- # === Private Methods ===
1240
-
1241
- def _extract_last_user_message(
1242
- self,
1243
- messages: List[LlmMessage]
1244
- ) -> str:
1245
- """마지막 사용자 메시지 추출"""
1246
- user_messages = [m for m in messages if m.role == "user"]
1247
- if not user_messages:
1248
- return ""
1249
-
1250
- last = user_messages[-1]
1251
- texts = [c.text for c in last.content if c.type == "text"]
1252
- return "\n".join(texts)
1253
-
1254
- def _extract_attachments(
1255
- self,
1256
- messages: List[LlmMessage]
1257
- ) -> List[str]:
1258
- """이미지 URL 등 첨부 파일 추출"""
1259
- attachments = []
1260
- for message in messages:
1261
- for content in message.content:
1262
- if content.type == "image":
1263
- if content.source.get("type") == "url":
1264
- attachments.append(content.source["data"])
1265
- return attachments
1266
-
1267
- def _handle_message(self, data: dict) -> LlmStreamEvent:
1268
- """message/content 이벤트 처리"""
1269
- chunk = data.get("chunk", data.get("message", ""))
1270
- return LlmStreamEvent(
1271
- type="content_delta",
1272
- delta={"text": str(chunk)}
1273
- )
1274
-
1275
- def _handle_partial(self, data: dict) -> LlmStreamEvent:
1276
- """message_partial 이벤트 처리 (토큰 스트리밍)"""
1277
- return LlmStreamEvent(
1278
- type="content_delta",
1279
- delta={"text": data.get("message", "")}
1280
- )
1281
-
1282
- def _handle_complete(self, data: dict) -> LlmStreamEvent:
1283
- """message_complete 이벤트 처리"""
1284
- if data.get("process_name"):
1285
- # 도구 완료
1286
- return LlmStreamEvent(
1287
- type="tool_call_delta",
1288
- delta={
1289
- "toolCall": {
1290
- "type": "tool_call",
1291
- "id": str(uuid.uuid4()),
1292
- "name": data.get("process_name", "unknown"),
1293
- "arguments": {}
1294
- }
1295
- }
1296
- )
1297
- return self._handle_message(data)
1298
-
1299
- def _handle_metadata(self, data: dict) -> LlmStreamEvent:
1300
- """message_metadata 이벤트 처리"""
1301
- return LlmStreamEvent(
1302
- type="content_delta",
1303
- delta={},
1304
- metadata={
1305
- "langgraph_node": data.get("langgraph_node"),
1306
- "step": data.get("step"),
1307
- "model": data.get("model")
1308
- }
1309
- )
1310
-
1311
- def _handle_process(self, data: dict) -> LlmStreamEvent:
1312
- """process 이벤트 처리"""
1313
- return LlmStreamEvent(
1314
- type="content_delta",
1315
- delta={},
1316
- metadata={
1317
- "process_name": data.get("process_name"),
1318
- "process_type": data.get("process_type")
1319
- }
1320
- )
1321
-
1322
- def _handle_done(self, data: dict) -> LlmStreamEvent:
1323
- """done 이벤트 처리"""
1324
- return LlmStreamEvent(
1325
- type="message_end",
1326
- usage={
1327
- "promptTokens": 0,
1328
- "completionTokens": 0,
1329
- "totalTokens": data.get("total_tokens", 0)
1330
- },
1331
- thread_id=data.get("thread_id"),
1332
- qa_id=data.get("qa_id")
1333
- )
1334
-
1335
- def _handle_error(self, data: dict) -> LlmStreamEvent:
1336
- """error 이벤트 처리"""
1337
- return LlmStreamEvent(
1338
- type="error",
1339
- error={
1340
- "type": data.get("error_code", "unknown"),
1341
- "message": data.get("error", "Unknown error")
1342
- }
1343
- )
1344
-
1345
- def _handle_unknown(self, data: dict) -> LlmStreamEvent:
1346
- """알 수 없는 이벤트 처리"""
1347
- return LlmStreamEvent(type="content_delta", delta={})
1348
- ```
1349
-
1350
- ## 4.5 설정 및 인증
1351
-
1352
- ### 4.5.1 gemini-cli 설정
1353
-
1354
- ```typescript
1355
- // packages/core/src/providers/didim/config.ts
1356
-
1357
- export interface DidimIntegrationConfig {
1358
- enabled: boolean;
1359
- baseUrl: string; // scenario-gateway URL (예: http://localhost:8008)
1360
- apiKey: string; // DidimAIStudio API-Key (시나리오별 발급)
1361
- threadId?: string; // 기존 대화 스레드 ID (선택적)
1362
-
1363
- // 선택적 설정
1364
- timeout?: number;
1365
- retries?: number;
1366
-
1367
- // 모드 선택
1368
- mode: 'direct' | 'gateway'; // direct: 직접 API, gateway: DidimAI 경유
1369
- }
1370
-
1371
- // 환경 변수
1372
- // DIDIM_AI_ENABLED=true
1373
- // DIDIM_AI_BASE_URL=http://scenario-gateway:8008 # 또는 외부 URL
1374
- // DIDIM_AI_API_KEY=your-scenario-api-key # 시나리오별 API-Key
1375
- // DIDIM_AI_MODE=gateway
1376
- ```
1377
-
1378
- ### 4.5.2 settings.json 확장
1379
-
1380
- ```json
1381
- {
1382
- "provider": {
1383
- "default": "gemini",
1384
- "gemini": { ... },
1385
- "claude": { ... },
1386
-
1387
- "didim-aistudio": {
1388
- "enabled": true,
1389
- "baseUrl": "http://scenario-gateway:8008",
1390
- "apiKey": "${DIDIM_AI_API_KEY}",
1391
- "mode": "gateway"
1392
- }
1393
- }
1394
- }
1395
- ```
1396
-
1397
- ### 4.5.3 API-Key 기반 인증
1398
-
1399
- DidimAIStudio는 시나리오별 API-Key 인증을 사용합니다.
1400
-
1401
- ```
1402
- ┌─────────────────────────────────────────────────────────────────────────┐
1403
- │ API-Key 인증 흐름 │
1404
- ├─────────────────────────────────────────────────────────────────────────┤
1405
- │ │
1406
- │ 1. API-Key 발급 │
1407
- │ DidimAIStudio 웹 UI → 시나리오 설정 → API-Key 생성 │
1408
- │ │
1409
- │ 2. API-Key 구조 (JWT) │
1410
- │ { │
1411
- │ "user_id": "user-uuid", │
1412
- │ "api_key_metadata": { │
1413
- │ "my_scenario_id": 123, │
1414
- │ ... │
1415
- │ }, │
1416
- │ ... │
1417
- │ } │
1418
- │ │
1419
- │ 3. 요청 시 헤더 │
1420
- │ Authorization: Bearer <API-KEY> │
1421
- │ │
1422
- │ 4. 인증 처리 (scenario-gateway) │
1423
- │ ApiKeyAuthMiddleware → passport_data 추출 → request.state 저장 │
1424
- │ │
1425
- └─────────────────────────────────────────────────────────────────────────┘
1426
- ```
1427
-
1428
- ### 4.5.4 DidimAIStudio 환경 변수 (참고)
1429
-
1430
- ```python
1431
- # /services/scenario-gateway/app/config/environment.py
1432
-
1433
- class Settings(BaseSettings):
1434
- # 서비스 설정
1435
- app_name: str = "Scenario Gate Service"
1436
- app_version: str = "1.0.0"
1437
- host: str = "0.0.0.0"
1438
- port: int = 8008
1439
-
1440
- # 환경
1441
- app_env: str = "development" # development, production
1442
- debug: bool = True
1443
-
1444
- # CORS
1445
- cors_allow_origins: List[str] = ["*"]
1446
- cors_allow_credentials: bool = True
1447
- cors_allow_methods: List[str] = ["*"]
1448
- cors_allow_headers: List[str] = ["*"]
1449
-
1450
- # Redis
1451
- redis_url: str = "redis://cache:6379/0"
1452
-
1453
- # 동기화 간격
1454
- stategraph_sync_interval: int = 60
1455
- ip_whitelist_sync_interval: int = 60
1456
- ```
1457
-
1458
- ## 4.6 프로바이더 매핑
1459
-
1460
- ### 4.6.1 프로바이더 ID 매핑
1461
-
1462
- ```typescript
1463
- // packages/core/src/providers/didim/providerMapping.ts
1464
-
1465
- /**
1466
- * Gemini CLI 프로바이더 ID ↔ DidimAIStudio 프로바이더 ID 매핑
1467
- */
1468
- export const PROVIDER_MAPPING = {
1469
- // Gemini CLI → DidimAIStudio
1470
- 'gemini': 'google',
1471
- 'claude': 'anthropic',
1472
- 'openai': 'openai',
1473
- 'gpt': 'openai',
1474
-
1475
- // DidimAIStudio 전용
1476
- 'bedrock': 'bedrock',
1477
- 'azure': 'azure_openai',
1478
- 'mistral': 'mistral',
1479
- 'groq': 'groq',
1480
- 'naver': 'naver',
1481
- 'vllm': 'vllm',
1482
- 'together': 'together',
1483
- 'cohere': 'cohere',
1484
- 'fireworks': 'fireworks',
1485
- 'huggingface': 'huggingface',
1486
- };
1487
-
1488
- /**
1489
- * 모델 이름에서 프로바이더 추론
1490
- */
1491
- export function detectProvider(modelName: string): string {
1492
- const name = modelName.toLowerCase();
1493
-
1494
- if (name.includes('gpt-') || name.includes('o1-')) return 'openai';
1495
- if (name.includes('claude')) return 'anthropic';
1496
- if (name.includes('gemini')) return 'google';
1497
- if (name.includes('mistral')) return 'mistral';
1498
- if (name.includes('llama')) return 'meta';
1499
- if (name.includes('command')) return 'cohere';
1500
-
1501
- return 'unknown';
1502
- }
1503
- ```
1504
-
1505
- ### 4.6.2 토큰 필드 매핑 통합
1506
-
1507
- ```python
1508
- # app/service/chat/provider_manager.py (확장)
1509
-
1510
- class ProviderManager:
1511
- TOKEN_FIELD_MAPPING = {
1512
- # 기존 매핑...
1513
-
1514
- # Gemini CLI 호환 매핑 추가
1515
- "gemini_cli": {
1516
- "input": "usage.promptTokens",
1517
- "output": "usage.completionTokens",
1518
- "total": "usage.totalTokens"
1519
- }
1520
- }
1521
-
1522
- def normalize_for_gemini_cli(self, usage: dict) -> dict:
1523
- """DidimAI 토큰 사용량을 Gemini CLI 형식으로 변환"""
1524
- return {
1525
- "promptTokens": usage.get("input_tokens", 0),
1526
- "completionTokens": usage.get("output_tokens", 0),
1527
- "totalTokens": usage.get("total_tokens", 0),
1528
- }
1529
- ```
1530
-
1531
- ## 4.7 에러 처리
1532
-
1533
- ### 4.7.1 에러 코드 매핑
1534
-
1535
- ```typescript
1536
- // packages/core/src/providers/didim/errorMapping.ts
1537
-
1538
- import { LlmError, LlmErrorType } from '../errors';
1539
-
1540
- /**
1541
- * DidimAIStudio 에러 코드 → Gemini CLI 에러 타입 매핑
1542
- */
1543
- export const ERROR_CODE_MAPPING: Record<string, LlmErrorType> = {
1544
- 'AUTH_FAILED': LlmErrorType.AUTHENTICATION,
1545
- 'RATE_LIMITED': LlmErrorType.RATE_LIMIT,
1546
- 'MODEL_OVERLOADED': LlmErrorType.MODEL_OVERLOADED,
1547
- 'CONTEXT_TOO_LONG': LlmErrorType.CONTEXT_LENGTH_EXCEEDED,
1548
- 'CONTENT_FILTERED': LlmErrorType.CONTENT_FILTER,
1549
- 'TIMEOUT': LlmErrorType.TIMEOUT,
1550
- 'NETWORK_ERROR': LlmErrorType.NETWORK,
1551
- 'INVALID_REQUEST': LlmErrorType.INVALID_REQUEST,
1552
- };
1553
-
1554
- export function mapDidimErrorToLlmError(
1555
- errorCode: string,
1556
- message: string
1557
- ): LlmError {
1558
- const errorType = ERROR_CODE_MAPPING[errorCode] || LlmErrorType.UNKNOWN;
1559
- return new LlmError(errorType, message, 'didim-aistudio');
1560
- }
1561
- ```
1562
-
1563
- ### 4.7.2 폴백 전략
1564
-
1565
- ```typescript
1566
- // packages/core/src/providers/didim/fallback.ts
1567
-
1568
- export interface FallbackConfig {
1569
- enabled: boolean;
1570
- fallbackProvider: string; // 'gemini' | 'claude' | 'openai'
1571
- maxRetries: number;
1572
- retryableErrors: LlmErrorType[];
1573
- }
1574
-
1575
- export const DEFAULT_FALLBACK_CONFIG: FallbackConfig = {
1576
- enabled: true,
1577
- fallbackProvider: 'gemini',
1578
- maxRetries: 2,
1579
- retryableErrors: [
1580
- LlmErrorType.RATE_LIMIT,
1581
- LlmErrorType.MODEL_OVERLOADED,
1582
- LlmErrorType.TIMEOUT,
1583
- LlmErrorType.NETWORK,
1584
- ],
1585
- };
1586
- ```
1587
-
1588
- ## 4.8 테스트 전략
1589
-
1590
- ### 4.8.1 단위 테스트
1591
-
1592
- ```typescript
1593
- // packages/core/src/providers/didim/converter.test.ts
1594
-
1595
- import { describe, it, expect } from 'vitest';
1596
- import { DidimTypeConverter } from './converter';
1597
-
1598
- describe('DidimTypeConverter', () => {
1599
- const converter = new DidimTypeConverter();
1600
-
1601
- describe('toLlmToDidimInput', () => {
1602
- it('should convert text message correctly', () => {
1603
- const request: LlmGenerateRequest = {
1604
- model: 'gemini-2.5-pro',
1605
- messages: [
1606
- {
1607
- role: 'user',
1608
- content: [{ type: 'text', text: 'Hello' }],
1609
- },
1610
- ],
1611
- };
1612
-
1613
- const result = converter.toLlmToDidimInput(request, {
1614
- scenarioMyPageId: 1,
1615
- userId: 'user-1',
1616
- threadId: 'thread-1',
1617
- qaId: 'qa-1',
1618
- });
1619
-
1620
- expect(result.message).toBe('Hello');
1621
- expect(result.scenario_my_page_id).toBe(1);
1622
- });
1623
-
1624
- it('should extract attachments from image content', () => {
1625
- const request: LlmGenerateRequest = {
1626
- model: 'gemini-2.5-pro',
1627
- messages: [
1628
- {
1629
- role: 'user',
1630
- content: [
1631
- { type: 'text', text: 'What is this?' },
1632
- {
1633
- type: 'image',
1634
- source: { type: 'url', mediaType: 'image/png', data: 'https://example.com/image.png' },
1635
- },
1636
- ],
1637
- },
1638
- ],
1639
- };
1640
-
1641
- const result = converter.toLlmToDidimInput(request, {
1642
- scenarioMyPageId: 1,
1643
- userId: 'user-1',
1644
- threadId: 'thread-1',
1645
- qaId: 'qa-1',
1646
- });
1647
-
1648
- expect(result.attachments).toContain('https://example.com/image.png');
1649
- });
1650
- });
1651
-
1652
- describe('fromDidimOutputToStreamEvent', () => {
1653
- it('should convert MESSAGE_PARTIAL to content_delta', () => {
1654
- const output: DidimSSEOutput = {
1655
- scenario_my_page_id: 1,
1656
- user_id: 'user-1',
1657
- thread_id: 'thread-1',
1658
- qa_id: 'qa-1',
1659
- status: 'MESSAGE_PARTIAL',
1660
- content: 'Hello',
1661
- delta: true,
1662
- };
1663
-
1664
- const result = converter.fromDidimOutputToStreamEvent(output);
1665
-
1666
- expect(result.type).toBe('content_delta');
1667
- expect(result.delta?.text).toBe('Hello');
1668
- });
1669
-
1670
- it('should convert COMPLETE to message_end with usage', () => {
1671
- const output: DidimSSEOutput = {
1672
- scenario_my_page_id: 1,
1673
- user_id: 'user-1',
1674
- thread_id: 'thread-1',
1675
- qa_id: 'qa-1',
1676
- status: 'COMPLETE',
1677
- total_tokens: 150,
1678
- };
1679
-
1680
- const result = converter.fromDidimOutputToStreamEvent(output);
1681
-
1682
- expect(result.type).toBe('message_end');
1683
- expect(result.usage?.totalTokens).toBe(150);
1684
- });
1685
- });
1686
- });
1687
- ```
1688
-
1689
- ### 4.8.2 통합 테스트
1690
-
1691
- ```typescript
1692
- // packages/core/src/providers/didim/adapter.integration.test.ts
1693
-
1694
- import { describe, it, expect, beforeAll } from 'vitest';
1695
- import { DidimAIStudioAdapter } from './adapter';
1696
-
1697
- describe('DidimAIStudioAdapter Integration', () => {
1698
- let adapter: DidimAIStudioAdapter;
1699
-
1700
- beforeAll(() => {
1701
- // 테스트 환경 설정
1702
- adapter = new DidimAIStudioAdapter({
1703
- apiKey: process.env.DIDIM_AI_API_KEY || '',
1704
- baseUrl: process.env.DIDIM_AI_BASE_URL || 'http://localhost:8000',
1705
- scenarioMyPageId: 1,
1706
- userId: 'test-user',
1707
- });
1708
- });
1709
-
1710
- it('should generate content via DidimAIStudio', async () => {
1711
- const request: LlmGenerateRequest = {
1712
- model: 'gpt-4',
1713
- messages: [
1714
- {
1715
- role: 'user',
1716
- content: [{ type: 'text', text: 'Say hello' }],
1717
- },
1718
- ],
1719
- };
1720
-
1721
- const response = await adapter.generateContent(request);
1722
-
1723
- expect(response.content).toBeDefined();
1724
- expect(response.content.length).toBeGreaterThan(0);
1725
- });
1726
-
1727
- it('should stream content via DidimAIStudio', async () => {
1728
- const request: LlmGenerateRequest = {
1729
- model: 'gpt-4',
1730
- messages: [
1731
- {
1732
- role: 'user',
1733
- content: [{ type: 'text', text: 'Count from 1 to 5' }],
1734
- },
1735
- ],
1736
- };
1737
-
1738
- const events: LlmStreamEvent[] = [];
1739
- const stream = await adapter.generateContentStream(request);
1740
-
1741
- for await (const event of stream) {
1742
- events.push(event);
1743
- }
1744
-
1745
- expect(events.length).toBeGreaterThan(0);
1746
- expect(events.some(e => e.type === 'message_end')).toBe(true);
1747
- });
1748
- });
1749
- ```
1750
-
1751
- ## 4.9 구현 일정
1752
-
1753
- > **참고**: DidimAIStudio 연동은 Phase 3 (프로바이더 확장) 이후에 진행됩니다.
1754
- > 전체 Multi-LLM 어댑터 리팩토링은 05-implementation-plan.md 참조
1755
-
1756
- ### Phase 1: 기반 작업 (3일)
1757
-
1758
- | 작업 | 담당 | 일정 |
1759
- |------|------|------|
1760
- | DidimAIStudio API 분석 (scenario-gateway, agents) | gemini-cli | 0.5일 |
1761
- | 공통 타입 정의 (TypeScript) | gemini-cli | 1일 |
1762
- | 에러 매핑 정의 | gemini-cli | 0.5일 |
1763
- | API-Key 발급 및 테스트 환경 구성 | 공통 | 1일 |
1764
-
1765
- ### Phase 2: 어댑터 구현 (5일)
1766
-
1767
- | 작업 | 담당 | 일정 |
1768
- |------|------|------|
1769
- | DidimAIStudioAdapter 구현 | gemini-cli | 2일 |
1770
- | DidimTypeConverter 구현 (SSE 파싱) | gemini-cli | 1.5일 |
1771
- | SSE 스트리밍 테스트 | gemini-cli | 0.5일 |
1772
- | 기존 API 호환성 검증 | 공통 | 1일 |
1773
-
1774
- ### Phase 3: 테스트 및 통합 (4일)
1775
-
1776
- | 작업 | 담당 | 일정 |
1777
- |------|------|------|
1778
- | 단위 테스트 작성 | gemini-cli | 1일 |
1779
- | 통합 테스트 작성 (Docker 환경) | 공통 | 1일 |
1780
- | E2E 테스트 (scenario-gateway ↔ agents) | 공통 | 1일 |
1781
- | 문서화 및 예제 작성 | 공통 | 1일 |
1782
-
1783
- ### 선택적 확장: Gemini CLI 전용 API (1주)
1784
-
1785
- | 작업 | 담당 | 일정 |
1786
- |------|------|------|
1787
- | `/api/v1/gemini-cli/*` 엔드포인트 추가 | DidimAIStudio | 2일 |
1788
- | GeminiCLIService 구현 | DidimAIStudio | 2일 |
1789
- | 통합 테스트 | 공통 | 1일 |
1790
-
1791
- ### 총 예상 기간: 2주 (기본) ~ 3주 (전용 API 포함)
1792
-
1793
- ## 4.10 향후 확장
1794
-
1795
- ### 4.10.1 단기 확장 (1-2개월)
1796
-
1797
- 1. **양방향 동기화**: 설정 변경 시 실시간 동기화
1798
- 2. **분산 트레이싱**: OpenTelemetry 기반 통합 트레이싱
1799
- 3. **공유 메모리**: 대화 히스토리 공유
1800
-
1801
- ### 4.10.2 장기 확장 (3-6개월)
1802
-
1803
- 1. **플러그인 시스템**: gemini-cli에서 DidimAI 에이전트 직접 호출
1804
- 2. **워크플로우 연동**: LangGraph 워크플로우를 CLI에서 실행
1805
- 3. **통합 대시보드**: 사용량, 비용, 성능 통합 모니터링
1806
-
1807
- ---
1808
-
1809
- ## 4.11 서버 측 문맥 관리 및 제약사항 (리뷰 피드백 C 반영)
1810
-
1811
- ### 4.11.1 문맥 관리 아키텍처 차이
1812
-
1813
- Gemini CLI(기본 모드)와 DidimAIStudio 연동 모드는 대화 문맥(히스토리) 관리 방식이 근본적으로 다릅니다:
1814
-
1815
- ```
1816
- ┌──────────────────────────────────────────────────────────────────────────┐
1817
- │ 문맥 관리 방식 비교 │
1818
- ├──────────────────────────────────────────────────────────────────────────┤
1819
- │ │
1820
- │ [기본 모드: 클라이언트 측 관리] │
1821
- │ ┌─────────────┐ 전체 히스토리 전송 ┌──────────────┐ │
1822
- │ │ Gemini CLI │ ───────────────────────▶ │ LLM API │ │
1823
- │ │ (히스토리 │ │ (Stateless) │ │
1824
- │ │ 로컬 저장) │ ◀─────────────────────── │ │ │
1825
- │ └─────────────┘ 응답 └──────────────┘ │
1826
- │ │
1827
- │ [Gateway 모드: 서버 측 관리] │
1828
- │ ┌─────────────┐ 마지막 메시지만 전송 ┌──────────────┐ │
1829
- │ │ Gemini CLI │ ───────────────────────▶ │ DidimAI │ │
1830
- │ │ (로컬 사본) │ + thread_id 헤더 │ Studio │ │
1831
- │ │ │ │ (thread에 │ │
1832
- │ │ │ ◀─────────────────────── │ 히스토리 │ │
1833
- │ └─────────────┘ 응답 + thread_id │ 서버 저장) │ │
1834
- │ │
1835
- └──────────────────────────────────────────────────────────────────────────┘
1836
- ```
1837
-
1838
- ### 4.11.2 알려진 제약사항
1839
-
1840
- > ⚠️ **중요**: 아래 제약사항들은 DidimAIStudio Gateway 모드 사용 시 적용됩니다.
1841
-
1842
- | 제약사항 | 설명 | 영향 |
1843
- |----------|------|------|
1844
- | **단방향 동기화** | CLI 로컬 히스토리 조작(삭제/수정)이 서버 thread에 반영되지 않음 | 로컬에서 대화 삭제해도 서버는 이전 문맥 유지 |
1845
- | **히스토리 전송 불가** | `extractLastUserMessage()`로 마지막 메시지만 전송 | 시스템 메시지, 이전 대화가 직접 전달되지 않음 |
1846
- | **서버 의존적 문맥** | Multi-turn 품질은 DidimAIStudio의 thread 관리에 의존 | 서버 측 thread 만료/삭제 시 문맥 손실 가능 |
1847
- | **도구 컨텍스트 미전달** | `tools[]` 정보가 gateway API로 전달되지 않음 | 시나리오에 사전 정의된 도구만 사용 가능 |
1848
-
1849
- ### 4.11.3 UX 안내 메시지 설계 (권고사항 2 반영)
1850
-
1851
- DidimAIStudio 연동 시 사용자에게 서버 측 문맥 관리 특성을 인지시키기 위한 UX 장치:
1852
-
1853
- ```typescript
1854
- // packages/cli/src/views/DidimModeIndicator.tsx
1855
-
1856
- const DIDIM_MODE_NOTICES = {
1857
- // 세션 시작 시 표시 (한 번만)
1858
- sessionStart: `
1859
- ℹ️ DidimAIStudio 모드로 연결되었습니다.
1860
- • 대화 히스토리는 서버에서 관리됩니다.
1861
- • 로컬에서 히스토리를 수정해도 서버에 반영되지 않습니다.
1862
- `,
1863
-
1864
- // 새 thread 시작 시
1865
- newThread: (threadId: string) => `
1866
- 🔗 새 대화 스레드가 시작되었습니다: ${threadId.substring(0, 8)}...
1867
- `,
1868
-
1869
- // 기존 thread 연결 시
1870
- resumeThread: (threadId: string) => `
1871
- 🔗 기존 대화를 이어갑니다: ${threadId.substring(0, 8)}...
1872
- (서버에 저장된 대화 문맥이 적용됩니다)
1873
- `,
1874
-
1875
- // 로컬 히스토리 삭제 시도 시 경고
1876
- localDeleteWarning: `
1877
- ⚠️ 로컬 히스토리만 삭제됩니다.
1878
- 서버의 대화 기록은 유지되며, 다음 질문 시 이전 문맥이 적용될 수 있습니다.
1879
- `,
1880
- };
1881
-
1882
- // 사용 예시
1883
- function renderSessionStart(): React.ReactNode {
1884
- const { provider } = useProviderContext();
1885
-
1886
- if (provider === 'didim') {
1887
- return (
1888
- <Box marginBottom={1}>
1889
- <Text color="cyan">{DIDIM_MODE_NOTICES.sessionStart}</Text>
1890
- </Box>
1891
- );
1892
- }
1893
- return null;
1894
- }
1895
- ```
1896
-
1897
- ### 4.11.4 향후 해결 방안 (Out of Scope)
1898
-
1899
- 아래 항목들은 현재 설계 범위 외이며, 향후 확장으로 고려됩니다:
1900
-
1901
- 1. **양방향 동기화 API**: CLI ↔ DidimAIStudio 간 히스토리 동기화 프로토콜
1902
- 2. **Thread 관리 CLI 명령어**: `gemini thread list`, `gemini thread delete <id>`
1903
- 3. **오프라인 모드 전환**: 서버 연결 불가 시 자동으로 기본 모드로 fallback
1904
-