@tyvm/knowhow 0.0.90 → 0.0.91

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 (262) hide show
  1. package/.depcheckrc +31 -0
  2. package/bin/knowhow.js +1 -1
  3. package/package.json +4 -32
  4. package/src/agents/tools/executeScript/index.ts +5 -0
  5. package/src/agents/tools/googleSearch.ts +2 -2
  6. package/src/agents/tools/index.ts +0 -3
  7. package/src/agents/tools/list.ts +0 -147
  8. package/src/agents/tools/loadWebpage.ts +3 -113
  9. package/src/auth/browserLogin.ts +10 -13
  10. package/src/cli.ts +63 -3
  11. package/src/clients/gemini.ts +96 -25
  12. package/src/clients/http.ts +7 -11
  13. package/src/clients/pricing/google.ts +122 -26
  14. package/src/conversion.ts +24 -54
  15. package/src/index.ts +8 -1
  16. package/src/login.ts +5 -6
  17. package/src/plugins/language.ts +0 -4
  18. package/src/plugins/plugins.ts +0 -14
  19. package/src/plugins/url.ts +31 -12
  20. package/src/services/GitHub.ts +2 -2
  21. package/src/services/KnowhowClient.ts +34 -34
  22. package/src/{plugins/downloader/downloader.ts → services/MediaProcessorService.ts} +109 -267
  23. package/src/services/S3.ts +16 -16
  24. package/src/services/index.ts +4 -4
  25. package/src/services/modules/index.ts +10 -2
  26. package/src/services/modules/types.ts +5 -2
  27. package/src/services/script-execution/ScriptExecutor.ts +29 -10
  28. package/src/services/script-execution/ScriptPolicy.ts +6 -2
  29. package/src/types.ts +1 -0
  30. package/src/utils/http.ts +127 -0
  31. package/src/workers/auth/PasskeySetup.ts +7 -11
  32. package/tests/clients/AIClient.test.ts +24 -21
  33. package/tests/manual/file-edits/figma.test.ts +3 -70
  34. package/tests/plugins/language/languagePlugin-content-triggers.test.ts +2 -0
  35. package/tests/plugins/language/languagePlugin.test.ts +2 -0
  36. package/tests/processors/ToolResponseCache.test.ts +2 -2
  37. package/tests/test.spec.ts +0 -14
  38. package/tests/unit/modules/moduleLoading.test.ts +7 -4
  39. package/tests/unit/plugins/pluginLoading.test.ts +6 -6
  40. package/ts_build/package.json +4 -32
  41. package/ts_build/src/agents/tools/ast/astAppendNode.d.ts +1 -1
  42. package/ts_build/src/agents/tools/ast/astAppendNode.js +2 -90
  43. package/ts_build/src/agents/tools/ast/astAppendNode.js.map +1 -1
  44. package/ts_build/src/agents/tools/ast/astDeleteNode.d.ts +1 -1
  45. package/ts_build/src/agents/tools/ast/astDeleteNode.js +2 -88
  46. package/ts_build/src/agents/tools/ast/astDeleteNode.js.map +1 -1
  47. package/ts_build/src/agents/tools/ast/astEditNode.d.ts +1 -1
  48. package/ts_build/src/agents/tools/ast/astEditNode.js +2 -90
  49. package/ts_build/src/agents/tools/ast/astEditNode.js.map +1 -1
  50. package/ts_build/src/agents/tools/ast/astGetPathForLine.d.ts +1 -1
  51. package/ts_build/src/agents/tools/ast/astGetPathForLine.js +2 -72
  52. package/ts_build/src/agents/tools/ast/astGetPathForLine.js.map +1 -1
  53. package/ts_build/src/agents/tools/ast/astListPaths.d.ts +1 -1
  54. package/ts_build/src/agents/tools/ast/astListPaths.js +2 -72
  55. package/ts_build/src/agents/tools/ast/astListPaths.js.map +1 -1
  56. package/ts_build/src/agents/tools/executeScript/index.d.ts +3 -2
  57. package/ts_build/src/agents/tools/executeScript/index.js +4 -1
  58. package/ts_build/src/agents/tools/executeScript/index.js.map +1 -1
  59. package/ts_build/src/agents/tools/googleSearch.js +2 -2
  60. package/ts_build/src/agents/tools/googleSearch.js.map +1 -1
  61. package/ts_build/src/agents/tools/index.d.ts +0 -3
  62. package/ts_build/src/agents/tools/index.js +0 -3
  63. package/ts_build/src/agents/tools/index.js.map +1 -1
  64. package/ts_build/src/agents/tools/list.js +0 -138
  65. package/ts_build/src/agents/tools/list.js.map +1 -1
  66. package/ts_build/src/agents/tools/loadWebpage.js +1 -89
  67. package/ts_build/src/agents/tools/loadWebpage.js.map +1 -1
  68. package/ts_build/src/agents/tools/textSearch.d.ts +1 -1
  69. package/ts_build/src/auth/browserLogin.js +7 -7
  70. package/ts_build/src/auth/browserLogin.js.map +1 -1
  71. package/ts_build/src/cli.d.ts +1 -1
  72. package/ts_build/src/cli.js +47 -1
  73. package/ts_build/src/cli.js.map +1 -1
  74. package/ts_build/src/clients/gemini.d.ts +1 -73
  75. package/ts_build/src/clients/gemini.js +57 -19
  76. package/ts_build/src/clients/gemini.js.map +1 -1
  77. package/ts_build/src/clients/http.js +5 -9
  78. package/ts_build/src/clients/http.js.map +1 -1
  79. package/ts_build/src/clients/pricing/google.d.ts +17 -73
  80. package/ts_build/src/clients/pricing/google.js +47 -10
  81. package/ts_build/src/clients/pricing/google.js.map +1 -1
  82. package/ts_build/src/conversion.d.ts +1 -4
  83. package/ts_build/src/conversion.js +12 -27
  84. package/ts_build/src/conversion.js.map +1 -1
  85. package/ts_build/src/index.d.ts +4 -0
  86. package/ts_build/src/index.js +7 -1
  87. package/ts_build/src/index.js.map +1 -1
  88. package/ts_build/src/login.js +5 -4
  89. package/ts_build/src/login.js.map +1 -1
  90. package/ts_build/src/plugins/downloader/downloader.js +3 -3
  91. package/ts_build/src/plugins/downloader/downloader.js.map +1 -1
  92. package/ts_build/src/plugins/language.js.map +1 -1
  93. package/ts_build/src/plugins/plugins.js +0 -14
  94. package/ts_build/src/plugins/plugins.js.map +1 -1
  95. package/ts_build/src/plugins/tree-sitter/editor.d.ts +3 -32
  96. package/ts_build/src/plugins/tree-sitter/editor.js +6 -208
  97. package/ts_build/src/plugins/tree-sitter/editor.js.map +1 -1
  98. package/ts_build/src/plugins/tree-sitter/parser.d.ts +19 -54
  99. package/ts_build/src/plugins/tree-sitter/parser.js +19 -293
  100. package/ts_build/src/plugins/tree-sitter/parser.js.map +1 -1
  101. package/ts_build/src/plugins/tree-sitter/simple-paths.d.ts +2 -15
  102. package/ts_build/src/plugins/tree-sitter/simple-paths.js +2 -324
  103. package/ts_build/src/plugins/tree-sitter/simple-paths.js.map +1 -1
  104. package/ts_build/src/plugins/url.js +27 -8
  105. package/ts_build/src/plugins/url.js.map +1 -1
  106. package/ts_build/src/services/GitHub.js +2 -2
  107. package/ts_build/src/services/GitHub.js.map +1 -1
  108. package/ts_build/src/services/KnowhowClient.d.ts +29 -29
  109. package/ts_build/src/services/KnowhowClient.js +33 -33
  110. package/ts_build/src/services/KnowhowClient.js.map +1 -1
  111. package/ts_build/src/services/MediaProcessorService.d.ts +22 -0
  112. package/ts_build/src/services/MediaProcessorService.js +215 -0
  113. package/ts_build/src/services/MediaProcessorService.js.map +1 -0
  114. package/ts_build/src/services/S3.js +12 -18
  115. package/ts_build/src/services/S3.js.map +1 -1
  116. package/ts_build/src/services/index.d.ts +3 -2
  117. package/ts_build/src/services/index.js +3 -3
  118. package/ts_build/src/services/index.js.map +1 -1
  119. package/ts_build/src/services/modules/index.js +10 -2
  120. package/ts_build/src/services/modules/index.js.map +1 -1
  121. package/ts_build/src/services/modules/types.d.ts +5 -2
  122. package/ts_build/src/services/script-execution/ScriptExecutor.js +22 -7
  123. package/ts_build/src/services/script-execution/ScriptExecutor.js.map +1 -1
  124. package/ts_build/src/services/script-execution/ScriptPolicy.d.ts +1 -1
  125. package/ts_build/src/services/script-execution/ScriptPolicy.js +4 -2
  126. package/ts_build/src/services/script-execution/ScriptPolicy.js.map +1 -1
  127. package/ts_build/src/types.d.ts +1 -0
  128. package/ts_build/src/types.js +1 -0
  129. package/ts_build/src/types.js.map +1 -1
  130. package/ts_build/src/utils/http.d.ts +27 -0
  131. package/ts_build/src/utils/http.js +98 -0
  132. package/ts_build/src/utils/http.js.map +1 -0
  133. package/ts_build/src/workers/auth/PasskeySetup.js +6 -7
  134. package/ts_build/src/workers/auth/PasskeySetup.js.map +1 -1
  135. package/ts_build/tests/clients/AIClient.test.js +11 -14
  136. package/ts_build/tests/clients/AIClient.test.js.map +1 -1
  137. package/ts_build/tests/manual/file-edits/figma.test.d.ts +0 -1
  138. package/ts_build/tests/manual/file-edits/figma.test.js +1 -46
  139. package/ts_build/tests/manual/file-edits/figma.test.js.map +1 -1
  140. package/ts_build/tests/plugins/language/languagePlugin-content-triggers.test.js +2 -0
  141. package/ts_build/tests/plugins/language/languagePlugin-content-triggers.test.js.map +1 -1
  142. package/ts_build/tests/plugins/language/languagePlugin.test.js +2 -0
  143. package/ts_build/tests/plugins/language/languagePlugin.test.js.map +1 -1
  144. package/ts_build/tests/processors/ToolResponseCache.test.js +2 -2
  145. package/ts_build/tests/processors/ToolResponseCache.test.js.map +1 -1
  146. package/ts_build/tests/test.spec.js +0 -14
  147. package/ts_build/tests/test.spec.js.map +1 -1
  148. package/ts_build/tests/tree-sitter/tree-sitter.test.d.ts +0 -1
  149. package/ts_build/tests/tree-sitter/tree-sitter.test.js +2 -183
  150. package/ts_build/tests/tree-sitter/tree-sitter.test.js.map +1 -1
  151. package/ts_build/tests/unit/modules/moduleLoading.test.js +6 -4
  152. package/ts_build/tests/unit/modules/moduleLoading.test.js.map +1 -1
  153. package/ts_build/tests/unit/plugins/pluginLoading.test.js +4 -4
  154. package/ts_build/tests/unit/plugins/pluginLoading.test.js.map +1 -1
  155. package/benchmarks/.dockerignore +0 -7
  156. package/benchmarks/README.md +0 -166
  157. package/benchmarks/docker/Dockerfile +0 -68
  158. package/benchmarks/example-config.yml +0 -27
  159. package/benchmarks/jest.config.js +0 -13
  160. package/benchmarks/package-lock.json +0 -4297
  161. package/benchmarks/package.json +0 -39
  162. package/benchmarks/results/27b0a06/2025-09-27/xai/xai-grok-code-fast-1.json +0 -2909
  163. package/benchmarks/results/4057aed/2025-08-14/anthropic/anthropic-claude-sonnet-4-20250514.json +0 -1671
  164. package/benchmarks/results/4542435/2025-08-05/lms/lms-openai-gpt-oss-20b.json +0 -2814
  165. package/benchmarks/results/4542435/2025-08-05/lms/lms-qwen-qwen3-30b-a3b-2507.json +0 -2014
  166. package/benchmarks/results/4fb9125/2025-08-07/anthropic/anthropic-claude-sonnet-4-20250514.json +0 -3121
  167. package/benchmarks/results/5766aee/2025-08-02/lms-qwen/qwen3-coder-30b.json +0 -98
  168. package/benchmarks/results/6d73808/2025-08-07/openai/openai-gpt-5.json +0 -3256
  169. package/benchmarks/results/77bf0a6/2025-08-02/lms-qwen/qwen3-30b-a3b-2507.json +0 -4298
  170. package/benchmarks/results/8c0d445/2025-08-03/anthropic/anthropic-claude-sonnet-4-20250514.json +0 -3031
  171. package/benchmarks/results/8c0d445/2025-08-03/openai/openai-gpt-4.1-2025-04-14.json +0 -2990
  172. package/benchmarks/results/ac6b2ab/2025-08-03/anthropic/anthropic-claude-sonnet-4-20250514.json +0 -3256
  173. package/benchmarks/results/ac6b2ab/2025-08-03/lms/lms-qwen-qwen3-coder-30b.json +0 -3007
  174. package/benchmarks/results/ac6b2ab/2025-08-03/openai/openai-gpt-4.1-2025-04-14.json +0 -3256
  175. package/benchmarks/results/ac6b2ab/2025-08-03/openai/openai-gpt-4.1-mini-2025-04-14.json +0 -3036
  176. package/benchmarks/results/ac6b2ab/2025-08-03/openai/openai-gpt-4.1-nano-2025-04-14.json +0 -3280
  177. package/benchmarks/results/adff675/2025-08-04/lms/lms-qwen-qwen3-30b-a3b-2507.json +0 -1920
  178. package/benchmarks/results/adff675/2025-08-04/lms/lms-qwen-qwen3-coder-30b.json +0 -3281
  179. package/benchmarks/results/b502ed9/2025-08-03/lms-qwen/qwen3-coder-30b.json +0 -2896
  180. package/benchmarks/results/d1a8129/2025-08-03/lms/lms-qwen-qwen3-coder-30b.json +0 -3011
  181. package/benchmarks/results/e60471c/2025-08-03/lms/qwen3-30b-a3b-2507.json +0 -3003
  182. package/benchmarks/scripts/build-and-run.sh +0 -47
  183. package/benchmarks/scripts/clone-exercism.sh +0 -92
  184. package/benchmarks/scripts/validate.sh +0 -48
  185. package/benchmarks/src/__tests__/runner.test.ts +0 -27
  186. package/benchmarks/src/cli.ts +0 -90
  187. package/benchmarks/src/evaluators/EvaluatorRegistry.ts +0 -64
  188. package/benchmarks/src/evaluators/JavaScriptEvaluator.ts +0 -183
  189. package/benchmarks/src/evaluators/index.ts +0 -3
  190. package/benchmarks/src/evaluators/types.ts +0 -22
  191. package/benchmarks/src/index.ts +0 -3
  192. package/benchmarks/src/providers.ts +0 -13
  193. package/benchmarks/src/runner.ts +0 -824
  194. package/benchmarks/src/types.ts +0 -63
  195. package/benchmarks/tsconfig.json +0 -19
  196. package/leaderboard/README.md +0 -148
  197. package/leaderboard/app/api/benchmark-data/route.ts +0 -131
  198. package/leaderboard/app/api/benchmark-detail/route.ts +0 -172
  199. package/leaderboard/app/details/[model]/[provider]/[language]/page.tsx +0 -501
  200. package/leaderboard/app/exercise/[model]/[provider]/[language]/[exercise]/page.tsx +0 -375
  201. package/leaderboard/app/globals.css +0 -27
  202. package/leaderboard/app/layout.tsx +0 -21
  203. package/leaderboard/app/page.tsx +0 -170
  204. package/leaderboard/components/LeaderboardTable.tsx +0 -168
  205. package/leaderboard/components/PerformanceChart.tsx +0 -109
  206. package/leaderboard/next-env.d.ts +0 -5
  207. package/leaderboard/next.config.js +0 -4
  208. package/leaderboard/package-lock.json +0 -6363
  209. package/leaderboard/package.json +0 -28
  210. package/leaderboard/postcss.config.js +0 -6
  211. package/leaderboard/tailwind.config.js +0 -17
  212. package/leaderboard/tsconfig.json +0 -28
  213. package/leaderboard/types/benchmark.ts +0 -67
  214. package/leaderboard/utils/dataProcessor.ts +0 -33
  215. package/src/agents/tools/asana/definitions.ts +0 -199
  216. package/src/agents/tools/asana/index.ts +0 -108
  217. package/src/agents/tools/ast/astAppendNode.ts +0 -90
  218. package/src/agents/tools/ast/astDeleteNode.ts +0 -88
  219. package/src/agents/tools/ast/astEditNode.ts +0 -95
  220. package/src/agents/tools/ast/astGetPathForLine.ts +0 -73
  221. package/src/agents/tools/ast/astListPaths.ts +0 -66
  222. package/src/agents/tools/ast/index.ts +0 -7
  223. package/src/agents/tools/github/definitions.ts +0 -89
  224. package/src/agents/tools/github/index.ts +0 -67
  225. package/src/chat-old.ts +0 -446
  226. package/src/plugins/asana.ts +0 -146
  227. package/src/plugins/downloader/plugin.ts +0 -103
  228. package/src/plugins/downloader/types.ts +0 -92
  229. package/src/plugins/figma.ts +0 -158
  230. package/src/plugins/github.ts +0 -219
  231. package/src/plugins/jira.ts +0 -115
  232. package/src/plugins/linear.ts +0 -230
  233. package/src/plugins/notion.ts +0 -179
  234. package/src/plugins/tree-sitter/editor.ts +0 -369
  235. package/src/plugins/tree-sitter/lang-packs/index.ts +0 -23
  236. package/src/plugins/tree-sitter/lang-packs/java.ts +0 -59
  237. package/src/plugins/tree-sitter/lang-packs/javascript.ts +0 -57
  238. package/src/plugins/tree-sitter/lang-packs/python.ts +0 -45
  239. package/src/plugins/tree-sitter/lang-packs/types.ts +0 -79
  240. package/src/plugins/tree-sitter/lang-packs/typescript.ts +0 -49
  241. package/src/plugins/tree-sitter/parser.ts +0 -470
  242. package/src/plugins/tree-sitter/simple-paths.ts +0 -467
  243. package/tests/tree-sitter/editor.test.ts +0 -113
  244. package/tests/tree-sitter/invalid.test.ts +0 -299
  245. package/tests/tree-sitter/paths/common-edits.test.ts +0 -564
  246. package/tests/tree-sitter/paths/debug-exact-position.test.ts +0 -44
  247. package/tests/tree-sitter/paths/debug-line-indexing.test.ts +0 -49
  248. package/tests/tree-sitter/paths/debug-paths.test.ts +0 -90
  249. package/tests/tree-sitter/paths/paths.test.ts +0 -170
  250. package/tests/tree-sitter/paths/simple-paths.test.ts +0 -367
  251. package/tests/tree-sitter/sample-after.ts +0 -48
  252. package/tests/tree-sitter/sample-before.ts +0 -25
  253. package/tests/tree-sitter/test-files/completely-broken.ts +0 -7
  254. package/tests/tree-sitter/test-files/duplicate-braces.ts +0 -39
  255. package/tests/tree-sitter/test-files/invalid-nesting.ts +0 -39
  256. package/tests/tree-sitter/test-files/malformed-signature.ts +0 -39
  257. package/tests/tree-sitter/test-files/mismatched-parens.ts +0 -39
  258. package/tests/tree-sitter/test-files/missing-semicolon.ts +0 -39
  259. package/tests/tree-sitter/test-files/partially-broken.ts +0 -20
  260. package/tests/tree-sitter/test-files/specific-errors.ts +0 -14
  261. package/tests/tree-sitter/test-files/unclosed-string.ts +0 -39
  262. package/tests/tree-sitter/tree-sitter.test.ts +0 -251
