codehava-agent-kit 1.0.1 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1164) hide show
  1. package/README.md +79 -37
  2. package/bin/cli.js +2 -6
  3. package/package.json +2 -2
  4. package/templates/.agent/.shared/ACTIVE-template.md +44 -0
  5. package/templates/.agent/.shared/HANDOFF-template.md +75 -0
  6. package/templates/.agent/.shared/MEMORY-schema.md +117 -0
  7. package/templates/.agent/.shared/STATE-template.md +59 -0
  8. package/templates/.agent/.shared/checklists/planning-quality.md +69 -0
  9. package/templates/.agent/.shared/types/api-backend/config.md +25 -0
  10. package/templates/.agent/.shared/types/api-backend/guide.md +41 -0
  11. package/templates/.agent/.shared/types/api-backend/skill-loadout.md +16 -0
  12. package/templates/.agent/.shared/types/application/config.md +27 -0
  13. package/templates/.agent/.shared/types/application/guide.md +51 -0
  14. package/templates/.agent/.shared/types/application/skill-loadout.md +39 -0
  15. package/templates/.agent/.shared/types/campaign/config.md +24 -0
  16. package/templates/.agent/.shared/types/campaign/guide.md +36 -0
  17. package/templates/.agent/.shared/types/campaign/skill-loadout.md +12 -0
  18. package/templates/.agent/.shared/types/utility/config.md +24 -0
  19. package/templates/.agent/.shared/types/utility/guide.md +31 -0
  20. package/templates/.agent/.shared/types/utility/skill-loadout.md +10 -0
  21. package/templates/.agent/.shared/types/workflow/config.md +25 -0
  22. package/templates/.agent/.shared/types/workflow/guide.md +41 -0
  23. package/templates/.agent/.shared/types/workflow/skill-loadout.md +13 -0
  24. package/templates/.agent/AGENTS_INDEX.md +11 -24
  25. package/templates/.agent/SKILLS_INDEX.md +75 -56
  26. package/templates/.agent/agents/backend-specialist.md +12 -0
  27. package/templates/.agent/agents/database-architect.md +11 -0
  28. package/templates/.agent/agents/frontend-specialist.md +12 -0
  29. package/templates/.agent/agents/mobile-developer.md +11 -0
  30. package/templates/.agent/agents/penetration-tester.md +13 -0
  31. package/templates/.agent/agents/test-engineer.md +10 -0
  32. package/templates/.agent/mcp_config.json +32 -15
  33. package/templates/.agent/rules/GEMINI.md +299 -159
  34. package/templates/.agent/skills/3d-web-experience/SKILL.md +259 -0
  35. package/templates/.agent/skills/acceptance-orchestrator/SKILL.md +106 -0
  36. package/templates/.agent/skills/address-github-comments/SKILL.md +61 -0
  37. package/templates/.agent/skills/advogado-especialista/SKILL.md +1109 -0
  38. package/templates/.agent/skills/advogado-especialista/references/fontes.md +139 -0
  39. package/templates/.agent/skills/agent-evaluation/SKILL.md +69 -0
  40. package/templates/.agent/skills/agent-framework-azure-ai-py/SKILL.md +338 -0
  41. package/templates/.agent/skills/agent-manager-skill/SKILL.md +42 -0
  42. package/templates/.agent/skills/agent-memory-mcp/SKILL.md +87 -0
  43. package/templates/.agent/skills/agent-memory-systems/SKILL.md +72 -0
  44. package/templates/.agent/skills/agent-orchestration-improve-agent/SKILL.md +352 -0
  45. package/templates/.agent/skills/agent-orchestration-multi-agent-optimize/SKILL.md +242 -0
  46. package/templates/.agent/skills/agent-orchestrator/SKILL.md +316 -0
  47. package/templates/.agent/skills/agent-orchestrator/references/capability-taxonomy.md +85 -0
  48. package/templates/.agent/skills/agent-orchestrator/references/orchestration-patterns.md +129 -0
  49. package/templates/.agent/skills/agent-orchestrator/scripts/match_skills.py +329 -0
  50. package/templates/.agent/skills/agent-orchestrator/scripts/orchestrate.py +304 -0
  51. package/templates/.agent/skills/agent-orchestrator/scripts/requirements.txt +1 -0
  52. package/templates/.agent/skills/agent-orchestrator/scripts/scan_registry.py +508 -0
  53. package/templates/.agent/skills/agent-tool-builder/SKILL.md +58 -0
  54. package/templates/.agent/skills/agentfolio/SKILL.md +96 -0
  55. package/templates/.agent/skills/agentic-actions-auditor/SKILL.md +332 -0
  56. package/templates/.agent/skills/agentmail/SKILL.md +247 -0
  57. package/templates/.agent/skills/agents-md/SKILL.md +120 -0
  58. package/templates/.agent/skills/agents-v2-py/SKILL.md +326 -0
  59. package/templates/.agent/skills/ai-agent-development/SKILL.md +173 -0
  60. package/templates/.agent/skills/ai-agents-architect/SKILL.md +96 -0
  61. package/templates/.agent/skills/ai-seo/SKILL.md +407 -0
  62. package/templates/.agent/skills/ai-seo/evals/evals.json +90 -0
  63. package/templates/.agent/skills/ai-seo/references/content-patterns.md +285 -0
  64. package/templates/.agent/skills/ai-seo/references/platform-ranking-factors.md +152 -0
  65. package/templates/.agent/skills/airflow-dag-patterns/SKILL.md +44 -0
  66. package/templates/.agent/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  67. package/templates/.agent/skills/akf-trust-metadata/SKILL.md +69 -0
  68. package/templates/.agent/skills/algolia-search/SKILL.md +68 -0
  69. package/templates/.agent/skills/algorithmic-art/LICENSE.txt +202 -0
  70. package/templates/.agent/skills/algorithmic-art/SKILL.md +410 -0
  71. package/templates/.agent/skills/algorithmic-art/templates/generator_template.js +223 -0
  72. package/templates/.agent/skills/algorithmic-art/templates/viewer.html +599 -0
  73. package/templates/.agent/skills/angular-ui-patterns/README.md +55 -0
  74. package/templates/.agent/skills/angular-ui-patterns/SKILL.md +512 -0
  75. package/templates/.agent/skills/angular-ui-patterns/metadata.json +12 -0
  76. package/templates/.agent/skills/antigravity-design-expert/SKILL.md +42 -0
  77. package/templates/.agent/skills/antigravity-skill-orchestrator/README.md +32 -0
  78. package/templates/.agent/skills/antigravity-skill-orchestrator/SKILL.md +123 -0
  79. package/templates/.agent/skills/api-design-principles/SKILL.md +40 -0
  80. package/templates/.agent/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  81. package/templates/.agent/skills/api-design-principles/assets/rest-api-template.py +182 -0
  82. package/templates/.agent/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  83. package/templates/.agent/skills/api-design-principles/references/rest-best-practices.md +408 -0
  84. package/templates/.agent/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  85. package/templates/.agent/skills/api-documentation/SKILL.md +163 -0
  86. package/templates/.agent/skills/api-documentation-generator/SKILL.md +487 -0
  87. package/templates/.agent/skills/api-documenter/SKILL.md +182 -0
  88. package/templates/.agent/skills/api-endpoint-builder/README.md +15 -0
  89. package/templates/.agent/skills/api-endpoint-builder/SKILL.md +324 -0
  90. package/templates/.agent/skills/api-fuzzing-bug-bounty/SKILL.md +437 -0
  91. package/templates/.agent/skills/api-security-best-practices/SKILL.md +910 -0
  92. package/templates/.agent/skills/api-security-testing/SKILL.md +171 -0
  93. package/templates/.agent/skills/api-testing-observability-api-mock/SKILL.md +49 -0
  94. package/templates/.agent/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  95. package/templates/.agent/skills/apify-actor-development/SKILL.md +221 -0
  96. package/templates/.agent/skills/apify-actor-development/references/actor-json.md +66 -0
  97. package/templates/.agent/skills/apify-actor-development/references/dataset-schema.md +209 -0
  98. package/templates/.agent/skills/apify-actor-development/references/input-schema.md +66 -0
  99. package/templates/.agent/skills/apify-actor-development/references/key-value-store-schema.md +129 -0
  100. package/templates/.agent/skills/apify-actor-development/references/logging.md +50 -0
  101. package/templates/.agent/skills/apify-actor-development/references/output-schema.md +49 -0
  102. package/templates/.agent/skills/apify-actor-development/references/standby-mode.md +61 -0
  103. package/templates/.agent/skills/apify-actorization/SKILL.md +185 -0
  104. package/templates/.agent/skills/apify-actorization/references/cli-actorization.md +81 -0
  105. package/templates/.agent/skills/apify-actorization/references/js-ts-actorization.md +111 -0
  106. package/templates/.agent/skills/apify-actorization/references/python-actorization.md +95 -0
  107. package/templates/.agent/skills/apify-actorization/references/schemas-and-output.md +140 -0
  108. package/templates/.agent/skills/apify-audience-analysis/SKILL.md +122 -0
  109. package/templates/.agent/skills/apify-audience-analysis/reference/scripts/run_actor.js +363 -0
  110. package/templates/.agent/skills/apify-brand-reputation-monitoring/SKILL.md +122 -0
  111. package/templates/.agent/skills/apify-brand-reputation-monitoring/reference/scripts/run_actor.js +363 -0
  112. package/templates/.agent/skills/apify-competitor-intelligence/SKILL.md +132 -0
  113. package/templates/.agent/skills/apify-competitor-intelligence/reference/scripts/run_actor.js +363 -0
  114. package/templates/.agent/skills/apify-content-analytics/SKILL.md +121 -0
  115. package/templates/.agent/skills/apify-content-analytics/reference/scripts/run_actor.js +363 -0
  116. package/templates/.agent/skills/apify-ecommerce/SKILL.md +265 -0
  117. package/templates/.agent/skills/apify-ecommerce/reference/scripts/package.json +3 -0
  118. package/templates/.agent/skills/apify-ecommerce/reference/scripts/run_actor.js +369 -0
  119. package/templates/.agent/skills/apify-influencer-discovery/SKILL.md +119 -0
  120. package/templates/.agent/skills/apify-influencer-discovery/reference/scripts/run_actor.js +363 -0
  121. package/templates/.agent/skills/apify-lead-generation/SKILL.md +121 -0
  122. package/templates/.agent/skills/apify-lead-generation/reference/scripts/run_actor.js +363 -0
  123. package/templates/.agent/skills/apify-market-research/SKILL.md +120 -0
  124. package/templates/.agent/skills/apify-market-research/reference/scripts/run_actor.js +363 -0
  125. package/templates/.agent/skills/apify-trend-analysis/SKILL.md +128 -0
  126. package/templates/.agent/skills/apify-trend-analysis/reference/scripts/run_actor.js +363 -0
  127. package/templates/.agent/skills/apify-ultimate-scraper/SKILL.md +231 -0
  128. package/templates/.agent/skills/apify-ultimate-scraper/reference/scripts/run_actor.js +363 -0
  129. package/templates/.agent/skills/app-store-optimization/HOW_TO_USE.md +281 -0
  130. package/templates/.agent/skills/app-store-optimization/README.md +430 -0
  131. package/templates/.agent/skills/app-store-optimization/SKILL.md +409 -0
  132. package/templates/.agent/skills/app-store-optimization/ab_test_planner.py +662 -0
  133. package/templates/.agent/skills/app-store-optimization/aso_scorer.py +482 -0
  134. package/templates/.agent/skills/app-store-optimization/competitor_analyzer.py +577 -0
  135. package/templates/.agent/skills/app-store-optimization/expected_output.json +170 -0
  136. package/templates/.agent/skills/app-store-optimization/keyword_analyzer.py +406 -0
  137. package/templates/.agent/skills/app-store-optimization/launch_checklist.py +739 -0
  138. package/templates/.agent/skills/app-store-optimization/localization_helper.py +588 -0
  139. package/templates/.agent/skills/app-store-optimization/metadata_optimizer.py +581 -0
  140. package/templates/.agent/skills/app-store-optimization/review_analyzer.py +714 -0
  141. package/templates/.agent/skills/app-store-optimization/sample_input.json +30 -0
  142. package/templates/.agent/skills/application-performance-performance-optimization/SKILL.md +157 -0
  143. package/templates/.agent/skills/architect-review/SKILL.md +172 -0
  144. package/templates/.agent/skills/architecture-decision-records/SKILL.md +444 -0
  145. package/templates/.agent/skills/architecture-patterns/SKILL.md +45 -0
  146. package/templates/.agent/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  147. package/templates/.agent/skills/ask-questions-if-underspecified/SKILL.md +86 -0
  148. package/templates/.agent/skills/async-python-patterns/SKILL.md +42 -0
  149. package/templates/.agent/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
  150. package/templates/.agent/skills/auth-implementation-patterns/SKILL.md +42 -0
  151. package/templates/.agent/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
  152. package/templates/.agent/skills/autonomous-agent-patterns/SKILL.md +764 -0
  153. package/templates/.agent/skills/autonomous-agents/SKILL.md +73 -0
  154. package/templates/.agent/skills/aws-cost-cleanup/SKILL.md +310 -0
  155. package/templates/.agent/skills/aws-cost-optimizer/SKILL.md +193 -0
  156. package/templates/.agent/skills/aws-penetration-testing/SKILL.md +409 -0
  157. package/templates/.agent/skills/aws-penetration-testing/references/advanced-aws-pentesting.md +469 -0
  158. package/templates/.agent/skills/aws-serverless/SKILL.md +328 -0
  159. package/templates/.agent/skills/aws-skills/SKILL.md +23 -0
  160. package/templates/.agent/skills/awt-e2e-testing/SKILL.md +30 -0
  161. package/templates/.agent/skills/azure-ai-agents-persistent-dotnet/SKILL.md +353 -0
  162. package/templates/.agent/skills/azure-ai-agents-persistent-java/SKILL.md +140 -0
  163. package/templates/.agent/skills/azure-cosmos-rust/SKILL.md +138 -0
  164. package/templates/.agent/skills/azure-eventhub-rust/SKILL.md +130 -0
  165. package/templates/.agent/skills/azure-identity-rust/SKILL.md +118 -0
  166. package/templates/.agent/skills/azure-keyvault-certificates-rust/SKILL.md +180 -0
  167. package/templates/.agent/skills/azure-keyvault-keys-rust/SKILL.md +170 -0
  168. package/templates/.agent/skills/azure-keyvault-secrets-rust/SKILL.md +145 -0
  169. package/templates/.agent/skills/azure-messaging-webpubsub-java/SKILL.md +307 -0
  170. package/templates/.agent/skills/azure-messaging-webpubsubservice-py/SKILL.md +248 -0
  171. package/templates/.agent/skills/azure-mgmt-apicenter-dotnet/SKILL.md +415 -0
  172. package/templates/.agent/skills/azure-mgmt-apicenter-py/SKILL.md +245 -0
  173. package/templates/.agent/skills/azure-mgmt-apimanagement-dotnet/SKILL.md +314 -0
  174. package/templates/.agent/skills/azure-mgmt-apimanagement-py/SKILL.md +281 -0
  175. package/templates/.agent/skills/azure-mgmt-mongodbatlas-dotnet/SKILL.md +359 -0
  176. package/templates/.agent/skills/azure-microsoft-playwright-testing-ts/SKILL.md +307 -0
  177. package/templates/.agent/skills/azure-security-keyvault-keys-dotnet/SKILL.md +410 -0
  178. package/templates/.agent/skills/azure-security-keyvault-keys-java/SKILL.md +367 -0
  179. package/templates/.agent/skills/azure-security-keyvault-secrets-java/SKILL.md +361 -0
  180. package/templates/.agent/skills/azure-storage-blob-rust/SKILL.md +135 -0
  181. package/templates/.agent/skills/azure-web-pubsub-ts/SKILL.md +315 -0
  182. package/templates/.agent/skills/backend-architect/SKILL.md +329 -0
  183. package/templates/.agent/skills/backend-dev-guidelines/SKILL.md +347 -0
  184. package/templates/.agent/skills/backend-dev-guidelines/resources/architecture-overview.md +451 -0
  185. package/templates/.agent/skills/backend-dev-guidelines/resources/async-and-errors.md +307 -0
  186. package/templates/.agent/skills/backend-dev-guidelines/resources/complete-examples.md +638 -0
  187. package/templates/.agent/skills/backend-dev-guidelines/resources/configuration.md +275 -0
  188. package/templates/.agent/skills/backend-dev-guidelines/resources/database-patterns.md +224 -0
  189. package/templates/.agent/skills/backend-dev-guidelines/resources/middleware-guide.md +213 -0
  190. package/templates/.agent/skills/backend-dev-guidelines/resources/routing-and-controllers.md +756 -0
  191. package/templates/.agent/skills/backend-dev-guidelines/resources/sentry-and-monitoring.md +336 -0
  192. package/templates/.agent/skills/backend-dev-guidelines/resources/services-and-repositories.md +789 -0
  193. package/templates/.agent/skills/backend-dev-guidelines/resources/testing-guide.md +235 -0
  194. package/templates/.agent/skills/backend-dev-guidelines/resources/validation-patterns.md +754 -0
  195. package/templates/.agent/skills/backend-development-feature-development/SKILL.md +183 -0
  196. package/templates/.agent/skills/backend-security-coder/SKILL.md +155 -0
  197. package/templates/.agent/skills/backtesting-frameworks/SKILL.md +42 -0
  198. package/templates/.agent/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
  199. package/templates/.agent/skills/bash-defensive-patterns/SKILL.md +46 -0
  200. package/templates/.agent/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
  201. package/templates/.agent/skills/bats-testing-patterns/SKILL.md +37 -0
  202. package/templates/.agent/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
  203. package/templates/.agent/skills/bazel-build-optimization/SKILL.md +400 -0
  204. package/templates/.agent/skills/binary-analysis-patterns/SKILL.md +453 -0
  205. package/templates/.agent/skills/biopython/SKILL.md +442 -0
  206. package/templates/.agent/skills/broken-authentication/SKILL.md +480 -0
  207. package/templates/.agent/skills/bullmq-specialist/SKILL.md +62 -0
  208. package/templates/.agent/skills/burp-suite-testing/SKILL.md +384 -0
  209. package/templates/.agent/skills/c4-architecture-c4-architecture/SKILL.md +392 -0
  210. package/templates/.agent/skills/canvas-design/LICENSE.txt +202 -0
  211. package/templates/.agent/skills/canvas-design/SKILL.md +135 -0
  212. package/templates/.agent/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  213. package/templates/.agent/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  214. package/templates/.agent/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  215. package/templates/.agent/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  216. package/templates/.agent/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  217. package/templates/.agent/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  218. package/templates/.agent/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  219. package/templates/.agent/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  220. package/templates/.agent/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  221. package/templates/.agent/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  222. package/templates/.agent/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  223. package/templates/.agent/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  224. package/templates/.agent/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  225. package/templates/.agent/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  226. package/templates/.agent/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  227. package/templates/.agent/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  228. package/templates/.agent/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  229. package/templates/.agent/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  230. package/templates/.agent/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  231. package/templates/.agent/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  232. package/templates/.agent/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  233. package/templates/.agent/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  234. package/templates/.agent/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  235. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  236. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  237. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  238. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  239. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  240. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  241. package/templates/.agent/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  242. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  243. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  244. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  245. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  246. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  247. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  248. package/templates/.agent/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  249. package/templates/.agent/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  250. package/templates/.agent/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  251. package/templates/.agent/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  252. package/templates/.agent/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  253. package/templates/.agent/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  254. package/templates/.agent/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  255. package/templates/.agent/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  256. package/templates/.agent/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  257. package/templates/.agent/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  258. package/templates/.agent/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  259. package/templates/.agent/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  260. package/templates/.agent/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  261. package/templates/.agent/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  262. package/templates/.agent/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  263. package/templates/.agent/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  264. package/templates/.agent/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  265. package/templates/.agent/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  266. package/templates/.agent/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  267. package/templates/.agent/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  268. package/templates/.agent/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  269. package/templates/.agent/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  270. package/templates/.agent/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  271. package/templates/.agent/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  272. package/templates/.agent/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  273. package/templates/.agent/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  274. package/templates/.agent/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  275. package/templates/.agent/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  276. package/templates/.agent/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  277. package/templates/.agent/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  278. package/templates/.agent/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  279. package/templates/.agent/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  280. package/templates/.agent/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  281. package/templates/.agent/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  282. package/templates/.agent/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  283. package/templates/.agent/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  284. package/templates/.agent/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  285. package/templates/.agent/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  286. package/templates/.agent/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  287. package/templates/.agent/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  288. package/templates/.agent/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  289. package/templates/.agent/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  290. package/templates/.agent/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  291. package/templates/.agent/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  292. package/templates/.agent/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  293. package/templates/.agent/skills/cc-skill-backend-patterns/SKILL.md +588 -0
  294. package/templates/.agent/skills/cc-skill-frontend-patterns/SKILL.md +637 -0
  295. package/templates/.agent/skills/cc-skill-security-review/SKILL.md +499 -0
  296. package/templates/.agent/skills/cdk-patterns/SKILL.md +78 -0
  297. package/templates/.agent/skills/claude-api/LICENSE.txt +202 -0
  298. package/templates/.agent/skills/claude-api/SKILL.md +252 -0
  299. package/templates/.agent/skills/claude-api/csharp/claude-api.md +70 -0
  300. package/templates/.agent/skills/claude-api/curl/examples.md +164 -0
  301. package/templates/.agent/skills/claude-api/go/claude-api.md +146 -0
  302. package/templates/.agent/skills/claude-api/java/claude-api.md +128 -0
  303. package/templates/.agent/skills/claude-api/php/claude-api.md +88 -0
  304. package/templates/.agent/skills/claude-api/python/agent-sdk/README.md +269 -0
  305. package/templates/.agent/skills/claude-api/python/agent-sdk/patterns.md +319 -0
  306. package/templates/.agent/skills/claude-api/python/claude-api/README.md +404 -0
  307. package/templates/.agent/skills/claude-api/python/claude-api/batches.md +182 -0
  308. package/templates/.agent/skills/claude-api/python/claude-api/files-api.md +162 -0
  309. package/templates/.agent/skills/claude-api/python/claude-api/streaming.md +162 -0
  310. package/templates/.agent/skills/claude-api/python/claude-api/tool-use.md +587 -0
  311. package/templates/.agent/skills/claude-api/ruby/claude-api.md +87 -0
  312. package/templates/.agent/skills/claude-api/shared/error-codes.md +205 -0
  313. package/templates/.agent/skills/claude-api/shared/live-sources.md +121 -0
  314. package/templates/.agent/skills/claude-api/shared/models.md +68 -0
  315. package/templates/.agent/skills/claude-api/shared/tool-use-concepts.md +305 -0
  316. package/templates/.agent/skills/claude-api/typescript/agent-sdk/README.md +220 -0
  317. package/templates/.agent/skills/claude-api/typescript/agent-sdk/patterns.md +150 -0
  318. package/templates/.agent/skills/claude-api/typescript/claude-api/README.md +313 -0
  319. package/templates/.agent/skills/claude-api/typescript/claude-api/batches.md +106 -0
  320. package/templates/.agent/skills/claude-api/typescript/claude-api/files-api.md +98 -0
  321. package/templates/.agent/skills/claude-api/typescript/claude-api/streaming.md +178 -0
  322. package/templates/.agent/skills/claude-api/typescript/claude-api/tool-use.md +477 -0
  323. package/templates/.agent/skills/claude-win11-speckit-update-skill/SKILL.md +23 -0
  324. package/templates/.agent/skills/clerk-auth/SKILL.md +58 -0
  325. package/templates/.agent/skills/cloud-architect/SKILL.md +131 -0
  326. package/templates/.agent/skills/cloud-devops/SKILL.md +235 -0
  327. package/templates/.agent/skills/cloud-penetration-testing/SKILL.md +507 -0
  328. package/templates/.agent/skills/cloud-penetration-testing/references/advanced-cloud-scripts.md +318 -0
  329. package/templates/.agent/skills/cloudflare-workers-expert/SKILL.md +89 -0
  330. package/templates/.agent/skills/code-refactoring-refactor-clean/SKILL.md +54 -0
  331. package/templates/.agent/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
  332. package/templates/.agent/skills/codebase-cleanup-deps-audit/SKILL.md +54 -0
  333. package/templates/.agent/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
  334. package/templates/.agent/skills/codebase-cleanup-refactor-clean/SKILL.md +54 -0
  335. package/templates/.agent/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
  336. package/templates/.agent/skills/codebase-cleanup-tech-debt/SKILL.md +389 -0
  337. package/templates/.agent/skills/computer-use-agents/SKILL.md +320 -0
  338. package/templates/.agent/skills/context-agent/SKILL.md +188 -0
  339. package/templates/.agent/skills/context-agent/references/compression-rules.md +64 -0
  340. package/templates/.agent/skills/context-agent/references/context-format.md +116 -0
  341. package/templates/.agent/skills/context-agent/scripts/active_context.py +227 -0
  342. package/templates/.agent/skills/context-agent/scripts/compressor.py +149 -0
  343. package/templates/.agent/skills/context-agent/scripts/config.py +69 -0
  344. package/templates/.agent/skills/context-agent/scripts/context_loader.py +155 -0
  345. package/templates/.agent/skills/context-agent/scripts/context_manager.py +302 -0
  346. package/templates/.agent/skills/context-agent/scripts/models.py +103 -0
  347. package/templates/.agent/skills/context-agent/scripts/project_registry.py +132 -0
  348. package/templates/.agent/skills/context-agent/scripts/requirements.txt +6 -0
  349. package/templates/.agent/skills/context-agent/scripts/search.py +115 -0
  350. package/templates/.agent/skills/context-agent/scripts/session_parser.py +206 -0
  351. package/templates/.agent/skills/context-agent/scripts/session_summary.py +319 -0
  352. package/templates/.agent/skills/context-optimization/SKILL.md +180 -0
  353. package/templates/.agent/skills/cost-optimization/SKILL.md +289 -0
  354. package/templates/.agent/skills/crypto-bd-agent/SKILL.md +235 -0
  355. package/templates/.agent/skills/database/SKILL.md +212 -0
  356. package/templates/.agent/skills/database-admin/SKILL.md +161 -0
  357. package/templates/.agent/skills/database-architect/SKILL.md +263 -0
  358. package/templates/.agent/skills/database-cloud-optimization-cost-optimize/SKILL.md +47 -0
  359. package/templates/.agent/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  360. package/templates/.agent/skills/database-migration/SKILL.md +439 -0
  361. package/templates/.agent/skills/database-migrations-migration-observability/SKILL.md +420 -0
  362. package/templates/.agent/skills/database-migrations-sql-migrations/SKILL.md +49 -0
  363. package/templates/.agent/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  364. package/templates/.agent/skills/database-optimizer/SKILL.md +163 -0
  365. package/templates/.agent/skills/dbos-golang/AGENTS.md +92 -0
  366. package/templates/.agent/skills/dbos-golang/SKILL.md +126 -0
  367. package/templates/.agent/skills/dbos-golang/references/_sections.md +41 -0
  368. package/templates/.agent/skills/dbos-golang/references/advanced-patching.md +86 -0
  369. package/templates/.agent/skills/dbos-golang/references/advanced-versioning.md +58 -0
  370. package/templates/.agent/skills/dbos-golang/references/client-enqueue.md +65 -0
  371. package/templates/.agent/skills/dbos-golang/references/client-setup.md +65 -0
  372. package/templates/.agent/skills/dbos-golang/references/comm-events.md +69 -0
  373. package/templates/.agent/skills/dbos-golang/references/comm-messages.md +57 -0
  374. package/templates/.agent/skills/dbos-golang/references/comm-streaming.md +75 -0
  375. package/templates/.agent/skills/dbos-golang/references/lifecycle-config.md +70 -0
  376. package/templates/.agent/skills/dbos-golang/references/pattern-debouncing.md +47 -0
  377. package/templates/.agent/skills/dbos-golang/references/pattern-idempotency.md +63 -0
  378. package/templates/.agent/skills/dbos-golang/references/pattern-scheduled.md +69 -0
  379. package/templates/.agent/skills/dbos-golang/references/pattern-sleep.md +52 -0
  380. package/templates/.agent/skills/dbos-golang/references/queue-basics.md +53 -0
  381. package/templates/.agent/skills/dbos-golang/references/queue-concurrency.md +49 -0
  382. package/templates/.agent/skills/dbos-golang/references/queue-deduplication.md +52 -0
  383. package/templates/.agent/skills/dbos-golang/references/queue-listening.md +49 -0
  384. package/templates/.agent/skills/dbos-golang/references/queue-partitioning.md +42 -0
  385. package/templates/.agent/skills/dbos-golang/references/queue-priority.md +45 -0
  386. package/templates/.agent/skills/dbos-golang/references/queue-rate-limiting.md +50 -0
  387. package/templates/.agent/skills/dbos-golang/references/step-basics.md +81 -0
  388. package/templates/.agent/skills/dbos-golang/references/step-concurrency.md +79 -0
  389. package/templates/.agent/skills/dbos-golang/references/step-retries.md +66 -0
  390. package/templates/.agent/skills/dbos-golang/references/test-setup.md +90 -0
  391. package/templates/.agent/skills/dbos-golang/references/workflow-background.md +64 -0
  392. package/templates/.agent/skills/dbos-golang/references/workflow-constraints.md +68 -0
  393. package/templates/.agent/skills/dbos-golang/references/workflow-control.md +48 -0
  394. package/templates/.agent/skills/dbos-golang/references/workflow-determinism.md +51 -0
  395. package/templates/.agent/skills/dbos-golang/references/workflow-introspection.md +64 -0
  396. package/templates/.agent/skills/dbos-golang/references/workflow-timeout.md +38 -0
  397. package/templates/.agent/skills/dbos-python/AGENTS.md +95 -0
  398. package/templates/.agent/skills/dbos-python/SKILL.md +95 -0
  399. package/templates/.agent/skills/dbos-python/references/_sections.md +41 -0
  400. package/templates/.agent/skills/dbos-python/references/advanced-async.md +101 -0
  401. package/templates/.agent/skills/dbos-python/references/advanced-patching.md +68 -0
  402. package/templates/.agent/skills/dbos-python/references/advanced-versioning.md +66 -0
  403. package/templates/.agent/skills/dbos-python/references/client-enqueue.md +54 -0
  404. package/templates/.agent/skills/dbos-python/references/client-setup.md +57 -0
  405. package/templates/.agent/skills/dbos-python/references/comm-events.md +61 -0
  406. package/templates/.agent/skills/dbos-python/references/comm-messages.md +56 -0
  407. package/templates/.agent/skills/dbos-python/references/comm-streaming.md +57 -0
  408. package/templates/.agent/skills/dbos-python/references/lifecycle-config.md +74 -0
  409. package/templates/.agent/skills/dbos-python/references/lifecycle-fastapi.md +66 -0
  410. package/templates/.agent/skills/dbos-python/references/pattern-classes.md +61 -0
  411. package/templates/.agent/skills/dbos-python/references/pattern-debouncing.md +59 -0
  412. package/templates/.agent/skills/dbos-python/references/pattern-idempotency.md +52 -0
  413. package/templates/.agent/skills/dbos-python/references/pattern-scheduled.md +56 -0
  414. package/templates/.agent/skills/dbos-python/references/pattern-sleep.md +58 -0
  415. package/templates/.agent/skills/dbos-python/references/queue-basics.md +60 -0
  416. package/templates/.agent/skills/dbos-python/references/queue-concurrency.md +57 -0
  417. package/templates/.agent/skills/dbos-python/references/queue-deduplication.md +51 -0
  418. package/templates/.agent/skills/dbos-python/references/queue-listening.md +64 -0
  419. package/templates/.agent/skills/dbos-python/references/queue-partitioning.md +62 -0
  420. package/templates/.agent/skills/dbos-python/references/queue-priority.md +62 -0
  421. package/templates/.agent/skills/dbos-python/references/queue-rate-limiting.md +55 -0
  422. package/templates/.agent/skills/dbos-python/references/step-basics.md +53 -0
  423. package/templates/.agent/skills/dbos-python/references/step-retries.md +44 -0
  424. package/templates/.agent/skills/dbos-python/references/step-transactions.md +58 -0
  425. package/templates/.agent/skills/dbos-python/references/test-fixtures.md +63 -0
  426. package/templates/.agent/skills/dbos-python/references/workflow-background.md +58 -0
  427. package/templates/.agent/skills/dbos-python/references/workflow-constraints.md +70 -0
  428. package/templates/.agent/skills/dbos-python/references/workflow-control.md +77 -0
  429. package/templates/.agent/skills/dbos-python/references/workflow-determinism.md +53 -0
  430. package/templates/.agent/skills/dbos-python/references/workflow-introspection.md +68 -0
  431. package/templates/.agent/skills/dbos-python/references/workflow-timeout.md +59 -0
  432. package/templates/.agent/skills/dbos-typescript/AGENTS.md +94 -0
  433. package/templates/.agent/skills/dbos-typescript/SKILL.md +104 -0
  434. package/templates/.agent/skills/dbos-typescript/references/_sections.md +41 -0
  435. package/templates/.agent/skills/dbos-typescript/references/advanced-patching.md +72 -0
  436. package/templates/.agent/skills/dbos-typescript/references/advanced-versioning.md +61 -0
  437. package/templates/.agent/skills/dbos-typescript/references/client-enqueue.md +75 -0
  438. package/templates/.agent/skills/dbos-typescript/references/client-setup.md +60 -0
  439. package/templates/.agent/skills/dbos-typescript/references/comm-events.md +57 -0
  440. package/templates/.agent/skills/dbos-typescript/references/comm-messages.md +55 -0
  441. package/templates/.agent/skills/dbos-typescript/references/comm-streaming.md +53 -0
  442. package/templates/.agent/skills/dbos-typescript/references/lifecycle-config.md +47 -0
  443. package/templates/.agent/skills/dbos-typescript/references/lifecycle-express.md +61 -0
  444. package/templates/.agent/skills/dbos-typescript/references/pattern-classes.md +67 -0
  445. package/templates/.agent/skills/dbos-typescript/references/pattern-debouncing.md +56 -0
  446. package/templates/.agent/skills/dbos-typescript/references/pattern-idempotency.md +53 -0
  447. package/templates/.agent/skills/dbos-typescript/references/pattern-scheduled.md +69 -0
  448. package/templates/.agent/skills/dbos-typescript/references/pattern-sleep.md +59 -0
  449. package/templates/.agent/skills/dbos-typescript/references/queue-basics.md +59 -0
  450. package/templates/.agent/skills/dbos-typescript/references/queue-concurrency.md +53 -0
  451. package/templates/.agent/skills/dbos-typescript/references/queue-deduplication.md +51 -0
  452. package/templates/.agent/skills/dbos-typescript/references/queue-listening.md +63 -0
  453. package/templates/.agent/skills/dbos-typescript/references/queue-partitioning.md +63 -0
  454. package/templates/.agent/skills/dbos-typescript/references/queue-priority.md +48 -0
  455. package/templates/.agent/skills/dbos-typescript/references/queue-rate-limiting.md +44 -0
  456. package/templates/.agent/skills/dbos-typescript/references/step-basics.md +63 -0
  457. package/templates/.agent/skills/dbos-typescript/references/step-retries.md +67 -0
  458. package/templates/.agent/skills/dbos-typescript/references/step-transactions.md +68 -0
  459. package/templates/.agent/skills/dbos-typescript/references/test-setup.md +104 -0
  460. package/templates/.agent/skills/dbos-typescript/references/workflow-background.md +54 -0
  461. package/templates/.agent/skills/dbos-typescript/references/workflow-constraints.md +65 -0
  462. package/templates/.agent/skills/dbos-typescript/references/workflow-control.md +57 -0
  463. package/templates/.agent/skills/dbos-typescript/references/workflow-determinism.md +54 -0
  464. package/templates/.agent/skills/dbos-typescript/references/workflow-introspection.md +70 -0
  465. package/templates/.agent/skills/dbos-typescript/references/workflow-timeout.md +39 -0
  466. package/templates/.agent/skills/dbt-transformation-patterns/SKILL.md +37 -0
  467. package/templates/.agent/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  468. package/templates/.agent/skills/ddd-strategic-design/SKILL.md +52 -0
  469. package/templates/.agent/skills/ddd-strategic-design/references/strategic-design-template.md +22 -0
  470. package/templates/.agent/skills/ddd-tactical-patterns/SKILL.md +53 -0
  471. package/templates/.agent/skills/ddd-tactical-patterns/references/tactical-checklist.md +25 -0
  472. package/templates/.agent/skills/debugger/SKILL.md +53 -0
  473. package/templates/.agent/skills/deployment-pipeline-design/SKILL.md +374 -0
  474. package/templates/.agent/skills/design-md/SKILL.md +179 -0
  475. package/templates/.agent/skills/design-orchestration/SKILL.md +169 -0
  476. package/templates/.agent/skills/design-spells/SKILL.md +36 -0
  477. package/templates/.agent/skills/devops-deploy/SKILL.md +294 -0
  478. package/templates/.agent/skills/devops-troubleshooter/SKILL.md +157 -0
  479. package/templates/.agent/skills/discord-bot-architect/SKILL.md +282 -0
  480. package/templates/.agent/skills/dispatching-parallel-agents/SKILL.md +182 -0
  481. package/templates/.agent/skills/django-access-review/SKILL.md +346 -0
  482. package/templates/.agent/skills/django-perf-review/SKILL.md +398 -0
  483. package/templates/.agent/skills/django-pro/SKILL.md +178 -0
  484. package/templates/.agent/skills/doc-coauthoring/SKILL.md +381 -0
  485. package/templates/.agent/skills/docker-expert/SKILL.md +413 -0
  486. package/templates/.agent/skills/docs-architect/SKILL.md +96 -0
  487. package/templates/.agent/skills/domain-driven-design/SKILL.md +74 -0
  488. package/templates/.agent/skills/domain-driven-design/references/ddd-deliverables.md +24 -0
  489. package/templates/.agent/skills/dotnet-architect/SKILL.md +194 -0
  490. package/templates/.agent/skills/dotnet-backend/SKILL.md +264 -0
  491. package/templates/.agent/skills/dotnet-backend-patterns/SKILL.md +40 -0
  492. package/templates/.agent/skills/dotnet-backend-patterns/assets/repository-template.cs.template +523 -0
  493. package/templates/.agent/skills/dotnet-backend-patterns/assets/service-template.cs.template +336 -0
  494. package/templates/.agent/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
  495. package/templates/.agent/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
  496. package/templates/.agent/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
  497. package/templates/.agent/skills/e2e-testing/SKILL.md +165 -0
  498. package/templates/.agent/skills/e2e-testing-patterns/SKILL.md +44 -0
  499. package/templates/.agent/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  500. package/templates/.agent/skills/enhance-prompt/SKILL.md +206 -0
  501. package/templates/.agent/skills/error-debugging-multi-agent-review/SKILL.md +219 -0
  502. package/templates/.agent/skills/error-handling-patterns/SKILL.md +38 -0
  503. package/templates/.agent/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  504. package/templates/.agent/skills/event-sourcing-architect/SKILL.md +66 -0
  505. package/templates/.agent/skills/event-store-design/SKILL.md +452 -0
  506. package/templates/.agent/skills/event-store-design/resources/implementation-playbook.md +25 -0
  507. package/templates/.agent/skills/expo-api-routes/SKILL.md +370 -0
  508. package/templates/.agent/skills/expo-tailwind-setup/SKILL.md +482 -0
  509. package/templates/.agent/skills/expo-ui-swift-ui/SKILL.md +46 -0
  510. package/templates/.agent/skills/fastapi-pro/SKILL.md +190 -0
  511. package/templates/.agent/skills/fastapi-router-py/SKILL.md +58 -0
  512. package/templates/.agent/skills/fastapi-templates/SKILL.md +35 -0
  513. package/templates/.agent/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  514. package/templates/.agent/skills/ffuf-web-fuzzing/SKILL.md +500 -0
  515. package/templates/.agent/skills/figma-automation/SKILL.md +185 -0
  516. package/templates/.agent/skills/firebase/SKILL.md +61 -0
  517. package/templates/.agent/skills/fixing-motion-performance/SKILL.md +152 -0
  518. package/templates/.agent/skills/flutter-expert/SKILL.md +197 -0
  519. package/templates/.agent/skills/food-database-query/SKILL.md +787 -0
  520. package/templates/.agent/skills/fp-backend/SKILL.md +1334 -0
  521. package/templates/.agent/skills/fp-react/SKILL.md +792 -0
  522. package/templates/.agent/skills/fp-ts-react/SKILL.md +797 -0
  523. package/templates/.agent/skills/frontend-design/LICENSE.txt +177 -0
  524. package/templates/.agent/skills/frontend-dev-guidelines/SKILL.md +364 -0
  525. package/templates/.agent/skills/frontend-dev-guidelines/resources/common-patterns.md +331 -0
  526. package/templates/.agent/skills/frontend-dev-guidelines/resources/complete-examples.md +872 -0
  527. package/templates/.agent/skills/frontend-dev-guidelines/resources/component-patterns.md +502 -0
  528. package/templates/.agent/skills/frontend-dev-guidelines/resources/data-fetching.md +767 -0
  529. package/templates/.agent/skills/frontend-dev-guidelines/resources/file-organization.md +502 -0
  530. package/templates/.agent/skills/frontend-dev-guidelines/resources/loading-and-error-states.md +501 -0
  531. package/templates/.agent/skills/frontend-dev-guidelines/resources/performance.md +406 -0
  532. package/templates/.agent/skills/frontend-dev-guidelines/resources/routing-guide.md +364 -0
  533. package/templates/.agent/skills/frontend-dev-guidelines/resources/styling-guide.md +428 -0
  534. package/templates/.agent/skills/frontend-dev-guidelines/resources/typescript-standards.md +418 -0
  535. package/templates/.agent/skills/frontend-developer/SKILL.md +169 -0
  536. package/templates/.agent/skills/frontend-mobile-development-component-scaffold/SKILL.md +406 -0
  537. package/templates/.agent/skills/frontend-mobile-security-xss-scan/SKILL.md +325 -0
  538. package/templates/.agent/skills/frontend-security-coder/SKILL.md +168 -0
  539. package/templates/.agent/skills/frontend-slides/SKILL.md +236 -0
  540. package/templates/.agent/skills/frontend-slides/STYLE_PRESETS.md +347 -0
  541. package/templates/.agent/skills/frontend-slides/animation-patterns.md +110 -0
  542. package/templates/.agent/skills/frontend-slides/html-template.md +347 -0
  543. package/templates/.agent/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  544. package/templates/.agent/skills/frontend-slides/viewport-base.css +153 -0
  545. package/templates/.agent/skills/frontend-ui-dark-ts/SKILL.md +594 -0
  546. package/templates/.agent/skills/gemini-api-dev/SKILL.md +133 -0
  547. package/templates/.agent/skills/gemini-api-integration/SKILL.md +188 -0
  548. package/templates/.agent/skills/gha-security-review/SKILL.md +188 -0
  549. package/templates/.agent/skills/git-advanced-workflows/SKILL.md +415 -0
  550. package/templates/.agent/skills/git-hooks-automation/SKILL.md +416 -0
  551. package/templates/.agent/skills/git-pr-workflows-git-workflow/SKILL.md +143 -0
  552. package/templates/.agent/skills/git-pr-workflows-onboard/SKILL.md +419 -0
  553. package/templates/.agent/skills/git-pr-workflows-pr-enhance/SKILL.md +51 -0
  554. package/templates/.agent/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
  555. package/templates/.agent/skills/git-pushing/SKILL.md +35 -0
  556. package/templates/.agent/skills/git-pushing/scripts/smart_commit.sh +19 -0
  557. package/templates/.agent/skills/github/SKILL.md +76 -0
  558. package/templates/.agent/skills/github/agents/openai.yaml +4 -0
  559. package/templates/.agent/skills/github-actions-templates/SKILL.md +348 -0
  560. package/templates/.agent/skills/github-automation/SKILL.md +230 -0
  561. package/templates/.agent/skills/github-issue-creator/SKILL.md +143 -0
  562. package/templates/.agent/skills/github-workflow-automation/SKILL.md +849 -0
  563. package/templates/.agent/skills/gitlab-automation/SKILL.md +257 -0
  564. package/templates/.agent/skills/gitlab-ci-patterns/SKILL.md +286 -0
  565. package/templates/.agent/skills/gitops-workflow/SKILL.md +306 -0
  566. package/templates/.agent/skills/gitops-workflow/references/argocd-setup.md +134 -0
  567. package/templates/.agent/skills/gitops-workflow/references/sync-policies.md +131 -0
  568. package/templates/.agent/skills/go-concurrency-patterns/SKILL.md +36 -0
  569. package/templates/.agent/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
  570. package/templates/.agent/skills/go-playwright/SKILL.md +76 -0
  571. package/templates/.agent/skills/go-playwright/resources/implementation-playbook.md +110 -0
  572. package/templates/.agent/skills/go-rod-master/SKILL.md +545 -0
  573. package/templates/.agent/skills/go-rod-master/examples/basic_scrape.go +41 -0
  574. package/templates/.agent/skills/go-rod-master/examples/concurrent_pages.go +81 -0
  575. package/templates/.agent/skills/go-rod-master/examples/request_hijacking.go +85 -0
  576. package/templates/.agent/skills/go-rod-master/examples/stealth_page.go +91 -0
  577. package/templates/.agent/skills/go-rod-master/references/api-reference.md +148 -0
  578. package/templates/.agent/skills/goal-analyzer/SKILL.md +607 -0
  579. package/templates/.agent/skills/godot-4-migration/SKILL.md +127 -0
  580. package/templates/.agent/skills/godot-gdscript-patterns/SKILL.md +36 -0
  581. package/templates/.agent/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
  582. package/templates/.agent/skills/golang-pro/SKILL.md +176 -0
  583. package/templates/.agent/skills/google-analytics-automation/SKILL.md +231 -0
  584. package/templates/.agent/skills/google-calendar-automation/SKILL.md +158 -0
  585. package/templates/.agent/skills/google-docs-automation/SKILL.md +81 -0
  586. package/templates/.agent/skills/google-drive-automation/SKILL.md +135 -0
  587. package/templates/.agent/skills/google-sheets-automation/SKILL.md +144 -0
  588. package/templates/.agent/skills/google-slides-automation/SKILL.md +140 -0
  589. package/templates/.agent/skills/googlesheets-automation/SKILL.md +200 -0
  590. package/templates/.agent/skills/graphql-architect/SKILL.md +180 -0
  591. package/templates/.agent/skills/grpc-golang/SKILL.md +104 -0
  592. package/templates/.agent/skills/grpc-golang/resources/implementation-playbook.md +548 -0
  593. package/templates/.agent/skills/hierarchical-agent-memory/SKILL.md +133 -0
  594. package/templates/.agent/skills/hig-patterns/SKILL.md +99 -0
  595. package/templates/.agent/skills/hig-patterns/references/charting-data.md +81 -0
  596. package/templates/.agent/skills/hig-patterns/references/collaboration-and-sharing.md +86 -0
  597. package/templates/.agent/skills/hig-patterns/references/drag-and-drop.md +134 -0
  598. package/templates/.agent/skills/hig-patterns/references/entering-data.md +69 -0
  599. package/templates/.agent/skills/hig-patterns/references/feedback.md +67 -0
  600. package/templates/.agent/skills/hig-patterns/references/file-management.md +135 -0
  601. package/templates/.agent/skills/hig-patterns/references/going-full-screen.md +79 -0
  602. package/templates/.agent/skills/hig-patterns/references/launching.md +81 -0
  603. package/templates/.agent/skills/hig-patterns/references/live-viewing-apps.md +79 -0
  604. package/templates/.agent/skills/hig-patterns/references/loading.md +59 -0
  605. package/templates/.agent/skills/hig-patterns/references/managing-accounts.md +107 -0
  606. package/templates/.agent/skills/hig-patterns/references/managing-notifications.md +99 -0
  607. package/templates/.agent/skills/hig-patterns/references/modality.md +82 -0
  608. package/templates/.agent/skills/hig-patterns/references/multitasking.md +131 -0
  609. package/templates/.agent/skills/hig-patterns/references/offering-help.md +117 -0
  610. package/templates/.agent/skills/hig-patterns/references/onboarding.md +69 -0
  611. package/templates/.agent/skills/hig-patterns/references/playing-audio.md +124 -0
  612. package/templates/.agent/skills/hig-patterns/references/playing-haptics.md +280 -0
  613. package/templates/.agent/skills/hig-patterns/references/playing-video.md +180 -0
  614. package/templates/.agent/skills/hig-patterns/references/printing.md +50 -0
  615. package/templates/.agent/skills/hig-patterns/references/ratings-and-reviews.md +48 -0
  616. package/templates/.agent/skills/hig-patterns/references/searching.md +70 -0
  617. package/templates/.agent/skills/hig-patterns/references/settings.md +84 -0
  618. package/templates/.agent/skills/hig-patterns/references/undo-and-redo.md +58 -0
  619. package/templates/.agent/skills/hig-patterns/references/workouts.md +76 -0
  620. package/templates/.agent/skills/hosted-agents/SKILL.md +283 -0
  621. package/templates/.agent/skills/hosted-agents-v2-py/SKILL.md +326 -0
  622. package/templates/.agent/skills/html-injection-testing/SKILL.md +502 -0
  623. package/templates/.agent/skills/hybrid-cloud-architect/SKILL.md +164 -0
  624. package/templates/.agent/skills/idor-testing/SKILL.md +446 -0
  625. package/templates/.agent/skills/intelligent-routing/SKILL.md +41 -44
  626. package/templates/.agent/skills/ios-debugger-agent/SKILL.md +59 -0
  627. package/templates/.agent/skills/ios-debugger-agent/agents/openai.yaml +4 -0
  628. package/templates/.agent/skills/javascript-mastery/SKILL.md +648 -0
  629. package/templates/.agent/skills/javascript-pro/SKILL.md +55 -0
  630. package/templates/.agent/skills/javascript-testing-patterns/SKILL.md +38 -0
  631. package/templates/.agent/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  632. package/templates/.agent/skills/javascript-typescript-typescript-scaffold/SKILL.md +364 -0
  633. package/templates/.agent/skills/k6-load-testing/SKILL.md +627 -0
  634. package/templates/.agent/skills/k8s-security-policies/SKILL.md +349 -0
  635. package/templates/.agent/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
  636. package/templates/.agent/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
  637. package/templates/.agent/skills/kpi-dashboard-design/SKILL.md +443 -0
  638. package/templates/.agent/skills/kubernetes-architect/SKILL.md +165 -0
  639. package/templates/.agent/skills/kubernetes-deployment/SKILL.md +166 -0
  640. package/templates/.agent/skills/langchain-architecture/SKILL.md +353 -0
  641. package/templates/.agent/skills/laravel-security-audit/SKILL.md +224 -0
  642. package/templates/.agent/skills/lightning-architecture-review/SKILL.md +52 -0
  643. package/templates/.agent/skills/linkerd-patterns/SKILL.md +326 -0
  644. package/templates/.agent/skills/linux-privilege-escalation/SKILL.md +510 -0
  645. package/templates/.agent/skills/linux-shell-scripting/SKILL.md +508 -0
  646. package/templates/.agent/skills/linux-troubleshooting/SKILL.md +220 -0
  647. package/templates/.agent/skills/llm-app-patterns/SKILL.md +763 -0
  648. package/templates/.agent/skills/llm-application-dev-langchain-agent/SKILL.md +249 -0
  649. package/templates/.agent/skills/llm-application-dev-prompt-optimize/SKILL.md +40 -0
  650. package/templates/.agent/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
  651. package/templates/.agent/skills/llm-prompt-optimizer/SKILL.md +182 -0
  652. package/templates/.agent/skills/local-legal-seo-audit/SKILL.md +347 -0
  653. package/templates/.agent/skills/m365-agents-dotnet/SKILL.md +294 -0
  654. package/templates/.agent/skills/m365-agents-py/SKILL.md +345 -0
  655. package/templates/.agent/skills/m365-agents-ts/SKILL.md +186 -0
  656. package/templates/.agent/skills/memory-safety-patterns/SKILL.md +36 -0
  657. package/templates/.agent/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
  658. package/templates/.agent/skills/microservices-patterns/SKILL.md +38 -0
  659. package/templates/.agent/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
  660. package/templates/.agent/skills/microsoft-azure-webjobs-extensions-authentication-events-dotnet/SKILL.md +445 -0
  661. package/templates/.agent/skills/mobile-developer/SKILL.md +203 -0
  662. package/templates/.agent/skills/mobile-security-coder/SKILL.md +182 -0
  663. package/templates/.agent/skills/modern-javascript-patterns/SKILL.md +38 -0
  664. package/templates/.agent/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
  665. package/templates/.agent/skills/monorepo-architect/SKILL.md +64 -0
  666. package/templates/.agent/skills/moodle-external-api-development/SKILL.md +600 -0
  667. package/templates/.agent/skills/multi-agent-brainstorming/SKILL.md +256 -0
  668. package/templates/.agent/skills/multi-agent-patterns/SKILL.md +256 -0
  669. package/templates/.agent/skills/multi-cloud-architecture/SKILL.md +192 -0
  670. package/templates/.agent/skills/n8n-code-javascript/SKILL.md +701 -0
  671. package/templates/.agent/skills/n8n-code-python/SKILL.md +750 -0
  672. package/templates/.agent/skills/n8n-node-configuration/SKILL.md +787 -0
  673. package/templates/.agent/skills/n8n-workflow-patterns/SKILL.md +413 -0
  674. package/templates/.agent/skills/nextjs-app-router-patterns/SKILL.md +36 -0
  675. package/templates/.agent/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
  676. package/templates/.agent/skills/nextjs-best-practices/SKILL.md +208 -0
  677. package/templates/.agent/skills/nextjs-supabase-auth/SKILL.md +61 -0
  678. package/templates/.agent/skills/nodejs-backend-patterns/SKILL.md +38 -0
  679. package/templates/.agent/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  680. package/templates/.agent/skills/nx-workspace-patterns/SKILL.md +467 -0
  681. package/templates/.agent/skills/odoo-docker-deployment/SKILL.md +139 -0
  682. package/templates/.agent/skills/odoo-performance-tuner/SKILL.md +105 -0
  683. package/templates/.agent/skills/odoo-qweb-templates/SKILL.md +95 -0
  684. package/templates/.agent/skills/odoo-rpc-api/SKILL.md +103 -0
  685. package/templates/.agent/skills/odoo-security-rules/SKILL.md +92 -0
  686. package/templates/.agent/skills/on-call-handoff-patterns/SKILL.md +456 -0
  687. package/templates/.agent/skills/openapi-spec-generation/SKILL.md +36 -0
  688. package/templates/.agent/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  689. package/templates/.agent/skills/openclaw-github-repo-commander/SKILL.md +95 -0
  690. package/templates/.agent/skills/performance-engineer/SKILL.md +176 -0
  691. package/templates/.agent/skills/performance-optimizer/README.md +20 -0
  692. package/templates/.agent/skills/performance-optimizer/SKILL.md +389 -0
  693. package/templates/.agent/skills/performance-testing-review-ai-review/SKILL.md +453 -0
  694. package/templates/.agent/skills/performance-testing-review-multi-agent-review/SKILL.md +219 -0
  695. package/templates/.agent/skills/pipecat-friday-agent/SKILL.md +79 -0
  696. package/templates/.agent/skills/pipecat-friday-agent/scripts/friday_agent.py +146 -0
  697. package/templates/.agent/skills/postgresql-optimization/SKILL.md +174 -0
  698. package/templates/.agent/skills/prisma-expert/SKILL.md +361 -0
  699. package/templates/.agent/skills/privacy-by-design/README.md +25 -0
  700. package/templates/.agent/skills/privacy-by-design/SKILL.md +208 -0
  701. package/templates/.agent/skills/product-design/SKILL.md +358 -0
  702. package/templates/.agent/skills/programmatic-seo/SKILL.md +351 -0
  703. package/templates/.agent/skills/progressive-web-app/SKILL.md +352 -0
  704. package/templates/.agent/skills/projection-patterns/SKILL.md +36 -0
  705. package/templates/.agent/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  706. package/templates/.agent/skills/prompt-caching/SKILL.md +66 -0
  707. package/templates/.agent/skills/prompt-engineer/README.md +659 -0
  708. package/templates/.agent/skills/prompt-engineer/SKILL.md +248 -0
  709. package/templates/.agent/skills/prompt-engineering/SKILL.md +177 -0
  710. package/templates/.agent/skills/prompt-engineering-patterns/SKILL.md +216 -0
  711. package/templates/.agent/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  712. package/templates/.agent/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
  713. package/templates/.agent/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
  714. package/templates/.agent/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
  715. package/templates/.agent/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
  716. package/templates/.agent/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
  717. package/templates/.agent/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
  718. package/templates/.agent/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  719. package/templates/.agent/skills/prompt-library/SKILL.md +325 -0
  720. package/templates/.agent/skills/pubmed-database/SKILL.md +460 -0
  721. package/templates/.agent/skills/python-development-python-scaffold/SKILL.md +334 -0
  722. package/templates/.agent/skills/python-fastapi-development/SKILL.md +215 -0
  723. package/templates/.agent/skills/python-packaging/SKILL.md +39 -0
  724. package/templates/.agent/skills/python-packaging/resources/implementation-playbook.md +869 -0
  725. package/templates/.agent/skills/python-performance-optimization/SKILL.md +39 -0
  726. package/templates/.agent/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
  727. package/templates/.agent/skills/python-pro/SKILL.md +156 -0
  728. package/templates/.agent/skills/python-testing-patterns/SKILL.md +40 -0
  729. package/templates/.agent/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
  730. package/templates/.agent/skills/radix-ui-design-system/SKILL.md +848 -0
  731. package/templates/.agent/skills/radix-ui-design-system/examples/README.md +63 -0
  732. package/templates/.agent/skills/radix-ui-design-system/examples/dialog-example.tsx +128 -0
  733. package/templates/.agent/skills/radix-ui-design-system/examples/dropdown-example.tsx +162 -0
  734. package/templates/.agent/skills/radix-ui-design-system/templates/component-template.tsx.template +148 -0
  735. package/templates/.agent/skills/react-best-practices/AGENTS.md +2249 -0
  736. package/templates/.agent/skills/react-best-practices/README.md +123 -0
  737. package/templates/.agent/skills/react-best-practices/SKILL.md +126 -0
  738. package/templates/.agent/skills/react-best-practices/metadata.json +15 -0
  739. package/templates/.agent/skills/react-best-practices/rules/_sections.md +46 -0
  740. package/templates/.agent/skills/react-best-practices/rules/_template.md +28 -0
  741. package/templates/.agent/skills/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  742. package/templates/.agent/skills/react-best-practices/rules/advanced-use-latest.md +49 -0
  743. package/templates/.agent/skills/react-best-practices/rules/async-api-routes.md +38 -0
  744. package/templates/.agent/skills/react-best-practices/rules/async-defer-await.md +80 -0
  745. package/templates/.agent/skills/react-best-practices/rules/async-dependencies.md +36 -0
  746. package/templates/.agent/skills/react-best-practices/rules/async-parallel.md +28 -0
  747. package/templates/.agent/skills/react-best-practices/rules/async-suspense-boundaries.md +99 -0
  748. package/templates/.agent/skills/react-best-practices/rules/bundle-barrel-imports.md +59 -0
  749. package/templates/.agent/skills/react-best-practices/rules/bundle-conditional.md +31 -0
  750. package/templates/.agent/skills/react-best-practices/rules/bundle-defer-third-party.md +49 -0
  751. package/templates/.agent/skills/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  752. package/templates/.agent/skills/react-best-practices/rules/bundle-preload.md +50 -0
  753. package/templates/.agent/skills/react-best-practices/rules/client-event-listeners.md +74 -0
  754. package/templates/.agent/skills/react-best-practices/rules/client-swr-dedup.md +56 -0
  755. package/templates/.agent/skills/react-best-practices/rules/js-batch-dom-css.md +82 -0
  756. package/templates/.agent/skills/react-best-practices/rules/js-cache-function-results.md +80 -0
  757. package/templates/.agent/skills/react-best-practices/rules/js-cache-property-access.md +28 -0
  758. package/templates/.agent/skills/react-best-practices/rules/js-cache-storage.md +70 -0
  759. package/templates/.agent/skills/react-best-practices/rules/js-combine-iterations.md +32 -0
  760. package/templates/.agent/skills/react-best-practices/rules/js-early-exit.md +50 -0
  761. package/templates/.agent/skills/react-best-practices/rules/js-hoist-regexp.md +45 -0
  762. package/templates/.agent/skills/react-best-practices/rules/js-index-maps.md +37 -0
  763. package/templates/.agent/skills/react-best-practices/rules/js-length-check-first.md +49 -0
  764. package/templates/.agent/skills/react-best-practices/rules/js-min-max-loop.md +82 -0
  765. package/templates/.agent/skills/react-best-practices/rules/js-set-map-lookups.md +24 -0
  766. package/templates/.agent/skills/react-best-practices/rules/js-tosorted-immutable.md +57 -0
  767. package/templates/.agent/skills/react-best-practices/rules/rendering-activity.md +26 -0
  768. package/templates/.agent/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  769. package/templates/.agent/skills/react-best-practices/rules/rendering-conditional-render.md +40 -0
  770. package/templates/.agent/skills/react-best-practices/rules/rendering-content-visibility.md +38 -0
  771. package/templates/.agent/skills/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  772. package/templates/.agent/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  773. package/templates/.agent/skills/react-best-practices/rules/rendering-svg-precision.md +28 -0
  774. package/templates/.agent/skills/react-best-practices/rules/rerender-defer-reads.md +39 -0
  775. package/templates/.agent/skills/react-best-practices/rules/rerender-dependencies.md +45 -0
  776. package/templates/.agent/skills/react-best-practices/rules/rerender-derived-state.md +29 -0
  777. package/templates/.agent/skills/react-best-practices/rules/rerender-functional-setstate.md +74 -0
  778. package/templates/.agent/skills/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  779. package/templates/.agent/skills/react-best-practices/rules/rerender-memo.md +44 -0
  780. package/templates/.agent/skills/react-best-practices/rules/rerender-transitions.md +40 -0
  781. package/templates/.agent/skills/react-best-practices/rules/server-after-nonblocking.md +73 -0
  782. package/templates/.agent/skills/react-best-practices/rules/server-cache-lru.md +41 -0
  783. package/templates/.agent/skills/react-best-practices/rules/server-cache-react.md +26 -0
  784. package/templates/.agent/skills/react-best-practices/rules/server-parallel-fetching.md +79 -0
  785. package/templates/.agent/skills/react-best-practices/rules/server-serialization.md +38 -0
  786. package/templates/.agent/skills/react-component-performance/SKILL.md +135 -0
  787. package/templates/.agent/skills/react-component-performance/agents/openai.yaml +4 -0
  788. package/templates/.agent/skills/react-component-performance/references/examples.md +88 -0
  789. package/templates/.agent/skills/react-flow-architect/SKILL.md +619 -0
  790. package/templates/.agent/skills/react-flow-node-ts/SKILL.md +72 -0
  791. package/templates/.agent/skills/react-modernization/SKILL.md +37 -0
  792. package/templates/.agent/skills/react-modernization/resources/implementation-playbook.md +512 -0
  793. package/templates/.agent/skills/react-native-architecture/SKILL.md +36 -0
  794. package/templates/.agent/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
  795. package/templates/.agent/skills/react-nextjs-development/SKILL.md +228 -0
  796. package/templates/.agent/skills/react-patterns/SKILL.md +203 -0
  797. package/templates/.agent/skills/react-state-management/SKILL.md +444 -0
  798. package/templates/.agent/skills/react-ui-patterns/SKILL.md +295 -0
  799. package/templates/.agent/skills/robius-app-architecture/SKILL.md +330 -0
  800. package/templates/.agent/skills/robius-widget-patterns/SKILL.md +428 -0
  801. package/templates/.agent/skills/rust-async-patterns/SKILL.md +36 -0
  802. package/templates/.agent/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
  803. package/templates/.agent/skills/screen-reader-testing/SKILL.md +36 -0
  804. package/templates/.agent/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
  805. package/templates/.agent/skills/search-specialist/SKILL.md +78 -0
  806. package/templates/.agent/skills/security/aws-compliance-checker/SKILL.md +516 -0
  807. package/templates/.agent/skills/security/aws-iam-best-practices/SKILL.md +397 -0
  808. package/templates/.agent/skills/security/aws-secrets-rotation/SKILL.md +465 -0
  809. package/templates/.agent/skills/security/aws-security-audit/SKILL.md +369 -0
  810. package/templates/.agent/skills/security-audit/SKILL.md +217 -0
  811. package/templates/.agent/skills/security-auditor/SKILL.md +165 -0
  812. package/templates/.agent/skills/security-bluebook-builder/SKILL.md +48 -0
  813. package/templates/.agent/skills/security-compliance-compliance-check/SKILL.md +58 -0
  814. package/templates/.agent/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
  815. package/templates/.agent/skills/security-requirement-extraction/SKILL.md +36 -0
  816. package/templates/.agent/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  817. package/templates/.agent/skills/security-scanning-security-dependencies/SKILL.md +46 -0
  818. package/templates/.agent/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
  819. package/templates/.agent/skills/security-scanning-security-hardening/SKILL.md +150 -0
  820. package/templates/.agent/skills/security-scanning-security-sast/SKILL.md +496 -0
  821. package/templates/.agent/skills/senior-architect/SKILL.md +215 -0
  822. package/templates/.agent/skills/senior-architect/references/architecture_patterns.md +103 -0
  823. package/templates/.agent/skills/senior-architect/references/system_design_workflows.md +103 -0
  824. package/templates/.agent/skills/senior-architect/references/tech_decision_guide.md +103 -0
  825. package/templates/.agent/skills/senior-architect/scripts/architecture_diagram_generator.py +114 -0
  826. package/templates/.agent/skills/senior-architect/scripts/dependency_analyzer.py +114 -0
  827. package/templates/.agent/skills/senior-architect/scripts/project_architect.py +114 -0
  828. package/templates/.agent/skills/senior-frontend/SKILL.md +490 -0
  829. package/templates/.agent/skills/senior-frontend/references/frontend_best_practices.md +806 -0
  830. package/templates/.agent/skills/senior-frontend/references/nextjs_optimization_guide.md +724 -0
  831. package/templates/.agent/skills/senior-frontend/references/react_patterns.md +746 -0
  832. package/templates/.agent/skills/senior-frontend/scripts/bundle_analyzer.py +407 -0
  833. package/templates/.agent/skills/senior-frontend/scripts/component_generator.py +329 -0
  834. package/templates/.agent/skills/senior-frontend/scripts/frontend_scaffolder.py +1005 -0
  835. package/templates/.agent/skills/seo/SKILL.md +139 -0
  836. package/templates/.agent/skills/seo/references/cwv-thresholds.md +108 -0
  837. package/templates/.agent/skills/seo/references/eeat-framework.md +214 -0
  838. package/templates/.agent/skills/seo/references/quality-gates.md +155 -0
  839. package/templates/.agent/skills/seo/references/schema-types.md +118 -0
  840. package/templates/.agent/skills/seo-audit/SKILL.md +487 -0
  841. package/templates/.agent/skills/seo-authority-builder/SKILL.md +141 -0
  842. package/templates/.agent/skills/seo-cannibalization-detector/SKILL.md +122 -0
  843. package/templates/.agent/skills/seo-competitor-pages/SKILL.md +229 -0
  844. package/templates/.agent/skills/seo-content/SKILL.md +186 -0
  845. package/templates/.agent/skills/seo-content-auditor/SKILL.md +82 -0
  846. package/templates/.agent/skills/seo-content-planner/SKILL.md +113 -0
  847. package/templates/.agent/skills/seo-content-refresher/SKILL.md +117 -0
  848. package/templates/.agent/skills/seo-content-writer/SKILL.md +95 -0
  849. package/templates/.agent/skills/seo-dataforseo/SKILL.md +395 -0
  850. package/templates/.agent/skills/seo-forensic-incident-response/SKILL.md +261 -0
  851. package/templates/.agent/skills/seo-geo/SKILL.md +254 -0
  852. package/templates/.agent/skills/seo-hreflang/SKILL.md +209 -0
  853. package/templates/.agent/skills/seo-image-gen/SKILL.md +183 -0
  854. package/templates/.agent/skills/seo-images/SKILL.md +193 -0
  855. package/templates/.agent/skills/seo-keyword-strategist/SKILL.md +94 -0
  856. package/templates/.agent/skills/seo-meta-optimizer/SKILL.md +91 -0
  857. package/templates/.agent/skills/seo-page/SKILL.md +103 -0
  858. package/templates/.agent/skills/seo-plan/SKILL.md +136 -0
  859. package/templates/.agent/skills/seo-plan/assets/agency.md +175 -0
  860. package/templates/.agent/skills/seo-plan/assets/ecommerce.md +167 -0
  861. package/templates/.agent/skills/seo-plan/assets/generic.md +144 -0
  862. package/templates/.agent/skills/seo-plan/assets/local-service.md +160 -0
  863. package/templates/.agent/skills/seo-plan/assets/publisher.md +153 -0
  864. package/templates/.agent/skills/seo-plan/assets/saas.md +135 -0
  865. package/templates/.agent/skills/seo-programmatic/SKILL.md +184 -0
  866. package/templates/.agent/skills/seo-schema/SKILL.md +178 -0
  867. package/templates/.agent/skills/seo-sitemap/SKILL.md +129 -0
  868. package/templates/.agent/skills/seo-snippet-hunter/SKILL.md +113 -0
  869. package/templates/.agent/skills/seo-structure-architect/SKILL.md +107 -0
  870. package/templates/.agent/skills/seo-technical/SKILL.md +175 -0
  871. package/templates/.agent/skills/shadcn/SKILL.md +249 -0
  872. package/templates/.agent/skills/shadcn/agents/openai.yml +5 -0
  873. package/templates/.agent/skills/shadcn/assets/shadcn-small.png +0 -0
  874. package/templates/.agent/skills/shadcn/assets/shadcn.png +0 -0
  875. package/templates/.agent/skills/shadcn/cli.md +255 -0
  876. package/templates/.agent/skills/shadcn/customization.md +202 -0
  877. package/templates/.agent/skills/shadcn/evals/evals.json +47 -0
  878. package/templates/.agent/skills/shadcn/mcp.md +94 -0
  879. package/templates/.agent/skills/shadcn/rules/base-vs-radix.md +306 -0
  880. package/templates/.agent/skills/shadcn/rules/composition.md +195 -0
  881. package/templates/.agent/skills/shadcn/rules/forms.md +192 -0
  882. package/templates/.agent/skills/shadcn/rules/icons.md +101 -0
  883. package/templates/.agent/skills/shadcn/rules/styling.md +162 -0
  884. package/templates/.agent/skills/similarity-search-patterns/SKILL.md +36 -0
  885. package/templates/.agent/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  886. package/templates/.agent/skills/site-architecture/SKILL.md +366 -0
  887. package/templates/.agent/skills/site-architecture/evals/evals.json +88 -0
  888. package/templates/.agent/skills/site-architecture/references/mermaid-templates.md +216 -0
  889. package/templates/.agent/skills/site-architecture/references/navigation-patterns.md +305 -0
  890. package/templates/.agent/skills/site-architecture/references/site-type-templates.md +293 -0
  891. package/templates/.agent/skills/smtp-penetration-testing/SKILL.md +504 -0
  892. package/templates/.agent/skills/social-orchestrator/SKILL.md +299 -0
  893. package/templates/.agent/skills/software-architecture/SKILL.md +81 -0
  894. package/templates/.agent/skills/solidity-security/SKILL.md +37 -0
  895. package/templates/.agent/skills/solidity-security/resources/implementation-playbook.md +524 -0
  896. package/templates/.agent/skills/spark-optimization/SKILL.md +430 -0
  897. package/templates/.agent/skills/spec-to-code-compliance/SKILL.md +358 -0
  898. package/templates/.agent/skills/speckit-updater/SKILL.md +167 -0
  899. package/templates/.agent/skills/sql-injection-testing/SKILL.md +452 -0
  900. package/templates/.agent/skills/sql-optimization-patterns/SKILL.md +38 -0
  901. package/templates/.agent/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  902. package/templates/.agent/skills/sqlmap-database-pentesting/SKILL.md +404 -0
  903. package/templates/.agent/skills/ssh-penetration-testing/SKILL.md +492 -0
  904. package/templates/.agent/skills/stitch-ui-design/README.md +165 -0
  905. package/templates/.agent/skills/stitch-ui-design/SKILL.md +382 -0
  906. package/templates/.agent/skills/stitch-ui-design/references/advanced-techniques.md +541 -0
  907. package/templates/.agent/skills/stitch-ui-design/references/prompt-examples.md +601 -0
  908. package/templates/.agent/skills/stride-analysis-patterns/SKILL.md +36 -0
  909. package/templates/.agent/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  910. package/templates/.agent/skills/stripe-automation/SKILL.md +201 -0
  911. package/templates/.agent/skills/stripe-integration/SKILL.md +457 -0
  912. package/templates/.agent/skills/subagent-driven-development/SKILL.md +242 -0
  913. package/templates/.agent/skills/subagent-driven-development/code-quality-reviewer-prompt.md +20 -0
  914. package/templates/.agent/skills/subagent-driven-development/implementer-prompt.md +78 -0
  915. package/templates/.agent/skills/subagent-driven-development/spec-reviewer-prompt.md +61 -0
  916. package/templates/.agent/skills/supabase-automation/SKILL.md +239 -0
  917. package/templates/.agent/skills/swift-concurrency-expert/SKILL.md +113 -0
  918. package/templates/.agent/skills/swift-concurrency-expert/agents/openai.yaml +4 -0
  919. package/templates/.agent/skills/swift-concurrency-expert/references/approachable-concurrency.md +63 -0
  920. package/templates/.agent/skills/swift-concurrency-expert/references/swift-6-2-concurrency.md +272 -0
  921. package/templates/.agent/skills/swift-concurrency-expert/references/swiftui-concurrency-tour-wwdc.md +33 -0
  922. package/templates/.agent/skills/swiftui-expert-skill/SKILL.md +244 -0
  923. package/templates/.agent/skills/swiftui-liquid-glass/SKILL.md +98 -0
  924. package/templates/.agent/skills/swiftui-liquid-glass/agents/openai.yaml +4 -0
  925. package/templates/.agent/skills/swiftui-liquid-glass/references/liquid-glass.md +280 -0
  926. package/templates/.agent/skills/swiftui-performance-audit/SKILL.md +114 -0
  927. package/templates/.agent/skills/swiftui-performance-audit/agents/openai.yaml +4 -0
  928. package/templates/.agent/skills/swiftui-performance-audit/references/code-smells.md +150 -0
  929. package/templates/.agent/skills/swiftui-performance-audit/references/demystify-swiftui-performance-wwdc23.md +46 -0
  930. package/templates/.agent/skills/swiftui-performance-audit/references/optimizing-swiftui-performance-instruments.md +29 -0
  931. package/templates/.agent/skills/swiftui-performance-audit/references/profiling-intake.md +44 -0
  932. package/templates/.agent/skills/swiftui-performance-audit/references/report-template.md +47 -0
  933. package/templates/.agent/skills/swiftui-performance-audit/references/understanding-hangs-in-your-app.md +33 -0
  934. package/templates/.agent/skills/swiftui-performance-audit/references/understanding-improving-swiftui-performance.md +52 -0
  935. package/templates/.agent/skills/swiftui-ui-patterns/SKILL.md +103 -0
  936. package/templates/.agent/skills/swiftui-ui-patterns/agents/openai.yaml +4 -0
  937. package/templates/.agent/skills/swiftui-ui-patterns/references/app-wiring.md +201 -0
  938. package/templates/.agent/skills/swiftui-ui-patterns/references/async-state.md +96 -0
  939. package/templates/.agent/skills/swiftui-ui-patterns/references/components-index.md +50 -0
  940. package/templates/.agent/skills/swiftui-ui-patterns/references/controls.md +57 -0
  941. package/templates/.agent/skills/swiftui-ui-patterns/references/deeplinks.md +66 -0
  942. package/templates/.agent/skills/swiftui-ui-patterns/references/focus.md +90 -0
  943. package/templates/.agent/skills/swiftui-ui-patterns/references/form.md +97 -0
  944. package/templates/.agent/skills/swiftui-ui-patterns/references/grids.md +71 -0
  945. package/templates/.agent/skills/swiftui-ui-patterns/references/haptics.md +71 -0
  946. package/templates/.agent/skills/swiftui-ui-patterns/references/input-toolbar.md +51 -0
  947. package/templates/.agent/skills/swiftui-ui-patterns/references/lightweight-clients.md +93 -0
  948. package/templates/.agent/skills/swiftui-ui-patterns/references/list.md +86 -0
  949. package/templates/.agent/skills/swiftui-ui-patterns/references/loading-placeholders.md +38 -0
  950. package/templates/.agent/skills/swiftui-ui-patterns/references/macos-settings.md +71 -0
  951. package/templates/.agent/skills/swiftui-ui-patterns/references/matched-transitions.md +59 -0
  952. package/templates/.agent/skills/swiftui-ui-patterns/references/media.md +73 -0
  953. package/templates/.agent/skills/swiftui-ui-patterns/references/menu-bar.md +101 -0
  954. package/templates/.agent/skills/swiftui-ui-patterns/references/navigationstack.md +159 -0
  955. package/templates/.agent/skills/swiftui-ui-patterns/references/overlay.md +45 -0
  956. package/templates/.agent/skills/swiftui-ui-patterns/references/performance.md +62 -0
  957. package/templates/.agent/skills/swiftui-ui-patterns/references/previews.md +48 -0
  958. package/templates/.agent/skills/swiftui-ui-patterns/references/scroll-reveal.md +133 -0
  959. package/templates/.agent/skills/swiftui-ui-patterns/references/scrollview.md +87 -0
  960. package/templates/.agent/skills/swiftui-ui-patterns/references/searchable.md +71 -0
  961. package/templates/.agent/skills/swiftui-ui-patterns/references/sheets.md +155 -0
  962. package/templates/.agent/skills/swiftui-ui-patterns/references/split-views.md +72 -0
  963. package/templates/.agent/skills/swiftui-ui-patterns/references/tabview.md +114 -0
  964. package/templates/.agent/skills/swiftui-ui-patterns/references/theming.md +71 -0
  965. package/templates/.agent/skills/swiftui-ui-patterns/references/title-menus.md +93 -0
  966. package/templates/.agent/skills/swiftui-ui-patterns/references/top-bar.md +49 -0
  967. package/templates/.agent/skills/swiftui-view-refactor/SKILL.md +210 -0
  968. package/templates/.agent/skills/swiftui-view-refactor/agents/openai.yaml +4 -0
  969. package/templates/.agent/skills/swiftui-view-refactor/references/mv-patterns.md +161 -0
  970. package/templates/.agent/skills/systematic-debugging/SKILL.md +172 -79
  971. package/templates/.agent/skills/systems-programming-rust-project/SKILL.md +443 -0
  972. package/templates/.agent/skills/tailwind-design-system/SKILL.md +36 -0
  973. package/templates/.agent/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
  974. package/templates/.agent/skills/tavily-web/SKILL.md +39 -0
  975. package/templates/.agent/skills/tdd-orchestrator/SKILL.md +202 -0
  976. package/templates/.agent/skills/temporal-golang-pro/SKILL.md +216 -0
  977. package/templates/.agent/skills/temporal-golang-pro/resources/implementation-playbook.md +242 -0
  978. package/templates/.agent/skills/temporal-golang-pro/resources/testing-strategies.md +145 -0
  979. package/templates/.agent/skills/temporal-python-pro/SKILL.md +368 -0
  980. package/templates/.agent/skills/temporal-python-testing/SKILL.md +173 -0
  981. package/templates/.agent/skills/temporal-python-testing/resources/integration-testing.md +455 -0
  982. package/templates/.agent/skills/temporal-python-testing/resources/local-setup.md +553 -0
  983. package/templates/.agent/skills/temporal-python-testing/resources/replay-testing.md +462 -0
  984. package/templates/.agent/skills/temporal-python-testing/resources/unit-testing.md +328 -0
  985. package/templates/.agent/skills/terraform-aws-modules/SKILL.md +78 -0
  986. package/templates/.agent/skills/terraform-specialist/SKILL.md +162 -0
  987. package/templates/.agent/skills/test-fixing/SKILL.md +121 -0
  988. package/templates/.agent/skills/testing-qa/SKILL.md +230 -0
  989. package/templates/.agent/skills/tool-design/SKILL.md +318 -0
  990. package/templates/.agent/skills/top-web-vulnerabilities/SKILL.md +547 -0
  991. package/templates/.agent/skills/typescript-advanced-types/SKILL.md +38 -0
  992. package/templates/.agent/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
  993. package/templates/.agent/skills/typescript-expert/SKILL.md +426 -0
  994. package/templates/.agent/skills/typescript-expert/references/tsconfig-strict.json +92 -0
  995. package/templates/.agent/skills/typescript-expert/references/typescript-cheatsheet.md +383 -0
  996. package/templates/.agent/skills/typescript-expert/references/utility-types.ts +335 -0
  997. package/templates/.agent/skills/typescript-expert/scripts/ts_diagnostic.py +203 -0
  998. package/templates/.agent/skills/typescript-pro/SKILL.md +53 -0
  999. package/templates/.agent/skills/ui-ux-designer/SKILL.md +207 -0
  1000. package/templates/.agent/skills/ui-ux-pro-max/SKILL.md +356 -0
  1001. package/templates/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -0
  1002. package/templates/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -0
  1003. package/templates/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -0
  1004. package/templates/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -0
  1005. package/templates/.agent/skills/ui-ux-pro-max/data/products.csv +97 -0
  1006. package/templates/.agent/skills/ui-ux-pro-max/data/prompts.csv +24 -0
  1007. package/templates/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  1008. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  1009. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  1010. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  1011. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  1012. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  1013. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  1014. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  1015. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  1016. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  1017. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  1018. package/templates/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  1019. package/templates/.agent/skills/ui-ux-pro-max/data/styles.csv +59 -0
  1020. package/templates/.agent/skills/ui-ux-pro-max/data/typography.csv +58 -0
  1021. package/templates/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  1022. package/templates/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  1023. package/templates/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  1024. package/templates/.agent/skills/ui-ux-pro-max/scripts/core.py +257 -0
  1025. package/templates/.agent/skills/ui-ux-pro-max/scripts/design_system.py +487 -0
  1026. package/templates/.agent/skills/ui-ux-pro-max/scripts/search.py +76 -0
  1027. package/templates/.agent/skills/uniprot-database/SKILL.md +195 -0
  1028. package/templates/.agent/skills/unit-testing-test-generate/SKILL.md +322 -0
  1029. package/templates/.agent/skills/unity-ecs-patterns/SKILL.md +36 -0
  1030. package/templates/.agent/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
  1031. package/templates/.agent/skills/using-git-worktrees/SKILL.md +223 -0
  1032. package/templates/.agent/skills/vector-database-engineer/SKILL.md +63 -0
  1033. package/templates/.agent/skills/vercel-ai-sdk-expert/SKILL.md +222 -0
  1034. package/templates/.agent/skills/vercel-automation/SKILL.md +230 -0
  1035. package/templates/.agent/skills/vercel-deployment/SKILL.md +80 -0
  1036. package/templates/.agent/skills/vibe-code-auditor/SKILL.md +334 -0
  1037. package/templates/.agent/skills/vibe-prd/SKILL.md +48 -6
  1038. package/templates/.agent/skills/vibers-code-review/SKILL.md +140 -0
  1039. package/templates/.agent/skills/voice-agents/SKILL.md +73 -0
  1040. package/templates/.agent/skills/wcag-audit-patterns/SKILL.md +44 -0
  1041. package/templates/.agent/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
  1042. package/templates/.agent/skills/web-artifacts-builder/LICENSE.txt +202 -0
  1043. package/templates/.agent/skills/web-artifacts-builder/SKILL.md +79 -0
  1044. package/templates/.agent/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  1045. package/templates/.agent/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  1046. package/templates/.agent/skills/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  1047. package/templates/.agent/skills/web-performance-optimization/SKILL.md +649 -0
  1048. package/templates/.agent/skills/web-scraper/SKILL.md +752 -0
  1049. package/templates/.agent/skills/web-scraper/references/data-transforms.md +397 -0
  1050. package/templates/.agent/skills/web-scraper/references/extraction-patterns.md +475 -0
  1051. package/templates/.agent/skills/web-scraper/references/output-templates.md +481 -0
  1052. package/templates/.agent/skills/web-security-testing/SKILL.md +183 -0
  1053. package/templates/.agent/skills/web3-testing/SKILL.md +430 -0
  1054. package/templates/.agent/skills/webapp-testing/LICENSE.txt +202 -0
  1055. package/templates/.agent/skills/webapp-testing/scripts/with_server.py +106 -0
  1056. package/templates/.agent/skills/webflow-automation/SKILL.md +239 -0
  1057. package/templates/.agent/skills/whatsapp-cloud-api/SKILL.md +488 -0
  1058. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/.env.example +20 -0
  1059. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/package.json +22 -0
  1060. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/src/index.ts +125 -0
  1061. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/src/template-manager.ts +67 -0
  1062. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/src/types.ts +216 -0
  1063. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/src/webhook-handler.ts +175 -0
  1064. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/src/whatsapp-client.ts +193 -0
  1065. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/nodejs/tsconfig.json +17 -0
  1066. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/.env.example +20 -0
  1067. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/app.py +123 -0
  1068. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/requirements.txt +4 -0
  1069. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/template_manager.py +100 -0
  1070. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/webhook_handler.py +139 -0
  1071. package/templates/.agent/skills/whatsapp-cloud-api/assets/boilerplate/python/whatsapp_client.py +219 -0
  1072. package/templates/.agent/skills/whatsapp-cloud-api/assets/examples/flow-example.json +170 -0
  1073. package/templates/.agent/skills/whatsapp-cloud-api/assets/examples/interactive-menu.json +186 -0
  1074. package/templates/.agent/skills/whatsapp-cloud-api/assets/examples/template-messages.json +173 -0
  1075. package/templates/.agent/skills/whatsapp-cloud-api/assets/examples/webhook-payloads.json +240 -0
  1076. package/templates/.agent/skills/whatsapp-cloud-api/references/advanced-features.md +546 -0
  1077. package/templates/.agent/skills/whatsapp-cloud-api/references/api-reference.md +566 -0
  1078. package/templates/.agent/skills/whatsapp-cloud-api/references/automation-patterns.md +690 -0
  1079. package/templates/.agent/skills/whatsapp-cloud-api/references/compliance.md +404 -0
  1080. package/templates/.agent/skills/whatsapp-cloud-api/references/message-types.md +1639 -0
  1081. package/templates/.agent/skills/whatsapp-cloud-api/references/setup-guide.md +692 -0
  1082. package/templates/.agent/skills/whatsapp-cloud-api/references/template-management.md +570 -0
  1083. package/templates/.agent/skills/whatsapp-cloud-api/references/webhook-setup.md +603 -0
  1084. package/templates/.agent/skills/whatsapp-cloud-api/scripts/send_test_message.py +137 -0
  1085. package/templates/.agent/skills/whatsapp-cloud-api/scripts/setup_project.py +118 -0
  1086. package/templates/.agent/skills/whatsapp-cloud-api/scripts/validate_config.py +190 -0
  1087. package/templates/.agent/skills/wiki-architect/SKILL.md +65 -0
  1088. package/templates/.agent/skills/wordpress-penetration-testing/SKILL.md +594 -0
  1089. package/templates/.agent/skills/workflow-orchestration-patterns/SKILL.md +336 -0
  1090. package/templates/.agent/skills/workflow-patterns/SKILL.md +37 -0
  1091. package/templates/.agent/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
  1092. package/templates/.agent/skills/writing-plans/SKILL.md +122 -0
  1093. package/templates/.agent/skills/writing-skills/SKILL.md +121 -0
  1094. package/templates/.agent/skills/writing-skills/anthropic-best-practices.md +1150 -0
  1095. package/templates/.agent/skills/writing-skills/examples.md +282 -0
  1096. package/templates/.agent/skills/writing-skills/gotchas.md +197 -0
  1097. package/templates/.agent/skills/writing-skills/graphviz-conventions.dot +172 -0
  1098. package/templates/.agent/skills/writing-skills/persuasion-principles.md +187 -0
  1099. package/templates/.agent/skills/writing-skills/references/anti-rationalization/README.md +255 -0
  1100. package/templates/.agent/skills/writing-skills/references/cso/README.md +268 -0
  1101. package/templates/.agent/skills/writing-skills/references/standards/README.md +152 -0
  1102. package/templates/.agent/skills/writing-skills/references/standards/metadata-standard.md +65 -0
  1103. package/templates/.agent/skills/writing-skills/references/templates/discipline.md +54 -0
  1104. package/templates/.agent/skills/writing-skills/references/templates/pattern.md +48 -0
  1105. package/templates/.agent/skills/writing-skills/references/templates/reference.md +35 -0
  1106. package/templates/.agent/skills/writing-skills/references/templates/technique.md +59 -0
  1107. package/templates/.agent/skills/writing-skills/references/templates/tier-3-platform.md +19 -0
  1108. package/templates/.agent/skills/writing-skills/references/testing/README.md +204 -0
  1109. package/templates/.agent/skills/writing-skills/references/tier-1-simple/README.md +75 -0
  1110. package/templates/.agent/skills/writing-skills/references/tier-2-expanded/README.md +69 -0
  1111. package/templates/.agent/skills/writing-skills/references/tier-3-platform/README.md +98 -0
  1112. package/templates/.agent/skills/writing-skills/render-graphs.js +168 -0
  1113. package/templates/.agent/skills/writing-skills/testing-skills-with-subagents.md +384 -0
  1114. package/templates/.agent/skills/zapier-make-patterns/SKILL.md +72 -0
  1115. package/templates/.agent/workflows/add-type.md +133 -0
  1116. package/templates/.agent/workflows/apply.md +95 -0
  1117. package/templates/.agent/workflows/graduate.md +150 -0
  1118. package/templates/.agent/workflows/launch.md +127 -0
  1119. package/templates/.agent/workflows/new-feature.md +21 -23
  1120. package/templates/.agent/workflows/pause.md +118 -0
  1121. package/templates/.agent/workflows/pipeline.md +95 -0
  1122. package/templates/.agent/workflows/progress.md +103 -0
  1123. package/templates/.agent/workflows/resume.md +105 -0
  1124. package/templates/.agent/workflows/unify.md +126 -0
  1125. package/templates/.agent/workflows/vibe-plan.md +135 -72
  1126. package/templates/.agent/workflows/vibe-recap.md +89 -12
  1127. package/templates/.antigravity/rules.md +76 -23
  1128. package/templates/AGENTS.md +7 -3
  1129. package/templates/.agent/skills/bullmq-worker/SKILL.md +0 -124
  1130. package/templates/.agent/skills/code-review-checklist/SKILL.md +0 -109
  1131. package/templates/.agent/skills/deployment-procedures/SKILL.md +0 -241
  1132. package/templates/.agent/skills/doc.md +0 -177
  1133. package/templates/.agent/skills/documentation-templates/SKILL.md +0 -194
  1134. package/templates/.agent/skills/game-development/2d-games/SKILL.md +0 -119
  1135. package/templates/.agent/skills/game-development/3d-games/SKILL.md +0 -135
  1136. package/templates/.agent/skills/game-development/SKILL.md +0 -167
  1137. package/templates/.agent/skills/game-development/game-art/SKILL.md +0 -185
  1138. package/templates/.agent/skills/game-development/game-audio/SKILL.md +0 -190
  1139. package/templates/.agent/skills/game-development/game-design/SKILL.md +0 -129
  1140. package/templates/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
  1141. package/templates/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
  1142. package/templates/.agent/skills/game-development/pc-games/SKILL.md +0 -144
  1143. package/templates/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
  1144. package/templates/.agent/skills/game-development/web-games/SKILL.md +0 -150
  1145. package/templates/.agent/skills/geo-fundamentals/SKILL.md +0 -156
  1146. package/templates/.agent/skills/geo-fundamentals/scripts/geo_checker.py +0 -289
  1147. package/templates/.agent/skills/i18n-localization/SKILL.md +0 -154
  1148. package/templates/.agent/skills/i18n-localization/scripts/i18n_checker.py +0 -241
  1149. package/templates/.agent/skills/lint-and-validate/SKILL.md +0 -45
  1150. package/templates/.agent/skills/lint-and-validate/scripts/lint_runner.py +0 -184
  1151. package/templates/.agent/skills/lint-and-validate/scripts/type_coverage.py +0 -173
  1152. package/templates/.agent/skills/mcp-builder/SKILL.md +0 -176
  1153. package/templates/.agent/skills/neo-storage/SKILL.md +0 -115
  1154. package/templates/.agent/skills/plan-writing/SKILL.md +0 -152
  1155. package/templates/.agent/skills/powershell-windows/SKILL.md +0 -167
  1156. package/templates/.agent/skills/rag-vector-db/SKILL.md +0 -67
  1157. package/templates/.agent/skills/red-team-tactics/SKILL.md +0 -199
  1158. package/templates/.agent/skills/server-management/SKILL.md +0 -161
  1159. package/templates/.agent/skills/tdd-workflow/SKILL.md +0 -149
  1160. package/templates/.agent/skills/uu-pdp-feature-check/SKILL.md +0 -116
  1161. package/templates/.agent/skills/vulnerability-scanner/SKILL.md +0 -276
  1162. package/templates/.agent/skills/vulnerability-scanner/checklists.md +0 -121
  1163. package/templates/.agent/skills/vulnerability-scanner/scripts/security_scan.py +0 -458
  1164. package/templates/.agent/skills/xendit-integration/SKILL.md +0 -100
