@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,1299 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { describe, it, expect, beforeEach, beforeAll, vi } from 'vitest';
7
- import { PolicyEngine } from './policy-engine.js';
8
- import { PolicyDecision, InProcessCheckerType, ApprovalMode, } from './types.js';
9
- import { SafetyCheckDecision } from '../safety/protocol.js';
10
- import { initializeShellParsers } from '../utils/shell-utils.js';
11
- import { buildArgsPatterns } from './utils.js';
12
- // Mock shell-utils to ensure consistent behavior across platforms (especially Windows CI)
13
- // We want to test PolicyEngine logic, not the shell parser's ability to parse commands
14
- vi.mock('../utils/shell-utils.js', async (importOriginal) => {
15
- const actual = await importOriginal();
16
- return {
17
- ...actual,
18
- initializeShellParsers: vi.fn().mockResolvedValue(undefined),
19
- splitCommands: vi.fn().mockImplementation((command) => {
20
- // Simple mock splitting logic for test cases
21
- if (command.includes('&&')) {
22
- return command.split('&&').map((c) => c.trim());
23
- }
24
- return [command];
25
- }),
26
- hasRedirection: vi.fn().mockImplementation((command) =>
27
- // Simple mock: true if '>' is present, unless it looks like "-> arrow"
28
- command.includes('>') && !command.includes('-> arrow')),
29
- };
30
- });
31
- describe('PolicyEngine', () => {
32
- let engine;
33
- let mockCheckerRunner;
34
- beforeAll(async () => {
35
- await initializeShellParsers();
36
- });
37
- beforeEach(() => {
38
- mockCheckerRunner = {
39
- runChecker: vi.fn(),
40
- };
41
- engine = new PolicyEngine({ approvalMode: ApprovalMode.DEFAULT }, mockCheckerRunner);
42
- });
43
- describe('constructor', () => {
44
- it('should use default config when none provided', async () => {
45
- const { decision } = await engine.check({ name: 'test' }, undefined);
46
- expect(decision).toBe(PolicyDecision.ASK_USER);
47
- });
48
- it('should respect custom default decision', async () => {
49
- engine = new PolicyEngine({ defaultDecision: PolicyDecision.DENY });
50
- const { decision } = await engine.check({ name: 'test' }, undefined);
51
- expect(decision).toBe(PolicyDecision.DENY);
52
- });
53
- it('should sort rules by priority', () => {
54
- const rules = [
55
- { toolName: 'tool1', decision: PolicyDecision.DENY, priority: 1 },
56
- { toolName: 'tool2', decision: PolicyDecision.ALLOW, priority: 10 },
57
- { toolName: 'tool3', decision: PolicyDecision.ASK_USER, priority: 5 },
58
- ];
59
- engine = new PolicyEngine({ rules });
60
- const sortedRules = engine.getRules();
61
- expect(sortedRules[0].priority).toBe(10);
62
- expect(sortedRules[1].priority).toBe(5);
63
- expect(sortedRules[2].priority).toBe(1);
64
- });
65
- });
66
- describe('check', () => {
67
- it('should match tool by name', async () => {
68
- const rules = [
69
- { toolName: 'shell', decision: PolicyDecision.ALLOW },
70
- { toolName: 'edit', decision: PolicyDecision.DENY },
71
- ];
72
- engine = new PolicyEngine({ rules });
73
- expect((await engine.check({ name: 'shell' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
74
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.DENY);
75
- expect((await engine.check({ name: 'other' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
76
- });
77
- it('should match unqualified tool names with qualified rules when serverName is provided', async () => {
78
- const rules = [
79
- {
80
- toolName: 'my-server__tool',
81
- decision: PolicyDecision.ALLOW,
82
- },
83
- ];
84
- engine = new PolicyEngine({ rules });
85
- // Match with qualified name (standard)
86
- expect((await engine.check({ name: 'my-server__tool' }, 'my-server')).decision).toBe(PolicyDecision.ALLOW);
87
- // Match with unqualified name + serverName (the fix)
88
- expect((await engine.check({ name: 'tool' }, 'my-server')).decision).toBe(PolicyDecision.ALLOW);
89
- // Should NOT match with unqualified name but NO serverName
90
- expect((await engine.check({ name: 'tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
91
- // Should NOT match with unqualified name but WRONG serverName
92
- expect((await engine.check({ name: 'tool' }, 'wrong-server')).decision).toBe(PolicyDecision.ASK_USER);
93
- });
94
- it('should match by args pattern', async () => {
95
- const rules = [
96
- {
97
- toolName: 'shell',
98
- argsPattern: /rm -rf/,
99
- decision: PolicyDecision.DENY,
100
- },
101
- {
102
- toolName: 'shell',
103
- decision: PolicyDecision.ALLOW,
104
- },
105
- ];
106
- engine = new PolicyEngine({ rules });
107
- const dangerousCall = {
108
- name: 'shell',
109
- args: { command: 'rm -rf /' },
110
- };
111
- const safeCall = {
112
- name: 'shell',
113
- args: { command: 'ls -la' },
114
- };
115
- expect((await engine.check(dangerousCall, undefined)).decision).toBe(PolicyDecision.DENY);
116
- expect((await engine.check(safeCall, undefined)).decision).toBe(PolicyDecision.ALLOW);
117
- });
118
- it('should apply rules by priority', async () => {
119
- const rules = [
120
- { toolName: 'shell', decision: PolicyDecision.DENY, priority: 1 },
121
- { toolName: 'shell', decision: PolicyDecision.ALLOW, priority: 10 },
122
- ];
123
- engine = new PolicyEngine({ rules });
124
- // Higher priority rule (ALLOW) should win
125
- expect((await engine.check({ name: 'shell' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
126
- });
127
- it('should apply wildcard rules (no toolName)', async () => {
128
- const rules = [
129
- { decision: PolicyDecision.DENY }, // Applies to all tools
130
- { toolName: 'safe-tool', decision: PolicyDecision.ALLOW, priority: 10 },
131
- ];
132
- engine = new PolicyEngine({ rules });
133
- expect((await engine.check({ name: 'safe-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
134
- expect((await engine.check({ name: 'any-other-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
135
- });
136
- it('should handle non-interactive mode', async () => {
137
- const config = {
138
- nonInteractive: true,
139
- rules: [
140
- { toolName: 'interactive-tool', decision: PolicyDecision.ASK_USER },
141
- { toolName: 'allowed-tool', decision: PolicyDecision.ALLOW },
142
- ],
143
- };
144
- engine = new PolicyEngine(config);
145
- // ASK_USER should become DENY in non-interactive mode
146
- expect((await engine.check({ name: 'interactive-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
147
- // ALLOW should remain ALLOW
148
- expect((await engine.check({ name: 'allowed-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
149
- // Default ASK_USER should also become DENY
150
- expect((await engine.check({ name: 'unknown-tool' }, undefined)).decision).toBe(PolicyDecision.DENY);
151
- });
152
- it('should dynamically switch between modes and respect rule modes', async () => {
153
- const rules = [
154
- {
155
- toolName: 'edit',
156
- decision: PolicyDecision.ASK_USER,
157
- priority: 10,
158
- },
159
- {
160
- toolName: 'edit',
161
- decision: PolicyDecision.ALLOW,
162
- priority: 20,
163
- modes: [ApprovalMode.AUTO_EDIT],
164
- },
165
- ];
166
- engine = new PolicyEngine({ rules });
167
- // Default mode: priority 20 rule doesn't match, falls back to priority 10
168
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
169
- // Switch to autoEdit mode
170
- engine.setApprovalMode(ApprovalMode.AUTO_EDIT);
171
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
172
- // Switch back to default
173
- engine.setApprovalMode(ApprovalMode.DEFAULT);
174
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
175
- });
176
- });
177
- describe('addRule', () => {
178
- it('should add a new rule and maintain priority order', () => {
179
- engine.addRule({
180
- toolName: 'tool1',
181
- decision: PolicyDecision.ALLOW,
182
- priority: 5,
183
- });
184
- engine.addRule({
185
- toolName: 'tool2',
186
- decision: PolicyDecision.DENY,
187
- priority: 10,
188
- });
189
- engine.addRule({
190
- toolName: 'tool3',
191
- decision: PolicyDecision.ASK_USER,
192
- priority: 1,
193
- });
194
- const rules = engine.getRules();
195
- expect(rules).toHaveLength(3);
196
- expect(rules[0].priority).toBe(10);
197
- expect(rules[1].priority).toBe(5);
198
- expect(rules[2].priority).toBe(1);
199
- });
200
- it('should apply newly added rules', async () => {
201
- expect((await engine.check({ name: 'new-tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
202
- engine.addRule({ toolName: 'new-tool', decision: PolicyDecision.ALLOW });
203
- expect((await engine.check({ name: 'new-tool' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
204
- });
205
- });
206
- describe('removeRulesForTool', () => {
207
- it('should remove rules for specific tool', () => {
208
- engine.addRule({ toolName: 'tool1', decision: PolicyDecision.ALLOW });
209
- engine.addRule({ toolName: 'tool2', decision: PolicyDecision.DENY });
210
- engine.addRule({
211
- toolName: 'tool1',
212
- decision: PolicyDecision.ASK_USER,
213
- priority: 10,
214
- });
215
- expect(engine.getRules()).toHaveLength(3);
216
- engine.removeRulesForTool('tool1');
217
- const remainingRules = engine.getRules();
218
- expect(remainingRules).toHaveLength(1);
219
- expect(remainingRules.some((r) => r.toolName === 'tool1')).toBe(false);
220
- expect(remainingRules.some((r) => r.toolName === 'tool2')).toBe(true);
221
- });
222
- it('should handle removing non-existent tool', () => {
223
- engine.addRule({ toolName: 'existing', decision: PolicyDecision.ALLOW });
224
- expect(() => engine.removeRulesForTool('non-existent')).not.toThrow();
225
- expect(engine.getRules()).toHaveLength(1);
226
- });
227
- });
228
- describe('getRules', () => {
229
- it('should return readonly array of rules', () => {
230
- const rules = [
231
- { toolName: 'tool1', decision: PolicyDecision.ALLOW },
232
- { toolName: 'tool2', decision: PolicyDecision.DENY },
233
- ];
234
- engine = new PolicyEngine({ rules });
235
- const retrievedRules = engine.getRules();
236
- expect(retrievedRules).toHaveLength(2);
237
- expect(retrievedRules[0].toolName).toBe('tool1');
238
- expect(retrievedRules[1].toolName).toBe('tool2');
239
- });
240
- });
241
- describe('MCP server wildcard patterns', () => {
242
- it('should match MCP server wildcard patterns', async () => {
243
- const rules = [
244
- {
245
- toolName: 'my-server__*',
246
- decision: PolicyDecision.ALLOW,
247
- priority: 10,
248
- },
249
- {
250
- toolName: 'blocked-server__*',
251
- decision: PolicyDecision.DENY,
252
- priority: 20,
253
- },
254
- ];
255
- engine = new PolicyEngine({ rules });
256
- // Should match my-server tools
257
- expect((await engine.check({ name: 'my-server__tool1' }, undefined)).decision).toBe(PolicyDecision.ALLOW);
258
- expect((await engine.check({ name: 'my-server__another_tool' }, undefined))
259
- .decision).toBe(PolicyDecision.ALLOW);
260
- // Should match blocked-server tools
261
- expect((await engine.check({ name: 'blocked-server__tool1' }, undefined))
262
- .decision).toBe(PolicyDecision.DENY);
263
- expect((await engine.check({ name: 'blocked-server__dangerous' }, undefined))
264
- .decision).toBe(PolicyDecision.DENY);
265
- // Should not match other patterns
266
- expect((await engine.check({ name: 'other-server__tool' }, undefined))
267
- .decision).toBe(PolicyDecision.ASK_USER);
268
- expect((await engine.check({ name: 'my-server-tool' }, undefined)).decision).toBe(PolicyDecision.ASK_USER); // No __ separator
269
- expect((await engine.check({ name: 'my-server' }, undefined)).decision).toBe(PolicyDecision.ASK_USER); // No tool name
270
- });
271
- it('should prioritize specific tool rules over server wildcards', async () => {
272
- const rules = [
273
- {
274
- toolName: 'my-server__*',
275
- decision: PolicyDecision.ALLOW,
276
- priority: 10,
277
- },
278
- {
279
- toolName: 'my-server__dangerous-tool',
280
- decision: PolicyDecision.DENY,
281
- priority: 20,
282
- },
283
- ];
284
- engine = new PolicyEngine({ rules });
285
- // Specific tool deny should override server allow
286
- expect((await engine.check({ name: 'my-server__dangerous-tool' }, undefined))
287
- .decision).toBe(PolicyDecision.DENY);
288
- expect((await engine.check({ name: 'my-server__safe-tool' }, undefined))
289
- .decision).toBe(PolicyDecision.ALLOW);
290
- });
291
- it('should NOT match spoofed server names when using wildcards', async () => {
292
- // Vulnerability: A rule for 'prefix__*' matches 'prefix__suffix__tool'
293
- // effectively allowing a server named 'prefix__suffix' to spoof 'prefix'.
294
- const rules = [
295
- {
296
- toolName: 'safe_server__*',
297
- decision: PolicyDecision.ALLOW,
298
- },
299
- ];
300
- engine = new PolicyEngine({ rules });
301
- // A tool from a different server 'safe_server__malicious'
302
- const spoofedToolCall = { name: 'safe_server__malicious__tool' };
303
- // CURRENT BEHAVIOR (FIXED): Matches because it starts with 'safe_server__' BUT serverName doesn't match 'safe_server'
304
- // We expect this to FAIL matching the ALLOW rule, thus falling back to default (ASK_USER)
305
- expect((await engine.check(spoofedToolCall, 'safe_server__malicious'))
306
- .decision).toBe(PolicyDecision.ASK_USER);
307
- });
308
- it('should verify tool name prefix even if serverName matches', async () => {
309
- const rules = [
310
- {
311
- toolName: 'safe_server__*',
312
- decision: PolicyDecision.ALLOW,
313
- },
314
- ];
315
- engine = new PolicyEngine({ rules });
316
- // serverName matches, but tool name does not start with prefix
317
- const invalidToolCall = { name: 'other_server__tool' };
318
- expect((await engine.check(invalidToolCall, 'safe_server')).decision).toBe(PolicyDecision.ASK_USER);
319
- });
320
- it('should allow when both serverName and tool name prefix match', async () => {
321
- const rules = [
322
- {
323
- toolName: 'safe_server__*',
324
- decision: PolicyDecision.ALLOW,
325
- },
326
- ];
327
- engine = new PolicyEngine({ rules });
328
- const validToolCall = { name: 'safe_server__tool' };
329
- expect((await engine.check(validToolCall, 'safe_server')).decision).toBe(PolicyDecision.ALLOW);
330
- });
331
- });
332
- describe('complex scenarios', () => {
333
- it('should handle multiple matching rules with different priorities', async () => {
334
- const rules = [
335
- { decision: PolicyDecision.DENY, priority: 0 }, // Default deny all
336
- { toolName: 'shell', decision: PolicyDecision.ASK_USER, priority: 5 },
337
- {
338
- toolName: 'shell',
339
- argsPattern: /"command":"ls/,
340
- decision: PolicyDecision.ALLOW,
341
- priority: 10,
342
- },
343
- ];
344
- engine = new PolicyEngine({ rules });
345
- // Matches highest priority rule (ls command)
346
- expect((await engine.check({ name: 'shell', args: { command: 'ls -la' } }, undefined)).decision).toBe(PolicyDecision.ALLOW);
347
- // Matches middle priority rule (shell without ls)
348
- expect((await engine.check({ name: 'shell', args: { command: 'pwd' } }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
349
- // Matches lowest priority rule (not shell)
350
- expect((await engine.check({ name: 'edit' }, undefined)).decision).toBe(PolicyDecision.DENY);
351
- });
352
- it('should correctly match commands with quotes in commandPrefix', async () => {
353
- const prefix = 'git commit -m "fix"';
354
- const patterns = buildArgsPatterns(undefined, prefix);
355
- const rules = [
356
- {
357
- toolName: 'run_shell_command',
358
- argsPattern: new RegExp(patterns[0]),
359
- decision: PolicyDecision.ALLOW,
360
- },
361
- ];
362
- engine = new PolicyEngine({ rules });
363
- const result = await engine.check({
364
- name: 'run_shell_command',
365
- args: { command: 'git commit -m "fix"' },
366
- }, undefined);
367
- expect(result.decision).toBe(PolicyDecision.ALLOW);
368
- });
369
- it('should handle tools with no args', async () => {
370
- const rules = [
371
- {
372
- toolName: 'read',
373
- argsPattern: /secret/,
374
- decision: PolicyDecision.DENY,
375
- },
376
- ];
377
- engine = new PolicyEngine({ rules });
378
- // Tool call without args should not match pattern
379
- expect((await engine.check({ name: 'read' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
380
- // Tool call with args not matching pattern
381
- expect((await engine.check({ name: 'read', args: { file: 'public.txt' } }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
382
- // Tool call with args matching pattern
383
- expect((await engine.check({ name: 'read', args: { file: 'secret.txt' } }, undefined)).decision).toBe(PolicyDecision.DENY);
384
- });
385
- it('should match args pattern regardless of property order', async () => {
386
- const rules = [
387
- {
388
- toolName: 'shell',
389
- // Pattern matches the stable stringified format
390
- argsPattern: /"command":"rm[^"]*-rf/,
391
- decision: PolicyDecision.DENY,
392
- },
393
- ];
394
- engine = new PolicyEngine({ rules });
395
- // Same args with different property order should both match
396
- const args1 = { command: 'rm -rf /', path: '/home' };
397
- const args2 = { path: '/home', command: 'rm -rf /' };
398
- expect((await engine.check({ name: 'shell', args: args1 }, undefined))
399
- .decision).toBe(PolicyDecision.DENY);
400
- expect((await engine.check({ name: 'shell', args: args2 }, undefined))
401
- .decision).toBe(PolicyDecision.DENY);
402
- // Verify safe command doesn't match
403
- const safeArgs = { command: 'ls -la', path: '/home' };
404
- expect((await engine.check({ name: 'shell', args: safeArgs }, undefined))
405
- .decision).toBe(PolicyDecision.ASK_USER);
406
- });
407
- it('should handle nested objects in args with stable stringification', async () => {
408
- const rules = [
409
- {
410
- toolName: 'api',
411
- argsPattern: /"sensitive":true/,
412
- decision: PolicyDecision.DENY,
413
- },
414
- ];
415
- engine = new PolicyEngine({ rules });
416
- // Nested objects with different key orders should match consistently
417
- const args1 = {
418
- data: { sensitive: true, value: 'secret' },
419
- method: 'POST',
420
- };
421
- const args2 = {
422
- method: 'POST',
423
- data: { value: 'secret', sensitive: true },
424
- };
425
- expect((await engine.check({ name: 'api', args: args1 }, undefined)).decision).toBe(PolicyDecision.DENY);
426
- expect((await engine.check({ name: 'api', args: args2 }, undefined)).decision).toBe(PolicyDecision.DENY);
427
- });
428
- it('should handle circular references without stack overflow', async () => {
429
- const rules = [
430
- {
431
- toolName: 'test',
432
- argsPattern: /\[Circular\]/,
433
- decision: PolicyDecision.DENY,
434
- },
435
- ];
436
- engine = new PolicyEngine({ rules });
437
- const circularArgs = {
438
- name: 'test',
439
- data: {},
440
- };
441
- // Create circular reference - TypeScript allows this since data is Record<string, unknown>
442
- circularArgs.data['self'] =
443
- circularArgs.data;
444
- // Should not throw stack overflow error
445
- await expect(engine.check({ name: 'test', args: circularArgs }, undefined)).resolves.not.toThrow();
446
- // Should detect the circular reference pattern
447
- expect((await engine.check({ name: 'test', args: circularArgs }, undefined))
448
- .decision).toBe(PolicyDecision.DENY);
449
- // Non-circular object should not match
450
- const normalArgs = { name: 'test', data: { value: 'normal' } };
451
- expect((await engine.check({ name: 'test', args: normalArgs }, undefined))
452
- .decision).toBe(PolicyDecision.ASK_USER);
453
- });
454
- it('should handle deep circular references', async () => {
455
- const rules = [
456
- {
457
- toolName: 'deep',
458
- argsPattern: /\[Circular\]/,
459
- decision: PolicyDecision.DENY,
460
- },
461
- ];
462
- engine = new PolicyEngine({ rules });
463
- const deepCircular = {
464
- level1: {
465
- level2: {
466
- level3: {},
467
- },
468
- },
469
- };
470
- // Create circular reference with proper type assertions
471
- const level3 = deepCircular.level1.level2.level3;
472
- level3['back'] = deepCircular.level1;
473
- // Should handle without stack overflow
474
- await expect(engine.check({ name: 'deep', args: deepCircular }, undefined)).resolves.not.toThrow();
475
- // Should detect the circular reference
476
- expect((await engine.check({ name: 'deep', args: deepCircular }, undefined))
477
- .decision).toBe(PolicyDecision.DENY);
478
- });
479
- it('should handle repeated non-circular objects correctly', async () => {
480
- const rules = [
481
- {
482
- toolName: 'test',
483
- argsPattern: /\[Circular\]/,
484
- decision: PolicyDecision.DENY,
485
- },
486
- {
487
- toolName: 'test',
488
- argsPattern: /"value":"shared"/,
489
- decision: PolicyDecision.ALLOW,
490
- priority: 10,
491
- },
492
- ];
493
- engine = new PolicyEngine({ rules });
494
- // Create an object with repeated references but no cycles
495
- const sharedObj = { value: 'shared' };
496
- const args = {
497
- first: sharedObj,
498
- second: sharedObj,
499
- third: { nested: sharedObj },
500
- };
501
- // Should NOT mark repeated objects as circular, and should match the shared value pattern
502
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
503
- });
504
- it('should omit undefined and function values from objects', async () => {
505
- const rules = [
506
- {
507
- toolName: 'test',
508
- argsPattern: /"definedValue":"test"/,
509
- decision: PolicyDecision.ALLOW,
510
- },
511
- ];
512
- engine = new PolicyEngine({ rules });
513
- const args = {
514
- definedValue: 'test',
515
- undefinedValue: undefined,
516
- functionValue: () => 'hello',
517
- nullValue: null,
518
- };
519
- // Should match pattern with defined value, undefined and functions omitted
520
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
521
- // Check that the pattern would NOT match if undefined was included
522
- const rulesWithUndefined = [
523
- {
524
- toolName: 'test',
525
- argsPattern: /undefinedValue/,
526
- decision: PolicyDecision.DENY,
527
- },
528
- ];
529
- engine = new PolicyEngine({ rules: rulesWithUndefined });
530
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
531
- // Check that the pattern would NOT match if function was included
532
- const rulesWithFunction = [
533
- {
534
- toolName: 'test',
535
- argsPattern: /functionValue/,
536
- decision: PolicyDecision.DENY,
537
- },
538
- ];
539
- engine = new PolicyEngine({ rules: rulesWithFunction });
540
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
541
- });
542
- it('should convert undefined and functions to null in arrays', async () => {
543
- const rules = [
544
- {
545
- toolName: 'test',
546
- argsPattern: /\["value",null,null,null\]/,
547
- decision: PolicyDecision.ALLOW,
548
- },
549
- ];
550
- engine = new PolicyEngine({ rules });
551
- const args = {
552
- array: ['value', undefined, () => 'hello', null],
553
- };
554
- // Should match pattern with undefined and functions converted to null
555
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
556
- });
557
- it('should produce valid JSON for all inputs', async () => {
558
- const testCases = [
559
- { input: { simple: 'string' }, desc: 'simple object' },
560
- {
561
- input: { nested: { deep: { value: 123 } } },
562
- desc: 'nested object',
563
- },
564
- { input: { data: [1, 2, 3] }, desc: 'simple array' },
565
- { input: { mixed: [1, { a: 'b' }, null] }, desc: 'mixed array' },
566
- {
567
- input: { undef: undefined, func: () => { }, normal: 'value' },
568
- desc: 'object with undefined and function',
569
- },
570
- {
571
- input: { data: ['a', undefined, () => { }, null] },
572
- desc: 'array with undefined and function',
573
- },
574
- ];
575
- for (const { input } of testCases) {
576
- const rules = [
577
- {
578
- toolName: 'test',
579
- argsPattern: /.*/,
580
- decision: PolicyDecision.ALLOW,
581
- },
582
- ];
583
- engine = new PolicyEngine({ rules });
584
- // Should not throw when checking (which internally uses stableStringify)
585
- await expect(engine.check({ name: 'test', args: input }, undefined)).resolves.not.toThrow();
586
- // The check should succeed
587
- expect((await engine.check({ name: 'test', args: input }, undefined))
588
- .decision).toBe(PolicyDecision.ALLOW);
589
- }
590
- });
591
- it('should respect toJSON methods on objects', async () => {
592
- const rules = [
593
- {
594
- toolName: 'test',
595
- argsPattern: /"sanitized":"safe"/,
596
- decision: PolicyDecision.ALLOW,
597
- },
598
- {
599
- toolName: 'test',
600
- argsPattern: /"dangerous":"data"/,
601
- decision: PolicyDecision.DENY,
602
- },
603
- ];
604
- engine = new PolicyEngine({ rules });
605
- // Object with toJSON that sanitizes output
606
- const args = {
607
- data: {
608
- dangerous: 'data',
609
- toJSON: () => ({ sanitized: 'safe' }),
610
- },
611
- };
612
- // Should match the sanitized pattern, not the dangerous one
613
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
614
- });
615
- it('should handle toJSON that returns primitives', async () => {
616
- const rules = [
617
- {
618
- toolName: 'test',
619
- argsPattern: /"value":"string-value"/,
620
- decision: PolicyDecision.ALLOW,
621
- },
622
- ];
623
- engine = new PolicyEngine({ rules });
624
- const args = {
625
- value: {
626
- complex: 'object',
627
- toJSON: () => 'string-value',
628
- },
629
- };
630
- // toJSON returns a string, which should be properly stringified
631
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
632
- });
633
- it('should handle toJSON that throws an error', async () => {
634
- const rules = [
635
- {
636
- toolName: 'test',
637
- argsPattern: /"fallback":"value"/,
638
- decision: PolicyDecision.ALLOW,
639
- },
640
- ];
641
- engine = new PolicyEngine({ rules });
642
- const args = {
643
- data: {
644
- fallback: 'value',
645
- toJSON: () => {
646
- throw new Error('toJSON error');
647
- },
648
- },
649
- };
650
- // Should fall back to regular object serialization when toJSON throws
651
- expect((await engine.check({ name: 'test', args }, undefined)).decision).toBe(PolicyDecision.ALLOW);
652
- });
653
- it('should downgrade ALLOW to ASK_USER for redirected shell commands', async () => {
654
- const rules = [
655
- {
656
- toolName: 'run_shell_command',
657
- // Matches "echo" prefix
658
- argsPattern: /"command":"echo/,
659
- decision: PolicyDecision.ALLOW,
660
- },
661
- ];
662
- engine = new PolicyEngine({ rules });
663
- // Safe command should be allowed
664
- expect((await engine.check({ name: 'run_shell_command', args: { command: 'echo "hello"' } }, undefined)).decision).toBe(PolicyDecision.ALLOW);
665
- // Redirected command should be downgraded to ASK_USER
666
- expect((await engine.check({
667
- name: 'run_shell_command',
668
- args: { command: 'echo "hello" > file.txt' },
669
- }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
670
- });
671
- it('should allow redirected shell commands when allowRedirection is true', async () => {
672
- const rules = [
673
- {
674
- toolName: 'run_shell_command',
675
- // Matches "echo" prefix
676
- argsPattern: /"command":"echo/,
677
- decision: PolicyDecision.ALLOW,
678
- allowRedirection: true,
679
- },
680
- ];
681
- engine = new PolicyEngine({ rules });
682
- // Redirected command should stay ALLOW
683
- expect((await engine.check({
684
- name: 'run_shell_command',
685
- args: { command: 'echo "hello" > file.txt' },
686
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
687
- });
688
- it('should NOT downgrade ALLOW to ASK_USER for quoted redirection chars', async () => {
689
- const rules = [
690
- {
691
- toolName: 'run_shell_command',
692
- argsPattern: /"command":"echo/,
693
- decision: PolicyDecision.ALLOW,
694
- },
695
- ];
696
- engine = new PolicyEngine({ rules });
697
- // Should remain ALLOW because it's not a real redirection
698
- expect((await engine.check({
699
- name: 'run_shell_command',
700
- args: { command: 'echo "-> arrow"' },
701
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
702
- });
703
- it('should preserve dir_path during recursive shell command checks', async () => {
704
- const rules = [
705
- {
706
- toolName: 'run_shell_command',
707
- // Rule that only allows echo in a specific directory
708
- // Note: stableStringify sorts keys alphabetically and has no spaces: {"command":"echo hello","dir_path":"/safe/path"}
709
- argsPattern: /"command":"echo hello".*"dir_path":"\/safe\/path"/,
710
- decision: PolicyDecision.ALLOW,
711
- },
712
- {
713
- // Catch-all ALLOW for shell but with low priority
714
- toolName: 'run_shell_command',
715
- decision: PolicyDecision.ALLOW,
716
- priority: -100,
717
- },
718
- ];
719
- engine = new PolicyEngine({ rules });
720
- // Compound command. The decomposition will call check() for "echo hello"
721
- // which should match our specific high-priority rule IF dir_path is preserved.
722
- const result = await engine.check({
723
- name: 'run_shell_command',
724
- args: { command: 'echo hello && pwd', dir_path: '/safe/path' },
725
- }, undefined);
726
- expect(result.decision).toBe(PolicyDecision.ALLOW);
727
- });
728
- it('should upgrade ASK_USER to ALLOW if all sub-commands are allowed', async () => {
729
- const rules = [
730
- {
731
- toolName: 'run_shell_command',
732
- argsPattern: /"command":"git status/,
733
- decision: PolicyDecision.ALLOW,
734
- priority: 20,
735
- },
736
- {
737
- toolName: 'run_shell_command',
738
- argsPattern: /"command":"ls/,
739
- decision: PolicyDecision.ALLOW,
740
- priority: 20,
741
- },
742
- {
743
- // Catch-all ASK_USER for shell
744
- toolName: 'run_shell_command',
745
- decision: PolicyDecision.ASK_USER,
746
- priority: 10,
747
- },
748
- ];
749
- engine = new PolicyEngine({ rules });
750
- // "git status && ls" matches the catch-all ASK_USER rule initially.
751
- // But since both parts are explicitly ALLOWed, the result should be upgraded to ALLOW.
752
- const result = await engine.check({
753
- name: 'run_shell_command',
754
- args: { command: 'git status && ls' },
755
- }, undefined);
756
- expect(result.decision).toBe(PolicyDecision.ALLOW);
757
- });
758
- it('should respect explicit DENY for compound commands even if parts are allowed', async () => {
759
- const rules = [
760
- {
761
- // Explicitly DENY the compound command
762
- toolName: 'run_shell_command',
763
- argsPattern: /"command":"git status && ls"/,
764
- decision: PolicyDecision.DENY,
765
- priority: 30,
766
- },
767
- {
768
- toolName: 'run_shell_command',
769
- argsPattern: /"command":"git status/,
770
- decision: PolicyDecision.ALLOW,
771
- priority: 20,
772
- },
773
- {
774
- toolName: 'run_shell_command',
775
- argsPattern: /"command":"ls/,
776
- decision: PolicyDecision.ALLOW,
777
- priority: 20,
778
- },
779
- ];
780
- engine = new PolicyEngine({ rules });
781
- const result = await engine.check({
782
- name: 'run_shell_command',
783
- args: { command: 'git status && ls' },
784
- }, undefined);
785
- expect(result.decision).toBe(PolicyDecision.DENY);
786
- });
787
- it('should propagate DENY from any sub-command', async () => {
788
- const rules = [
789
- {
790
- toolName: 'run_shell_command',
791
- argsPattern: /"command":"rm/,
792
- decision: PolicyDecision.DENY,
793
- priority: 20,
794
- },
795
- {
796
- toolName: 'run_shell_command',
797
- argsPattern: /"command":"echo/,
798
- decision: PolicyDecision.ALLOW,
799
- priority: 20,
800
- },
801
- {
802
- toolName: 'run_shell_command',
803
- decision: PolicyDecision.ASK_USER,
804
- priority: 10,
805
- },
806
- ];
807
- engine = new PolicyEngine({ rules });
808
- // "echo hello && rm -rf /" -> echo is ALLOW, rm is DENY -> Result DENY
809
- const result = await engine.check({
810
- name: 'run_shell_command',
811
- args: { command: 'echo hello && rm -rf /' },
812
- }, undefined);
813
- expect(result.decision).toBe(PolicyDecision.DENY);
814
- });
815
- it('should DENY redirected shell commands in non-interactive mode', async () => {
816
- const config = {
817
- nonInteractive: true,
818
- rules: [
819
- {
820
- toolName: 'run_shell_command',
821
- decision: PolicyDecision.ALLOW,
822
- },
823
- ],
824
- };
825
- engine = new PolicyEngine(config);
826
- // Redirected command should be DENIED in non-interactive mode
827
- // (Normally ASK_USER, but ASK_USER -> DENY in non-interactive)
828
- expect((await engine.check({
829
- name: 'run_shell_command',
830
- args: { command: 'echo "hello" > file.txt' },
831
- }, undefined)).decision).toBe(PolicyDecision.DENY);
832
- });
833
- it('should default to ASK_USER for atomic commands when matching a wildcard ASK_USER rule', async () => {
834
- // Regression test: atomic commands were auto-allowing because of optimistic initialization
835
- const rules = [
836
- {
837
- toolName: 'run_shell_command',
838
- decision: PolicyDecision.ASK_USER,
839
- },
840
- ];
841
- engine = new PolicyEngine({ rules });
842
- // Atomic command "whoami" matches the wildcard rule (ASK_USER).
843
- // It should NOT be upgraded to ALLOW.
844
- expect((await engine.check({
845
- name: 'run_shell_command',
846
- args: { command: 'whoami' },
847
- }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
848
- });
849
- it('should allow redirected shell commands in non-interactive mode if allowRedirection is true', async () => {
850
- const config = {
851
- nonInteractive: true,
852
- rules: [
853
- {
854
- toolName: 'run_shell_command',
855
- decision: PolicyDecision.ALLOW,
856
- allowRedirection: true,
857
- },
858
- ],
859
- };
860
- engine = new PolicyEngine(config);
861
- // Redirected command should stay ALLOW even in non-interactive mode
862
- expect((await engine.check({
863
- name: 'run_shell_command',
864
- args: { command: 'echo "hello" > file.txt' },
865
- }, undefined)).decision).toBe(PolicyDecision.ALLOW);
866
- });
867
- it('should avoid infinite recursion for commands with substitution', async () => {
868
- const rules = [
869
- {
870
- toolName: 'run_shell_command',
871
- decision: PolicyDecision.ALLOW,
872
- },
873
- ];
874
- engine = new PolicyEngine({ rules });
875
- // Command with substitution triggers splitCommands returning the same command as its first element.
876
- // This verifies the fix for the infinite recursion bug.
877
- const result = await engine.check({
878
- name: 'run_shell_command',
879
- args: { command: 'echo $(ls)' },
880
- }, undefined);
881
- expect(result.decision).toBe(PolicyDecision.ALLOW);
882
- });
883
- it('should require confirmation for a compound command with redirection even if individual commands are allowed', async () => {
884
- const rules = [
885
- {
886
- toolName: 'run_shell_command',
887
- argsPattern: /"command":"mkdir\b/,
888
- decision: PolicyDecision.ALLOW,
889
- priority: 20,
890
- },
891
- {
892
- toolName: 'run_shell_command',
893
- argsPattern: /"command":"echo\b/,
894
- decision: PolicyDecision.ALLOW,
895
- priority: 20,
896
- },
897
- ];
898
- engine = new PolicyEngine({ rules });
899
- // The full command has redirection, even if the individual split commands do not.
900
- // splitCommands will return ['mkdir -p "bar"', 'echo "hello"']
901
- // The redirection '> bar/test.md' is stripped by splitCommands.
902
- const result = await engine.check({
903
- name: 'run_shell_command',
904
- args: { command: 'mkdir -p "bar" && echo "hello" > bar/test.md' },
905
- }, undefined);
906
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
907
- });
908
- it('should report redirection when a sub-command specifically has redirection', async () => {
909
- const rules = [
910
- {
911
- toolName: 'run_shell_command',
912
- argsPattern: /"command":"mkdir\b/,
913
- decision: PolicyDecision.ALLOW,
914
- priority: 20,
915
- },
916
- {
917
- toolName: 'run_shell_command',
918
- argsPattern: /"command":"echo\b/,
919
- decision: PolicyDecision.ALLOW,
920
- priority: 20,
921
- },
922
- ];
923
- engine = new PolicyEngine({ rules });
924
- // In this case, we mock splitCommands to keep the redirection in the sub-command
925
- vi.mocked(initializeShellParsers).mockResolvedValue(undefined);
926
- const { splitCommands } = await import('../utils/shell-utils.js');
927
- vi.mocked(splitCommands).mockReturnValueOnce([
928
- 'mkdir bar',
929
- 'echo hello > bar/test.md',
930
- ]);
931
- const result = await engine.check({
932
- name: 'run_shell_command',
933
- args: { command: 'mkdir bar && echo hello > bar/test.md' },
934
- }, undefined);
935
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
936
- });
937
- it('should allow redirected shell commands in AUTO_EDIT mode if individual commands are allowed', async () => {
938
- const rules = [
939
- {
940
- toolName: 'run_shell_command',
941
- argsPattern: /"command":"echo\b/,
942
- decision: PolicyDecision.ALLOW,
943
- priority: 20,
944
- },
945
- ];
946
- engine = new PolicyEngine({ rules });
947
- engine.setApprovalMode(ApprovalMode.AUTO_EDIT);
948
- const result = await engine.check({
949
- name: 'run_shell_command',
950
- args: { command: 'echo "hello" > test.txt' },
951
- }, undefined);
952
- expect(result.decision).toBe(PolicyDecision.ALLOW);
953
- });
954
- it('should allow compound commands with safe operators (&&, ||) if individual commands are allowed', async () => {
955
- const rules = [
956
- {
957
- toolName: 'run_shell_command',
958
- argsPattern: /"command":"echo\b/,
959
- decision: PolicyDecision.ALLOW,
960
- priority: 20,
961
- },
962
- ];
963
- engine = new PolicyEngine({ rules });
964
- // "echo hello && echo world" should be allowed since both parts are ALLOW and no redirection is present.
965
- const result = await engine.check({
966
- name: 'run_shell_command',
967
- args: { command: 'echo hello && echo world' },
968
- }, undefined);
969
- expect(result.decision).toBe(PolicyDecision.ALLOW);
970
- });
971
- });
972
- describe('safety checker integration', () => {
973
- it('should call checker when rule allows and has safety_checker', async () => {
974
- const rules = [
975
- {
976
- toolName: 'test-tool',
977
- decision: PolicyDecision.ALLOW,
978
- },
979
- ];
980
- const checkers = [
981
- {
982
- toolName: 'test-tool',
983
- checker: {
984
- type: 'external',
985
- name: 'test-checker',
986
- config: { content: 'test-content' },
987
- },
988
- },
989
- ];
990
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
991
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
992
- decision: SafetyCheckDecision.ALLOW,
993
- });
994
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
995
- expect(result.decision).toBe(PolicyDecision.ALLOW);
996
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith({ name: 'test-tool', args: { foo: 'bar' } }, {
997
- type: 'external',
998
- name: 'test-checker',
999
- config: { content: 'test-content' },
1000
- });
1001
- });
1002
- it('should handle checker errors as DENY', async () => {
1003
- const rules = [
1004
- {
1005
- toolName: 'test',
1006
- decision: PolicyDecision.ALLOW,
1007
- },
1008
- ];
1009
- const checkers = [
1010
- {
1011
- toolName: 'test',
1012
- checker: {
1013
- type: 'in-process',
1014
- name: InProcessCheckerType.ALLOWED_PATH,
1015
- },
1016
- },
1017
- ];
1018
- mockCheckerRunner.runChecker = vi
1019
- .fn()
1020
- .mockRejectedValue(new Error('Checker failed'));
1021
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1022
- const { decision } = await engine.check({ name: 'test' }, undefined);
1023
- expect(decision).toBe(PolicyDecision.DENY);
1024
- });
1025
- it('should return DENY when checker denies', async () => {
1026
- const rules = [
1027
- {
1028
- toolName: 'test-tool',
1029
- decision: PolicyDecision.ALLOW,
1030
- },
1031
- ];
1032
- const checkers = [
1033
- {
1034
- toolName: 'test-tool',
1035
- checker: {
1036
- type: 'external',
1037
- name: 'test-checker',
1038
- config: { content: 'test-content' },
1039
- },
1040
- },
1041
- ];
1042
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1043
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1044
- decision: SafetyCheckDecision.DENY,
1045
- reason: 'test reason',
1046
- });
1047
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1048
- expect(result.decision).toBe(PolicyDecision.DENY);
1049
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1050
- });
1051
- it('should not call checker if decision is not ALLOW', async () => {
1052
- const rules = [
1053
- {
1054
- toolName: 'test-tool',
1055
- decision: PolicyDecision.ASK_USER,
1056
- },
1057
- ];
1058
- const checkers = [
1059
- {
1060
- toolName: 'test-tool',
1061
- checker: {
1062
- type: 'external',
1063
- name: 'test-checker',
1064
- config: { content: 'test-content' },
1065
- },
1066
- },
1067
- ];
1068
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1069
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1070
- decision: SafetyCheckDecision.ALLOW,
1071
- });
1072
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1073
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1074
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1075
- });
1076
- it('should run checkers when rule allows', async () => {
1077
- const rules = [
1078
- {
1079
- toolName: 'test',
1080
- decision: PolicyDecision.ALLOW,
1081
- },
1082
- ];
1083
- const checkers = [
1084
- {
1085
- toolName: 'test',
1086
- checker: {
1087
- type: 'in-process',
1088
- name: InProcessCheckerType.ALLOWED_PATH,
1089
- },
1090
- },
1091
- ];
1092
- mockCheckerRunner.runChecker = vi.fn().mockResolvedValue({
1093
- decision: SafetyCheckDecision.ALLOW,
1094
- });
1095
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1096
- const { decision } = await engine.check({ name: 'test' }, undefined);
1097
- expect(decision).toBe(PolicyDecision.ALLOW);
1098
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledTimes(1);
1099
- });
1100
- it('should not call checker if rule has no safety_checker', async () => {
1101
- const rules = [
1102
- {
1103
- toolName: 'test-tool',
1104
- decision: PolicyDecision.ALLOW,
1105
- },
1106
- ];
1107
- engine = new PolicyEngine({ rules }, mockCheckerRunner);
1108
- const result = await engine.check({ name: 'test-tool', args: { foo: 'bar' } }, undefined);
1109
- expect(result.decision).toBe(PolicyDecision.ALLOW);
1110
- expect(mockCheckerRunner.runChecker).not.toHaveBeenCalled();
1111
- });
1112
- });
1113
- describe('serverName requirement', () => {
1114
- it('should require serverName for checks', async () => {
1115
- // @ts-expect-error - intentionally testing missing serverName
1116
- expect((await engine.check({ name: 'test' })).decision).toBe(PolicyDecision.ASK_USER);
1117
- // When serverName is provided (even undefined), it should work
1118
- expect((await engine.check({ name: 'test' }, undefined)).decision).toBe(PolicyDecision.ASK_USER);
1119
- expect((await engine.check({ name: 'test' }, 'some-server')).decision).toBe(PolicyDecision.ASK_USER);
1120
- });
1121
- it('should run multiple checkers in priority order and stop at first denial', async () => {
1122
- const rules = [
1123
- {
1124
- toolName: 'test',
1125
- decision: PolicyDecision.ALLOW,
1126
- },
1127
- ];
1128
- const checkers = [
1129
- {
1130
- toolName: 'test',
1131
- priority: 10,
1132
- checker: { type: 'external', name: 'checker1' },
1133
- },
1134
- {
1135
- toolName: 'test',
1136
- priority: 20, // Should run first
1137
- checker: { type: 'external', name: 'checker2' },
1138
- },
1139
- ];
1140
- mockCheckerRunner.runChecker = vi
1141
- .fn()
1142
- .mockImplementation(async (_toolCall, config) => {
1143
- if (config.name === 'checker2') {
1144
- return {
1145
- decision: SafetyCheckDecision.DENY,
1146
- reason: 'checker2 denied',
1147
- };
1148
- }
1149
- return { decision: SafetyCheckDecision.ALLOW };
1150
- });
1151
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1152
- const { decision, rule } = await engine.check({ name: 'test' }, undefined);
1153
- expect(decision).toBe(PolicyDecision.DENY);
1154
- expect(rule).toBeDefined();
1155
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledTimes(1);
1156
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'checker2' }));
1157
- });
1158
- });
1159
- describe('addChecker', () => {
1160
- it('should add a new checker and maintain priority order', () => {
1161
- const checker1 = {
1162
- checker: { type: 'external', name: 'checker1' },
1163
- priority: 5,
1164
- };
1165
- const checker2 = {
1166
- checker: { type: 'external', name: 'checker2' },
1167
- priority: 10,
1168
- };
1169
- engine.addChecker(checker1);
1170
- engine.addChecker(checker2);
1171
- const checkers = engine.getCheckers();
1172
- expect(checkers).toHaveLength(2);
1173
- expect(checkers[0].priority).toBe(10);
1174
- expect(checkers[0].checker.name).toBe('checker2');
1175
- expect(checkers[1].priority).toBe(5);
1176
- expect(checkers[1].checker.name).toBe('checker1');
1177
- });
1178
- });
1179
- describe('checker matching logic', () => {
1180
- it('should match checkers using toolName and argsPattern', async () => {
1181
- const rules = [
1182
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1183
- ];
1184
- const matchingChecker = {
1185
- checker: { type: 'external', name: 'matching' },
1186
- toolName: 'tool',
1187
- argsPattern: /"safe":true/,
1188
- };
1189
- const nonMatchingChecker = {
1190
- checker: { type: 'external', name: 'non-matching' },
1191
- toolName: 'other',
1192
- };
1193
- engine = new PolicyEngine({ rules, checkers: [matchingChecker, nonMatchingChecker] }, mockCheckerRunner);
1194
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1195
- decision: SafetyCheckDecision.ALLOW,
1196
- });
1197
- await engine.check({ name: 'tool', args: { safe: true } }, undefined);
1198
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'matching' }));
1199
- expect(mockCheckerRunner.runChecker).not.toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'non-matching' }));
1200
- });
1201
- it('should support wildcard patterns for checkers', async () => {
1202
- const rules = [
1203
- { toolName: 'server__tool', decision: PolicyDecision.ALLOW },
1204
- ];
1205
- const wildcardChecker = {
1206
- checker: { type: 'external', name: 'wildcard' },
1207
- toolName: 'server__*',
1208
- };
1209
- engine = new PolicyEngine({ rules, checkers: [wildcardChecker] }, mockCheckerRunner);
1210
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1211
- decision: SafetyCheckDecision.ALLOW,
1212
- });
1213
- await engine.check({ name: 'server__tool' }, 'server');
1214
- expect(mockCheckerRunner.runChecker).toHaveBeenCalledWith(expect.anything(), expect.objectContaining({ name: 'wildcard' }));
1215
- });
1216
- it('should run safety checkers when decision is ASK_USER and downgrade to DENY on failure', async () => {
1217
- const rules = [
1218
- { toolName: 'tool', decision: PolicyDecision.ASK_USER },
1219
- ];
1220
- const checkers = [
1221
- {
1222
- checker: {
1223
- type: 'in-process',
1224
- name: InProcessCheckerType.ALLOWED_PATH,
1225
- },
1226
- },
1227
- ];
1228
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1229
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1230
- decision: SafetyCheckDecision.DENY,
1231
- reason: 'Safety check failed',
1232
- });
1233
- const result = await engine.check({ name: 'tool' }, undefined);
1234
- expect(result.decision).toBe(PolicyDecision.DENY);
1235
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1236
- });
1237
- it('should run safety checkers when decision is ASK_USER and keep ASK_USER on success', async () => {
1238
- const rules = [
1239
- { toolName: 'tool', decision: PolicyDecision.ASK_USER },
1240
- ];
1241
- const checkers = [
1242
- {
1243
- checker: {
1244
- type: 'in-process',
1245
- name: InProcessCheckerType.ALLOWED_PATH,
1246
- },
1247
- },
1248
- ];
1249
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1250
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1251
- decision: SafetyCheckDecision.ALLOW,
1252
- });
1253
- const result = await engine.check({ name: 'tool' }, undefined);
1254
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1255
- expect(mockCheckerRunner.runChecker).toHaveBeenCalled();
1256
- });
1257
- it('should downgrade ALLOW to ASK_USER if checker returns ASK_USER', async () => {
1258
- const rules = [
1259
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1260
- ];
1261
- const checkers = [
1262
- {
1263
- checker: {
1264
- type: 'in-process',
1265
- name: InProcessCheckerType.ALLOWED_PATH,
1266
- },
1267
- },
1268
- ];
1269
- engine = new PolicyEngine({ rules, checkers }, mockCheckerRunner);
1270
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1271
- decision: SafetyCheckDecision.ASK_USER,
1272
- reason: 'Suspicious path',
1273
- });
1274
- const result = await engine.check({ name: 'tool' }, undefined);
1275
- expect(result.decision).toBe(PolicyDecision.ASK_USER);
1276
- });
1277
- it('should DENY if checker returns ASK_USER in non-interactive mode', async () => {
1278
- const rules = [
1279
- { toolName: 'tool', decision: PolicyDecision.ALLOW },
1280
- ];
1281
- const checkers = [
1282
- {
1283
- checker: {
1284
- type: 'in-process',
1285
- name: InProcessCheckerType.ALLOWED_PATH,
1286
- },
1287
- },
1288
- ];
1289
- engine = new PolicyEngine({ rules, checkers, nonInteractive: true }, mockCheckerRunner);
1290
- vi.mocked(mockCheckerRunner.runChecker).mockResolvedValue({
1291
- decision: SafetyCheckDecision.ASK_USER,
1292
- reason: 'Suspicious path',
1293
- });
1294
- const result = await engine.check({ name: 'tool' }, undefined);
1295
- expect(result.decision).toBe(PolicyDecision.DENY);
1296
- });
1297
- });
1298
- });
1299
- //# sourceMappingURL=policy-engine.test.js.map