@@ -1,28 +0,0 @@
1
- {
2
- "name": "leaderboard",
3
- "version": "0.1.0",
4
- "private": true,
5
- "scripts": {
6
- "dev": "next dev -p 3333",
7
- "build": "next build",
8
- "start": "next start",
9
- "lint": "next lint"
10
- },
11
- "dependencies": {
12
- "next": "^14.2.31",
13
- "react": "^18",
14
- "react-dom": "^18",
15
- "recharts": "^2.8.0"
16
- },
17
- "devDependencies": {
18
- "@types/node": "^20",
19
- "@types/react": "^18",
20
- "@types/react-dom": "^18",
21
- "autoprefixer": "^10.0.1",
22
- "eslint": "^8",
23
- "eslint-config-next": "14.0.0",
24
- "postcss": "^8",
25
- "tailwindcss": "^3.3.0",
26
- "typescript": "^5"
27
- }
28
- }
@@ -1,6 +0,0 @@
1
- module.exports = {
2
- plugins: {
3
- tailwindcss: {},
4
- autoprefixer: {},
5
- },
6
- }
@@ -1,17 +0,0 @@
1
- /** @type {import('tailwindcss').Config} */
2
- module.exports = {
3
- content: [
4
- './pages/**/*.{js,ts,jsx,tsx,mdx}',
5
- './components/**/*.{js,ts,jsx,tsx,mdx}',
6
- './app/**/*.{js,ts,jsx,tsx,mdx}',
7
- ],
8
- theme: {
9
- extend: {
10
- colors: {
11
- background: 'var(--background)',
12
- foreground: 'var(--foreground)',
13
- },
14
- },
15
- },
16
- plugins: [],
17
- }
@@ -1,28 +0,0 @@
1
- {
2
- "compilerOptions": {
3
- "target": "es5",
4
- "lib": ["dom", "dom.iterable", "es6"],
5
- "allowJs": true,
6
- "skipLibCheck": true,
7
- "strict": true,
8
- "noEmit": true,
9
- "esModuleInterop": true,
10
- "module": "esnext",
11
- "moduleResolution": "bundler",
12
- "resolveJsonModule": true,
13
- "isolatedModules": true,
14
- "jsx": "preserve",
15
- "incremental": true,
16
- "plugins": [
17
- {
18
- "name": "next"
19
- }
20
- ],
21
- "baseUrl": ".",
22
- "paths": {
23
- "@/*": ["./*"]
24
- }
25
- },
26
- "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"],
27
- "exclude": ["node_modules"]
28
- }
@@ -1,67 +0,0 @@
1
- export interface BenchmarkConfig {
2
- language: string;
3
- maxExercises: number;
4
- model: string;
5
- provider: string;
6
- agent?: string;
7
- limits: BenchmarkLimits;
8
- outputFile: string;
9
- }
10
-
11
- export interface BenchmarkLimits {
12
- maxTurns: number;
13
- maxTime: number;
14
- maxCost: number;
15
- }
16
-
17
- export interface ExerciseResult {
18
- exerciseName: string;
19
- status: 'success' | 'failure' | 'timeout' | 'cost_limit' | 'turn_limit';
20
- testResult?: any;
21
- turns: number;
22
- timeElapsed: number;
23
- cost: number;
24
- startTime: string;
25
- endTime: string;
26
- errorMessage?: string;
27
- finalOutput?: string;
28
- }
29
-
30
- export interface BenchmarkResults {
31
- config: BenchmarkConfig;
32
- commitHash?: string;
33
- exercises: ExerciseResult[];
34
- summary: {
35
- totalExercises: number;
36
- testableExercises?: number;
37
- testsPassedCount?: number;
38
- testsFailedCount?: number;
39
- testPassRate?: number;
40
- agentSuccessRate?: number;
41
- successCount: number;
42
- failureCount: number;
43
- timeoutCount: number;
44
- costLimitCount: number;
45
- turnLimitCount: number;
46
- totalTime: number;
47
- totalCost: number;
48
- averageTurns: number;
49
- averageTime: number;
50
- successRate: number;
51
- };
52
- startTime: string;
53
- endTime: string;
54
- }
55
-
56
- export interface LeaderboardEntry {
57
- model: string;
58
- provider: string;
59
- language: string;
60
- successRate: number;
61
- totalExercises: number;
62
- averageCost: number;
63
- averageTime: number;
64
- averageTurns: number;
65
- totalRuns: number;
66
- lastRun: string;
67
- }
@@ -1,33 +0,0 @@
1
- import { LeaderboardEntry } from '@/types/benchmark';
2
-
3
- export async function loadLeaderboardData(): Promise<LeaderboardEntry[]> {
4
- try {
5
- const response = await fetch('/api/benchmark-data');
6
- const data = await response.json();
7
- return data;
8
- } catch (error) {
9
- console.error('Error loading benchmark results:', error);
10
- return [];
11
- }
12
- }
13
-
14
- export function formatPercentage(value: number): string {
15
- return `${value.toFixed(1)}%`;
16
- }
17
-
18
- export function formatCurrency(value: number): string {
19
- return `$${value.toFixed(3)}`;
20
- }
21
-
22
- export function formatTime(seconds: number): string {
23
- if (seconds < 60) {
24
- return `${seconds.toFixed(1)}s`;
25
- }
26
- const minutes = Math.floor(seconds / 60);
27
- const remainingSeconds = seconds % 60;
28
- return `${minutes}m ${remainingSeconds.toFixed(1)}s`;
29
- }
30
-
31
- export function formatNumber(value: number): string {
32
- return value.toFixed(1);
33
- }
@@ -1,199 +0,0 @@
1
- export const definitions = [
2
- {
3
- type: "function",
4
- function: {
5
- name: "createTask",
6
- description: "Create a new task in Asana",
7
- parameters: {
8
- type: "object",
9
- positional: true,
10
- properties: {
11
- projectId: {
12
- type: "string",
13
- description: "The ID of the project where the task will be created",
14
- },
15
- taskName: {
16
- type: "string",
17
- description: "The name of the task to be created",
18
- },
19
- taskNotes: {
20
- type: "string",
21
- description: "The notes or description of the task",
22
- },
23
- },
24
- required: ["projectId", "taskName", "taskNotes"],
25
- },
26
- returns: {
27
- type: "object",
28
- description: "The created task object",
29
- },
30
- },
31
- },
32
- {
33
- type: "function",
34
- function: {
35
- name: "updateTask",
36
- description: "Update an existing task in Asana",
37
- parameters: {
38
- type: "object",
39
- positional: true,
40
- properties: {
41
- taskId: {
42
- type: "string",
43
- description: "The ID of the task to be updated",
44
- },
45
- updates: {
46
- type: "object",
47
- description:
48
- "An object containing the updates to be applied to the task",
49
- },
50
- },
51
- required: ["taskId", "updates"],
52
- },
53
- returns: {
54
- type: "object",
55
- description: "The updated task object",
56
- },
57
- },
58
- },
59
- {
60
- type: "function",
61
- function: {
62
- name: "searchTasks",
63
- description: "Search for tasks in Asana based on a search term",
64
- parameters: {
65
- type: "object",
66
- positional: true,
67
- properties: {
68
- searchTerm: {
69
- type: "string",
70
- description: "The term to search for in task names and notes",
71
- },
72
- },
73
- required: ["searchTerm"],
74
- },
75
- returns: {
76
- type: "array",
77
- description: "An array of tasks that match the search term",
78
- },
79
- },
80
- },
81
- {
82
- type: "function",
83
- function: {
84
- name: "listProjects",
85
- description: "List all projects in Asana",
86
- parameters: {
87
- type: "object",
88
- positional: true,
89
- properties: {},
90
- required: [],
91
- },
92
- returns: {
93
- type: "array",
94
- description: "An array of project objects",
95
- },
96
- },
97
- },
98
-
99
- {
100
- type: "function",
101
- function: {
102
- name: "findTask",
103
- description: "Find a specific task in Asana by its ID",
104
- parameters: {
105
- type: "object",
106
- positional: true,
107
- properties: {
108
- taskId: {
109
- type: "string",
110
- description: "The ID of the task to be found",
111
- },
112
- },
113
- required: ["taskId"],
114
- },
115
- returns: {
116
- type: "object",
117
- description: "The task object that matches the given ID",
118
- },
119
- },
120
- },
121
- {
122
- type: "function",
123
- function: {
124
- name: "myTasks",
125
- description:
126
- "Retrieve tasks assigned to the current user in Asana, only shows the uncompleted ones",
127
- parameters: {
128
- type: "object",
129
- positional: true,
130
- properties: {
131
- project: {
132
- type: "string",
133
- description: "The ID of the project to filter tasks by (optional)",
134
- },
135
- },
136
- required: [],
137
- },
138
- returns: {
139
- type: "array",
140
- description: "An array of tasks assigned to the current user",
141
- },
142
- },
143
- },
144
- {
145
- type: "function",
146
- function: {
147
- name: "getSubtasks",
148
- description: "Retrieve all subtasks for a given Asana task.",
149
- parameters: {
150
- type: "object",
151
- positional: true,
152
- properties: {
153
- taskId: {
154
- type: "string",
155
- description:
156
- "The ID of the parent task for which to retrieve subtasks.",
157
- },
158
- },
159
- required: ["taskId"],
160
- },
161
- returns: {
162
- type: "array",
163
- description:
164
- "An array of subtasks associated with the specified parent task.",
165
- },
166
- },
167
- },
168
- {
169
- type: "function",
170
- function: {
171
- name: "createSubtask",
172
- description: "Create a new subtask under a given Asana task.",
173
- parameters: {
174
- type: "object",
175
- positional: true,
176
- properties: {
177
- taskId: {
178
- type: "string",
179
- description:
180
- "The ID of the parent task under which the subtask will be created.",
181
- },
182
- taskName: {
183
- type: "string",
184
- description: "The name of the subtask to be created.",
185
- },
186
- taskNotes: {
187
- type: "string",
188
- description: "The optional notes or description of the subtask.",
189
- },
190
- },
191
- required: ["taskId", "taskName"],
192
- },
193
- returns: {
194
- type: "object",
195
- description: "The created subtask object.",
196
- },
197
- },
198
- },
199
- ];
@@ -1,108 +0,0 @@
1
- const workspace = process.env.ASANA_WORKSPACE;
2
- class AsanaTools {
3
- private client = require("asana").ApiClient.instance;
4
-
5
- constructor(private accessToken: string) {
6
- this.client.authentications.token = process.env.ASANA_TOKEN;
7
- this.client.defaultHeaders = {
8
- "Asana-Enable": "new_user_task_lists,new_goal_memberships",
9
- };
10
- }
11
-
12
- async createTask(projectId: string, taskName: string, taskNotes: string) {
13
- if (!workspace) {
14
- throw new Error("Need to set ENV Variable ASANA Workspace");
15
- }
16
-
17
- const task = await this.client.tasks.create({
18
- workspace,
19
- projects: [projectId],
20
- name: taskName,
21
- notes: taskNotes,
22
- });
23
- console.log(`Task created: ${task.permalink_url}`);
24
- return task;
25
- }
26
-
27
- async updateTask(taskId: string, updates: object) {
28
- const task = await this.client.tasks.updateTask(taskId, updates);
29
- console.log(`Task updated: ${task.permalink_url}`);
30
- return task;
31
- }
32
-
33
- async searchTasks(searchTerm: string) {
34
- if (!workspace) {
35
- throw new Error("Need to set ENV Variable ASANA Workspace");
36
- }
37
- searchTerm = searchTerm.toLowerCase();
38
- const allTasks = await this.client.tasks.findAll({
39
- opt_expand: "notes",
40
- workspace,
41
- });
42
- const found = allTasks.data.filter(
43
- (t) =>
44
- t.notes.toLowerCase().includes(searchTerm) ||
45
- t.name.toLowerCase().includes(searchTerm)
46
- );
47
-
48
- console.log("Found", found.length, "tasks");
49
- return found;
50
- }
51
-
52
- async findTask(taskId: string) {
53
- const task = await this.client.tasks.findById(taskId);
54
- console.log(`Task found: ${task.permalink_url}`);
55
- return task;
56
- }
57
-
58
- async getSubtasks(taskId: string) {
59
- const tasks = await this.client.tasks.subtasks(taskId);
60
- return tasks.data;
61
- }
62
-
63
- async createSubtask(taskId: string, taskName: string, taskNotes = "") {
64
- const task = await this.client.tasks.addSubtask(taskId, {
65
- name: taskName,
66
- notes: taskNotes,
67
- });
68
- return task;
69
- }
70
-
71
- async myTasks(project?: string) {
72
- const me = await this.client.users.me();
73
- const tasks = await this.client.tasks.findAll({
74
- assignee: Number(me.gid),
75
- project,
76
- workspace,
77
- opt_expand: "completed",
78
- });
79
- return tasks.data.filter((t) => !t.completed);
80
- }
81
-
82
- async listProjects() {
83
- if (!workspace) {
84
- throw new Error("Need to set ENV Variable ASANA Workspace");
85
- }
86
- const allData = [];
87
- let projects = await this.client.projects.findAll({
88
- workspace,
89
- archived: false,
90
- });
91
- do {
92
- allData.push(...projects.data);
93
- projects = await projects.nextPage();
94
- } while (projects && projects?.data?.length);
95
-
96
- return allData;
97
- }
98
- }
99
-
100
- const asana = new AsanaTools(process.env.ASANA_TOKEN);
101
- export const createTask = asana.createTask.bind(asana);
102
- export const updateTask = asana.updateTask.bind(asana);
103
- export const searchTasks = asana.searchTasks.bind(asana);
104
- export const findTask = asana.findTask.bind(asana);
105
- export const getSubtasks = asana.getSubtasks.bind(asana);
106
- export const createSubtask = asana.createSubtask.bind(asana);
107
- export const myTasks = asana.myTasks.bind(asana);
108
- export const listProjects = asana.listProjects.bind(asana);
@@ -1,90 +0,0 @@
1
- import * as fs from "fs";
2
- import { fileExists } from "../../../utils";
3
- import { services, ToolsService } from "../../../services";
4
- import { LanguageAgnosticParser } from "../../../plugins/tree-sitter/parser";
5
- import { TreeEditor } from "../../../plugins/tree-sitter/editor";
6
-
7
- /**
8
- * Append a child node to a specific path in a file using tree-sitter AST parsing
9
- */
10
- export async function astAppendNode(filePath: string, parentPath: string, newContent: string): Promise<string> {
11
- // Get context from bound ToolsService
12
- const toolService = (
13
- this instanceof ToolsService ? this : services().Tools
14
- ) as ToolsService;
15
-
16
- const context = toolService.getContext();
17
-
18
- const exists = await fileExists(filePath);
19
- if (!exists) {
20
- throw new Error(`File not found: ${filePath}`);
21
- }
22
-
23
- // Read original content for event emission
24
- let originalContent = "";
25
- try {
26
- originalContent = fs.readFileSync(filePath, "utf8");
27
- } catch (error) {
28
- throw new Error(`Failed to read file ${filePath}: ${error.message}`);
29
- }
30
-
31
- // Emit pre-edit blocking event
32
- if (context.Events) {
33
- await context.Events.emitBlocking("file:pre-edit", {
34
- filePath,
35
- operation: "ast-append-node",
36
- content: newContent,
37
- originalContent,
38
- astParentPath: parentPath,
39
- });
40
- }
41
-
42
- try {
43
- if (!LanguageAgnosticParser.supportsFile(filePath)) {
44
- throw new Error(`Unsupported file type for AST parsing: ${filePath}`);
45
- }
46
-
47
- const parser = LanguageAgnosticParser.createParserForFile(filePath);
48
- const editor = new TreeEditor(parser, originalContent);
49
- const updatedEditor = editor.appendChild(parentPath, newContent);
50
- const updatedContent = updatedEditor.getCurrentText();
51
-
52
- // Write the updated content back to the file
53
- fs.writeFileSync(filePath, updatedContent, "utf8");
54
-
55
- // Emit post-edit blocking event (only on success)
56
- let eventResults: any[] = [];
57
- if (context.Events) {
58
- eventResults = await context.Events.emitBlocking("file:post-edit", {
59
- filePath,
60
- operation: "ast-append-node",
61
- content: newContent,
62
- originalContent,
63
- updatedContent,
64
- astParentPath: parentPath,
65
- success: true,
66
- });
67
- }
68
-
69
- const result = {
70
- file: filePath,
71
- parentPath,
72
- action: "appendChild",
73
- success: true,
74
- message: `Successfully appended child node to path: ${parentPath}`,
75
- };
76
-
77
- // Format event results
78
- let eventResultsText = "";
79
- if (eventResults && eventResults.length > 0) {
80
- eventResultsText =
81
- "\n\nAdditional Information:\n" +
82
- JSON.stringify(eventResults, null, 2);
83
- }
84
-
85
- return JSON.stringify(result, null, 2) + eventResultsText;
86
- } catch (error: any) {
87
- // Do NOT emit post-edit event on error
88
- throw new Error(`Failed to append node in ${filePath}: ${error.message}`);
89
- }
90
- }
@@ -1,88 +0,0 @@
1
- import * as fs from "fs";
2
- import { fileExists } from "../../../utils";
3
- import { services, ToolsService } from "../../../services";
4
- import { LanguageAgnosticParser } from "../../../plugins/tree-sitter/parser";
5
- import { TreeEditor } from "../../../plugins/tree-sitter/editor";
6
-
7
- /**
8
- * Delete a node at a specific path in a file using tree-sitter AST parsing
9
- */
10
- export async function astDeleteNode(filePath: string, path: string): Promise<string> {
11
- // Get context from bound ToolsService
12
- const toolService = (
13
- this instanceof ToolsService ? this : services().Tools
14
- ) as ToolsService;
15
-
16
- const context = toolService.getContext();
17
-
18
- const exists = await fileExists(filePath);
19
- if (!exists) {
20
- throw new Error(`File not found: ${filePath}`);
21
- }
22
-
23
- // Read original content for event emission
24
- let originalContent = "";
25
- try {
26
- originalContent = fs.readFileSync(filePath, "utf8");
27
- } catch (error) {
28
- throw new Error(`Failed to read file ${filePath}: ${error.message}`);
29
- }
30
-
31
- // Emit pre-edit blocking event
32
- if (context.Events) {
33
- await context.Events.emitBlocking("file:pre-edit", {
34
- filePath,
35
- operation: "ast-delete-node",
36
- originalContent,
37
- astPath: path,
38
- });
39
- }
40
-
41
- try {
42
- if (!LanguageAgnosticParser.supportsFile(filePath)) {
43
- throw new Error(`Unsupported file type for AST parsing: ${filePath}`);
44
- }
45
-
46
- const parser = LanguageAgnosticParser.createParserForFile(filePath);
47
- const editor = new TreeEditor(parser, originalContent);
48
- const updatedEditor = editor.deleteNodeByPath(path);
49
- const updatedContent = updatedEditor.getCurrentText();
50
-
51
- // Write the updated content back to the file
52
- fs.writeFileSync(filePath, updatedContent, "utf8");
53
-
54
- // Emit post-edit blocking event (only on success)
55
- let eventResults: any[] = [];
56
- if (context.Events) {
57
- eventResults = await context.Events.emitBlocking("file:post-edit", {
58
- filePath,
59
- operation: "ast-delete-node",
60
- originalContent,
61
- updatedContent,
62
- astPath: path,
63
- success: true,
64
- });
65
- }
66
-
67
- const result = {
68
- file: filePath,
69
- path,
70
- action: "delete",
71
- success: true,
72
- message: `Successfully deleted node at path: ${path}`,
73
- };
74
-
75
- // Format event results
76
- let eventResultsText = "";
77
- if (eventResults && eventResults.length > 0) {
78
- eventResultsText =
79
- "\n\nAdditional Information:\n" +
80
- JSON.stringify(eventResults, null, 2);
81
- }
82
-
83
- return JSON.stringify(result, null, 2) + eventResultsText;
84
- } catch (error: any) {
85
- // Do NOT emit post-edit event on error
86
- throw new Error(`Failed to delete node in ${filePath}: ${error.message}`);
87
- }
88
- }