onbuzz 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (506) hide show
  1. package/LICENSE +267 -0
  2. package/README.md +425 -0
  3. package/bin/cli.js +556 -0
  4. package/bin/loxia-terminal-v2.js +162 -0
  5. package/bin/loxia-terminal.js +90 -0
  6. package/bin/start-with-terminal.js +200 -0
  7. package/node_modules/@isaacs/balanced-match/LICENSE.md +23 -0
  8. package/node_modules/@isaacs/balanced-match/README.md +60 -0
  9. package/node_modules/@isaacs/balanced-match/dist/commonjs/index.d.ts +9 -0
  10. package/node_modules/@isaacs/balanced-match/dist/commonjs/index.d.ts.map +1 -0
  11. package/node_modules/@isaacs/balanced-match/dist/commonjs/index.js +59 -0
  12. package/node_modules/@isaacs/balanced-match/dist/commonjs/index.js.map +1 -0
  13. package/node_modules/@isaacs/balanced-match/dist/commonjs/package.json +3 -0
  14. package/node_modules/@isaacs/balanced-match/dist/esm/index.d.ts +9 -0
  15. package/node_modules/@isaacs/balanced-match/dist/esm/index.d.ts.map +1 -0
  16. package/node_modules/@isaacs/balanced-match/dist/esm/index.js +54 -0
  17. package/node_modules/@isaacs/balanced-match/dist/esm/index.js.map +1 -0
  18. package/node_modules/@isaacs/balanced-match/dist/esm/package.json +3 -0
  19. package/node_modules/@isaacs/balanced-match/package.json +79 -0
  20. package/node_modules/@isaacs/brace-expansion/LICENSE +23 -0
  21. package/node_modules/@isaacs/brace-expansion/README.md +97 -0
  22. package/node_modules/@isaacs/brace-expansion/dist/commonjs/index.d.ts +6 -0
  23. package/node_modules/@isaacs/brace-expansion/dist/commonjs/index.d.ts.map +1 -0
  24. package/node_modules/@isaacs/brace-expansion/dist/commonjs/index.js +199 -0
  25. package/node_modules/@isaacs/brace-expansion/dist/commonjs/index.js.map +1 -0
  26. package/node_modules/@isaacs/brace-expansion/dist/commonjs/package.json +3 -0
  27. package/node_modules/@isaacs/brace-expansion/dist/esm/index.d.ts +6 -0
  28. package/node_modules/@isaacs/brace-expansion/dist/esm/index.d.ts.map +1 -0
  29. package/node_modules/@isaacs/brace-expansion/dist/esm/index.js +195 -0
  30. package/node_modules/@isaacs/brace-expansion/dist/esm/index.js.map +1 -0
  31. package/node_modules/@isaacs/brace-expansion/dist/esm/package.json +3 -0
  32. package/node_modules/@isaacs/brace-expansion/package.json +60 -0
  33. package/node_modules/glob/LICENSE.md +63 -0
  34. package/node_modules/glob/README.md +1177 -0
  35. package/node_modules/glob/dist/commonjs/glob.d.ts +388 -0
  36. package/node_modules/glob/dist/commonjs/glob.d.ts.map +1 -0
  37. package/node_modules/glob/dist/commonjs/glob.js +247 -0
  38. package/node_modules/glob/dist/commonjs/glob.js.map +1 -0
  39. package/node_modules/glob/dist/commonjs/has-magic.d.ts +14 -0
  40. package/node_modules/glob/dist/commonjs/has-magic.d.ts.map +1 -0
  41. package/node_modules/glob/dist/commonjs/has-magic.js +27 -0
  42. package/node_modules/glob/dist/commonjs/has-magic.js.map +1 -0
  43. package/node_modules/glob/dist/commonjs/ignore.d.ts +24 -0
  44. package/node_modules/glob/dist/commonjs/ignore.d.ts.map +1 -0
  45. package/node_modules/glob/dist/commonjs/ignore.js +119 -0
  46. package/node_modules/glob/dist/commonjs/ignore.js.map +1 -0
  47. package/node_modules/glob/dist/commonjs/index.d.ts +97 -0
  48. package/node_modules/glob/dist/commonjs/index.d.ts.map +1 -0
  49. package/node_modules/glob/dist/commonjs/index.js +68 -0
  50. package/node_modules/glob/dist/commonjs/index.js.map +1 -0
  51. package/node_modules/glob/dist/commonjs/index.min.js +4 -0
  52. package/node_modules/glob/dist/commonjs/index.min.js.map +7 -0
  53. package/node_modules/glob/dist/commonjs/package.json +3 -0
  54. package/node_modules/glob/dist/commonjs/pattern.d.ts +76 -0
  55. package/node_modules/glob/dist/commonjs/pattern.d.ts.map +1 -0
  56. package/node_modules/glob/dist/commonjs/pattern.js +219 -0
  57. package/node_modules/glob/dist/commonjs/pattern.js.map +1 -0
  58. package/node_modules/glob/dist/commonjs/processor.d.ts +59 -0
  59. package/node_modules/glob/dist/commonjs/processor.d.ts.map +1 -0
  60. package/node_modules/glob/dist/commonjs/processor.js +301 -0
  61. package/node_modules/glob/dist/commonjs/processor.js.map +1 -0
  62. package/node_modules/glob/dist/commonjs/walker.d.ts +97 -0
  63. package/node_modules/glob/dist/commonjs/walker.d.ts.map +1 -0
  64. package/node_modules/glob/dist/commonjs/walker.js +387 -0
  65. package/node_modules/glob/dist/commonjs/walker.js.map +1 -0
  66. package/node_modules/glob/dist/esm/glob.d.ts +388 -0
  67. package/node_modules/glob/dist/esm/glob.d.ts.map +1 -0
  68. package/node_modules/glob/dist/esm/glob.js +243 -0
  69. package/node_modules/glob/dist/esm/glob.js.map +1 -0
  70. package/node_modules/glob/dist/esm/has-magic.d.ts +14 -0
  71. package/node_modules/glob/dist/esm/has-magic.d.ts.map +1 -0
  72. package/node_modules/glob/dist/esm/has-magic.js +23 -0
  73. package/node_modules/glob/dist/esm/has-magic.js.map +1 -0
  74. package/node_modules/glob/dist/esm/ignore.d.ts +24 -0
  75. package/node_modules/glob/dist/esm/ignore.d.ts.map +1 -0
  76. package/node_modules/glob/dist/esm/ignore.js +115 -0
  77. package/node_modules/glob/dist/esm/ignore.js.map +1 -0
  78. package/node_modules/glob/dist/esm/index.d.ts +97 -0
  79. package/node_modules/glob/dist/esm/index.d.ts.map +1 -0
  80. package/node_modules/glob/dist/esm/index.js +55 -0
  81. package/node_modules/glob/dist/esm/index.js.map +1 -0
  82. package/node_modules/glob/dist/esm/index.min.js +4 -0
  83. package/node_modules/glob/dist/esm/index.min.js.map +7 -0
  84. package/node_modules/glob/dist/esm/package.json +3 -0
  85. package/node_modules/glob/dist/esm/pattern.d.ts +76 -0
  86. package/node_modules/glob/dist/esm/pattern.d.ts.map +1 -0
  87. package/node_modules/glob/dist/esm/pattern.js +215 -0
  88. package/node_modules/glob/dist/esm/pattern.js.map +1 -0
  89. package/node_modules/glob/dist/esm/processor.d.ts +59 -0
  90. package/node_modules/glob/dist/esm/processor.d.ts.map +1 -0
  91. package/node_modules/glob/dist/esm/processor.js +294 -0
  92. package/node_modules/glob/dist/esm/processor.js.map +1 -0
  93. package/node_modules/glob/dist/esm/walker.d.ts +97 -0
  94. package/node_modules/glob/dist/esm/walker.d.ts.map +1 -0
  95. package/node_modules/glob/dist/esm/walker.js +381 -0
  96. package/node_modules/glob/dist/esm/walker.js.map +1 -0
  97. package/node_modules/glob/node_modules/minimatch/LICENSE.md +55 -0
  98. package/node_modules/glob/node_modules/minimatch/README.md +453 -0
  99. package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +2 -0
  100. package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +1 -0
  101. package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +14 -0
  102. package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +1 -0
  103. package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.d.ts +20 -0
  104. package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.d.ts.map +1 -0
  105. package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.js +591 -0
  106. package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.js.map +1 -0
  107. package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts +8 -0
  108. package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +1 -0
  109. package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.js +152 -0
  110. package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +1 -0
  111. package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.d.ts +15 -0
  112. package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.d.ts.map +1 -0
  113. package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.js +30 -0
  114. package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.js.map +1 -0
  115. package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.d.ts +94 -0
  116. package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.d.ts.map +1 -0
  117. package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.js +1029 -0
  118. package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.js.map +1 -0
  119. package/node_modules/glob/node_modules/minimatch/dist/commonjs/package.json +3 -0
  120. package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.d.ts +22 -0
  121. package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +1 -0
  122. package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.js +38 -0
  123. package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.js.map +1 -0
  124. package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +2 -0
  125. package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +1 -0
  126. package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.js +10 -0
  127. package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +1 -0
  128. package/node_modules/glob/node_modules/minimatch/dist/esm/ast.d.ts +20 -0
  129. package/node_modules/glob/node_modules/minimatch/dist/esm/ast.d.ts.map +1 -0
  130. package/node_modules/glob/node_modules/minimatch/dist/esm/ast.js +587 -0
  131. package/node_modules/glob/node_modules/minimatch/dist/esm/ast.js.map +1 -0
  132. package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.d.ts +8 -0
  133. package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +1 -0
  134. package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.js +148 -0
  135. package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.js.map +1 -0
  136. package/node_modules/glob/node_modules/minimatch/dist/esm/escape.d.ts +15 -0
  137. package/node_modules/glob/node_modules/minimatch/dist/esm/escape.d.ts.map +1 -0
  138. package/node_modules/glob/node_modules/minimatch/dist/esm/escape.js +26 -0
  139. package/node_modules/glob/node_modules/minimatch/dist/esm/escape.js.map +1 -0
  140. package/node_modules/glob/node_modules/minimatch/dist/esm/index.d.ts +94 -0
  141. package/node_modules/glob/node_modules/minimatch/dist/esm/index.d.ts.map +1 -0
  142. package/node_modules/glob/node_modules/minimatch/dist/esm/index.js +1016 -0
  143. package/node_modules/glob/node_modules/minimatch/dist/esm/index.js.map +1 -0
  144. package/node_modules/glob/node_modules/minimatch/dist/esm/package.json +3 -0
  145. package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.d.ts +22 -0
  146. package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.d.ts.map +1 -0
  147. package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.js +34 -0
  148. package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.js.map +1 -0
  149. package/node_modules/glob/node_modules/minimatch/package.json +67 -0
  150. package/node_modules/glob/package.json +101 -0
  151. package/node_modules/minipass/LICENSE +15 -0
  152. package/node_modules/minipass/README.md +825 -0
  153. package/node_modules/minipass/dist/commonjs/index.d.ts +549 -0
  154. package/node_modules/minipass/dist/commonjs/index.d.ts.map +1 -0
  155. package/node_modules/minipass/dist/commonjs/index.js +1028 -0
  156. package/node_modules/minipass/dist/commonjs/index.js.map +1 -0
  157. package/node_modules/minipass/dist/commonjs/package.json +3 -0
  158. package/node_modules/minipass/dist/esm/index.d.ts +549 -0
  159. package/node_modules/minipass/dist/esm/index.d.ts.map +1 -0
  160. package/node_modules/minipass/dist/esm/index.js +1018 -0
  161. package/node_modules/minipass/dist/esm/index.js.map +1 -0
  162. package/node_modules/minipass/dist/esm/package.json +3 -0
  163. package/node_modules/minipass/package.json +82 -0
  164. package/node_modules/package-json-from-dist/LICENSE.md +63 -0
  165. package/node_modules/package-json-from-dist/README.md +110 -0
  166. package/node_modules/package-json-from-dist/dist/commonjs/index.d.ts +89 -0
  167. package/node_modules/package-json-from-dist/dist/commonjs/index.d.ts.map +1 -0
  168. package/node_modules/package-json-from-dist/dist/commonjs/index.js +134 -0
  169. package/node_modules/package-json-from-dist/dist/commonjs/index.js.map +1 -0
  170. package/node_modules/package-json-from-dist/dist/commonjs/package.json +3 -0
  171. package/node_modules/package-json-from-dist/dist/esm/index.d.ts +89 -0
  172. package/node_modules/package-json-from-dist/dist/esm/index.d.ts.map +1 -0
  173. package/node_modules/package-json-from-dist/dist/esm/index.js +129 -0
  174. package/node_modules/package-json-from-dist/dist/esm/index.js.map +1 -0
  175. package/node_modules/package-json-from-dist/dist/esm/package.json +3 -0
  176. package/node_modules/package-json-from-dist/package.json +68 -0
  177. package/node_modules/path-scurry/LICENSE.md +55 -0
  178. package/node_modules/path-scurry/README.md +636 -0
  179. package/node_modules/path-scurry/dist/commonjs/index.d.ts +1115 -0
  180. package/node_modules/path-scurry/dist/commonjs/index.d.ts.map +1 -0
  181. package/node_modules/path-scurry/dist/commonjs/index.js +2018 -0
  182. package/node_modules/path-scurry/dist/commonjs/index.js.map +1 -0
  183. package/node_modules/path-scurry/dist/commonjs/package.json +3 -0
  184. package/node_modules/path-scurry/dist/esm/index.d.ts +1115 -0
  185. package/node_modules/path-scurry/dist/esm/index.d.ts.map +1 -0
  186. package/node_modules/path-scurry/dist/esm/index.js +1983 -0
  187. package/node_modules/path-scurry/dist/esm/index.js.map +1 -0
  188. package/node_modules/path-scurry/dist/esm/package.json +3 -0
  189. package/node_modules/path-scurry/node_modules/lru-cache/LICENSE.md +55 -0
  190. package/node_modules/path-scurry/node_modules/lru-cache/README.md +383 -0
  191. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.d.ts +1323 -0
  192. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.d.ts.map +1 -0
  193. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.js +1589 -0
  194. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.js.map +1 -0
  195. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.min.js +2 -0
  196. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.min.js.map +7 -0
  197. package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/package.json +3 -0
  198. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.d.ts +1323 -0
  199. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.d.ts.map +1 -0
  200. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.js +1585 -0
  201. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.js.map +1 -0
  202. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.min.js +2 -0
  203. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.min.js.map +7 -0
  204. package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/package.json +3 -0
  205. package/node_modules/path-scurry/node_modules/lru-cache/package.json +101 -0
  206. package/node_modules/path-scurry/package.json +88 -0
  207. package/node_modules/rimraf/LICENSE.md +55 -0
  208. package/node_modules/rimraf/README.md +226 -0
  209. package/node_modules/rimraf/dist/commonjs/default-tmp.d.ts +3 -0
  210. package/node_modules/rimraf/dist/commonjs/default-tmp.d.ts.map +1 -0
  211. package/node_modules/rimraf/dist/commonjs/default-tmp.js +58 -0
  212. package/node_modules/rimraf/dist/commonjs/default-tmp.js.map +1 -0
  213. package/node_modules/rimraf/dist/commonjs/error.d.ts +6 -0
  214. package/node_modules/rimraf/dist/commonjs/error.d.ts.map +1 -0
  215. package/node_modules/rimraf/dist/commonjs/error.js +10 -0
  216. package/node_modules/rimraf/dist/commonjs/error.js.map +1 -0
  217. package/node_modules/rimraf/dist/commonjs/fix-eperm.d.ts +3 -0
  218. package/node_modules/rimraf/dist/commonjs/fix-eperm.d.ts.map +1 -0
  219. package/node_modules/rimraf/dist/commonjs/fix-eperm.js +38 -0
  220. package/node_modules/rimraf/dist/commonjs/fix-eperm.js.map +1 -0
  221. package/node_modules/rimraf/dist/commonjs/fs.d.ts +15 -0
  222. package/node_modules/rimraf/dist/commonjs/fs.d.ts.map +1 -0
  223. package/node_modules/rimraf/dist/commonjs/fs.js +33 -0
  224. package/node_modules/rimraf/dist/commonjs/fs.js.map +1 -0
  225. package/node_modules/rimraf/dist/commonjs/ignore-enoent.d.ts +3 -0
  226. package/node_modules/rimraf/dist/commonjs/ignore-enoent.d.ts.map +1 -0
  227. package/node_modules/rimraf/dist/commonjs/ignore-enoent.js +24 -0
  228. package/node_modules/rimraf/dist/commonjs/ignore-enoent.js.map +1 -0
  229. package/node_modules/rimraf/dist/commonjs/index.d.ts +50 -0
  230. package/node_modules/rimraf/dist/commonjs/index.d.ts.map +1 -0
  231. package/node_modules/rimraf/dist/commonjs/index.js +78 -0
  232. package/node_modules/rimraf/dist/commonjs/index.js.map +1 -0
  233. package/node_modules/rimraf/dist/commonjs/opt-arg.d.ts +34 -0
  234. package/node_modules/rimraf/dist/commonjs/opt-arg.d.ts.map +1 -0
  235. package/node_modules/rimraf/dist/commonjs/opt-arg.js +53 -0
  236. package/node_modules/rimraf/dist/commonjs/opt-arg.js.map +1 -0
  237. package/node_modules/rimraf/dist/commonjs/package.json +3 -0
  238. package/node_modules/rimraf/dist/commonjs/path-arg.d.ts +4 -0
  239. package/node_modules/rimraf/dist/commonjs/path-arg.d.ts.map +1 -0
  240. package/node_modules/rimraf/dist/commonjs/path-arg.js +48 -0
  241. package/node_modules/rimraf/dist/commonjs/path-arg.js.map +1 -0
  242. package/node_modules/rimraf/dist/commonjs/readdir-or-error.d.ts +3 -0
  243. package/node_modules/rimraf/dist/commonjs/readdir-or-error.d.ts.map +1 -0
  244. package/node_modules/rimraf/dist/commonjs/readdir-or-error.js +19 -0
  245. package/node_modules/rimraf/dist/commonjs/readdir-or-error.js.map +1 -0
  246. package/node_modules/rimraf/dist/commonjs/retry-busy.d.ts +8 -0
  247. package/node_modules/rimraf/dist/commonjs/retry-busy.d.ts.map +1 -0
  248. package/node_modules/rimraf/dist/commonjs/retry-busy.js +65 -0
  249. package/node_modules/rimraf/dist/commonjs/retry-busy.js.map +1 -0
  250. package/node_modules/rimraf/dist/commonjs/rimraf-manual.d.ts +3 -0
  251. package/node_modules/rimraf/dist/commonjs/rimraf-manual.d.ts.map +1 -0
  252. package/node_modules/rimraf/dist/commonjs/rimraf-manual.js +8 -0
  253. package/node_modules/rimraf/dist/commonjs/rimraf-manual.js.map +1 -0
  254. package/node_modules/rimraf/dist/commonjs/rimraf-move-remove.d.ts +4 -0
  255. package/node_modules/rimraf/dist/commonjs/rimraf-move-remove.d.ts.map +1 -0
  256. package/node_modules/rimraf/dist/commonjs/rimraf-move-remove.js +138 -0
  257. package/node_modules/rimraf/dist/commonjs/rimraf-move-remove.js.map +1 -0
  258. package/node_modules/rimraf/dist/commonjs/rimraf-native.d.ts +4 -0
  259. package/node_modules/rimraf/dist/commonjs/rimraf-native.d.ts.map +1 -0
  260. package/node_modules/rimraf/dist/commonjs/rimraf-native.js +24 -0
  261. package/node_modules/rimraf/dist/commonjs/rimraf-native.js.map +1 -0
  262. package/node_modules/rimraf/dist/commonjs/rimraf-posix.d.ts +4 -0
  263. package/node_modules/rimraf/dist/commonjs/rimraf-posix.d.ts.map +1 -0
  264. package/node_modules/rimraf/dist/commonjs/rimraf-posix.js +103 -0
  265. package/node_modules/rimraf/dist/commonjs/rimraf-posix.js.map +1 -0
  266. package/node_modules/rimraf/dist/commonjs/rimraf-windows.d.ts +4 -0
  267. package/node_modules/rimraf/dist/commonjs/rimraf-windows.d.ts.map +1 -0
  268. package/node_modules/rimraf/dist/commonjs/rimraf-windows.js +159 -0
  269. package/node_modules/rimraf/dist/commonjs/rimraf-windows.js.map +1 -0
  270. package/node_modules/rimraf/dist/commonjs/use-native.d.ts +4 -0
  271. package/node_modules/rimraf/dist/commonjs/use-native.d.ts.map +1 -0
  272. package/node_modules/rimraf/dist/commonjs/use-native.js +18 -0
  273. package/node_modules/rimraf/dist/commonjs/use-native.js.map +1 -0
  274. package/node_modules/rimraf/dist/esm/bin.d.mts +3 -0
  275. package/node_modules/rimraf/dist/esm/bin.d.mts.map +1 -0
  276. package/node_modules/rimraf/dist/esm/bin.mjs +250 -0
  277. package/node_modules/rimraf/dist/esm/bin.mjs.map +1 -0
  278. package/node_modules/rimraf/dist/esm/default-tmp.d.ts +3 -0
  279. package/node_modules/rimraf/dist/esm/default-tmp.d.ts.map +1 -0
  280. package/node_modules/rimraf/dist/esm/default-tmp.js +55 -0
  281. package/node_modules/rimraf/dist/esm/default-tmp.js.map +1 -0
  282. package/node_modules/rimraf/dist/esm/error.d.ts +6 -0
  283. package/node_modules/rimraf/dist/esm/error.d.ts.map +1 -0
  284. package/node_modules/rimraf/dist/esm/error.js +5 -0
  285. package/node_modules/rimraf/dist/esm/error.js.map +1 -0
  286. package/node_modules/rimraf/dist/esm/fix-eperm.d.ts +3 -0
  287. package/node_modules/rimraf/dist/esm/fix-eperm.d.ts.map +1 -0
  288. package/node_modules/rimraf/dist/esm/fix-eperm.js +33 -0
  289. package/node_modules/rimraf/dist/esm/fix-eperm.js.map +1 -0
  290. package/node_modules/rimraf/dist/esm/fs.d.ts +15 -0
  291. package/node_modules/rimraf/dist/esm/fs.d.ts.map +1 -0
  292. package/node_modules/rimraf/dist/esm/fs.js +18 -0
  293. package/node_modules/rimraf/dist/esm/fs.js.map +1 -0
  294. package/node_modules/rimraf/dist/esm/ignore-enoent.d.ts +3 -0
  295. package/node_modules/rimraf/dist/esm/ignore-enoent.d.ts.map +1 -0
  296. package/node_modules/rimraf/dist/esm/ignore-enoent.js +19 -0
  297. package/node_modules/rimraf/dist/esm/ignore-enoent.js.map +1 -0
  298. package/node_modules/rimraf/dist/esm/index.d.ts +50 -0
  299. package/node_modules/rimraf/dist/esm/index.d.ts.map +1 -0
  300. package/node_modules/rimraf/dist/esm/index.js +70 -0
  301. package/node_modules/rimraf/dist/esm/index.js.map +1 -0
  302. package/node_modules/rimraf/dist/esm/opt-arg.d.ts +34 -0
  303. package/node_modules/rimraf/dist/esm/opt-arg.d.ts.map +1 -0
  304. package/node_modules/rimraf/dist/esm/opt-arg.js +46 -0
  305. package/node_modules/rimraf/dist/esm/opt-arg.js.map +1 -0
  306. package/node_modules/rimraf/dist/esm/package.json +3 -0
  307. package/node_modules/rimraf/dist/esm/path-arg.d.ts +4 -0
  308. package/node_modules/rimraf/dist/esm/path-arg.d.ts.map +1 -0
  309. package/node_modules/rimraf/dist/esm/path-arg.js +46 -0
  310. package/node_modules/rimraf/dist/esm/path-arg.js.map +1 -0
  311. package/node_modules/rimraf/dist/esm/readdir-or-error.d.ts +3 -0
  312. package/node_modules/rimraf/dist/esm/readdir-or-error.d.ts.map +1 -0
  313. package/node_modules/rimraf/dist/esm/readdir-or-error.js +14 -0
  314. package/node_modules/rimraf/dist/esm/readdir-or-error.js.map +1 -0
  315. package/node_modules/rimraf/dist/esm/retry-busy.d.ts +8 -0
  316. package/node_modules/rimraf/dist/esm/retry-busy.d.ts.map +1 -0
  317. package/node_modules/rimraf/dist/esm/retry-busy.js +60 -0
  318. package/node_modules/rimraf/dist/esm/retry-busy.js.map +1 -0
  319. package/node_modules/rimraf/dist/esm/rimraf-manual.d.ts +3 -0
  320. package/node_modules/rimraf/dist/esm/rimraf-manual.d.ts.map +1 -0
  321. package/node_modules/rimraf/dist/esm/rimraf-manual.js +5 -0
  322. package/node_modules/rimraf/dist/esm/rimraf-manual.js.map +1 -0
  323. package/node_modules/rimraf/dist/esm/rimraf-move-remove.d.ts +4 -0
  324. package/node_modules/rimraf/dist/esm/rimraf-move-remove.d.ts.map +1 -0
  325. package/node_modules/rimraf/dist/esm/rimraf-move-remove.js +133 -0
  326. package/node_modules/rimraf/dist/esm/rimraf-move-remove.js.map +1 -0
  327. package/node_modules/rimraf/dist/esm/rimraf-native.d.ts +4 -0
  328. package/node_modules/rimraf/dist/esm/rimraf-native.d.ts.map +1 -0
  329. package/node_modules/rimraf/dist/esm/rimraf-native.js +19 -0
  330. package/node_modules/rimraf/dist/esm/rimraf-native.js.map +1 -0
  331. package/node_modules/rimraf/dist/esm/rimraf-posix.d.ts +4 -0
  332. package/node_modules/rimraf/dist/esm/rimraf-posix.d.ts.map +1 -0
  333. package/node_modules/rimraf/dist/esm/rimraf-posix.js +98 -0
  334. package/node_modules/rimraf/dist/esm/rimraf-posix.js.map +1 -0
  335. package/node_modules/rimraf/dist/esm/rimraf-windows.d.ts +4 -0
  336. package/node_modules/rimraf/dist/esm/rimraf-windows.d.ts.map +1 -0
  337. package/node_modules/rimraf/dist/esm/rimraf-windows.js +154 -0
  338. package/node_modules/rimraf/dist/esm/rimraf-windows.js.map +1 -0
  339. package/node_modules/rimraf/dist/esm/use-native.d.ts +4 -0
  340. package/node_modules/rimraf/dist/esm/use-native.d.ts.map +1 -0
  341. package/node_modules/rimraf/dist/esm/use-native.js +15 -0
  342. package/node_modules/rimraf/dist/esm/use-native.js.map +1 -0
  343. package/node_modules/rimraf/package.json +92 -0
  344. package/package.json +152 -0
  345. package/scripts/install-scanners.js +258 -0
  346. package/scripts/watchdog.js +147 -0
  347. package/src/analyzers/CSSAnalyzer.js +297 -0
  348. package/src/analyzers/ConfigValidator.js +690 -0
  349. package/src/analyzers/ESLintAnalyzer.js +320 -0
  350. package/src/analyzers/JavaScriptAnalyzer.js +261 -0
  351. package/src/analyzers/PrettierFormatter.js +247 -0
  352. package/src/analyzers/PythonAnalyzer.js +283 -0
  353. package/src/analyzers/SecurityAnalyzer.js +729 -0
  354. package/src/analyzers/SparrowAnalyzer.js +341 -0
  355. package/src/analyzers/TypeScriptAnalyzer.js +247 -0
  356. package/src/analyzers/codeCloneDetector/analyzer.js +344 -0
  357. package/src/analyzers/codeCloneDetector/detector.js +250 -0
  358. package/src/analyzers/codeCloneDetector/index.js +192 -0
  359. package/src/analyzers/codeCloneDetector/parser.js +199 -0
  360. package/src/analyzers/codeCloneDetector/reporter.js +148 -0
  361. package/src/analyzers/codeCloneDetector/scanner.js +88 -0
  362. package/src/core/agentPool.js +1957 -0
  363. package/src/core/agentScheduler.js +3212 -0
  364. package/src/core/contextManager.js +709 -0
  365. package/src/core/flowExecutor.js +928 -0
  366. package/src/core/messageProcessor.js +808 -0
  367. package/src/core/orchestrator.js +584 -0
  368. package/src/core/stateManager.js +1500 -0
  369. package/src/index.js +972 -0
  370. package/src/interfaces/cli.js +553 -0
  371. package/src/interfaces/terminal/__tests__/smoke/advancedFeatures.test.js +208 -0
  372. package/src/interfaces/terminal/__tests__/smoke/agentControl.test.js +236 -0
  373. package/src/interfaces/terminal/__tests__/smoke/agents.test.js +138 -0
  374. package/src/interfaces/terminal/__tests__/smoke/components.test.js +137 -0
  375. package/src/interfaces/terminal/__tests__/smoke/connection.test.js +350 -0
  376. package/src/interfaces/terminal/__tests__/smoke/enhancements.test.js +156 -0
  377. package/src/interfaces/terminal/__tests__/smoke/imports.test.js +332 -0
  378. package/src/interfaces/terminal/__tests__/smoke/messages.test.js +256 -0
  379. package/src/interfaces/terminal/__tests__/smoke/tools.test.js +388 -0
  380. package/src/interfaces/terminal/api/apiClient.js +299 -0
  381. package/src/interfaces/terminal/api/messageRouter.js +262 -0
  382. package/src/interfaces/terminal/api/session.js +266 -0
  383. package/src/interfaces/terminal/api/websocket.js +497 -0
  384. package/src/interfaces/terminal/components/AgentCreator.js +705 -0
  385. package/src/interfaces/terminal/components/AgentEditor.js +678 -0
  386. package/src/interfaces/terminal/components/AgentSwitcher.js +330 -0
  387. package/src/interfaces/terminal/components/ErrorBoundary.js +92 -0
  388. package/src/interfaces/terminal/components/ErrorPanel.js +264 -0
  389. package/src/interfaces/terminal/components/Header.js +28 -0
  390. package/src/interfaces/terminal/components/HelpPanel.js +231 -0
  391. package/src/interfaces/terminal/components/InputBox.js +118 -0
  392. package/src/interfaces/terminal/components/Layout.js +603 -0
  393. package/src/interfaces/terminal/components/LoadingSpinner.js +71 -0
  394. package/src/interfaces/terminal/components/MessageList.js +281 -0
  395. package/src/interfaces/terminal/components/MultilineTextInput.js +251 -0
  396. package/src/interfaces/terminal/components/SearchPanel.js +265 -0
  397. package/src/interfaces/terminal/components/SettingsPanel.js +415 -0
  398. package/src/interfaces/terminal/components/StatusBar.js +65 -0
  399. package/src/interfaces/terminal/components/TextInput.js +127 -0
  400. package/src/interfaces/terminal/config/agentEditorConstants.js +227 -0
  401. package/src/interfaces/terminal/config/constants.js +393 -0
  402. package/src/interfaces/terminal/index.js +168 -0
  403. package/src/interfaces/terminal/state/useAgentControl.js +496 -0
  404. package/src/interfaces/terminal/state/useAgents.js +537 -0
  405. package/src/interfaces/terminal/state/useConnection.js +444 -0
  406. package/src/interfaces/terminal/state/useMessages.js +630 -0
  407. package/src/interfaces/terminal/state/useTools.js +554 -0
  408. package/src/interfaces/terminal/utils/debugLogger.js +44 -0
  409. package/src/interfaces/terminal/utils/settingsStorage.js +232 -0
  410. package/src/interfaces/terminal/utils/theme.js +85 -0
  411. package/src/interfaces/webServer.js +5457 -0
  412. package/src/modules/fileExplorer/controller.js +413 -0
  413. package/src/modules/fileExplorer/index.js +37 -0
  414. package/src/modules/fileExplorer/middleware.js +92 -0
  415. package/src/modules/fileExplorer/routes.js +158 -0
  416. package/src/modules/fileExplorer/types.js +44 -0
  417. package/src/services/agentActivityService.js +399 -0
  418. package/src/services/aiService.js +2618 -0
  419. package/src/services/apiKeyManager.js +334 -0
  420. package/src/services/benchmarkService.js +196 -0
  421. package/src/services/budgetService.js +565 -0
  422. package/src/services/contextInjectionService.js +268 -0
  423. package/src/services/conversationCompactionService.js +1103 -0
  424. package/src/services/credentialVault.js +685 -0
  425. package/src/services/errorHandler.js +810 -0
  426. package/src/services/fileAttachmentService.js +547 -0
  427. package/src/services/flowContextService.js +189 -0
  428. package/src/services/memoryService.js +521 -0
  429. package/src/services/modelRouterService.js +365 -0
  430. package/src/services/modelsService.js +323 -0
  431. package/src/services/ollamaService.js +452 -0
  432. package/src/services/portRegistry.js +336 -0
  433. package/src/services/portTracker.js +223 -0
  434. package/src/services/projectDetector.js +404 -0
  435. package/src/services/promptService.js +372 -0
  436. package/src/services/qualityInspector.js +796 -0
  437. package/src/services/scheduleService.js +725 -0
  438. package/src/services/serviceRegistry.js +386 -0
  439. package/src/services/skillsService.js +486 -0
  440. package/src/services/telegramService.js +920 -0
  441. package/src/services/tokenCountingService.js +316 -0
  442. package/src/services/visualEditorBridge.js +1033 -0
  443. package/src/services/visualEditorServer.js +1727 -0
  444. package/src/services/whatsappService.js +663 -0
  445. package/src/tools/__tests__/webTool.e2e.test.js +569 -0
  446. package/src/tools/__tests__/webTool.unit.test.js +195 -0
  447. package/src/tools/agentCommunicationTool.js +1343 -0
  448. package/src/tools/agentDelayTool.js +498 -0
  449. package/src/tools/asyncToolManager.js +604 -0
  450. package/src/tools/baseTool.js +887 -0
  451. package/src/tools/browserTool.js +897 -0
  452. package/src/tools/cloneDetectionTool.js +581 -0
  453. package/src/tools/codeMapTool.js +857 -0
  454. package/src/tools/dependencyResolverTool.js +1212 -0
  455. package/src/tools/docxTool.js +623 -0
  456. package/src/tools/excelTool.js +636 -0
  457. package/src/tools/fileContentReplaceTool.js +840 -0
  458. package/src/tools/fileTreeTool.js +833 -0
  459. package/src/tools/filesystemTool.js +1217 -0
  460. package/src/tools/helpTool.js +198 -0
  461. package/src/tools/imageTool.js +1034 -0
  462. package/src/tools/importAnalyzerTool.js +1056 -0
  463. package/src/tools/jobDoneTool.js +388 -0
  464. package/src/tools/memoryTool.js +554 -0
  465. package/src/tools/pdfTool.js +627 -0
  466. package/src/tools/seekTool.js +883 -0
  467. package/src/tools/skillsTool.js +276 -0
  468. package/src/tools/staticAnalysisTool.js +2146 -0
  469. package/src/tools/taskManagerTool.js +2836 -0
  470. package/src/tools/terminalTool.js +2486 -0
  471. package/src/tools/userPromptTool.js +474 -0
  472. package/src/tools/videoTool.js +1139 -0
  473. package/src/tools/visionTool.js +507 -0
  474. package/src/tools/visualEditorTool.js +1175 -0
  475. package/src/tools/webTool.js +3114 -0
  476. package/src/tools/whatsappTool.js +457 -0
  477. package/src/types/agent.js +519 -0
  478. package/src/types/contextReference.js +972 -0
  479. package/src/types/conversation.js +730 -0
  480. package/src/types/toolCommand.js +747 -0
  481. package/src/utilities/attachmentValidator.js +288 -0
  482. package/src/utilities/browserStealth.js +630 -0
  483. package/src/utilities/configManager.js +618 -0
  484. package/src/utilities/constants.js +870 -0
  485. package/src/utilities/directoryAccessManager.js +566 -0
  486. package/src/utilities/fileProcessor.js +307 -0
  487. package/src/utilities/humanBehavior.js +453 -0
  488. package/src/utilities/jsonRepair.js +242 -0
  489. package/src/utilities/logger.js +436 -0
  490. package/src/utilities/platformUtils.js +255 -0
  491. package/src/utilities/platformUtils.test.js +98 -0
  492. package/src/utilities/stealthConstants.js +377 -0
  493. package/src/utilities/structuredFileValidator.js +699 -0
  494. package/src/utilities/tagParser.js +878 -0
  495. package/src/utilities/toolConstants.js +415 -0
  496. package/src/utilities/userDataDir.js +300 -0
  497. package/web-ui/build/brands/autopilot/favicon.svg +1 -0
  498. package/web-ui/build/brands/autopilot/logo.webp +0 -0
  499. package/web-ui/build/brands/onbuzz/favicon.svg +1 -0
  500. package/web-ui/build/brands/onbuzz/logo-text.webp +0 -0
  501. package/web-ui/build/brands/onbuzz/logo.webp +0 -0
  502. package/web-ui/build/index.html +15 -0
  503. package/web-ui/build/logo.png +0 -0
  504. package/web-ui/build/logo2.png +0 -0
  505. package/web-ui/build/static/index-SmQFfvBs.js +746 -0
  506. package/web-ui/build/static/index-V2ySwjHp.css +1 -0
