cli-jaw 0.1.6 → 0.1.8

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 (746) hide show
  1. package/README.ko.md +68 -71
  2. package/README.md +123 -92
  3. package/README.zh-CN.md +68 -73
  4. package/dist/bin/cli-claw.js +96 -0
  5. package/dist/bin/cli-claw.js.map +1 -0
  6. package/dist/bin/cli-jaw.js +0 -0
  7. package/dist/bin/commands/doctor.js +3 -0
  8. package/dist/bin/commands/doctor.js.map +1 -1
  9. package/dist/bin/commands/init.js +36 -19
  10. package/dist/bin/commands/init.js.map +1 -1
  11. package/dist/bin/postinstall.js +175 -104
  12. package/dist/bin/postinstall.js.map +1 -1
  13. package/dist/lib/mcp-sync.js +43 -4
  14. package/dist/lib/mcp-sync.js.map +1 -1
  15. package/dist/server.js +22 -103
  16. package/dist/server.js.map +1 -1
  17. package/dist/src/cli/acp-client.js +1 -1
  18. package/dist/src/cli/command-context.js +73 -0
  19. package/dist/src/cli/command-context.js.map +1 -0
  20. package/dist/src/core/db.js +1 -1
  21. package/dist/src/memory/heartbeat.js +2 -1
  22. package/dist/src/memory/heartbeat.js.map +1 -1
  23. package/dist/src/orchestrator/collect.js +53 -0
  24. package/dist/src/orchestrator/collect.js.map +1 -0
  25. package/dist/src/orchestrator/gateway.js +49 -0
  26. package/dist/src/orchestrator/gateway.js.map +1 -0
  27. package/dist/src/telegram/bot.js +32 -119
  28. package/dist/src/telegram/bot.js.map +1 -1
  29. package/package.json +7 -7
  30. package/public/css/sidebar.css +14 -0
  31. package/public/dist/bundle.js +21 -21
  32. package/public/dist/bundle.js.map +3 -3
  33. package/public/index.html +2 -2
  34. package/public/js/features/settings.js +1 -2
  35. package/public/js/main.js +0 -1
  36. package/scripts/check-copilot-gap.js +57 -0
  37. package/scripts/check-deps-offline.mjs +75 -0
  38. package/scripts/check-deps-online.sh +26 -0
  39. package/scripts/i18n-registry.py +208 -0
  40. package/scripts/postinstall-guard.cjs +63 -0
  41. package/scripts/release.sh +30 -0
  42. package/skills_ref/1password/SKILL.md +0 -70
  43. package/skills_ref/agents-sdk/SKILL.md +0 -155
  44. package/skills_ref/agents-sdk/references/callable.md +0 -92
  45. package/skills_ref/agents-sdk/references/codemode.md +0 -207
  46. package/skills_ref/agents-sdk/references/email.md +0 -146
  47. package/skills_ref/agents-sdk/references/mcp.md +0 -154
  48. package/skills_ref/agents-sdk/references/state-scheduling.md +0 -164
  49. package/skills_ref/agents-sdk/references/streaming-chat.md +0 -178
  50. package/skills_ref/agents-sdk/references/workflows.md +0 -132
  51. package/skills_ref/algorithmic-art/LICENSE.txt +0 -202
  52. package/skills_ref/algorithmic-art/SKILL.md +0 -405
  53. package/skills_ref/algorithmic-art/templates/generator_template.js +0 -223
  54. package/skills_ref/algorithmic-art/templates/viewer.html +0 -599
  55. package/skills_ref/apple-notes/SKILL.md +0 -77
  56. package/skills_ref/apple-reminders/SKILL.md +0 -118
  57. package/skills_ref/atlas/SKILL.md +0 -99
  58. package/skills_ref/brainstorming/SKILL.md +0 -96
  59. package/skills_ref/browser/SKILL.md +0 -179
  60. package/skills_ref/canvas-design/LICENSE.txt +0 -202
  61. package/skills_ref/canvas-design/SKILL.md +0 -130
  62. package/skills_ref/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +0 -93
  63. package/skills_ref/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  64. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  65. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-OFL.txt +0 -93
  66. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  67. package/skills_ref/canvas-design/canvas-fonts/Boldonse-OFL.txt +0 -93
  68. package/skills_ref/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  69. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  70. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +0 -93
  71. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  72. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  73. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  74. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +0 -93
  75. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  76. package/skills_ref/canvas-design/canvas-fonts/DMMono-OFL.txt +0 -93
  77. package/skills_ref/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  78. package/skills_ref/canvas-design/canvas-fonts/EricaOne-OFL.txt +0 -94
  79. package/skills_ref/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  80. package/skills_ref/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  81. package/skills_ref/canvas-design/canvas-fonts/GeistMono-OFL.txt +0 -93
  82. package/skills_ref/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  83. package/skills_ref/canvas-design/canvas-fonts/Gloock-OFL.txt +0 -93
  84. package/skills_ref/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  85. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  86. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +0 -93
  87. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  88. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  89. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  90. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  91. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  92. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  93. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  94. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  95. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +0 -93
  96. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  97. package/skills_ref/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  98. package/skills_ref/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  99. package/skills_ref/canvas-design/canvas-fonts/Italiana-OFL.txt +0 -93
  100. package/skills_ref/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  101. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  102. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +0 -93
  103. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  104. package/skills_ref/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  105. package/skills_ref/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  106. package/skills_ref/canvas-design/canvas-fonts/Jura-OFL.txt +0 -93
  107. package/skills_ref/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +0 -93
  108. package/skills_ref/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  109. package/skills_ref/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  110. package/skills_ref/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  111. package/skills_ref/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  112. package/skills_ref/canvas-design/canvas-fonts/Lora-OFL.txt +0 -93
  113. package/skills_ref/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  114. package/skills_ref/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  115. package/skills_ref/canvas-design/canvas-fonts/NationalPark-OFL.txt +0 -93
  116. package/skills_ref/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  117. package/skills_ref/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +0 -93
  118. package/skills_ref/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  119. package/skills_ref/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  120. package/skills_ref/canvas-design/canvas-fonts/Outfit-OFL.txt +0 -93
  121. package/skills_ref/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  122. package/skills_ref/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  123. package/skills_ref/canvas-design/canvas-fonts/PixelifySans-OFL.txt +0 -93
  124. package/skills_ref/canvas-design/canvas-fonts/PoiretOne-OFL.txt +0 -93
  125. package/skills_ref/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  126. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  127. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-OFL.txt +0 -93
  128. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  129. package/skills_ref/canvas-design/canvas-fonts/Silkscreen-OFL.txt +0 -93
  130. package/skills_ref/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  131. package/skills_ref/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  132. package/skills_ref/canvas-design/canvas-fonts/SmoochSans-OFL.txt +0 -93
  133. package/skills_ref/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  134. package/skills_ref/canvas-design/canvas-fonts/Tektur-OFL.txt +0 -93
  135. package/skills_ref/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  136. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  137. package/skills_ref/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  138. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  139. package/skills_ref/canvas-design/canvas-fonts/WorkSans-OFL.txt +0 -93
  140. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  141. package/skills_ref/canvas-design/canvas-fonts/YoungSerif-OFL.txt +0 -93
  142. package/skills_ref/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  143. package/skills_ref/changelog-generator/SKILL.md +0 -104
  144. package/skills_ref/cloudflare-deploy/SKILL.md +0 -207
  145. package/skills_ref/codebase-orientation/SKILL.md +0 -29
  146. package/skills_ref/config-file-explainer/SKILL.md +0 -26
  147. package/skills_ref/context-compression/SKILL.md +0 -265
  148. package/skills_ref/context-compression/references/evaluation-framework.md +0 -213
  149. package/skills_ref/context-compression/scripts/compression_evaluator.py +0 -658
  150. package/skills_ref/data-structure-chooser/SKILL.md +0 -26
  151. package/skills_ref/debugging-checklist/SKILL.md +0 -26
  152. package/skills_ref/debugging-helpers/CREATION-LOG.md +0 -119
  153. package/skills_ref/debugging-helpers/SKILL.md +0 -296
  154. package/skills_ref/debugging-helpers/condition-based-waiting-example.ts +0 -158
  155. package/skills_ref/debugging-helpers/condition-based-waiting.md +0 -115
  156. package/skills_ref/debugging-helpers/defense-in-depth.md +0 -122
  157. package/skills_ref/debugging-helpers/find-polluter.sh +0 -63
  158. package/skills_ref/debugging-helpers/root-cause-tracing.md +0 -169
  159. package/skills_ref/debugging-helpers/test-academic.md +0 -14
  160. package/skills_ref/debugging-helpers/test-pressure-1.md +0 -58
  161. package/skills_ref/debugging-helpers/test-pressure-2.md +0 -68
  162. package/skills_ref/debugging-helpers/test-pressure-3.md +0 -69
  163. package/skills_ref/deep-research/.env.example +0 -7
  164. package/skills_ref/deep-research/README.md +0 -246
  165. package/skills_ref/deep-research/SKILL.md +0 -106
  166. package/skills_ref/deep-research/requirements.txt +0 -2
  167. package/skills_ref/deep-research/scripts/research.py +0 -692
  168. package/skills_ref/dependency-install-helper/SKILL.md +0 -26
  169. package/skills_ref/dev/SKILL.md +0 -65
  170. package/skills_ref/dev-backend/SKILL.md +0 -61
  171. package/skills_ref/dev-data/SKILL.md +0 -76
  172. package/skills_ref/dev-frontend/LICENSE.txt +0 -177
  173. package/skills_ref/dev-frontend/SKILL.md +0 -42
  174. package/skills_ref/dev-testing/LICENSE.txt +0 -202
  175. package/skills_ref/dev-testing/SKILL.md +0 -96
  176. package/skills_ref/dev-testing/examples/console_logging.py +0 -35
  177. package/skills_ref/dev-testing/examples/element_discovery.py +0 -40
  178. package/skills_ref/dev-testing/examples/static_html_automation.py +0 -33
  179. package/skills_ref/dev-testing/scripts/with_server.py +0 -106
  180. package/skills_ref/develop-web-game/SKILL.md +0 -149
  181. package/skills_ref/differential-review/.claude-plugin/plugin.json +0 -10
  182. package/skills_ref/differential-review/README.md +0 -109
  183. package/skills_ref/differential-review/commands/diff-review.md +0 -21
  184. package/skills_ref/differential-review/skills/differential-review/SKILL.md +0 -220
  185. package/skills_ref/differential-review/skills/differential-review/adversarial.md +0 -203
  186. package/skills_ref/differential-review/skills/differential-review/methodology.md +0 -234
  187. package/skills_ref/differential-review/skills/differential-review/patterns.md +0 -300
  188. package/skills_ref/differential-review/skills/differential-review/reporting.md +0 -369
  189. package/skills_ref/dispatching-parallel-agents/SKILL.md +0 -180
  190. package/skills_ref/doc-coauthoring/SKILL.md +0 -375
  191. package/skills_ref/docx/LICENSE.txt +0 -30
  192. package/skills_ref/docx/SKILL.md +0 -481
  193. package/skills_ref/docx/scripts/__init__.py +0 -1
  194. package/skills_ref/docx/scripts/accept_changes.py +0 -135
  195. package/skills_ref/docx/scripts/comment.py +0 -318
  196. package/skills_ref/docx/scripts/office/helpers/__init__.py +0 -0
  197. package/skills_ref/docx/scripts/office/helpers/merge_runs.py +0 -199
  198. package/skills_ref/docx/scripts/office/helpers/simplify_redlines.py +0 -197
  199. package/skills_ref/docx/scripts/office/pack.py +0 -159
  200. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  201. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  202. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  203. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  204. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  205. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  206. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  207. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  208. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  209. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  210. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  211. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  212. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  213. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  214. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  215. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  216. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  217. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  218. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  219. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  220. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  221. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  222. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  223. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  224. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  225. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  226. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  227. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  228. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  229. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  230. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  231. package/skills_ref/docx/scripts/office/schemas/mce/mc.xsd +0 -75
  232. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  233. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  234. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  235. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  236. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  237. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  238. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  239. package/skills_ref/docx/scripts/office/soffice.py +0 -183
  240. package/skills_ref/docx/scripts/office/unpack.py +0 -132
  241. package/skills_ref/docx/scripts/office/validate.py +0 -111
  242. package/skills_ref/docx/scripts/office/validators/__init__.py +0 -15
  243. package/skills_ref/docx/scripts/office/validators/base.py +0 -847
  244. package/skills_ref/docx/scripts/office/validators/docx.py +0 -446
  245. package/skills_ref/docx/scripts/office/validators/pptx.py +0 -275
  246. package/skills_ref/docx/scripts/office/validators/redlining.py +0 -247
  247. package/skills_ref/docx/scripts/templates/comments.xml +0 -3
  248. package/skills_ref/docx/scripts/templates/commentsExtended.xml +0 -3
  249. package/skills_ref/docx/scripts/templates/commentsExtensible.xml +0 -3
  250. package/skills_ref/docx/scripts/templates/commentsIds.xml +0 -3
  251. package/skills_ref/docx/scripts/templates/people.xml +0 -3
  252. package/skills_ref/durable-objects/SKILL.md +0 -186
  253. package/skills_ref/durable-objects/references/rules.md +0 -286
  254. package/skills_ref/durable-objects/references/testing.md +0 -264
  255. package/skills_ref/durable-objects/references/workers.md +0 -346
  256. package/skills_ref/email-draft-polish/SKILL.md +0 -24
  257. package/skills_ref/error-message-explainer/SKILL.md +0 -27
  258. package/skills_ref/fal-image-edit/SKILL.md +0 -249
  259. package/skills_ref/fal-image-edit/scripts/edit-image.sh +0 -199
  260. package/skills_ref/figma-implement-design/SKILL.md +0 -264
  261. package/skills_ref/git-worktrees/SKILL.md +0 -218
  262. package/skills_ref/github/SKILL.md +0 -210
  263. package/skills_ref/gog/SKILL.md +0 -116
  264. package/skills_ref/goplaces/SKILL.md +0 -52
  265. package/skills_ref/himalaya/SKILL.md +0 -257
  266. package/skills_ref/hugging-face-cli/SKILL.md +0 -186
  267. package/skills_ref/hugging-face-cli/references/commands.md +0 -954
  268. package/skills_ref/hugging-face-cli/references/examples.md +0 -374
  269. package/skills_ref/hugging-face-evaluation/SKILL.md +0 -651
  270. package/skills_ref/hugging-face-evaluation/examples/.env.example +0 -7
  271. package/skills_ref/hugging-face-evaluation/examples/USAGE_EXAMPLES.md +0 -382
  272. package/skills_ref/hugging-face-evaluation/examples/artificial_analysis_to_hub.py +0 -141
  273. package/skills_ref/hugging-face-evaluation/examples/example_readme_tables.md +0 -135
  274. package/skills_ref/hugging-face-evaluation/examples/metric_mapping.json +0 -50
  275. package/skills_ref/hugging-face-evaluation/requirements.txt +0 -20
  276. package/skills_ref/hugging-face-evaluation/scripts/evaluation_manager.py +0 -1374
  277. package/skills_ref/hugging-face-evaluation/scripts/inspect_eval_uv.py +0 -104
  278. package/skills_ref/hugging-face-evaluation/scripts/inspect_vllm_uv.py +0 -317
  279. package/skills_ref/hugging-face-evaluation/scripts/lighteval_vllm_uv.py +0 -303
  280. package/skills_ref/hugging-face-evaluation/scripts/run_eval_job.py +0 -98
  281. package/skills_ref/hugging-face-evaluation/scripts/run_vllm_eval_job.py +0 -331
  282. package/skills_ref/hugging-face-evaluation/scripts/test_extraction.py +0 -206
  283. package/skills_ref/hugging-face-model-trainer/SKILL.md +0 -718
  284. package/skills_ref/hugging-face-model-trainer/references/gguf_conversion.md +0 -296
  285. package/skills_ref/hugging-face-model-trainer/references/hardware_guide.md +0 -283
  286. package/skills_ref/hugging-face-model-trainer/references/hub_saving.md +0 -364
  287. package/skills_ref/hugging-face-model-trainer/references/reliability_principles.md +0 -371
  288. package/skills_ref/hugging-face-model-trainer/references/trackio_guide.md +0 -189
  289. package/skills_ref/hugging-face-model-trainer/references/training_methods.md +0 -150
  290. package/skills_ref/hugging-face-model-trainer/references/training_patterns.md +0 -203
  291. package/skills_ref/hugging-face-model-trainer/references/troubleshooting.md +0 -282
  292. package/skills_ref/hugging-face-model-trainer/references/unsloth.md +0 -313
  293. package/skills_ref/hugging-face-model-trainer/scripts/convert_to_gguf.py +0 -424
  294. package/skills_ref/hugging-face-model-trainer/scripts/dataset_inspector.py +0 -417
  295. package/skills_ref/hugging-face-model-trainer/scripts/estimate_cost.py +0 -150
  296. package/skills_ref/hugging-face-model-trainer/scripts/train_dpo_example.py +0 -106
  297. package/skills_ref/hugging-face-model-trainer/scripts/train_grpo_example.py +0 -89
  298. package/skills_ref/hugging-face-model-trainer/scripts/train_sft_example.py +0 -122
  299. package/skills_ref/hugging-face-model-trainer/scripts/unsloth_sft_example.py +0 -512
  300. package/skills_ref/imagegen/SKILL.md +0 -174
  301. package/skills_ref/insecure-defaults/.claude-plugin/plugin.json +0 -10
  302. package/skills_ref/insecure-defaults/README.md +0 -45
  303. package/skills_ref/insecure-defaults/skills/insecure-defaults/SKILL.md +0 -117
  304. package/skills_ref/insecure-defaults/skills/insecure-defaults/references/examples.md +0 -409
  305. package/skills_ref/jupyter-notebook/SKILL.md +0 -107
  306. package/skills_ref/linear/SKILL.md +0 -87
  307. package/skills_ref/linter-fix-guide/SKILL.md +0 -27
  308. package/skills_ref/log-summarizer/SKILL.md +0 -27
  309. package/skills_ref/mcp-builder/LICENSE.txt +0 -202
  310. package/skills_ref/mcp-builder/SKILL.md +0 -236
  311. package/skills_ref/mcp-builder/reference/evaluation.md +0 -602
  312. package/skills_ref/mcp-builder/reference/mcp_best_practices.md +0 -249
  313. package/skills_ref/mcp-builder/reference/node_mcp_server.md +0 -970
  314. package/skills_ref/mcp-builder/reference/python_mcp_server.md +0 -719
  315. package/skills_ref/mcp-builder/scripts/connections.py +0 -151
  316. package/skills_ref/mcp-builder/scripts/evaluation.py +0 -373
  317. package/skills_ref/mcp-builder/scripts/example_evaluation.xml +0 -22
  318. package/skills_ref/mcp-builder/scripts/requirements.txt +0 -2
  319. package/skills_ref/memory/SKILL.md +0 -129
  320. package/skills_ref/modern-python/.claude-plugin/plugin.json +0 -10
  321. package/skills_ref/modern-python/README.md +0 -66
  322. package/skills_ref/modern-python/hooks/hooks.json +0 -16
  323. package/skills_ref/modern-python/hooks/setup-shims.bats +0 -70
  324. package/skills_ref/modern-python/hooks/setup-shims.sh +0 -24
  325. package/skills_ref/modern-python/hooks/shims/pip +0 -27
  326. package/skills_ref/modern-python/hooks/shims/pip-shim.bats +0 -45
  327. package/skills_ref/modern-python/hooks/shims/pip3 +0 -27
  328. package/skills_ref/modern-python/hooks/shims/pipx +0 -41
  329. package/skills_ref/modern-python/hooks/shims/pipx-shim.bats +0 -64
  330. package/skills_ref/modern-python/hooks/shims/python +0 -26
  331. package/skills_ref/modern-python/hooks/shims/python-shim.bats +0 -53
  332. package/skills_ref/modern-python/hooks/shims/python3 +0 -26
  333. package/skills_ref/modern-python/hooks/shims/uv +0 -27
  334. package/skills_ref/modern-python/hooks/shims/uv-shim.bats +0 -47
  335. package/skills_ref/modern-python/skills/modern-python/SKILL.md +0 -333
  336. package/skills_ref/modern-python/skills/modern-python/references/dependabot.md +0 -43
  337. package/skills_ref/modern-python/skills/modern-python/references/migration-checklist.md +0 -141
  338. package/skills_ref/modern-python/skills/modern-python/references/pep723-scripts.md +0 -259
  339. package/skills_ref/modern-python/skills/modern-python/references/prek.md +0 -211
  340. package/skills_ref/modern-python/skills/modern-python/references/pyproject.md +0 -254
  341. package/skills_ref/modern-python/skills/modern-python/references/ruff-config.md +0 -240
  342. package/skills_ref/modern-python/skills/modern-python/references/security-setup.md +0 -255
  343. package/skills_ref/modern-python/skills/modern-python/references/testing.md +0 -284
  344. package/skills_ref/modern-python/skills/modern-python/references/uv-commands.md +0 -200
  345. package/skills_ref/modern-python/skills/modern-python/templates/dependabot.yml +0 -36
  346. package/skills_ref/modern-python/skills/modern-python/templates/pre-commit-config.yaml +0 -66
  347. package/skills_ref/nano-banana-pro/SKILL.md +0 -58
  348. package/skills_ref/netlify-deploy/SKILL.md +0 -233
  349. package/skills_ref/notion/SKILL.md +0 -304
  350. package/skills_ref/notion-knowledge-capture/SKILL.md +0 -56
  351. package/skills_ref/notion-meeting-intelligence/SKILL.md +0 -60
  352. package/skills_ref/notion-research-documentation/SKILL.md +0 -59
  353. package/skills_ref/notion-spec-to-implementation/SKILL.md +0 -58
  354. package/skills_ref/obsidian/SKILL.md +0 -81
  355. package/skills_ref/openai-docs/SKILL.md +0 -56
  356. package/skills_ref/openhue/SKILL.md +0 -112
  357. package/skills_ref/pdf/SKILL.md +0 -69
  358. package/skills_ref/postgres/README.md +0 -77
  359. package/skills_ref/postgres/SKILL.md +0 -129
  360. package/skills_ref/postgres/connections.example.json +0 -34
  361. package/skills_ref/postgres/requirements.txt +0 -1
  362. package/skills_ref/postgres/scripts/query.py +0 -262
  363. package/skills_ref/pptx/LICENSE.txt +0 -30
  364. package/skills_ref/pptx/SKILL.md +0 -232
  365. package/skills_ref/pptx/editing.md +0 -205
  366. package/skills_ref/pptx/pptxgenjs.md +0 -420
  367. package/skills_ref/pptx/scripts/__init__.py +0 -0
  368. package/skills_ref/pptx/scripts/add_slide.py +0 -195
  369. package/skills_ref/pptx/scripts/clean.py +0 -286
  370. package/skills_ref/pptx/scripts/office/helpers/__init__.py +0 -0
  371. package/skills_ref/pptx/scripts/office/helpers/merge_runs.py +0 -199
  372. package/skills_ref/pptx/scripts/office/helpers/simplify_redlines.py +0 -197
  373. package/skills_ref/pptx/scripts/office/pack.py +0 -159
  374. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  375. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  376. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  377. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  378. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  379. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  380. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  381. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  382. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  383. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  384. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  385. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  386. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  387. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  388. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  389. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  390. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  391. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  392. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  393. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  394. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  395. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  396. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  397. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  398. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  399. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  400. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  401. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  402. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  403. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  404. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  405. package/skills_ref/pptx/scripts/office/schemas/mce/mc.xsd +0 -75
  406. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  407. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  408. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  409. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  410. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  411. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  412. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  413. package/skills_ref/pptx/scripts/office/soffice.py +0 -183
  414. package/skills_ref/pptx/scripts/office/unpack.py +0 -132
  415. package/skills_ref/pptx/scripts/office/validate.py +0 -111
  416. package/skills_ref/pptx/scripts/office/validators/__init__.py +0 -15
  417. package/skills_ref/pptx/scripts/office/validators/base.py +0 -847
  418. package/skills_ref/pptx/scripts/office/validators/docx.py +0 -446
  419. package/skills_ref/pptx/scripts/office/validators/pptx.py +0 -275
  420. package/skills_ref/pptx/scripts/office/validators/redlining.py +0 -247
  421. package/skills_ref/pptx/scripts/thumbnail.py +0 -289
  422. package/skills_ref/property-based-testing/.claude-plugin/plugin.json +0 -9
  423. package/skills_ref/property-based-testing/README.md +0 -47
  424. package/skills_ref/property-based-testing/skills/property-based-testing/README.md +0 -88
  425. package/skills_ref/property-based-testing/skills/property-based-testing/SKILL.md +0 -123
  426. package/skills_ref/property-based-testing/skills/property-based-testing/references/design.md +0 -191
  427. package/skills_ref/property-based-testing/skills/property-based-testing/references/generating.md +0 -204
  428. package/skills_ref/property-based-testing/skills/property-based-testing/references/interpreting-failures.md +0 -239
  429. package/skills_ref/property-based-testing/skills/property-based-testing/references/libraries.md +0 -130
  430. package/skills_ref/property-based-testing/skills/property-based-testing/references/refactoring.md +0 -181
  431. package/skills_ref/property-based-testing/skills/property-based-testing/references/reviewing.md +0 -209
  432. package/skills_ref/property-based-testing/skills/property-based-testing/references/strategies.md +0 -124
  433. package/skills_ref/react-best-practices/AGENTS.md +0 -2934
  434. package/skills_ref/react-best-practices/README.md +0 -123
  435. package/skills_ref/react-best-practices/SKILL.md +0 -136
  436. package/skills_ref/react-best-practices/metadata.json +0 -15
  437. package/skills_ref/react-best-practices/rules/_sections.md +0 -46
  438. package/skills_ref/react-best-practices/rules/_template.md +0 -28
  439. package/skills_ref/react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  440. package/skills_ref/react-best-practices/rules/advanced-init-once.md +0 -42
  441. package/skills_ref/react-best-practices/rules/advanced-use-latest.md +0 -39
  442. package/skills_ref/react-best-practices/rules/async-api-routes.md +0 -38
  443. package/skills_ref/react-best-practices/rules/async-defer-await.md +0 -80
  444. package/skills_ref/react-best-practices/rules/async-dependencies.md +0 -51
  445. package/skills_ref/react-best-practices/rules/async-parallel.md +0 -28
  446. package/skills_ref/react-best-practices/rules/async-suspense-boundaries.md +0 -99
  447. package/skills_ref/react-best-practices/rules/bundle-barrel-imports.md +0 -59
  448. package/skills_ref/react-best-practices/rules/bundle-conditional.md +0 -31
  449. package/skills_ref/react-best-practices/rules/bundle-defer-third-party.md +0 -49
  450. package/skills_ref/react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  451. package/skills_ref/react-best-practices/rules/bundle-preload.md +0 -50
  452. package/skills_ref/react-best-practices/rules/client-event-listeners.md +0 -74
  453. package/skills_ref/react-best-practices/rules/client-localstorage-schema.md +0 -71
  454. package/skills_ref/react-best-practices/rules/client-passive-event-listeners.md +0 -48
  455. package/skills_ref/react-best-practices/rules/client-swr-dedup.md +0 -56
  456. package/skills_ref/react-best-practices/rules/js-batch-dom-css.md +0 -107
  457. package/skills_ref/react-best-practices/rules/js-cache-function-results.md +0 -80
  458. package/skills_ref/react-best-practices/rules/js-cache-property-access.md +0 -28
  459. package/skills_ref/react-best-practices/rules/js-cache-storage.md +0 -70
  460. package/skills_ref/react-best-practices/rules/js-combine-iterations.md +0 -32
  461. package/skills_ref/react-best-practices/rules/js-early-exit.md +0 -50
  462. package/skills_ref/react-best-practices/rules/js-hoist-regexp.md +0 -45
  463. package/skills_ref/react-best-practices/rules/js-index-maps.md +0 -37
  464. package/skills_ref/react-best-practices/rules/js-length-check-first.md +0 -49
  465. package/skills_ref/react-best-practices/rules/js-min-max-loop.md +0 -82
  466. package/skills_ref/react-best-practices/rules/js-set-map-lookups.md +0 -24
  467. package/skills_ref/react-best-practices/rules/js-tosorted-immutable.md +0 -57
  468. package/skills_ref/react-best-practices/rules/rendering-activity.md +0 -26
  469. package/skills_ref/react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  470. package/skills_ref/react-best-practices/rules/rendering-conditional-render.md +0 -40
  471. package/skills_ref/react-best-practices/rules/rendering-content-visibility.md +0 -38
  472. package/skills_ref/react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  473. package/skills_ref/react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  474. package/skills_ref/react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  475. package/skills_ref/react-best-practices/rules/rendering-svg-precision.md +0 -28
  476. package/skills_ref/react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  477. package/skills_ref/react-best-practices/rules/rerender-defer-reads.md +0 -39
  478. package/skills_ref/react-best-practices/rules/rerender-dependencies.md +0 -45
  479. package/skills_ref/react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  480. package/skills_ref/react-best-practices/rules/rerender-derived-state.md +0 -29
  481. package/skills_ref/react-best-practices/rules/rerender-functional-setstate.md +0 -74
  482. package/skills_ref/react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  483. package/skills_ref/react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  484. package/skills_ref/react-best-practices/rules/rerender-memo.md +0 -44
  485. package/skills_ref/react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  486. package/skills_ref/react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  487. package/skills_ref/react-best-practices/rules/rerender-transitions.md +0 -40
  488. package/skills_ref/react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  489. package/skills_ref/react-best-practices/rules/server-after-nonblocking.md +0 -73
  490. package/skills_ref/react-best-practices/rules/server-auth-actions.md +0 -96
  491. package/skills_ref/react-best-practices/rules/server-cache-lru.md +0 -41
  492. package/skills_ref/react-best-practices/rules/server-cache-react.md +0 -76
  493. package/skills_ref/react-best-practices/rules/server-dedup-props.md +0 -65
  494. package/skills_ref/react-best-practices/rules/server-parallel-fetching.md +0 -83
  495. package/skills_ref/react-best-practices/rules/server-serialization.md +0 -38
  496. package/skills_ref/receiving-code-review/SKILL.md +0 -213
  497. package/skills_ref/registry.json +0 -1493
  498. package/skills_ref/render-deploy/SKILL.md +0 -462
  499. package/skills_ref/requesting-code-review/SKILL.md +0 -105
  500. package/skills_ref/requesting-code-review/code-reviewer.md +0 -146
  501. package/skills_ref/screen-capture/SKILL.md +0 -162
  502. package/skills_ref/security-best-practices/LICENSE.txt +0 -201
  503. package/skills_ref/security-best-practices/SKILL.md +0 -86
  504. package/skills_ref/security-best-practices/agents/openai.yaml +0 -4
  505. package/skills_ref/security-best-practices/references/golang-general-backend-security.md +0 -826
  506. package/skills_ref/security-best-practices/references/javascript-express-web-server-security.md +0 -1158
  507. package/skills_ref/security-best-practices/references/javascript-general-web-frontend-security.md +0 -747
  508. package/skills_ref/security-best-practices/references/javascript-jquery-web-frontend-security.md +0 -678
  509. package/skills_ref/security-best-practices/references/javascript-typescript-nextjs-web-server-security.md +0 -1144
  510. package/skills_ref/security-best-practices/references/javascript-typescript-react-web-frontend-security.md +0 -990
  511. package/skills_ref/security-best-practices/references/javascript-typescript-vue-web-frontend-security.md +0 -791
  512. package/skills_ref/security-best-practices/references/python-django-web-server-security.md +0 -882
  513. package/skills_ref/security-best-practices/references/python-fastapi-web-server-security.md +0 -1036
  514. package/skills_ref/security-best-practices/references/python-flask-web-server-security.md +0 -705
  515. package/skills_ref/security-ownership-map/LICENSE.txt +0 -201
  516. package/skills_ref/security-ownership-map/SKILL.md +0 -206
  517. package/skills_ref/security-ownership-map/agents/openai.yaml +0 -4
  518. package/skills_ref/security-ownership-map/references/neo4j-import.md +0 -60
  519. package/skills_ref/security-ownership-map/scripts/build_ownership_map.py +0 -956
  520. package/skills_ref/security-ownership-map/scripts/community_maintainers.py +0 -544
  521. package/skills_ref/security-ownership-map/scripts/query_ownership.py +0 -483
  522. package/skills_ref/security-ownership-map/scripts/run_ownership_map.py +0 -200
  523. package/skills_ref/security-threat-model/LICENSE.txt +0 -201
  524. package/skills_ref/security-threat-model/SKILL.md +0 -81
  525. package/skills_ref/security-threat-model/agents/openai.yaml +0 -4
  526. package/skills_ref/security-threat-model/references/prompt-template.md +0 -255
  527. package/skills_ref/security-threat-model/references/security-controls-and-assets.md +0 -32
  528. package/skills_ref/sentry/SKILL.md +0 -123
  529. package/skills_ref/skill-creator/SKILL.md +0 -372
  530. package/skills_ref/sora/SKILL.md +0 -153
  531. package/skills_ref/speech/SKILL.md +0 -144
  532. package/skills_ref/spotify-player/SKILL.md +0 -64
  533. package/skills_ref/static-analysis/.claude-plugin/plugin.json +0 -8
  534. package/skills_ref/static-analysis/README.md +0 -65
  535. package/skills_ref/static-analysis/agents/semgrep-scanner.md +0 -71
  536. package/skills_ref/static-analysis/agents/semgrep-triager.md +0 -107
  537. package/skills_ref/static-analysis/skills/codeql/SKILL.md +0 -119
  538. package/skills_ref/static-analysis/skills/codeql/references/diagnostic-query-templates.md +0 -339
  539. package/skills_ref/static-analysis/skills/codeql/references/language-details.md +0 -207
  540. package/skills_ref/static-analysis/skills/codeql/references/performance-tuning.md +0 -111
  541. package/skills_ref/static-analysis/skills/codeql/references/ruleset-catalog.md +0 -63
  542. package/skills_ref/static-analysis/skills/codeql/references/threat-models.md +0 -44
  543. package/skills_ref/static-analysis/skills/codeql/workflows/build-database.md +0 -669
  544. package/skills_ref/static-analysis/skills/codeql/workflows/create-data-extensions.md +0 -536
  545. package/skills_ref/static-analysis/skills/codeql/workflows/run-analysis.md +0 -436
  546. package/skills_ref/static-analysis/skills/sarif-parsing/SKILL.md +0 -479
  547. package/skills_ref/static-analysis/skills/sarif-parsing/resources/jq-queries.md +0 -162
  548. package/skills_ref/static-analysis/skills/sarif-parsing/resources/sarif_helpers.py +0 -331
  549. package/skills_ref/static-analysis/skills/semgrep/SKILL.md +0 -431
  550. package/skills_ref/static-analysis/skills/semgrep/references/rulesets.md +0 -162
  551. package/skills_ref/static-analysis/skills/semgrep/references/scanner-task-prompt.md +0 -102
  552. package/skills_ref/static-analysis/skills/semgrep/references/triage-task-prompt.md +0 -122
  553. package/skills_ref/static-analysis/skills/semgrep/scripts/merge_triaged_sarif.py +0 -252
  554. package/skills_ref/summarize/SKILL.md +0 -87
  555. package/skills_ref/tdd/SKILL.md +0 -371
  556. package/skills_ref/tdd/testing-anti-patterns.md +0 -299
  557. package/skills_ref/telegram-send/SKILL.md +0 -99
  558. package/skills_ref/terraform/README.md +0 -105
  559. package/skills_ref/terraform/code-generation/.claude-plugin/plugin.json +0 -30
  560. package/skills_ref/terraform/code-generation/skills/azure-verified-modules/SKILL.md +0 -613
  561. package/skills_ref/terraform/code-generation/skills/terraform-style-guide/SKILL.md +0 -353
  562. package/skills_ref/terraform/code-generation/skills/terraform-test/SKILL.md +0 -1669
  563. package/skills_ref/terraform/module-generation/.claude-plugin/plugin.json +0 -30
  564. package/skills_ref/terraform/module-generation/skills/refactor-module/SKILL.md +0 -538
  565. package/skills_ref/terraform/module-generation/skills/terraform-stacks/SKILL.md +0 -468
  566. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/api-monitoring.md +0 -543
  567. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/component-blocks.md +0 -476
  568. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/deployment-blocks.md +0 -391
  569. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/examples.md +0 -1529
  570. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/linked-stacks.md +0 -187
  571. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/troubleshooting.md +0 -671
  572. package/skills_ref/terraform/provider-development/.claude-plugin/plugin.json +0 -13
  573. package/skills_ref/terraform/provider-development/skills/new-terraform-provider/SKILL.md +0 -25
  574. package/skills_ref/terraform/provider-development/skills/new-terraform-provider/assets/main.go +0 -40
  575. package/skills_ref/terraform/provider-development/skills/provider-actions/SKILL.md +0 -478
  576. package/skills_ref/terraform/provider-development/skills/provider-resources/SKILL.md +0 -599
  577. package/skills_ref/terraform/provider-development/skills/run-acceptance-tests/SKILL.md +0 -41
  578. package/skills_ref/theme-factory/LICENSE.txt +0 -202
  579. package/skills_ref/theme-factory/SKILL.md +0 -59
  580. package/skills_ref/theme-factory/theme-showcase.pdf +0 -0
  581. package/skills_ref/theme-factory/themes/arctic-frost.md +0 -19
  582. package/skills_ref/theme-factory/themes/botanical-garden.md +0 -19
  583. package/skills_ref/theme-factory/themes/desert-rose.md +0 -19
  584. package/skills_ref/theme-factory/themes/forest-canopy.md +0 -19
  585. package/skills_ref/theme-factory/themes/golden-hour.md +0 -19
  586. package/skills_ref/theme-factory/themes/midnight-galaxy.md +0 -19
  587. package/skills_ref/theme-factory/themes/modern-minimalist.md +0 -19
  588. package/skills_ref/theme-factory/themes/ocean-depths.md +0 -19
  589. package/skills_ref/theme-factory/themes/sunset-boulevard.md +0 -19
  590. package/skills_ref/theme-factory/themes/tech-innovation.md +0 -19
  591. package/skills_ref/things-mac/SKILL.md +0 -86
  592. package/skills_ref/tmux/SKILL.md +0 -153
  593. package/skills_ref/transcribe/SKILL.md +0 -81
  594. package/skills_ref/trello/SKILL.md +0 -95
  595. package/skills_ref/tts/SKILL.md +0 -99
  596. package/skills_ref/vercel-deploy/SKILL.md +0 -115
  597. package/skills_ref/video-downloader/SKILL.md +0 -99
  598. package/skills_ref/video-downloader/scripts/download_video.py +0 -145
  599. package/skills_ref/video-frames/SKILL.md +0 -46
  600. package/skills_ref/vision-click/SKILL.md +0 -128
  601. package/skills_ref/weather/SKILL.md +0 -112
  602. package/skills_ref/web-artifacts-builder/LICENSE.txt +0 -202
  603. package/skills_ref/web-artifacts-builder/SKILL.md +0 -74
  604. package/skills_ref/web-artifacts-builder/scripts/bundle-artifact.sh +0 -54
  605. package/skills_ref/web-artifacts-builder/scripts/init-artifact.sh +0 -322
  606. package/skills_ref/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  607. package/skills_ref/web-perf/SKILL.md +0 -193
  608. package/skills_ref/web-routing/SKILL.md +0 -26
  609. package/skills_ref/whatsapp/SKILL.md +0 -255
  610. package/skills_ref/whatsapp/assets/agent-app-integration-example.json +0 -35
  611. package/skills_ref/whatsapp/assets/databases-example.json +0 -11
  612. package/skills_ref/whatsapp/assets/function-decide-route-interactive-buttons.json +0 -6
  613. package/skills_ref/whatsapp/assets/functions-example.json +0 -5
  614. package/skills_ref/whatsapp/assets/workflow-agent-simple.json +0 -31
  615. package/skills_ref/whatsapp/assets/workflow-api-template-wait-agent.json +0 -59
  616. package/skills_ref/whatsapp/assets/workflow-customer-support-intake-agent.json +0 -56
  617. package/skills_ref/whatsapp/assets/workflow-decision.json +0 -83
  618. package/skills_ref/whatsapp/assets/workflow-interactive-buttons-decide-ai.json +0 -89
  619. package/skills_ref/whatsapp/assets/workflow-interactive-buttons-decide-function.json +0 -88
  620. package/skills_ref/whatsapp/assets/workflow-linear.json +0 -53
  621. package/skills_ref/whatsapp/package.json +0 -10
  622. package/skills_ref/whatsapp/references/app-integrations.md +0 -89
  623. package/skills_ref/whatsapp/references/databases-reference.md +0 -21
  624. package/skills_ref/whatsapp/references/execution-context.md +0 -42
  625. package/skills_ref/whatsapp/references/function-contracts.md +0 -55
  626. package/skills_ref/whatsapp/references/functions-payloads.md +0 -87
  627. package/skills_ref/whatsapp/references/functions-reference.md +0 -133
  628. package/skills_ref/whatsapp/references/graph-contract.md +0 -145
  629. package/skills_ref/whatsapp/references/node-types.md +0 -430
  630. package/skills_ref/whatsapp/references/triggers.md +0 -20
  631. package/skills_ref/whatsapp/references/workflow-overview.md +0 -22
  632. package/skills_ref/whatsapp/references/workflow-reference.md +0 -123
  633. package/skills_ref/whatsapp/scripts/configure-prop.js +0 -113
  634. package/skills_ref/whatsapp/scripts/create-connect-token.js +0 -38
  635. package/skills_ref/whatsapp/scripts/create-function.js +0 -64
  636. package/skills_ref/whatsapp/scripts/create-integration.js +0 -137
  637. package/skills_ref/whatsapp/scripts/create-row.js +0 -47
  638. package/skills_ref/whatsapp/scripts/create-trigger.js +0 -88
  639. package/skills_ref/whatsapp/scripts/create-workflow.js +0 -85
  640. package/skills_ref/whatsapp/scripts/delete-integration.js +0 -44
  641. package/skills_ref/whatsapp/scripts/delete-row.js +0 -49
  642. package/skills_ref/whatsapp/scripts/delete-trigger.js +0 -44
  643. package/skills_ref/whatsapp/scripts/deploy-function.js +0 -47
  644. package/skills_ref/whatsapp/scripts/edit-graph.js +0 -289
  645. package/skills_ref/whatsapp/scripts/get-action-schema.js +0 -44
  646. package/skills_ref/whatsapp/scripts/get-context-value.js +0 -80
  647. package/skills_ref/whatsapp/scripts/get-execution-event.js +0 -55
  648. package/skills_ref/whatsapp/scripts/get-execution.js +0 -44
  649. package/skills_ref/whatsapp/scripts/get-function.js +0 -43
  650. package/skills_ref/whatsapp/scripts/get-graph.js +0 -85
  651. package/skills_ref/whatsapp/scripts/get-table.js +0 -45
  652. package/skills_ref/whatsapp/scripts/get-workflow.js +0 -44
  653. package/skills_ref/whatsapp/scripts/invoke-function.js +0 -60
  654. package/skills_ref/whatsapp/scripts/lib/databases/args.js +0 -87
  655. package/skills_ref/whatsapp/scripts/lib/databases/filters.js +0 -30
  656. package/skills_ref/whatsapp/scripts/lib/databases/kapso-api.js +0 -70
  657. package/skills_ref/whatsapp/scripts/lib/functions/args.js +0 -55
  658. package/skills_ref/whatsapp/scripts/lib/functions/kapso-api.js +0 -70
  659. package/skills_ref/whatsapp/scripts/lib/workflows/args.js +0 -53
  660. package/skills_ref/whatsapp/scripts/lib/workflows/kapso-api.js +0 -123
  661. package/skills_ref/whatsapp/scripts/lib/workflows/result.js +0 -16
  662. package/skills_ref/whatsapp/scripts/list-accounts.js +0 -62
  663. package/skills_ref/whatsapp/scripts/list-apps.js +0 -42
  664. package/skills_ref/whatsapp/scripts/list-execution-events.js +0 -61
  665. package/skills_ref/whatsapp/scripts/list-executions.js +0 -53
  666. package/skills_ref/whatsapp/scripts/list-function-invocations.js +0 -53
  667. package/skills_ref/whatsapp/scripts/list-functions.js +0 -41
  668. package/skills_ref/whatsapp/scripts/list-integrations.js +0 -41
  669. package/skills_ref/whatsapp/scripts/list-provider-models.js +0 -48
  670. package/skills_ref/whatsapp/scripts/list-tables.js +0 -41
  671. package/skills_ref/whatsapp/scripts/list-triggers.js +0 -44
  672. package/skills_ref/whatsapp/scripts/list-whatsapp-phone-numbers.js +0 -56
  673. package/skills_ref/whatsapp/scripts/list-workflows.js +0 -44
  674. package/skills_ref/whatsapp/scripts/openapi-explore.mjs +0 -1273
  675. package/skills_ref/whatsapp/scripts/query-rows.js +0 -71
  676. package/skills_ref/whatsapp/scripts/reload-props.js +0 -110
  677. package/skills_ref/whatsapp/scripts/resume-execution.js +0 -75
  678. package/skills_ref/whatsapp/scripts/search-actions.js +0 -64
  679. package/skills_ref/whatsapp/scripts/update-execution-status.js +0 -51
  680. package/skills_ref/whatsapp/scripts/update-function.js +0 -65
  681. package/skills_ref/whatsapp/scripts/update-graph.js +0 -154
  682. package/skills_ref/whatsapp/scripts/update-integration.js +0 -82
  683. package/skills_ref/whatsapp/scripts/update-row.js +0 -51
  684. package/skills_ref/whatsapp/scripts/update-trigger.js +0 -60
  685. package/skills_ref/whatsapp/scripts/update-workflow-settings.js +0 -67
  686. package/skills_ref/whatsapp/scripts/upsert-row.js +0 -64
  687. package/skills_ref/whatsapp/scripts/validate-graph.js +0 -293
  688. package/skills_ref/whatsapp/scripts/variables-delete.js +0 -37
  689. package/skills_ref/whatsapp/scripts/variables-list.js +0 -55
  690. package/skills_ref/whatsapp/scripts/variables-set.js +0 -39
  691. package/skills_ref/writing-plans/SKILL.md +0 -116
  692. package/skills_ref/xlsx/LICENSE.txt +0 -30
  693. package/skills_ref/xlsx/SKILL.md +0 -292
  694. package/skills_ref/xlsx/scripts/office/helpers/__init__.py +0 -0
  695. package/skills_ref/xlsx/scripts/office/helpers/merge_runs.py +0 -199
  696. package/skills_ref/xlsx/scripts/office/helpers/simplify_redlines.py +0 -197
  697. package/skills_ref/xlsx/scripts/office/pack.py +0 -159
  698. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  699. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  700. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  701. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  702. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  703. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  704. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  705. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  706. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  707. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  708. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  709. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  710. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  711. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  712. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  713. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  714. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  715. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  716. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  717. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  718. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  719. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  720. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  721. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  722. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  723. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  724. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  725. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  726. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  727. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  728. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  729. package/skills_ref/xlsx/scripts/office/schemas/mce/mc.xsd +0 -75
  730. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  731. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  732. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  733. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  734. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  735. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  736. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  737. package/skills_ref/xlsx/scripts/office/soffice.py +0 -183
  738. package/skills_ref/xlsx/scripts/office/unpack.py +0 -132
  739. package/skills_ref/xlsx/scripts/office/validate.py +0 -111
  740. package/skills_ref/xlsx/scripts/office/validators/__init__.py +0 -15
  741. package/skills_ref/xlsx/scripts/office/validators/base.py +0 -847
  742. package/skills_ref/xlsx/scripts/office/validators/docx.py +0 -446
  743. package/skills_ref/xlsx/scripts/office/validators/pptx.py +0 -275
  744. package/skills_ref/xlsx/scripts/office/validators/redlining.py +0 -247
  745. package/skills_ref/xlsx/scripts/recalc.py +0 -184
  746. package/skills_ref/xurl/SKILL.md +0 -461