@@ -0,0 +1,1639 @@
1
+ # WhatsApp Cloud API - Tipos de Mensagem (Referencia Completa)
2
+
3
+ > Referencia completa de todos os tipos de mensagem suportados pela WhatsApp Cloud API v21.0.
4
+ > Exemplos em Node.js/TypeScript (axios) e Python (httpx async).
5
+
6
+ **Base URL:** `https://graph.facebook.com/v21.0`
7
+
8
+ **Variaveis de ambiente necessarias:**
9
+
10
+ ```env
11
+ WHATSAPP_TOKEN=seu_token_aqui
12
+ PHONE_NUMBER_ID=seu_phone_number_id
13
+ ```
14
+
15
+ ---
16
+
17
+ ## 1. Mensagem de Texto (Text Message)
18
+
19
+ Mensagem de texto simples. Suporta ate 4096 caracteres. A opcao `preview_url` gera uma
20
+ pre-visualizacao automatica quando a mensagem contem um link.
21
+
22
+ ### Payload JSON
23
+
24
+ ```json
25
+ {
26
+ "messaging_product": "whatsapp",
27
+ "recipient_type": "individual",
28
+ "to": "5511999999999",
29
+ "type": "text",
30
+ "text": {
31
+ "preview_url": true,
32
+ "body": "Confira nosso site: https://exemplo.com.br"
33
+ }
34
+ }
35
+ ```
36
+
37
+ ### Node.js / TypeScript
38
+
39
+ ```typescript
40
+ import axios from "axios";
41
+
42
+ interface TextMessage {
43
+ messaging_product: "whatsapp";
44
+ recipient_type: "individual";
45
+ to: string;
46
+ type: "text";
47
+ text: {
48
+ preview_url?: boolean;
49
+ body: string;
50
+ };
51
+ }
52
+
53
+ async function sendTextMessage(to: string, body: string, previewUrl = false): Promise<string> {
54
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
55
+
56
+ const payload: TextMessage = {
57
+ messaging_product: "whatsapp",
58
+ recipient_type: "individual",
59
+ to,
60
+ type: "text",
61
+ text: { preview_url: previewUrl, body },
62
+ };
63
+
64
+ const { data } = await axios.post(url, payload, {
65
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
66
+ });
67
+
68
+ return data.messages[0].id;
69
+ }
70
+ ```
71
+
72
+ ### Python
73
+
74
+ ```python
75
+ import os
76
+ import httpx
77
+
78
+ async def send_text_message(to: str, body: str, preview_url: bool = False) -> str:
79
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
80
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
81
+
82
+ payload = {
83
+ "messaging_product": "whatsapp",
84
+ "recipient_type": "individual",
85
+ "to": to,
86
+ "type": "text",
87
+ "text": {"preview_url": preview_url, "body": body},
88
+ }
89
+
90
+ async with httpx.AsyncClient() as client:
91
+ response = await client.post(url, json=payload, headers=headers)
92
+ response.raise_for_status()
93
+ data = response.json()
94
+ return data["messages"][0]["id"]
95
+ ```
96
+
97
+ ### Resposta esperada
98
+
99
+ ```json
100
+ {
101
+ "messaging_product": "whatsapp",
102
+ "contacts": [{ "input": "5511999999999", "wa_id": "5511999999999" }],
103
+ "messages": [{ "id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ..." }]
104
+ }
105
+ ```
106
+
107
+ ### Notas
108
+
109
+ - Limite de 4096 caracteres no campo `body`.
110
+ - `preview_url: true` exige que o corpo contenha uma URL valida para gerar a pre-visualizacao.
111
+ - Formatacao suportada: `*negrito*`, `_italico_`, `~tachado~`, `` `monoespaco` ``.
112
+
113
+ ---
114
+
115
+ ## 2. Mensagem de Template (Template Message)
116
+
117
+ Templates sao mensagens pre-aprovadas pela Meta. Obrigatorias para iniciar conversas (fora da
118
+ janela de 24h). Suportam variaveis, cabecalhos com midia e botoes.
119
+
120
+ ### 2a. Template com variaveis
121
+
122
+ ```json
123
+ {
124
+ "messaging_product": "whatsapp",
125
+ "to": "5511999999999",
126
+ "type": "template",
127
+ "template": {
128
+ "name": "pedido_confirmado",
129
+ "language": { "code": "pt_BR" },
130
+ "components": [
131
+ {
132
+ "type": "body",
133
+ "parameters": [
134
+ { "type": "text", "text": "Renato" },
135
+ { "type": "text", "text": "#12345" }
136
+ ]
137
+ }
138
+ ]
139
+ }
140
+ }
141
+ ```
142
+
143
+ ### 2b. Template com cabecalho de imagem
144
+
145
+ ```json
146
+ {
147
+ "messaging_product": "whatsapp",
148
+ "to": "5511999999999",
149
+ "type": "template",
150
+ "template": {
151
+ "name": "promo_imagem",
152
+ "language": { "code": "pt_BR" },
153
+ "components": [
154
+ {
155
+ "type": "header",
156
+ "parameters": [
157
+ {
158
+ "type": "image",
159
+ "image": { "link": "https://exemplo.com/banner.jpg" }
160
+ }
161
+ ]
162
+ },
163
+ {
164
+ "type": "body",
165
+ "parameters": [{ "type": "text", "text": "20%" }]
166
+ }
167
+ ]
168
+ }
169
+ }
170
+ ```
171
+
172
+ ### 2c. Template com botoes (Quick Reply + CTA)
173
+
174
+ ```json
175
+ {
176
+ "messaging_product": "whatsapp",
177
+ "to": "5511999999999",
178
+ "type": "template",
179
+ "template": {
180
+ "name": "acompanhar_pedido",
181
+ "language": { "code": "pt_BR" },
182
+ "components": [
183
+ {
184
+ "type": "body",
185
+ "parameters": [{ "type": "text", "text": "#12345" }]
186
+ },
187
+ {
188
+ "type": "button",
189
+ "sub_type": "quick_reply",
190
+ "index": "0",
191
+ "parameters": [{ "type": "payload", "payload": "SIM_CONFIRMAR" }]
192
+ },
193
+ {
194
+ "type": "button",
195
+ "sub_type": "url",
196
+ "index": "1",
197
+ "parameters": [{ "type": "text", "text": "12345" }]
198
+ }
199
+ ]
200
+ }
201
+ }
202
+ ```
203
+
204
+ ### Node.js / TypeScript
205
+
206
+ ```typescript
207
+ interface TemplateParameter {
208
+ type: "text" | "image" | "document" | "video" | "payload";
209
+ text?: string;
210
+ payload?: string;
211
+ image?: { link: string };
212
+ }
213
+
214
+ interface TemplateComponent {
215
+ type: "header" | "body" | "button";
216
+ sub_type?: "quick_reply" | "url";
217
+ index?: string;
218
+ parameters: TemplateParameter[];
219
+ }
220
+
221
+ interface TemplateMessage {
222
+ messaging_product: "whatsapp";
223
+ to: string;
224
+ type: "template";
225
+ template: {
226
+ name: string;
227
+ language: { code: string };
228
+ components: TemplateComponent[];
229
+ };
230
+ }
231
+
232
+ async function sendTemplateMessage(
233
+ to: string,
234
+ templateName: string,
235
+ languageCode: string,
236
+ components: TemplateComponent[]
237
+ ): Promise<string> {
238
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
239
+
240
+ const payload: TemplateMessage = {
241
+ messaging_product: "whatsapp",
242
+ to,
243
+ type: "template",
244
+ template: {
245
+ name: templateName,
246
+ language: { code: languageCode },
247
+ components,
248
+ },
249
+ };
250
+
251
+ const { data } = await axios.post(url, payload, {
252
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
253
+ });
254
+
255
+ return data.messages[0].id;
256
+ }
257
+ ```
258
+
259
+ ### Python
260
+
261
+ ```python
262
+ async def send_template_message(
263
+ to: str,
264
+ template_name: str,
265
+ language_code: str,
266
+ components: list[dict],
267
+ ) -> str:
268
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
269
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
270
+
271
+ payload = {
272
+ "messaging_product": "whatsapp",
273
+ "to": to,
274
+ "type": "template",
275
+ "template": {
276
+ "name": template_name,
277
+ "language": {"code": language_code},
278
+ "components": components,
279
+ },
280
+ }
281
+
282
+ async with httpx.AsyncClient() as client:
283
+ response = await client.post(url, json=payload, headers=headers)
284
+ response.raise_for_status()
285
+ return response.json()["messages"][0]["id"]
286
+ ```
287
+
288
+ ### Notas
289
+
290
+ - Templates precisam ser aprovados no Meta Business Manager antes do uso.
291
+ - O campo `language.code` deve corresponder exatamente ao idioma aprovado (ex: `pt_BR`).
292
+ - Botoes do tipo `url` usam sufixos dinamicos: o parametro e concatenado ao final da URL base definida no template.
293
+ - Botoes do tipo `quick_reply` retornam o `payload` configurado no webhook quando clicados.
294
+ - Limite de 3 botoes quick_reply ou 2 botoes CTA por template.
295
+
296
+ ---
297
+
298
+ ## 3. Mensagem de Imagem (Image Message)
299
+
300
+ Envia uma imagem para o destinatario. Pode ser por URL publica ou por media ID
301
+ (apos upload previo para a API de midia).
302
+
303
+ ### 3a. Via URL
304
+
305
+ ```json
306
+ {
307
+ "messaging_product": "whatsapp",
308
+ "to": "5511999999999",
309
+ "type": "image",
310
+ "image": {
311
+ "link": "https://exemplo.com/foto.jpg",
312
+ "caption": "Foto do produto"
313
+ }
314
+ }
315
+ ```
316
+
317
+ ### 3b. Via Media ID
318
+
319
+ ```json
320
+ {
321
+ "messaging_product": "whatsapp",
322
+ "to": "5511999999999",
323
+ "type": "image",
324
+ "image": {
325
+ "id": "1234567890",
326
+ "caption": "Foto do produto"
327
+ }
328
+ }
329
+ ```
330
+
331
+ ### Node.js / TypeScript
332
+
333
+ ```typescript
334
+ interface ImageMessage {
335
+ messaging_product: "whatsapp";
336
+ to: string;
337
+ type: "image";
338
+ image: {
339
+ link?: string;
340
+ id?: string;
341
+ caption?: string;
342
+ };
343
+ }
344
+
345
+ async function sendImageMessage(
346
+ to: string,
347
+ source: { link: string } | { id: string },
348
+ caption?: string
349
+ ): Promise<string> {
350
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
351
+
352
+ const payload: ImageMessage = {
353
+ messaging_product: "whatsapp",
354
+ to,
355
+ type: "image",
356
+ image: { ...source, caption },
357
+ };
358
+
359
+ const { data } = await axios.post(url, payload, {
360
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
361
+ });
362
+
363
+ return data.messages[0].id;
364
+ }
365
+ ```
366
+
367
+ ### Python
368
+
369
+ ```python
370
+ async def send_image_message(
371
+ to: str,
372
+ source: dict, # {"link": "..."} ou {"id": "..."}
373
+ caption: str | None = None,
374
+ ) -> str:
375
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
376
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
377
+
378
+ image_payload = {**source}
379
+ if caption:
380
+ image_payload["caption"] = caption
381
+
382
+ payload = {
383
+ "messaging_product": "whatsapp",
384
+ "to": to,
385
+ "type": "image",
386
+ "image": image_payload,
387
+ }
388
+
389
+ async with httpx.AsyncClient() as client:
390
+ response = await client.post(url, json=payload, headers=headers)
391
+ response.raise_for_status()
392
+ return response.json()["messages"][0]["id"]
393
+ ```
394
+
395
+ ### Notas
396
+
397
+ - Formatos suportados: JPEG, PNG.
398
+ - Tamanho maximo: 5 MB.
399
+ - A URL precisa ser publica e acessivel (sem autenticacao).
400
+ - `caption` e opcional, ate 1024 caracteres.
401
+
402
+ ---
403
+
404
+ ## 4. Mensagem de Documento (Document Message)
405
+
406
+ Envia documentos como PDFs, planilhas, etc. O campo `filename` define o nome exibido
407
+ para download no dispositivo do destinatario.
408
+
409
+ ### Payload JSON
410
+
411
+ ```json
412
+ {
413
+ "messaging_product": "whatsapp",
414
+ "to": "5511999999999",
415
+ "type": "document",
416
+ "document": {
417
+ "link": "https://exemplo.com/relatorio.pdf",
418
+ "caption": "Relatorio mensal - Janeiro 2026",
419
+ "filename": "relatorio-janeiro-2026.pdf"
420
+ }
421
+ }
422
+ ```
423
+
424
+ ### Node.js / TypeScript
425
+
426
+ ```typescript
427
+ interface DocumentMessage {
428
+ messaging_product: "whatsapp";
429
+ to: string;
430
+ type: "document";
431
+ document: {
432
+ link?: string;
433
+ id?: string;
434
+ caption?: string;
435
+ filename?: string;
436
+ };
437
+ }
438
+
439
+ async function sendDocumentMessage(
440
+ to: string,
441
+ source: { link: string } | { id: string },
442
+ filename: string,
443
+ caption?: string
444
+ ): Promise<string> {
445
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
446
+
447
+ const payload: DocumentMessage = {
448
+ messaging_product: "whatsapp",
449
+ to,
450
+ type: "document",
451
+ document: { ...source, filename, caption },
452
+ };
453
+
454
+ const { data } = await axios.post(url, payload, {
455
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
456
+ });
457
+
458
+ return data.messages[0].id;
459
+ }
460
+ ```
461
+
462
+ ### Python
463
+
464
+ ```python
465
+ async def send_document_message(
466
+ to: str,
467
+ source: dict,
468
+ filename: str,
469
+ caption: str | None = None,
470
+ ) -> str:
471
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
472
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
473
+
474
+ doc_payload = {**source, "filename": filename}
475
+ if caption:
476
+ doc_payload["caption"] = caption
477
+
478
+ payload = {
479
+ "messaging_product": "whatsapp",
480
+ "to": to,
481
+ "type": "document",
482
+ "document": doc_payload,
483
+ }
484
+
485
+ async with httpx.AsyncClient() as client:
486
+ response = await client.post(url, json=payload, headers=headers)
487
+ response.raise_for_status()
488
+ return response.json()["messages"][0]["id"]
489
+ ```
490
+
491
+ ### Notas
492
+
493
+ - Formatos suportados: PDF, DOC, DOCX, XLS, XLSX, PPT, PPTX, TXT e outros.
494
+ - Tamanho maximo: 100 MB.
495
+ - `filename` e exibido no dispositivo do destinatario como nome do arquivo para download.
496
+ - `caption` e opcional, ate 1024 caracteres.
497
+
498
+ ---
499
+
500
+ ## 5. Mensagem de Video (Video Message)
501
+
502
+ Envia um video com legenda opcional. Util para tutoriais, demonstracoes de produto, etc.
503
+
504
+ ### Payload JSON
505
+
506
+ ```json
507
+ {
508
+ "messaging_product": "whatsapp",
509
+ "to": "5511999999999",
510
+ "type": "video",
511
+ "video": {
512
+ "link": "https://exemplo.com/demo.mp4",
513
+ "caption": "Demonstracao do produto"
514
+ }
515
+ }
516
+ ```
517
+
518
+ ### Node.js / TypeScript
519
+
520
+ ```typescript
521
+ interface VideoMessage {
522
+ messaging_product: "whatsapp";
523
+ to: string;
524
+ type: "video";
525
+ video: {
526
+ link?: string;
527
+ id?: string;
528
+ caption?: string;
529
+ };
530
+ }
531
+
532
+ async function sendVideoMessage(
533
+ to: string,
534
+ source: { link: string } | { id: string },
535
+ caption?: string
536
+ ): Promise<string> {
537
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
538
+
539
+ const payload: VideoMessage = {
540
+ messaging_product: "whatsapp",
541
+ to,
542
+ type: "video",
543
+ video: { ...source, caption },
544
+ };
545
+
546
+ const { data } = await axios.post(url, payload, {
547
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
548
+ });
549
+
550
+ return data.messages[0].id;
551
+ }
552
+ ```
553
+
554
+ ### Python
555
+
556
+ ```python
557
+ async def send_video_message(
558
+ to: str,
559
+ source: dict,
560
+ caption: str | None = None,
561
+ ) -> str:
562
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
563
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
564
+
565
+ video_payload = {**source}
566
+ if caption:
567
+ video_payload["caption"] = caption
568
+
569
+ payload = {
570
+ "messaging_product": "whatsapp",
571
+ "to": to,
572
+ "type": "video",
573
+ "video": video_payload,
574
+ }
575
+
576
+ async with httpx.AsyncClient() as client:
577
+ response = await client.post(url, json=payload, headers=headers)
578
+ response.raise_for_status()
579
+ return response.json()["messages"][0]["id"]
580
+ ```
581
+
582
+ ### Notas
583
+
584
+ - Formatos suportados: MP4, 3GPP (somente codecs H.264 e AAC).
585
+ - Tamanho maximo: 16 MB.
586
+ - `caption` e opcional, ate 1024 caracteres.
587
+
588
+ ---
589
+
590
+ ## 6. Mensagem de Audio (Audio Message)
591
+
592
+ Envia uma mensagem de voz ou arquivo de audio. Reproduzido diretamente no chat como
593
+ mensagem de voz.
594
+
595
+ ### Payload JSON
596
+
597
+ ```json
598
+ {
599
+ "messaging_product": "whatsapp",
600
+ "to": "5511999999999",
601
+ "type": "audio",
602
+ "audio": {
603
+ "link": "https://exemplo.com/audio.ogg"
604
+ }
605
+ }
606
+ ```
607
+
608
+ ### Node.js / TypeScript
609
+
610
+ ```typescript
611
+ interface AudioMessage {
612
+ messaging_product: "whatsapp";
613
+ to: string;
614
+ type: "audio";
615
+ audio: {
616
+ link?: string;
617
+ id?: string;
618
+ };
619
+ }
620
+
621
+ async function sendAudioMessage(
622
+ to: string,
623
+ source: { link: string } | { id: string }
624
+ ): Promise<string> {
625
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
626
+
627
+ const payload: AudioMessage = {
628
+ messaging_product: "whatsapp",
629
+ to,
630
+ type: "audio",
631
+ audio: source,
632
+ };
633
+
634
+ const { data } = await axios.post(url, payload, {
635
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
636
+ });
637
+
638
+ return data.messages[0].id;
639
+ }
640
+ ```
641
+
642
+ ### Python
643
+
644
+ ```python
645
+ async def send_audio_message(
646
+ to: str,
647
+ source: dict,
648
+ ) -> str:
649
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
650
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
651
+
652
+ payload = {
653
+ "messaging_product": "whatsapp",
654
+ "to": to,
655
+ "type": "audio",
656
+ "audio": source,
657
+ }
658
+
659
+ async with httpx.AsyncClient() as client:
660
+ response = await client.post(url, json=payload, headers=headers)
661
+ response.raise_for_status()
662
+ return response.json()["messages"][0]["id"]
663
+ ```
664
+
665
+ ### Notas
666
+
667
+ - Formatos suportados: OGG (com codec OPUS), MP3, AMR, AAC, M4A.
668
+ - Tamanho maximo: 16 MB.
669
+ - Audio NAO suporta `caption`.
670
+ - Arquivos `.ogg` com codec OPUS sao reproduzidos como mensagem de voz (com icone de microfone).
671
+
672
+ ---
673
+
674
+ ## 7. Botoes Interativos - Quick Reply (Interactive Buttons)
675
+
676
+ Exibe ate 3 botoes de resposta rapida. Quando o usuario toca em um botao, a resposta
677
+ e enviada automaticamente como mensagem de texto e o `id` do botao e retornado no webhook.
678
+
679
+ ### Payload JSON
680
+
681
+ ```json
682
+ {
683
+ "messaging_product": "whatsapp",
684
+ "to": "5511999999999",
685
+ "type": "interactive",
686
+ "interactive": {
687
+ "type": "button",
688
+ "header": {
689
+ "type": "text",
690
+ "text": "Confirmacao de Pedido"
691
+ },
692
+ "body": {
693
+ "text": "Seu pedido #12345 esta pronto. Deseja confirmar a entrega?"
694
+ },
695
+ "footer": {
696
+ "text": "Responda em ate 24h"
697
+ },
698
+ "action": {
699
+ "buttons": [
700
+ { "type": "reply", "reply": { "id": "btn_confirmar", "title": "Confirmar" } },
701
+ { "type": "reply", "reply": { "id": "btn_reagendar", "title": "Reagendar" } },
702
+ { "type": "reply", "reply": { "id": "btn_cancelar", "title": "Cancelar" } }
703
+ ]
704
+ }
705
+ }
706
+ }
707
+ ```
708
+
709
+ ### Node.js / TypeScript
710
+
711
+ ```typescript
712
+ interface ReplyButton {
713
+ type: "reply";
714
+ reply: { id: string; title: string };
715
+ }
716
+
717
+ interface InteractiveButtonMessage {
718
+ messaging_product: "whatsapp";
719
+ to: string;
720
+ type: "interactive";
721
+ interactive: {
722
+ type: "button";
723
+ header?: { type: "text"; text: string };
724
+ body: { text: string };
725
+ footer?: { text: string };
726
+ action: { buttons: ReplyButton[] };
727
+ };
728
+ }
729
+
730
+ async function sendButtonMessage(
731
+ to: string,
732
+ body: string,
733
+ buttons: Array<{ id: string; title: string }>,
734
+ header?: string,
735
+ footer?: string
736
+ ): Promise<string> {
737
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
738
+
739
+ const interactive: InteractiveButtonMessage["interactive"] = {
740
+ type: "button",
741
+ body: { text: body },
742
+ action: {
743
+ buttons: buttons.map((b) => ({
744
+ type: "reply" as const,
745
+ reply: { id: b.id, title: b.title },
746
+ })),
747
+ },
748
+ };
749
+
750
+ if (header) interactive.header = { type: "text", text: header };
751
+ if (footer) interactive.footer = { text: footer };
752
+
753
+ const payload: InteractiveButtonMessage = {
754
+ messaging_product: "whatsapp",
755
+ to,
756
+ type: "interactive",
757
+ interactive,
758
+ };
759
+
760
+ const { data } = await axios.post(url, payload, {
761
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
762
+ });
763
+
764
+ return data.messages[0].id;
765
+ }
766
+ ```
767
+
768
+ ### Python
769
+
770
+ ```python
771
+ async def send_button_message(
772
+ to: str,
773
+ body: str,
774
+ buttons: list[dict], # [{"id": "btn_1", "title": "Opcao 1"}, ...]
775
+ header: str | None = None,
776
+ footer: str | None = None,
777
+ ) -> str:
778
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
779
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
780
+
781
+ interactive: dict = {
782
+ "type": "button",
783
+ "body": {"text": body},
784
+ "action": {
785
+ "buttons": [
786
+ {"type": "reply", "reply": {"id": b["id"], "title": b["title"]}}
787
+ for b in buttons
788
+ ]
789
+ },
790
+ }
791
+
792
+ if header:
793
+ interactive["header"] = {"type": "text", "text": header}
794
+ if footer:
795
+ interactive["footer"] = {"text": footer}
796
+
797
+ payload = {
798
+ "messaging_product": "whatsapp",
799
+ "to": to,
800
+ "type": "interactive",
801
+ "interactive": interactive,
802
+ }
803
+
804
+ async with httpx.AsyncClient() as client:
805
+ response = await client.post(url, json=payload, headers=headers)
806
+ response.raise_for_status()
807
+ return response.json()["messages"][0]["id"]
808
+ ```
809
+
810
+ ### Notas
811
+
812
+ - Maximo de 3 botoes por mensagem.
813
+ - Titulo do botao: ate 20 caracteres.
814
+ - ID do botao: ate 256 caracteres.
815
+ - `body` e obrigatorio; `header` e `footer` sao opcionais.
816
+ - O `header` tambem pode ser do tipo `image`, `video` ou `document`.
817
+
818
+ ---
819
+
820
+ ## 8. Lista Interativa (Interactive List)
821
+
822
+ Exibe um menu com secoes e opcoes selecionaveis. Ideal para catalogos, menus de atendimento,
823
+ selecao de horarios, etc.
824
+
825
+ ### Payload JSON
826
+
827
+ ```json
828
+ {
829
+ "messaging_product": "whatsapp",
830
+ "to": "5511999999999",
831
+ "type": "interactive",
832
+ "interactive": {
833
+ "type": "list",
834
+ "header": {
835
+ "type": "text",
836
+ "text": "Cardapio do Dia"
837
+ },
838
+ "body": {
839
+ "text": "Escolha uma opcao do nosso cardapio:"
840
+ },
841
+ "footer": {
842
+ "text": "Entrega em ate 40min"
843
+ },
844
+ "action": {
845
+ "button": "Ver opcoes",
846
+ "sections": [
847
+ {
848
+ "title": "Pratos Principais",
849
+ "rows": [
850
+ { "id": "prato_1", "title": "Frango Grelhado", "description": "Com arroz e salada - R$32" },
851
+ { "id": "prato_2", "title": "Peixe Assado", "description": "Com pure e legumes - R$38" }
852
+ ]
853
+ },
854
+ {
855
+ "title": "Bebidas",
856
+ "rows": [
857
+ { "id": "bebida_1", "title": "Suco Natural", "description": "Laranja, limao ou maracuja - R$8" },
858
+ { "id": "bebida_2", "title": "Agua Mineral", "description": "Com ou sem gas - R$5" }
859
+ ]
860
+ }
861
+ ]
862
+ }
863
+ }
864
+ }
865
+ ```
866
+
867
+ ### Node.js / TypeScript
868
+
869
+ ```typescript
870
+ interface ListRow {
871
+ id: string;
872
+ title: string;
873
+ description?: string;
874
+ }
875
+
876
+ interface ListSection {
877
+ title: string;
878
+ rows: ListRow[];
879
+ }
880
+
881
+ interface InteractiveListMessage {
882
+ messaging_product: "whatsapp";
883
+ to: string;
884
+ type: "interactive";
885
+ interactive: {
886
+ type: "list";
887
+ header?: { type: "text"; text: string };
888
+ body: { text: string };
889
+ footer?: { text: string };
890
+ action: {
891
+ button: string;
892
+ sections: ListSection[];
893
+ };
894
+ };
895
+ }
896
+
897
+ async function sendListMessage(
898
+ to: string,
899
+ body: string,
900
+ buttonText: string,
901
+ sections: ListSection[],
902
+ header?: string,
903
+ footer?: string
904
+ ): Promise<string> {
905
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
906
+
907
+ const interactive: InteractiveListMessage["interactive"] = {
908
+ type: "list",
909
+ body: { text: body },
910
+ action: { button: buttonText, sections },
911
+ };
912
+
913
+ if (header) interactive.header = { type: "text", text: header };
914
+ if (footer) interactive.footer = { text: footer };
915
+
916
+ const payload: InteractiveListMessage = {
917
+ messaging_product: "whatsapp",
918
+ to,
919
+ type: "interactive",
920
+ interactive,
921
+ };
922
+
923
+ const { data } = await axios.post(url, payload, {
924
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
925
+ });
926
+
927
+ return data.messages[0].id;
928
+ }
929
+ ```
930
+
931
+ ### Python
932
+
933
+ ```python
934
+ async def send_list_message(
935
+ to: str,
936
+ body: str,
937
+ button_text: str,
938
+ sections: list[dict],
939
+ header: str | None = None,
940
+ footer: str | None = None,
941
+ ) -> str:
942
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
943
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
944
+
945
+ interactive: dict = {
946
+ "type": "list",
947
+ "body": {"text": body},
948
+ "action": {"button": button_text, "sections": sections},
949
+ }
950
+
951
+ if header:
952
+ interactive["header"] = {"type": "text", "text": header}
953
+ if footer:
954
+ interactive["footer"] = {"text": footer}
955
+
956
+ payload = {
957
+ "messaging_product": "whatsapp",
958
+ "to": to,
959
+ "type": "interactive",
960
+ "interactive": interactive,
961
+ }
962
+
963
+ async with httpx.AsyncClient() as client:
964
+ response = await client.post(url, json=payload, headers=headers)
965
+ response.raise_for_status()
966
+ return response.json()["messages"][0]["id"]
967
+ ```
968
+
969
+ ### Notas
970
+
971
+ - Maximo de 10 secoes.
972
+ - Maximo de 10 opcoes (rows) no total entre todas as secoes.
973
+ - Titulo da row: ate 24 caracteres.
974
+ - Descricao da row: ate 72 caracteres (opcional).
975
+ - Texto do botao (`action.button`): ate 20 caracteres.
976
+ - `header` so suporta tipo `text` em listas (sem midia).
977
+
978
+ ---
979
+
980
+ ## 9. Mensagem de Localizacao (Location Message)
981
+
982
+ Compartilha uma localizacao geografica com coordenadas, nome e endereco.
983
+ Util para enviar endereco de lojas, pontos de encontro, etc.
984
+
985
+ ### Payload JSON
986
+
987
+ ```json
988
+ {
989
+ "messaging_product": "whatsapp",
990
+ "to": "5511999999999",
991
+ "type": "location",
992
+ "location": {
993
+ "latitude": -23.5505,
994
+ "longitude": -46.6333,
995
+ "name": "Loja Centro SP",
996
+ "address": "Av. Paulista, 1000 - Bela Vista, Sao Paulo - SP"
997
+ }
998
+ }
999
+ ```
1000
+
1001
+ ### Node.js / TypeScript
1002
+
1003
+ ```typescript
1004
+ interface LocationMessage {
1005
+ messaging_product: "whatsapp";
1006
+ to: string;
1007
+ type: "location";
1008
+ location: {
1009
+ latitude: number;
1010
+ longitude: number;
1011
+ name?: string;
1012
+ address?: string;
1013
+ };
1014
+ }
1015
+
1016
+ async function sendLocationMessage(
1017
+ to: string,
1018
+ latitude: number,
1019
+ longitude: number,
1020
+ name?: string,
1021
+ address?: string
1022
+ ): Promise<string> {
1023
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1024
+
1025
+ const payload: LocationMessage = {
1026
+ messaging_product: "whatsapp",
1027
+ to,
1028
+ type: "location",
1029
+ location: { latitude, longitude, name, address },
1030
+ };
1031
+
1032
+ const { data } = await axios.post(url, payload, {
1033
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1034
+ });
1035
+
1036
+ return data.messages[0].id;
1037
+ }
1038
+ ```
1039
+
1040
+ ### Python
1041
+
1042
+ ```python
1043
+ async def send_location_message(
1044
+ to: str,
1045
+ latitude: float,
1046
+ longitude: float,
1047
+ name: str | None = None,
1048
+ address: str | None = None,
1049
+ ) -> str:
1050
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1051
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1052
+
1053
+ location_data: dict = {"latitude": latitude, "longitude": longitude}
1054
+ if name:
1055
+ location_data["name"] = name
1056
+ if address:
1057
+ location_data["address"] = address
1058
+
1059
+ payload = {
1060
+ "messaging_product": "whatsapp",
1061
+ "to": to,
1062
+ "type": "location",
1063
+ "location": location_data,
1064
+ }
1065
+
1066
+ async with httpx.AsyncClient() as client:
1067
+ response = await client.post(url, json=payload, headers=headers)
1068
+ response.raise_for_status()
1069
+ return response.json()["messages"][0]["id"]
1070
+ ```
1071
+
1072
+ ### Notas
1073
+
1074
+ - `latitude` e `longitude` sao obrigatorios.
1075
+ - `name` e `address` sao opcionais mas recomendados para melhor experiencia do usuario.
1076
+ - A localizacao e exibida com um mapa integrado no WhatsApp.
1077
+
1078
+ ---
1079
+
1080
+ ## 10. Mensagem de Contato (Contact Message)
1081
+
1082
+ Compartilha um cartao de contato (vCard) com informacoes como nome, telefone, email, etc.
1083
+ O destinatario pode salvar o contato diretamente na agenda.
1084
+
1085
+ ### Payload JSON
1086
+
1087
+ ```json
1088
+ {
1089
+ "messaging_product": "whatsapp",
1090
+ "to": "5511999999999",
1091
+ "type": "contacts",
1092
+ "contacts": [
1093
+ {
1094
+ "name": {
1095
+ "formatted_name": "Suporte TechCo",
1096
+ "first_name": "Suporte",
1097
+ "last_name": "TechCo"
1098
+ },
1099
+ "phones": [
1100
+ { "phone": "+5511988887777", "type": "WORK", "wa_id": "5511988887777" }
1101
+ ],
1102
+ "emails": [
1103
+ { "email": "suporte@techco.com.br", "type": "WORK" }
1104
+ ],
1105
+ "org": {
1106
+ "company": "TechCo Solucoes"
1107
+ },
1108
+ "urls": [
1109
+ { "url": "https://techco.com.br", "type": "WORK" }
1110
+ ]
1111
+ }
1112
+ ]
1113
+ }
1114
+ ```
1115
+
1116
+ ### Node.js / TypeScript
1117
+
1118
+ ```typescript
1119
+ interface ContactName {
1120
+ formatted_name: string;
1121
+ first_name?: string;
1122
+ last_name?: string;
1123
+ }
1124
+
1125
+ interface ContactPhone {
1126
+ phone: string;
1127
+ type?: "CELL" | "MAIN" | "IPHONE" | "HOME" | "WORK";
1128
+ wa_id?: string;
1129
+ }
1130
+
1131
+ interface ContactInfo {
1132
+ name: ContactName;
1133
+ phones?: ContactPhone[];
1134
+ emails?: Array<{ email: string; type?: string }>;
1135
+ org?: { company: string };
1136
+ urls?: Array<{ url: string; type?: string }>;
1137
+ }
1138
+
1139
+ interface ContactMessage {
1140
+ messaging_product: "whatsapp";
1141
+ to: string;
1142
+ type: "contacts";
1143
+ contacts: ContactInfo[];
1144
+ }
1145
+
1146
+ async function sendContactMessage(
1147
+ to: string,
1148
+ contacts: ContactInfo[]
1149
+ ): Promise<string> {
1150
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1151
+
1152
+ const payload: ContactMessage = {
1153
+ messaging_product: "whatsapp",
1154
+ to,
1155
+ type: "contacts",
1156
+ contacts,
1157
+ };
1158
+
1159
+ const { data } = await axios.post(url, payload, {
1160
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1161
+ });
1162
+
1163
+ return data.messages[0].id;
1164
+ }
1165
+ ```
1166
+
1167
+ ### Python
1168
+
1169
+ ```python
1170
+ async def send_contact_message(
1171
+ to: str,
1172
+ contacts: list[dict],
1173
+ ) -> str:
1174
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1175
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1176
+
1177
+ payload = {
1178
+ "messaging_product": "whatsapp",
1179
+ "to": to,
1180
+ "type": "contacts",
1181
+ "contacts": contacts,
1182
+ }
1183
+
1184
+ async with httpx.AsyncClient() as client:
1185
+ response = await client.post(url, json=payload, headers=headers)
1186
+ response.raise_for_status()
1187
+ return response.json()["messages"][0]["id"]
1188
+ ```
1189
+
1190
+ ### Notas
1191
+
1192
+ - O campo `name.formatted_name` e obrigatorio.
1193
+ - Pode enviar multiplos contatos em uma unica mensagem (array `contacts`).
1194
+ - `wa_id` permite que o destinatario inicie conversa direto com o contato no WhatsApp.
1195
+ - Campos suportados: `addresses`, `birthday`, `emails`, `name`, `org`, `phones`, `urls`.
1196
+
1197
+ ---
1198
+
1199
+ ## 11. Mensagem de Reacao (Reaction Message)
1200
+
1201
+ Reage a uma mensagem existente com um emoji. Para remover a reacao, envie com `emoji` vazio.
1202
+
1203
+ ### Payload JSON (adicionar reacao)
1204
+
1205
+ ```json
1206
+ {
1207
+ "messaging_product": "whatsapp",
1208
+ "to": "5511999999999",
1209
+ "type": "reaction",
1210
+ "reaction": {
1211
+ "message_id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ...",
1212
+ "emoji": "\ud83d\udc4d"
1213
+ }
1214
+ }
1215
+ ```
1216
+
1217
+ ### Payload JSON (remover reacao)
1218
+
1219
+ ```json
1220
+ {
1221
+ "messaging_product": "whatsapp",
1222
+ "to": "5511999999999",
1223
+ "type": "reaction",
1224
+ "reaction": {
1225
+ "message_id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ...",
1226
+ "emoji": ""
1227
+ }
1228
+ }
1229
+ ```
1230
+
1231
+ ### Node.js / TypeScript
1232
+
1233
+ ```typescript
1234
+ interface ReactionMessage {
1235
+ messaging_product: "whatsapp";
1236
+ to: string;
1237
+ type: "reaction";
1238
+ reaction: {
1239
+ message_id: string;
1240
+ emoji: string;
1241
+ };
1242
+ }
1243
+
1244
+ async function sendReaction(
1245
+ to: string,
1246
+ messageId: string,
1247
+ emoji: string
1248
+ ): Promise<string> {
1249
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1250
+
1251
+ const payload: ReactionMessage = {
1252
+ messaging_product: "whatsapp",
1253
+ to,
1254
+ type: "reaction",
1255
+ reaction: { message_id: messageId, emoji },
1256
+ };
1257
+
1258
+ const { data } = await axios.post(url, payload, {
1259
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1260
+ });
1261
+
1262
+ return data.messages[0].id;
1263
+ }
1264
+
1265
+ async function removeReaction(to: string, messageId: string): Promise<string> {
1266
+ return sendReaction(to, messageId, "");
1267
+ }
1268
+ ```
1269
+
1270
+ ### Python
1271
+
1272
+ ```python
1273
+ async def send_reaction(to: str, message_id: str, emoji: str) -> str:
1274
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1275
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1276
+
1277
+ payload = {
1278
+ "messaging_product": "whatsapp",
1279
+ "to": to,
1280
+ "type": "reaction",
1281
+ "reaction": {"message_id": message_id, "emoji": emoji},
1282
+ }
1283
+
1284
+ async with httpx.AsyncClient() as client:
1285
+ response = await client.post(url, json=payload, headers=headers)
1286
+ response.raise_for_status()
1287
+ return response.json()["messages"][0]["id"]
1288
+
1289
+
1290
+ async def remove_reaction(to: str, message_id: str) -> str:
1291
+ return await send_reaction(to, message_id, "")
1292
+ ```
1293
+
1294
+ ### Notas
1295
+
1296
+ - `message_id` deve ser o ID da mensagem original a qual se deseja reagir.
1297
+ - Para remover uma reacao, envie `emoji` como string vazia `""`.
1298
+ - Apenas um emoji por reacao por remetente por mensagem.
1299
+ - Qualquer emoji Unicode e suportado.
1300
+
1301
+ ---
1302
+
1303
+ ## 12. Mensagem com Contexto / Resposta (Reply / Context Message)
1304
+
1305
+ Responde a uma mensagem especifica usando o `message_id` como contexto. A mensagem
1306
+ aparece no chat do destinatario com a citacao visual da mensagem original.
1307
+
1308
+ Funciona com qualquer tipo de mensagem (texto, imagem, botoes, etc.) adicionando o campo `context`.
1309
+
1310
+ ### Payload JSON (resposta de texto)
1311
+
1312
+ ```json
1313
+ {
1314
+ "messaging_product": "whatsapp",
1315
+ "to": "5511999999999",
1316
+ "context": {
1317
+ "message_id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ..."
1318
+ },
1319
+ "type": "text",
1320
+ "text": {
1321
+ "body": "Obrigado pela sua mensagem! Vamos verificar e retornar em breve."
1322
+ }
1323
+ }
1324
+ ```
1325
+
1326
+ ### Payload JSON (resposta com imagem)
1327
+
1328
+ ```json
1329
+ {
1330
+ "messaging_product": "whatsapp",
1331
+ "to": "5511999999999",
1332
+ "context": {
1333
+ "message_id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ..."
1334
+ },
1335
+ "type": "image",
1336
+ "image": {
1337
+ "link": "https://exemplo.com/resposta.jpg",
1338
+ "caption": "Aqui esta a imagem solicitada"
1339
+ }
1340
+ }
1341
+ ```
1342
+
1343
+ ### Node.js / TypeScript
1344
+
1345
+ ```typescript
1346
+ interface ContextPayload {
1347
+ message_id: string;
1348
+ }
1349
+
1350
+ async function sendReplyMessage(
1351
+ to: string,
1352
+ replyToMessageId: string,
1353
+ body: string
1354
+ ): Promise<string> {
1355
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1356
+
1357
+ const payload = {
1358
+ messaging_product: "whatsapp",
1359
+ to,
1360
+ context: { message_id: replyToMessageId } as ContextPayload,
1361
+ type: "text",
1362
+ text: { body },
1363
+ };
1364
+
1365
+ const { data } = await axios.post(url, payload, {
1366
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1367
+ });
1368
+
1369
+ return data.messages[0].id;
1370
+ }
1371
+
1372
+ // Funcao generica que adiciona contexto a qualquer payload de mensagem
1373
+ async function sendWithContext<T extends Record<string, unknown>>(
1374
+ basePayload: T,
1375
+ replyToMessageId: string
1376
+ ): Promise<string> {
1377
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1378
+
1379
+ const payload = {
1380
+ ...basePayload,
1381
+ context: { message_id: replyToMessageId },
1382
+ };
1383
+
1384
+ const { data } = await axios.post(url, payload, {
1385
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1386
+ });
1387
+
1388
+ return data.messages[0].id;
1389
+ }
1390
+ ```
1391
+
1392
+ ### Python
1393
+
1394
+ ```python
1395
+ async def send_reply_message(
1396
+ to: str,
1397
+ reply_to_message_id: str,
1398
+ body: str,
1399
+ ) -> str:
1400
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1401
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1402
+
1403
+ payload = {
1404
+ "messaging_product": "whatsapp",
1405
+ "to": to,
1406
+ "context": {"message_id": reply_to_message_id},
1407
+ "type": "text",
1408
+ "text": {"body": body},
1409
+ }
1410
+
1411
+ async with httpx.AsyncClient() as client:
1412
+ response = await client.post(url, json=payload, headers=headers)
1413
+ response.raise_for_status()
1414
+ return response.json()["messages"][0]["id"]
1415
+
1416
+
1417
+ async def send_with_context(
1418
+ base_payload: dict,
1419
+ reply_to_message_id: str,
1420
+ ) -> str:
1421
+ """Adiciona contexto de resposta a qualquer payload de mensagem."""
1422
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1423
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1424
+
1425
+ payload = {**base_payload, "context": {"message_id": reply_to_message_id}}
1426
+
1427
+ async with httpx.AsyncClient() as client:
1428
+ response = await client.post(url, json=payload, headers=headers)
1429
+ response.raise_for_status()
1430
+ return response.json()["messages"][0]["id"]
1431
+ ```
1432
+
1433
+ ### Notas
1434
+
1435
+ - O campo `context.message_id` deve conter o ID da mensagem original.
1436
+ - Funciona com todos os tipos de mensagem: texto, imagem, video, documento, interativos, etc.
1437
+ - A mensagem original e exibida como citacao visual no chat.
1438
+ - O `message_id` e obtido atraves do webhook ao receber mensagens.
1439
+
1440
+ ---
1441
+
1442
+ ## 13. Marcar como Lido (Mark as Read)
1443
+
1444
+ Marca uma mensagem recebida como lida, exibindo as marcas azuis (blue checkmarks)
1445
+ no dispositivo do remetente. Tambem aciona o evento de "digitando" brevemente.
1446
+
1447
+ **Nota:** Este endpoint usa uma acao diferente (`"read"`) e NAO e um tipo de mensagem.
1448
+
1449
+ ### Payload JSON
1450
+
1451
+ ```json
1452
+ {
1453
+ "messaging_product": "whatsapp",
1454
+ "status": "read",
1455
+ "message_id": "wamid.HBgLNTUxMTk5OTk5OTk5FQ..."
1456
+ }
1457
+ ```
1458
+
1459
+ ### Node.js / TypeScript
1460
+
1461
+ ```typescript
1462
+ interface MarkAsReadPayload {
1463
+ messaging_product: "whatsapp";
1464
+ status: "read";
1465
+ message_id: string;
1466
+ }
1467
+
1468
+ async function markAsRead(messageId: string): Promise<boolean> {
1469
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1470
+
1471
+ const payload: MarkAsReadPayload = {
1472
+ messaging_product: "whatsapp",
1473
+ status: "read",
1474
+ message_id: messageId,
1475
+ };
1476
+
1477
+ const { data } = await axios.post(url, payload, {
1478
+ headers: { Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}` },
1479
+ });
1480
+
1481
+ return data.success === true;
1482
+ }
1483
+ ```
1484
+
1485
+ ### Python
1486
+
1487
+ ```python
1488
+ async def mark_as_read(message_id: str) -> bool:
1489
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1490
+ headers = {"Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}"}
1491
+
1492
+ payload = {
1493
+ "messaging_product": "whatsapp",
1494
+ "status": "read",
1495
+ "message_id": message_id,
1496
+ }
1497
+
1498
+ async with httpx.AsyncClient() as client:
1499
+ response = await client.post(url, json=payload, headers=headers)
1500
+ response.raise_for_status()
1501
+ return response.json().get("success", False)
1502
+ ```
1503
+
1504
+ ### Resposta esperada
1505
+
1506
+ ```json
1507
+ {
1508
+ "success": true
1509
+ }
1510
+ ```
1511
+
1512
+ ### Notas
1513
+
1514
+ - O `message_id` deve ser de uma mensagem RECEBIDA (nao enviada).
1515
+ - Marcar como lido e idempotente: chamar mais de uma vez nao causa erro.
1516
+ - Tambem dispara um breve indicador de "digitando" no chat do remetente.
1517
+ - Recomenda-se marcar mensagens como lidas ao processa-las no webhook para boa experiencia do usuario.
1518
+
1519
+ ---
1520
+
1521
+ ## Referencia Rapida - Limites e Formatos
1522
+
1523
+ | Tipo | Tamanho Max | Formatos | Caption |
1524
+ |---------------|-------------|-----------------------------------|---------|
1525
+ | Texto | 4096 chars | - | - |
1526
+ | Imagem | 5 MB | JPEG, PNG | 1024 ch |
1527
+ | Documento | 100 MB | PDF, DOC, XLS, PPT, TXT, etc. | 1024 ch |
1528
+ | Video | 16 MB | MP4, 3GPP (H.264 + AAC) | 1024 ch |
1529
+ | Audio | 16 MB | OGG/OPUS, MP3, AMR, AAC, M4A | N/A |
1530
+ | Sticker | 100 KB (s) / 500 KB (a) | WEBP | N/A |
1531
+
1532
+ | Interativo | Limite |
1533
+ |---------------|-----------------------------------------------------|
1534
+ | Botoes | 3 botoes, titulo ate 20 chars |
1535
+ | Lista | 10 secoes, 10 rows total, titulo ate 24 chars |
1536
+ | Reacao | 1 emoji por remetente por mensagem |
1537
+
1538
+ ---
1539
+
1540
+ ## Tratamento de Erros Comum
1541
+
1542
+ Todas as funcoes acima podem lancar erros da API. Estrutura padrao de erro:
1543
+
1544
+ ```json
1545
+ {
1546
+ "error": {
1547
+ "message": "(#131030) Recipient phone number not in allowed list",
1548
+ "type": "OAuthException",
1549
+ "code": 131030,
1550
+ "error_subcode": 2655007,
1551
+ "fbtrace_id": "AbCdEfGhIjKlMnOp"
1552
+ }
1553
+ }
1554
+ ```
1555
+
1556
+ ### Codigos de erro frequentes
1557
+
1558
+ | Codigo | Significado |
1559
+ |---------|------------------------------------------------------|
1560
+ | 131030 | Numero do destinatario nao esta na lista permitida |
1561
+ | 131031 | Conta do remetente bloqueada |
1562
+ | 131047 | Re-engagement message (mais de 24h sem janela) |
1563
+ | 131051 | Tipo de mensagem nao suportado |
1564
+ | 131053 | Upload de midia falhou |
1565
+ | 130429 | Limite de taxa (rate limit) excedido |
1566
+ | 132000 | Quantidade de parametros do template nao confere |
1567
+ | 132015 | Template pausado/desativado |
1568
+
1569
+ ### Wrapper com tratamento de erro (Node.js)
1570
+
1571
+ ```typescript
1572
+ import axios, { AxiosError } from "axios";
1573
+
1574
+ interface WhatsAppError {
1575
+ error: {
1576
+ message: string;
1577
+ type: string;
1578
+ code: number;
1579
+ error_subcode?: number;
1580
+ fbtrace_id: string;
1581
+ };
1582
+ }
1583
+
1584
+ async function sendWhatsAppRequest<T>(payload: T): Promise<Record<string, unknown>> {
1585
+ const url = `https://graph.facebook.com/v21.0/${process.env.PHONE_NUMBER_ID}/messages`;
1586
+
1587
+ try {
1588
+ const { data } = await axios.post(url, payload, {
1589
+ headers: {
1590
+ Authorization: `Bearer ${process.env.WHATSAPP_TOKEN}`,
1591
+ "Content-Type": "application/json",
1592
+ },
1593
+ });
1594
+ return data;
1595
+ } catch (err) {
1596
+ if (err instanceof AxiosError && err.response) {
1597
+ const waError = err.response.data as WhatsAppError;
1598
+ throw new Error(
1599
+ `WhatsApp API Error [${waError.error.code}]: ${waError.error.message}`
1600
+ );
1601
+ }
1602
+ throw err;
1603
+ }
1604
+ }
1605
+ ```
1606
+
1607
+ ### Wrapper com tratamento de erro (Python)
1608
+
1609
+ ```python
1610
+ import httpx
1611
+
1612
+
1613
+ class WhatsAppAPIError(Exception):
1614
+ def __init__(self, code: int, message: str, fbtrace_id: str):
1615
+ self.code = code
1616
+ self.fbtrace_id = fbtrace_id
1617
+ super().__init__(f"WhatsApp API Error [{code}]: {message}")
1618
+
1619
+
1620
+ async def send_whatsapp_request(payload: dict) -> dict:
1621
+ url = f"https://graph.facebook.com/v21.0/{os.environ['PHONE_NUMBER_ID']}/messages"
1622
+ headers = {
1623
+ "Authorization": f"Bearer {os.environ['WHATSAPP_TOKEN']}",
1624
+ "Content-Type": "application/json",
1625
+ }
1626
+
1627
+ async with httpx.AsyncClient() as client:
1628
+ response = await client.post(url, json=payload, headers=headers)
1629
+
1630
+ if response.status_code != 200:
1631
+ error_data = response.json().get("error", {})
1632
+ raise WhatsAppAPIError(
1633
+ code=error_data.get("code", response.status_code),
1634
+ message=error_data.get("message", "Unknown error"),
1635
+ fbtrace_id=error_data.get("fbtrace_id", ""),
1636
+ )
1637
+
1638
+ return response.json()
1639
+ ```