@@ -0,0 +1,690 @@
1
+ /**
2
+ * ConfigValidator - Validate configuration files for errors and security issues
3
+ *
4
+ * Validates common configuration files:
5
+ * - package.json, tsconfig.json (JSON Schema)
6
+ * - Dockerfile (hadolint)
7
+ * - docker-compose.yml (yamllint)
8
+ * - Kubernetes YAML (checkov, yamllint)
9
+ * - Terraform (checkov)
10
+ * - .env files (secret detection)
11
+ * - GitHub Actions workflows (yamllint)
12
+ */
13
+
14
+ import { exec } from 'child_process';
15
+ import { promisify } from 'util';
16
+ import path from 'path';
17
+ import fs from 'fs/promises';
18
+ import { STATIC_ANALYSIS } from '../utilities/constants.js';
19
+
20
+ const execAsync = promisify(exec);
21
+
22
+ class ConfigValidator {
23
+ constructor(logger = null) {
24
+ this.logger = logger;
25
+ this.availableScanners = null;
26
+ this.scannerCache = new Map();
27
+ }
28
+
29
+ /**
30
+ * Detect which validation tools are available
31
+ * @returns {Promise<Object>} Available validators
32
+ */
33
+ async detectAvailableValidators() {
34
+ // Return cached result if available
35
+ if (this.availableScanners !== null) {
36
+ return this.availableScanners;
37
+ }
38
+
39
+ const available = {
40
+ checkov: false,
41
+ hadolint: false,
42
+ yamllint: false,
43
+ jsonSchema: false
44
+ };
45
+
46
+ // Check for checkov (Infrastructure as Code scanner)
47
+ try {
48
+ await execAsync('checkov --version', { timeout: 5000 });
49
+ available.checkov = true;
50
+ this.logger?.debug('checkov detected');
51
+ } catch (error) {
52
+ this.logger?.debug('checkov not available', { error: error.message });
53
+ }
54
+
55
+ // Check for hadolint (Dockerfile linter)
56
+ try {
57
+ await execAsync('hadolint --version', { timeout: 5000 });
58
+ available.hadolint = true;
59
+ this.logger?.debug('hadolint detected');
60
+ } catch (error) {
61
+ this.logger?.debug('hadolint not available', { error: error.message });
62
+ }
63
+
64
+ // Check for yamllint (YAML linter)
65
+ try {
66
+ await execAsync('yamllint --version', { timeout: 5000 });
67
+ available.yamllint = true;
68
+ this.logger?.debug('yamllint detected');
69
+ } catch (error) {
70
+ this.logger?.debug('yamllint not available', { error: error.message });
71
+ }
72
+
73
+ // Check for ajv (JSON Schema validation - npm package)
74
+ try {
75
+ await import('ajv');
76
+ available.jsonSchema = true;
77
+ this.logger?.debug('JSON Schema validation available');
78
+ } catch (error) {
79
+ this.logger?.debug('ajv not available', { error: error.message });
80
+ }
81
+
82
+ this.availableScanners = available;
83
+ return available;
84
+ }
85
+
86
+ /**
87
+ * Validate a configuration file
88
+ * @param {string} filePath - Path to config file
89
+ * @param {Object} options - Validation options
90
+ * @returns {Promise<Array>} Validation issues
91
+ */
92
+ async validate(filePath, options = {}) {
93
+ const issues = [];
94
+ const available = await this.detectAvailableValidators();
95
+ const fileType = this.detectFileType(filePath);
96
+
97
+ this.logger?.debug('Validating config file', { filePath, fileType });
98
+
99
+ // Route to appropriate validator based on file type
100
+ switch (fileType) {
101
+ case 'dockerfile':
102
+ if (available.hadolint) {
103
+ const hadolintIssues = await this.validateDockerfile(filePath, options);
104
+ issues.push(...hadolintIssues);
105
+ }
106
+ if (available.checkov) {
107
+ const checkovIssues = await this.validateWithCheckov(filePath, 'dockerfile', options);
108
+ issues.push(...checkovIssues);
109
+ }
110
+ break;
111
+
112
+ case 'docker-compose':
113
+ if (available.yamllint) {
114
+ const yamlIssues = await this.validateYAML(filePath, options);
115
+ issues.push(...yamlIssues);
116
+ }
117
+ if (available.checkov) {
118
+ const checkovIssues = await this.validateWithCheckov(filePath, 'docker_compose', options);
119
+ issues.push(...checkovIssues);
120
+ }
121
+ break;
122
+
123
+ case 'kubernetes':
124
+ if (available.yamllint) {
125
+ const yamlIssues = await this.validateYAML(filePath, options);
126
+ issues.push(...yamlIssues);
127
+ }
128
+ if (available.checkov) {
129
+ const checkovIssues = await this.validateWithCheckov(filePath, 'kubernetes', options);
130
+ issues.push(...checkovIssues);
131
+ }
132
+ break;
133
+
134
+ case 'terraform':
135
+ if (available.checkov) {
136
+ const checkovIssues = await this.validateWithCheckov(filePath, 'terraform', options);
137
+ issues.push(...checkovIssues);
138
+ }
139
+ break;
140
+
141
+ case 'package.json':
142
+ if (available.jsonSchema) {
143
+ const schemaIssues = await this.validatePackageJson(filePath, options);
144
+ issues.push(...schemaIssues);
145
+ }
146
+ break;
147
+
148
+ case 'tsconfig.json':
149
+ if (available.jsonSchema) {
150
+ const schemaIssues = await this.validateTsConfig(filePath, options);
151
+ issues.push(...schemaIssues);
152
+ }
153
+ break;
154
+
155
+ case 'github-actions':
156
+ if (available.yamllint) {
157
+ const yamlIssues = await this.validateYAML(filePath, options);
158
+ issues.push(...yamlIssues);
159
+ }
160
+ break;
161
+
162
+ case 'env':
163
+ // Always check .env files for secrets (no external tool needed)
164
+ const secretIssues = await this.validateEnvFile(filePath, options);
165
+ issues.push(...secretIssues);
166
+ break;
167
+
168
+ case 'yaml':
169
+ if (available.yamllint) {
170
+ const yamlIssues = await this.validateYAML(filePath, options);
171
+ issues.push(...yamlIssues);
172
+ }
173
+ break;
174
+
175
+ default:
176
+ this.logger?.warn('Unknown config file type', { filePath, fileType });
177
+ return [];
178
+ }
179
+
180
+ return this.normalizeResults(issues);
181
+ }
182
+
183
+ /**
184
+ * Validate Dockerfile using hadolint
185
+ * @private
186
+ */
187
+ async validateDockerfile(filePath, options = {}) {
188
+ try {
189
+ const result = await execAsync(
190
+ `hadolint --format json "${filePath}"`,
191
+ {
192
+ maxBuffer: 10 * 1024 * 1024,
193
+ timeout: 30000
194
+ }
195
+ );
196
+
197
+ const output = JSON.parse(result.stdout);
198
+ return this.parseHadolintResults(output, filePath);
199
+ } catch (error) {
200
+ // hadolint exits with non-zero if issues found
201
+ if (error.stdout) {
202
+ try {
203
+ const output = JSON.parse(error.stdout);
204
+ return this.parseHadolintResults(output, filePath);
205
+ } catch (parseError) {
206
+ this.logger?.error('Failed to parse hadolint output', {
207
+ error: parseError.message
208
+ });
209
+ }
210
+ }
211
+ this.logger?.error('hadolint validation failed', { error: error.message });
212
+ return [];
213
+ }
214
+ }
215
+
216
+ /**
217
+ * Parse hadolint results
218
+ * @private
219
+ */
220
+ parseHadolintResults(output, filePath) {
221
+ const issues = [];
222
+
223
+ if (Array.isArray(output)) {
224
+ for (const issue of output) {
225
+ issues.push({
226
+ file: filePath,
227
+ line: issue.line || 1,
228
+ column: issue.column || 1,
229
+ severity: this.mapHadolintSeverity(issue.level),
230
+ rule: issue.code,
231
+ message: issue.message,
232
+ category: 'dockerfile',
233
+ validator: 'hadolint'
234
+ });
235
+ }
236
+ }
237
+
238
+ return issues;
239
+ }
240
+
241
+ /**
242
+ * Validate YAML files using yamllint
243
+ * @private
244
+ */
245
+ async validateYAML(filePath, options = {}) {
246
+ try {
247
+ const result = await execAsync(
248
+ `yamllint -f parsable "${filePath}"`,
249
+ {
250
+ maxBuffer: 10 * 1024 * 1024,
251
+ timeout: 30000
252
+ }
253
+ );
254
+
255
+ return this.parseYamllintResults(result.stdout, filePath);
256
+ } catch (error) {
257
+ // yamllint exits with non-zero if issues found
258
+ if (error.stdout) {
259
+ return this.parseYamllintResults(error.stdout, filePath);
260
+ }
261
+ this.logger?.error('yamllint validation failed', { error: error.message });
262
+ return [];
263
+ }
264
+ }
265
+
266
+ /**
267
+ * Parse yamllint results
268
+ * @private
269
+ */
270
+ parseYamllintResults(output, filePath) {
271
+ const issues = [];
272
+ const lines = output.split('\n').filter(line => line.trim());
273
+
274
+ for (const line of lines) {
275
+ // Format: file:line:column: [level] message (rule)
276
+ const match = line.match(/^(.+?):(\d+):(\d+):\s*\[(\w+)\]\s*(.+?)\s*\((.+?)\)/);
277
+ if (match) {
278
+ const [, file, lineNum, col, level, message, rule] = match;
279
+ issues.push({
280
+ file: filePath,
281
+ line: parseInt(lineNum, 10),
282
+ column: parseInt(col, 10),
283
+ severity: this.mapYamllintSeverity(level),
284
+ rule: rule,
285
+ message: message,
286
+ category: 'yaml',
287
+ validator: 'yamllint'
288
+ });
289
+ }
290
+ }
291
+
292
+ return issues;
293
+ }
294
+
295
+ /**
296
+ * Validate with checkov (Infrastructure as Code)
297
+ * @private
298
+ */
299
+ async validateWithCheckov(filePath, framework, options = {}) {
300
+ try {
301
+ const result = await execAsync(
302
+ `checkov -f "${filePath}" --framework ${framework} --output json --compact`,
303
+ {
304
+ maxBuffer: 10 * 1024 * 1024,
305
+ timeout: 60000
306
+ }
307
+ );
308
+
309
+ const output = JSON.parse(result.stdout);
310
+ return this.parseCheckovResults(output, filePath);
311
+ } catch (error) {
312
+ // checkov exits with non-zero if issues found
313
+ if (error.stdout) {
314
+ try {
315
+ const output = JSON.parse(error.stdout);
316
+ return this.parseCheckovResults(output, filePath);
317
+ } catch (parseError) {
318
+ this.logger?.error('Failed to parse checkov output', {
319
+ error: parseError.message
320
+ });
321
+ }
322
+ }
323
+ this.logger?.error('checkov validation failed', { error: error.message });
324
+ return [];
325
+ }
326
+ }
327
+
328
+ /**
329
+ * Parse checkov results
330
+ * @private
331
+ */
332
+ parseCheckovResults(output, filePath) {
333
+ const issues = [];
334
+
335
+ if (output.results && output.results.failed_checks) {
336
+ for (const check of output.results.failed_checks) {
337
+ issues.push({
338
+ file: filePath,
339
+ line: check.file_line_range ? check.file_line_range[0] : 1,
340
+ column: 1,
341
+ severity: this.mapCheckovSeverity(check.check_class),
342
+ rule: check.check_id,
343
+ message: check.check_name || check.check_id,
344
+ category: 'security',
345
+ validator: 'checkov',
346
+ remediation: check.guideline,
347
+ cwe: check.cwe,
348
+ references: check.guideline ? [check.guideline] : []
349
+ });
350
+ }
351
+ }
352
+
353
+ return issues;
354
+ }
355
+
356
+ /**
357
+ * Validate package.json using JSON Schema
358
+ * @private
359
+ */
360
+ async validatePackageJson(filePath, options = {}) {
361
+ try {
362
+ const Ajv = (await import('ajv')).default;
363
+ const addFormats = (await import('ajv-formats')).default;
364
+
365
+ const content = await fs.readFile(filePath, 'utf-8');
366
+ const packageJson = JSON.parse(content);
367
+
368
+ const ajv = new Ajv({ allErrors: true, strict: false });
369
+ addFormats(ajv);
370
+
371
+ // Basic package.json schema (simplified)
372
+ const schema = {
373
+ type: 'object',
374
+ required: ['name', 'version'],
375
+ properties: {
376
+ name: { type: 'string', pattern: '^(?:@[a-z0-9-~][a-z0-9-._~]*/)?[a-z0-9-~][a-z0-9-._~]*$' },
377
+ version: { type: 'string' },
378
+ description: { type: 'string' },
379
+ main: { type: 'string' },
380
+ type: { type: 'string', enum: ['module', 'commonjs'] },
381
+ scripts: { type: 'object' },
382
+ dependencies: { type: 'object' },
383
+ devDependencies: { type: 'object' }
384
+ },
385
+ additionalProperties: true
386
+ };
387
+
388
+ const validate = ajv.compile(schema);
389
+ const valid = validate(packageJson);
390
+
391
+ if (!valid && validate.errors) {
392
+ return validate.errors.map(error => ({
393
+ file: filePath,
394
+ line: 1,
395
+ column: 1,
396
+ severity: STATIC_ANALYSIS.SEVERITY.ERROR,
397
+ rule: 'json-schema',
398
+ message: error.instancePath ? `${error.instancePath} ${error.message}` : `must have required property '${error.params.missingProperty}'`,
399
+ category: 'validation',
400
+ validator: 'json-schema'
401
+ }));
402
+ }
403
+
404
+ return [];
405
+ } catch (error) {
406
+ this.logger?.error('package.json validation failed', { error: error.message });
407
+ return [{
408
+ file: filePath,
409
+ line: 1,
410
+ column: 1,
411
+ severity: STATIC_ANALYSIS.SEVERITY.ERROR,
412
+ rule: 'json-parse',
413
+ message: `Invalid JSON: ${error.message}`,
414
+ category: 'syntax',
415
+ validator: 'json-parse'
416
+ }];
417
+ }
418
+ }
419
+
420
+ /**
421
+ * Validate tsconfig.json using JSON Schema
422
+ * @private
423
+ */
424
+ async validateTsConfig(filePath, options = {}) {
425
+ try {
426
+ const content = await fs.readFile(filePath, 'utf-8');
427
+ const tsconfig = JSON.parse(content);
428
+
429
+ const issues = [];
430
+
431
+ // Check for common misconfigurations
432
+ if (tsconfig.compilerOptions) {
433
+ const opts = tsconfig.compilerOptions;
434
+
435
+ // Check for strict mode
436
+ if (!opts.strict) {
437
+ issues.push({
438
+ file: filePath,
439
+ line: 1,
440
+ column: 1,
441
+ severity: STATIC_ANALYSIS.SEVERITY.WARNING,
442
+ rule: 'strict-mode',
443
+ message: 'Consider enabling "strict" mode for better type safety',
444
+ category: 'best-practice',
445
+ validator: 'tsconfig-validator'
446
+ });
447
+ }
448
+
449
+ // Check for noImplicitAny
450
+ if (opts.noImplicitAny === false) {
451
+ issues.push({
452
+ file: filePath,
453
+ line: 1,
454
+ column: 1,
455
+ severity: STATIC_ANALYSIS.SEVERITY.WARNING,
456
+ rule: 'no-implicit-any',
457
+ message: 'Disabling noImplicitAny reduces type safety',
458
+ category: 'best-practice',
459
+ validator: 'tsconfig-validator'
460
+ });
461
+ }
462
+ }
463
+
464
+ return issues;
465
+ } catch (error) {
466
+ this.logger?.error('tsconfig.json validation failed', { error: error.message });
467
+ return [{
468
+ file: filePath,
469
+ line: 1,
470
+ column: 1,
471
+ severity: STATIC_ANALYSIS.SEVERITY.ERROR,
472
+ rule: 'json-parse',
473
+ message: `Invalid JSON: ${error.message}`,
474
+ category: 'syntax',
475
+ validator: 'json-parse'
476
+ }];
477
+ }
478
+ }
479
+
480
+ /**
481
+ * Validate .env file for security issues
482
+ * @private
483
+ */
484
+ async validateEnvFile(filePath, options = {}) {
485
+ try {
486
+ const content = await fs.readFile(filePath, 'utf-8');
487
+ const issues = [];
488
+ const lines = content.split('\n');
489
+
490
+ const secretPatterns = [
491
+ { pattern: /password|passwd|pwd/i, name: 'password' },
492
+ { pattern: /api[_-]?key/i, name: 'API key' },
493
+ { pattern: /secret/i, name: 'secret' },
494
+ { pattern: /token/i, name: 'token' },
495
+ { pattern: /private[_-]?key/i, name: 'private key' },
496
+ { pattern: /aws[_-]?access/i, name: 'AWS credentials' }
497
+ ];
498
+
499
+ lines.forEach((line, index) => {
500
+ const trimmed = line.trim();
501
+
502
+ // Skip comments and empty lines
503
+ if (!trimmed || trimmed.startsWith('#')) return;
504
+
505
+ // Check for hardcoded values (not references to other env vars)
506
+ if (trimmed.includes('=')) {
507
+ const [key, value] = trimmed.split('=');
508
+ const keyLower = key.toLowerCase();
509
+ const valueTrimmed = value?.trim() || '';
510
+
511
+ // Check if value looks like a real secret (not empty, not a placeholder)
512
+ const looksLikeSecret = valueTrimmed &&
513
+ valueTrimmed !== '' &&
514
+ !valueTrimmed.startsWith('$') && // Not env var reference
515
+ valueTrimmed !== 'your-key-here' &&
516
+ valueTrimmed !== 'changeme' &&
517
+ valueTrimmed.length > 5;
518
+
519
+ if (looksLikeSecret) {
520
+ for (const { pattern, name } of secretPatterns) {
521
+ if (pattern.test(keyLower)) {
522
+ issues.push({
523
+ file: filePath,
524
+ line: index + 1,
525
+ column: 1,
526
+ severity: STATIC_ANALYSIS.SEVERITY.CRITICAL,
527
+ rule: 'hardcoded-secret',
528
+ message: `Potential hardcoded ${name} detected in .env file`,
529
+ category: 'security',
530
+ validator: 'env-validator',
531
+ remediation: 'Use environment-specific .env files and add .env to .gitignore'
532
+ });
533
+ break;
534
+ }
535
+ }
536
+ }
537
+ }
538
+ });
539
+
540
+ return issues;
541
+ } catch (error) {
542
+ this.logger?.error('.env validation failed', { error: error.message });
543
+ return [];
544
+ }
545
+ }
546
+
547
+ /**
548
+ * Detect configuration file type
549
+ * @private
550
+ */
551
+ detectFileType(filePath) {
552
+ const basename = path.basename(filePath).toLowerCase();
553
+ const dirname = path.dirname(filePath);
554
+
555
+ // Exact filename matches
556
+ if (basename === 'dockerfile') return 'dockerfile';
557
+ if (basename === 'docker-compose.yml' || basename === 'docker-compose.yaml') return 'docker-compose';
558
+ if (basename === 'package.json') return 'package.json';
559
+ if (basename === 'tsconfig.json') return 'tsconfig.json';
560
+ if (basename === '.env' || basename.endsWith('.env')) return 'env';
561
+
562
+ // Path-based detection
563
+ if (dirname.includes('.github/workflows')) return 'github-actions';
564
+ if (dirname.includes('kubernetes') || dirname.includes('k8s')) return 'kubernetes';
565
+
566
+ // Extension-based detection
567
+ const ext = path.extname(filePath).toLowerCase();
568
+ if (ext === '.tf' || ext === '.tfvars') return 'terraform';
569
+ if (ext === '.yml' || ext === '.yaml') return 'yaml';
570
+ if (ext === '.json') return 'json';
571
+
572
+ return 'unknown';
573
+ }
574
+
575
+ /**
576
+ * Normalize all validator results to common format
577
+ * @private
578
+ */
579
+ normalizeResults(results) {
580
+ return results.map(result => ({
581
+ file: result.file,
582
+ line: result.line || 1,
583
+ column: result.column || 1,
584
+ severity: result.severity || STATIC_ANALYSIS.SEVERITY.WARNING,
585
+ rule: result.rule || 'unknown',
586
+ message: result.message || 'Validation issue detected',
587
+ category: result.category || 'validation',
588
+ validator: result.validator,
589
+ cwe: result.cwe || null,
590
+ remediation: result.remediation || null,
591
+ references: result.references || []
592
+ }));
593
+ }
594
+
595
+ /**
596
+ * Map hadolint severity to our standard
597
+ * @private
598
+ */
599
+ mapHadolintSeverity(level) {
600
+ const map = {
601
+ 'error': STATIC_ANALYSIS.SEVERITY.ERROR,
602
+ 'warning': STATIC_ANALYSIS.SEVERITY.WARNING,
603
+ 'info': STATIC_ANALYSIS.SEVERITY.INFO,
604
+ 'style': STATIC_ANALYSIS.SEVERITY.INFO
605
+ };
606
+ return map[level?.toLowerCase()] || STATIC_ANALYSIS.SEVERITY.WARNING;
607
+ }
608
+
609
+ /**
610
+ * Map yamllint severity to our standard
611
+ * @private
612
+ */
613
+ mapYamllintSeverity(level) {
614
+ const map = {
615
+ 'error': STATIC_ANALYSIS.SEVERITY.ERROR,
616
+ 'warning': STATIC_ANALYSIS.SEVERITY.WARNING
617
+ };
618
+ return map[level?.toLowerCase()] || STATIC_ANALYSIS.SEVERITY.WARNING;
619
+ }
620
+
621
+ /**
622
+ * Map checkov severity to our standard
623
+ * @private
624
+ */
625
+ mapCheckovSeverity(checkClass) {
626
+ // checkov uses check_class to categorize severity
627
+ // Most security issues are treated as errors
628
+ return STATIC_ANALYSIS.SEVERITY.ERROR;
629
+ }
630
+
631
+ /**
632
+ * Get validator status report
633
+ * @returns {Promise<Object>} Validator availability and status
634
+ */
635
+ async getValidatorStatus() {
636
+ const available = await this.detectAvailableValidators();
637
+ return {
638
+ validators: available,
639
+ recommendations: this.getInstallRecommendations(available)
640
+ };
641
+ }
642
+
643
+ /**
644
+ * Get installation recommendations for missing validators
645
+ * @private
646
+ */
647
+ getInstallRecommendations(available) {
648
+ const recommendations = [];
649
+
650
+ if (!available.checkov) {
651
+ recommendations.push({
652
+ validator: 'checkov',
653
+ reason: 'Infrastructure as Code security scanning (Docker, Kubernetes, Terraform)',
654
+ install: 'pip install checkov',
655
+ priority: 'high'
656
+ });
657
+ }
658
+
659
+ if (!available.hadolint) {
660
+ recommendations.push({
661
+ validator: 'hadolint',
662
+ reason: 'Dockerfile linting and best practices',
663
+ install: 'Download from https://github.com/hadolint/hadolint/releases',
664
+ priority: 'high'
665
+ });
666
+ }
667
+
668
+ if (!available.yamllint) {
669
+ recommendations.push({
670
+ validator: 'yamllint',
671
+ reason: 'YAML file validation',
672
+ install: 'pip install yamllint',
673
+ priority: 'medium'
674
+ });
675
+ }
676
+
677
+ if (!available.jsonSchema) {
678
+ recommendations.push({
679
+ validator: 'ajv (JSON Schema)',
680
+ reason: 'JSON configuration validation',
681
+ install: 'npm install ajv ajv-formats',
682
+ priority: 'medium'
683
+ });
684
+ }
685
+
686
+ return recommendations;
687
+ }
688
+ }
689
+
690
+ export default ConfigValidator;