@@ -1,970 +0,0 @@
1
- # Node/TypeScript MCP Server Implementation Guide
2
-
3
- ## Overview
4
-
5
- This document provides Node/TypeScript-specific best practices and examples for implementing MCP servers using the MCP TypeScript SDK. It covers project structure, server setup, tool registration patterns, input validation with Zod, error handling, and complete working examples.
6
-
7
- ---
8
-
9
- ## Quick Reference
10
-
11
- ### Key Imports
12
- ```typescript
13
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
14
- import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
15
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
16
- import express from "express";
17
- import { z } from "zod";
18
- ```
19
-
20
- ### Server Initialization
21
- ```typescript
22
- const server = new McpServer({
23
- name: "service-mcp-server",
24
- version: "1.0.0"
25
- });
26
- ```
27
-
28
- ### Tool Registration Pattern
29
- ```typescript
30
- server.registerTool(
31
- "tool_name",
32
- {
33
- title: "Tool Display Name",
34
- description: "What the tool does",
35
- inputSchema: { param: z.string() },
36
- outputSchema: { result: z.string() }
37
- },
38
- async ({ param }) => {
39
- const output = { result: `Processed: ${param}` };
40
- return {
41
- content: [{ type: "text", text: JSON.stringify(output) }],
42
- structuredContent: output // Modern pattern for structured data
43
- };
44
- }
45
- );
46
- ```
47
-
48
- ---
49
-
50
- ## MCP TypeScript SDK
51
-
52
- The official MCP TypeScript SDK provides:
53
- - `McpServer` class for server initialization
54
- - `registerTool` method for tool registration
55
- - Zod schema integration for runtime input validation
56
- - Type-safe tool handler implementations
57
-
58
- **IMPORTANT - Use Modern APIs Only:**
59
- - **DO use**: `server.registerTool()`, `server.registerResource()`, `server.registerPrompt()`
60
- - **DO NOT use**: Old deprecated APIs such as `server.tool()`, `server.setRequestHandler(ListToolsRequestSchema, ...)`, or manual handler registration
61
- - The `register*` methods provide better type safety, automatic schema handling, and are the recommended approach
62
-
63
- See the MCP SDK documentation in the references for complete details.
64
-
65
- ## Server Naming Convention
66
-
67
- Node/TypeScript MCP servers must follow this naming pattern:
68
- - **Format**: `{service}-mcp-server` (lowercase with hyphens)
69
- - **Examples**: `github-mcp-server`, `jira-mcp-server`, `stripe-mcp-server`
70
-
71
- The name should be:
72
- - General (not tied to specific features)
73
- - Descriptive of the service/API being integrated
74
- - Easy to infer from the task description
75
- - Without version numbers or dates
76
-
77
- ## Project Structure
78
-
79
- Create the following structure for Node/TypeScript MCP servers:
80
-
81
- ```
82
- {service}-mcp-server/
83
- ├── package.json
84
- ├── tsconfig.json
85
- ├── README.md
86
- ├── src/
87
- │ ├── index.ts # Main entry point with McpServer initialization
88
- │ ├── types.ts # TypeScript type definitions and interfaces
89
- │ ├── tools/ # Tool implementations (one file per domain)
90
- │ ├── services/ # API clients and shared utilities
91
- │ ├── schemas/ # Zod validation schemas
92
- │ └── constants.ts # Shared constants (API_URL, CHARACTER_LIMIT, etc.)
93
- └── dist/ # Built JavaScript files (entry point: dist/index.js)
94
- ```
95
-
96
- ## Tool Implementation
97
-
98
- ### Tool Naming
99
-
100
- Use snake_case for tool names (e.g., "search_users", "create_project", "get_channel_info") with clear, action-oriented names.
101
-
102
- **Avoid Naming Conflicts**: Include the service context to prevent overlaps:
103
- - Use "slack_send_message" instead of just "send_message"
104
- - Use "github_create_issue" instead of just "create_issue"
105
- - Use "asana_list_tasks" instead of just "list_tasks"
106
-
107
- ### Tool Structure
108
-
109
- Tools are registered using the `registerTool` method with the following requirements:
110
- - Use Zod schemas for runtime input validation and type safety
111
- - The `description` field must be explicitly provided - JSDoc comments are NOT automatically extracted
112
- - Explicitly provide `title`, `description`, `inputSchema`, and `annotations`
113
- - The `inputSchema` must be a Zod schema object (not a JSON schema)
114
- - Type all parameters and return values explicitly
115
-
116
- ```typescript
117
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
118
- import { z } from "zod";
119
-
120
- const server = new McpServer({
121
- name: "example-mcp",
122
- version: "1.0.0"
123
- });
124
-
125
- // Zod schema for input validation
126
- const UserSearchInputSchema = z.object({
127
- query: z.string()
128
- .min(2, "Query must be at least 2 characters")
129
- .max(200, "Query must not exceed 200 characters")
130
- .describe("Search string to match against names/emails"),
131
- limit: z.number()
132
- .int()
133
- .min(1)
134
- .max(100)
135
- .default(20)
136
- .describe("Maximum results to return"),
137
- offset: z.number()
138
- .int()
139
- .min(0)
140
- .default(0)
141
- .describe("Number of results to skip for pagination"),
142
- response_format: z.nativeEnum(ResponseFormat)
143
- .default(ResponseFormat.MARKDOWN)
144
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
145
- }).strict();
146
-
147
- // Type definition from Zod schema
148
- type UserSearchInput = z.infer<typeof UserSearchInputSchema>;
149
-
150
- server.registerTool(
151
- "example_search_users",
152
- {
153
- title: "Search Example Users",
154
- description: `Search for users in the Example system by name, email, or team.
155
-
156
- This tool searches across all user profiles in the Example platform, supporting partial matches and various search filters. It does NOT create or modify users, only searches existing ones.
157
-
158
- Args:
159
- - query (string): Search string to match against names/emails
160
- - limit (number): Maximum results to return, between 1-100 (default: 20)
161
- - offset (number): Number of results to skip for pagination (default: 0)
162
- - response_format ('markdown' | 'json'): Output format (default: 'markdown')
163
-
164
- Returns:
165
- For JSON format: Structured data with schema:
166
- {
167
- "total": number, // Total number of matches found
168
- "count": number, // Number of results in this response
169
- "offset": number, // Current pagination offset
170
- "users": [
171
- {
172
- "id": string, // User ID (e.g., "U123456789")
173
- "name": string, // Full name (e.g., "John Doe")
174
- "email": string, // Email address
175
- "team": string, // Team name (optional)
176
- "active": boolean // Whether user is active
177
- }
178
- ],
179
- "has_more": boolean, // Whether more results are available
180
- "next_offset": number // Offset for next page (if has_more is true)
181
- }
182
-
183
- Examples:
184
- - Use when: "Find all marketing team members" -> params with query="team:marketing"
185
- - Use when: "Search for John's account" -> params with query="john"
186
- - Don't use when: You need to create a user (use example_create_user instead)
187
-
188
- Error Handling:
189
- - Returns "Error: Rate limit exceeded" if too many requests (429 status)
190
- - Returns "No users found matching '<query>'" if search returns empty`,
191
- inputSchema: UserSearchInputSchema,
192
- annotations: {
193
- readOnlyHint: true,
194
- destructiveHint: false,
195
- idempotentHint: true,
196
- openWorldHint: true
197
- }
198
- },
199
- async (params: UserSearchInput) => {
200
- try {
201
- // Input validation is handled by Zod schema
202
- // Make API request using validated parameters
203
- const data = await makeApiRequest<any>(
204
- "users/search",
205
- "GET",
206
- undefined,
207
- {
208
- q: params.query,
209
- limit: params.limit,
210
- offset: params.offset
211
- }
212
- );
213
-
214
- const users = data.users || [];
215
- const total = data.total || 0;
216
-
217
- if (!users.length) {
218
- return {
219
- content: [{
220
- type: "text",
221
- text: `No users found matching '${params.query}'`
222
- }]
223
- };
224
- }
225
-
226
- // Prepare structured output
227
- const output = {
228
- total,
229
- count: users.length,
230
- offset: params.offset,
231
- users: users.map((user: any) => ({
232
- id: user.id,
233
- name: user.name,
234
- email: user.email,
235
- ...(user.team ? { team: user.team } : {}),
236
- active: user.active ?? true
237
- })),
238
- has_more: total > params.offset + users.length,
239
- ...(total > params.offset + users.length ? {
240
- next_offset: params.offset + users.length
241
- } : {})
242
- };
243
-
244
- // Format text representation based on requested format
245
- let textContent: string;
246
- if (params.response_format === ResponseFormat.MARKDOWN) {
247
- const lines = [`# User Search Results: '${params.query}'`, "",
248
- `Found ${total} users (showing ${users.length})`, ""];
249
- for (const user of users) {
250
- lines.push(`## ${user.name} (${user.id})`);
251
- lines.push(`- **Email**: ${user.email}`);
252
- if (user.team) lines.push(`- **Team**: ${user.team}`);
253
- lines.push("");
254
- }
255
- textContent = lines.join("\n");
256
- } else {
257
- textContent = JSON.stringify(output, null, 2);
258
- }
259
-
260
- return {
261
- content: [{ type: "text", text: textContent }],
262
- structuredContent: output // Modern pattern for structured data
263
- };
264
- } catch (error) {
265
- return {
266
- content: [{
267
- type: "text",
268
- text: handleApiError(error)
269
- }]
270
- };
271
- }
272
- }
273
- );
274
- ```
275
-
276
- ## Zod Schemas for Input Validation
277
-
278
- Zod provides runtime type validation:
279
-
280
- ```typescript
281
- import { z } from "zod";
282
-
283
- // Basic schema with validation
284
- const CreateUserSchema = z.object({
285
- name: z.string()
286
- .min(1, "Name is required")
287
- .max(100, "Name must not exceed 100 characters"),
288
- email: z.string()
289
- .email("Invalid email format"),
290
- age: z.number()
291
- .int("Age must be a whole number")
292
- .min(0, "Age cannot be negative")
293
- .max(150, "Age cannot be greater than 150")
294
- }).strict(); // Use .strict() to forbid extra fields
295
-
296
- // Enums
297
- enum ResponseFormat {
298
- MARKDOWN = "markdown",
299
- JSON = "json"
300
- }
301
-
302
- const SearchSchema = z.object({
303
- response_format: z.nativeEnum(ResponseFormat)
304
- .default(ResponseFormat.MARKDOWN)
305
- .describe("Output format")
306
- });
307
-
308
- // Optional fields with defaults
309
- const PaginationSchema = z.object({
310
- limit: z.number()
311
- .int()
312
- .min(1)
313
- .max(100)
314
- .default(20)
315
- .describe("Maximum results to return"),
316
- offset: z.number()
317
- .int()
318
- .min(0)
319
- .default(0)
320
- .describe("Number of results to skip")
321
- });
322
- ```
323
-
324
- ## Response Format Options
325
-
326
- Support multiple output formats for flexibility:
327
-
328
- ```typescript
329
- enum ResponseFormat {
330
- MARKDOWN = "markdown",
331
- JSON = "json"
332
- }
333
-
334
- const inputSchema = z.object({
335
- query: z.string(),
336
- response_format: z.nativeEnum(ResponseFormat)
337
- .default(ResponseFormat.MARKDOWN)
338
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
339
- });
340
- ```
341
-
342
- **Markdown format**:
343
- - Use headers, lists, and formatting for clarity
344
- - Convert timestamps to human-readable format
345
- - Show display names with IDs in parentheses
346
- - Omit verbose metadata
347
- - Group related information logically
348
-
349
- **JSON format**:
350
- - Return complete, structured data suitable for programmatic processing
351
- - Include all available fields and metadata
352
- - Use consistent field names and types
353
-
354
- ## Pagination Implementation
355
-
356
- For tools that list resources:
357
-
358
- ```typescript
359
- const ListSchema = z.object({
360
- limit: z.number().int().min(1).max(100).default(20),
361
- offset: z.number().int().min(0).default(0)
362
- });
363
-
364
- async function listItems(params: z.infer<typeof ListSchema>) {
365
- const data = await apiRequest(params.limit, params.offset);
366
-
367
- const response = {
368
- total: data.total,
369
- count: data.items.length,
370
- offset: params.offset,
371
- items: data.items,
372
- has_more: data.total > params.offset + data.items.length,
373
- next_offset: data.total > params.offset + data.items.length
374
- ? params.offset + data.items.length
375
- : undefined
376
- };
377
-
378
- return JSON.stringify(response, null, 2);
379
- }
380
- ```
381
-
382
- ## Character Limits and Truncation
383
-
384
- Add a CHARACTER_LIMIT constant to prevent overwhelming responses:
385
-
386
- ```typescript
387
- // At module level in constants.ts
388
- export const CHARACTER_LIMIT = 25000; // Maximum response size in characters
389
-
390
- async function searchTool(params: SearchInput) {
391
- let result = generateResponse(data);
392
-
393
- // Check character limit and truncate if needed
394
- if (result.length > CHARACTER_LIMIT) {
395
- const truncatedData = data.slice(0, Math.max(1, data.length / 2));
396
- response.data = truncatedData;
397
- response.truncated = true;
398
- response.truncation_message =
399
- `Response truncated from ${data.length} to ${truncatedData.length} items. ` +
400
- `Use 'offset' parameter or add filters to see more results.`;
401
- result = JSON.stringify(response, null, 2);
402
- }
403
-
404
- return result;
405
- }
406
- ```
407
-
408
- ## Error Handling
409
-
410
- Provide clear, actionable error messages:
411
-
412
- ```typescript
413
- import axios, { AxiosError } from "axios";
414
-
415
- function handleApiError(error: unknown): string {
416
- if (error instanceof AxiosError) {
417
- if (error.response) {
418
- switch (error.response.status) {
419
- case 404:
420
- return "Error: Resource not found. Please check the ID is correct.";
421
- case 403:
422
- return "Error: Permission denied. You don't have access to this resource.";
423
- case 429:
424
- return "Error: Rate limit exceeded. Please wait before making more requests.";
425
- default:
426
- return `Error: API request failed with status ${error.response.status}`;
427
- }
428
- } else if (error.code === "ECONNABORTED") {
429
- return "Error: Request timed out. Please try again.";
430
- }
431
- }
432
- return `Error: Unexpected error occurred: ${error instanceof Error ? error.message : String(error)}`;
433
- }
434
- ```
435
-
436
- ## Shared Utilities
437
-
438
- Extract common functionality into reusable functions:
439
-
440
- ```typescript
441
- // Shared API request function
442
- async function makeApiRequest<T>(
443
- endpoint: string,
444
- method: "GET" | "POST" | "PUT" | "DELETE" = "GET",
445
- data?: any,
446
- params?: any
447
- ): Promise<T> {
448
- try {
449
- const response = await axios({
450
- method,
451
- url: `${API_BASE_URL}/${endpoint}`,
452
- data,
453
- params,
454
- timeout: 30000,
455
- headers: {
456
- "Content-Type": "application/json",
457
- "Accept": "application/json"
458
- }
459
- });
460
- return response.data;
461
- } catch (error) {
462
- throw error;
463
- }
464
- }
465
- ```
466
-
467
- ## Async/Await Best Practices
468
-
469
- Always use async/await for network requests and I/O operations:
470
-
471
- ```typescript
472
- // Good: Async network request
473
- async function fetchData(resourceId: string): Promise<ResourceData> {
474
- const response = await axios.get(`${API_URL}/resource/${resourceId}`);
475
- return response.data;
476
- }
477
-
478
- // Bad: Promise chains
479
- function fetchData(resourceId: string): Promise<ResourceData> {
480
- return axios.get(`${API_URL}/resource/${resourceId}`)
481
- .then(response => response.data); // Harder to read and maintain
482
- }
483
- ```
484
-
485
- ## TypeScript Best Practices
486
-
487
- 1. **Use Strict TypeScript**: Enable strict mode in tsconfig.json
488
- 2. **Define Interfaces**: Create clear interface definitions for all data structures
489
- 3. **Avoid `any`**: Use proper types or `unknown` instead of `any`
490
- 4. **Zod for Runtime Validation**: Use Zod schemas to validate external data
491
- 5. **Type Guards**: Create type guard functions for complex type checking
492
- 6. **Error Handling**: Always use try-catch with proper error type checking
493
- 7. **Null Safety**: Use optional chaining (`?.`) and nullish coalescing (`??`)
494
-
495
- ```typescript
496
- // Good: Type-safe with Zod and interfaces
497
- interface UserResponse {
498
- id: string;
499
- name: string;
500
- email: string;
501
- team?: string;
502
- active: boolean;
503
- }
504
-
505
- const UserSchema = z.object({
506
- id: z.string(),
507
- name: z.string(),
508
- email: z.string().email(),
509
- team: z.string().optional(),
510
- active: z.boolean()
511
- });
512
-
513
- type User = z.infer<typeof UserSchema>;
514
-
515
- async function getUser(id: string): Promise<User> {
516
- const data = await apiCall(`/users/${id}`);
517
- return UserSchema.parse(data); // Runtime validation
518
- }
519
-
520
- // Bad: Using any
521
- async function getUser(id: string): Promise<any> {
522
- return await apiCall(`/users/${id}`); // No type safety
523
- }
524
- ```
525
-
526
- ## Package Configuration
527
-
528
- ### package.json
529
-
530
- ```json
531
- {
532
- "name": "{service}-mcp-server",
533
- "version": "1.0.0",
534
- "description": "MCP server for {Service} API integration",
535
- "type": "module",
536
- "main": "dist/index.js",
537
- "scripts": {
538
- "start": "node dist/index.js",
539
- "dev": "tsx watch src/index.ts",
540
- "build": "tsc",
541
- "clean": "rm -rf dist"
542
- },
543
- "engines": {
544
- "node": ">=18"
545
- },
546
- "dependencies": {
547
- "@modelcontextprotocol/sdk": "^1.6.1",
548
- "axios": "^1.7.9",
549
- "zod": "^3.23.8"
550
- },
551
- "devDependencies": {
552
- "@types/node": "^22.10.0",
553
- "tsx": "^4.19.2",
554
- "typescript": "^5.7.2"
555
- }
556
- }
557
- ```
558
-
559
- ### tsconfig.json
560
-
561
- ```json
562
- {
563
- "compilerOptions": {
564
- "target": "ES2022",
565
- "module": "Node16",
566
- "moduleResolution": "Node16",
567
- "lib": ["ES2022"],
568
- "outDir": "./dist",
569
- "rootDir": "./src",
570
- "strict": true,
571
- "esModuleInterop": true,
572
- "skipLibCheck": true,
573
- "forceConsistentCasingInFileNames": true,
574
- "declaration": true,
575
- "declarationMap": true,
576
- "sourceMap": true,
577
- "allowSyntheticDefaultImports": true
578
- },
579
- "include": ["src/**/*"],
580
- "exclude": ["node_modules", "dist"]
581
- }
582
- ```
583
-
584
- ## Complete Example
585
-
586
- ```typescript
587
- #!/usr/bin/env node
588
- /**
589
- * MCP Server for Example Service.
590
- *
591
- * This server provides tools to interact with Example API, including user search,
592
- * project management, and data export capabilities.
593
- */
594
-
595
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
596
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
597
- import { z } from "zod";
598
- import axios, { AxiosError } from "axios";
599
-
600
- // Constants
601
- const API_BASE_URL = "https://api.example.com/v1";
602
- const CHARACTER_LIMIT = 25000;
603
-
604
- // Enums
605
- enum ResponseFormat {
606
- MARKDOWN = "markdown",
607
- JSON = "json"
608
- }
609
-
610
- // Zod schemas
611
- const UserSearchInputSchema = z.object({
612
- query: z.string()
613
- .min(2, "Query must be at least 2 characters")
614
- .max(200, "Query must not exceed 200 characters")
615
- .describe("Search string to match against names/emails"),
616
- limit: z.number()
617
- .int()
618
- .min(1)
619
- .max(100)
620
- .default(20)
621
- .describe("Maximum results to return"),
622
- offset: z.number()
623
- .int()
624
- .min(0)
625
- .default(0)
626
- .describe("Number of results to skip for pagination"),
627
- response_format: z.nativeEnum(ResponseFormat)
628
- .default(ResponseFormat.MARKDOWN)
629
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
630
- }).strict();
631
-
632
- type UserSearchInput = z.infer<typeof UserSearchInputSchema>;
633
-
634
- // Shared utility functions
635
- async function makeApiRequest<T>(
636
- endpoint: string,
637
- method: "GET" | "POST" | "PUT" | "DELETE" = "GET",
638
- data?: any,
639
- params?: any
640
- ): Promise<T> {
641
- try {
642
- const response = await axios({
643
- method,
644
- url: `${API_BASE_URL}/${endpoint}`,
645
- data,
646
- params,
647
- timeout: 30000,
648
- headers: {
649
- "Content-Type": "application/json",
650
- "Accept": "application/json"
651
- }
652
- });
653
- return response.data;
654
- } catch (error) {
655
- throw error;
656
- }
657
- }
658
-
659
- function handleApiError(error: unknown): string {
660
- if (error instanceof AxiosError) {
661
- if (error.response) {
662
- switch (error.response.status) {
663
- case 404:
664
- return "Error: Resource not found. Please check the ID is correct.";
665
- case 403:
666
- return "Error: Permission denied. You don't have access to this resource.";
667
- case 429:
668
- return "Error: Rate limit exceeded. Please wait before making more requests.";
669
- default:
670
- return `Error: API request failed with status ${error.response.status}`;
671
- }
672
- } else if (error.code === "ECONNABORTED") {
673
- return "Error: Request timed out. Please try again.";
674
- }
675
- }
676
- return `Error: Unexpected error occurred: ${error instanceof Error ? error.message : String(error)}`;
677
- }
678
-
679
- // Create MCP server instance
680
- const server = new McpServer({
681
- name: "example-mcp",
682
- version: "1.0.0"
683
- });
684
-
685
- // Register tools
686
- server.registerTool(
687
- "example_search_users",
688
- {
689
- title: "Search Example Users",
690
- description: `[Full description as shown above]`,
691
- inputSchema: UserSearchInputSchema,
692
- annotations: {
693
- readOnlyHint: true,
694
- destructiveHint: false,
695
- idempotentHint: true,
696
- openWorldHint: true
697
- }
698
- },
699
- async (params: UserSearchInput) => {
700
- // Implementation as shown above
701
- }
702
- );
703
-
704
- // Main function
705
- // For stdio (local):
706
- async function runStdio() {
707
- if (!process.env.EXAMPLE_API_KEY) {
708
- console.error("ERROR: EXAMPLE_API_KEY environment variable is required");
709
- process.exit(1);
710
- }
711
-
712
- const transport = new StdioServerTransport();
713
- await server.connect(transport);
714
- console.error("MCP server running via stdio");
715
- }
716
-
717
- // For streamable HTTP (remote):
718
- async function runHTTP() {
719
- if (!process.env.EXAMPLE_API_KEY) {
720
- console.error("ERROR: EXAMPLE_API_KEY environment variable is required");
721
- process.exit(1);
722
- }
723
-
724
- const app = express();
725
- app.use(express.json());
726
-
727
- app.post('/mcp', async (req, res) => {
728
- const transport = new StreamableHTTPServerTransport({
729
- sessionIdGenerator: undefined,
730
- enableJsonResponse: true
731
- });
732
- res.on('close', () => transport.close());
733
- await server.connect(transport);
734
- await transport.handleRequest(req, res, req.body);
735
- });
736
-
737
- const port = parseInt(process.env.PORT || '3000');
738
- app.listen(port, () => {
739
- console.error(`MCP server running on http://localhost:${port}/mcp`);
740
- });
741
- }
742
-
743
- // Choose transport based on environment
744
- const transport = process.env.TRANSPORT || 'stdio';
745
- if (transport === 'http') {
746
- runHTTP().catch(error => {
747
- console.error("Server error:", error);
748
- process.exit(1);
749
- });
750
- } else {
751
- runStdio().catch(error => {
752
- console.error("Server error:", error);
753
- process.exit(1);
754
- });
755
- }
756
- ```
757
-
758
- ---
759
-
760
- ## Advanced MCP Features
761
-
762
- ### Resource Registration
763
-
764
- Expose data as resources for efficient, URI-based access:
765
-
766
- ```typescript
767
- import { ResourceTemplate } from "@modelcontextprotocol/sdk/types.js";
768
-
769
- // Register a resource with URI template
770
- server.registerResource(
771
- {
772
- uri: "file://documents/{name}",
773
- name: "Document Resource",
774
- description: "Access documents by name",
775
- mimeType: "text/plain"
776
- },
777
- async (uri: string) => {
778
- // Extract parameter from URI
779
- const match = uri.match(/^file:\/\/documents\/(.+)$/);
780
- if (!match) {
781
- throw new Error("Invalid URI format");
782
- }
783
-
784
- const documentName = match[1];
785
- const content = await loadDocument(documentName);
786
-
787
- return {
788
- contents: [{
789
- uri,
790
- mimeType: "text/plain",
791
- text: content
792
- }]
793
- };
794
- }
795
- );
796
-
797
- // List available resources dynamically
798
- server.registerResourceList(async () => {
799
- const documents = await getAvailableDocuments();
800
- return {
801
- resources: documents.map(doc => ({
802
- uri: `file://documents/${doc.name}`,
803
- name: doc.name,
804
- mimeType: "text/plain",
805
- description: doc.description
806
- }))
807
- };
808
- });
809
- ```
810
-
811
- **When to use Resources vs Tools:**
812
- - **Resources**: For data access with simple URI-based parameters
813
- - **Tools**: For complex operations requiring validation and business logic
814
- - **Resources**: When data is relatively static or template-based
815
- - **Tools**: When operations have side effects or complex workflows
816
-
817
- ### Transport Options
818
-
819
- The TypeScript SDK supports two main transport mechanisms:
820
-
821
- #### Streamable HTTP (Recommended for Remote Servers)
822
-
823
- ```typescript
824
- import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
825
- import express from "express";
826
-
827
- const app = express();
828
- app.use(express.json());
829
-
830
- app.post('/mcp', async (req, res) => {
831
- // Create new transport for each request (stateless, prevents request ID collisions)
832
- const transport = new StreamableHTTPServerTransport({
833
- sessionIdGenerator: undefined,
834
- enableJsonResponse: true
835
- });
836
-
837
- res.on('close', () => transport.close());
838
-
839
- await server.connect(transport);
840
- await transport.handleRequest(req, res, req.body);
841
- });
842
-
843
- app.listen(3000);
844
- ```
845
-
846
- #### stdio (For Local Integrations)
847
-
848
- ```typescript
849
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
850
-
851
- const transport = new StdioServerTransport();
852
- await server.connect(transport);
853
- ```
854
-
855
- **Transport selection:**
856
- - **Streamable HTTP**: Web services, remote access, multiple clients
857
- - **stdio**: Command-line tools, local development, subprocess integration
858
-
859
- ### Notification Support
860
-
861
- Notify clients when server state changes:
862
-
863
- ```typescript
864
- // Notify when tools list changes
865
- server.notification({
866
- method: "notifications/tools/list_changed"
867
- });
868
-
869
- // Notify when resources change
870
- server.notification({
871
- method: "notifications/resources/list_changed"
872
- });
873
- ```
874
-
875
- Use notifications sparingly - only when server capabilities genuinely change.
876
-
877
- ---
878
-
879
- ## Code Best Practices
880
-
881
- ### Code Composability and Reusability
882
-
883
- Your implementation MUST prioritize composability and code reuse:
884
-
885
- 1. **Extract Common Functionality**:
886
- - Create reusable helper functions for operations used across multiple tools
887
- - Build shared API clients for HTTP requests instead of duplicating code
888
- - Centralize error handling logic in utility functions
889
- - Extract business logic into dedicated functions that can be composed
890
- - Extract shared markdown or JSON field selection & formatting functionality
891
-
892
- 2. **Avoid Duplication**:
893
- - NEVER copy-paste similar code between tools
894
- - If you find yourself writing similar logic twice, extract it into a function
895
- - Common operations like pagination, filtering, field selection, and formatting should be shared
896
- - Authentication/authorization logic should be centralized
897
-
898
- ## Building and Running
899
-
900
- Always build your TypeScript code before running:
901
-
902
- ```bash
903
- # Build the project
904
- npm run build
905
-
906
- # Run the server
907
- npm start
908
-
909
- # Development with auto-reload
910
- npm run dev
911
- ```
912
-
913
- Always ensure `npm run build` completes successfully before considering the implementation complete.
914
-
915
- ## Quality Checklist
916
-
917
- Before finalizing your Node/TypeScript MCP server implementation, ensure:
918
-
919
- ### Strategic Design
920
- - [ ] Tools enable complete workflows, not just API endpoint wrappers
921
- - [ ] Tool names reflect natural task subdivisions
922
- - [ ] Response formats optimize for agent context efficiency
923
- - [ ] Human-readable identifiers used where appropriate
924
- - [ ] Error messages guide agents toward correct usage
925
-
926
- ### Implementation Quality
927
- - [ ] FOCUSED IMPLEMENTATION: Most important and valuable tools implemented
928
- - [ ] All tools registered using `registerTool` with complete configuration
929
- - [ ] All tools include `title`, `description`, `inputSchema`, and `annotations`
930
- - [ ] Annotations correctly set (readOnlyHint, destructiveHint, idempotentHint, openWorldHint)
931
- - [ ] All tools use Zod schemas for runtime input validation with `.strict()` enforcement
932
- - [ ] All Zod schemas have proper constraints and descriptive error messages
933
- - [ ] All tools have comprehensive descriptions with explicit input/output types
934
- - [ ] Descriptions include return value examples and complete schema documentation
935
- - [ ] Error messages are clear, actionable, and educational
936
-
937
- ### TypeScript Quality
938
- - [ ] TypeScript interfaces are defined for all data structures
939
- - [ ] Strict TypeScript is enabled in tsconfig.json
940
- - [ ] No use of `any` type - use `unknown` or proper types instead
941
- - [ ] All async functions have explicit Promise<T> return types
942
- - [ ] Error handling uses proper type guards (e.g., `axios.isAxiosError`, `z.ZodError`)
943
-
944
- ### Advanced Features (where applicable)
945
- - [ ] Resources registered for appropriate data endpoints
946
- - [ ] Appropriate transport configured (stdio or streamable HTTP)
947
- - [ ] Notifications implemented for dynamic server capabilities
948
- - [ ] Type-safe with SDK interfaces
949
-
950
- ### Project Configuration
951
- - [ ] Package.json includes all necessary dependencies
952
- - [ ] Build script produces working JavaScript in dist/ directory
953
- - [ ] Main entry point is properly configured as dist/index.js
954
- - [ ] Server name follows format: `{service}-mcp-server`
955
- - [ ] tsconfig.json properly configured with strict mode
956
-
957
- ### Code Quality
958
- - [ ] Pagination is properly implemented where applicable
959
- - [ ] Large responses check CHARACTER_LIMIT constant and truncate with clear messages
960
- - [ ] Filtering options are provided for potentially large result sets
961
- - [ ] All network operations handle timeouts and connection errors gracefully
962
- - [ ] Common functionality is extracted into reusable functions
963
- - [ ] Return types are consistent across similar operations
964
-
965
- ### Testing and Build
966
- - [ ] `npm run build` completes successfully without errors
967
- - [ ] dist/index.js created and executable
968
- - [ ] Server runs: `node dist/index.js --help`
969
- - [ ] All imports resolve correctly
970
- - [ ] Sample tool calls work as expected