gkt-node 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (758) hide show
  1. package/README.md +89 -0
  2. package/assets/.agent/brain/agent_index.json +208 -0
  3. package/assets/.agent/brain/project_context.json +31 -0
  4. package/assets/.agent/skills/ab-test-setup/SKILL.md +232 -0
  5. package/assets/.agent/skills/agent-evaluation/SKILL.md +64 -0
  6. package/assets/.agent/skills/agent-memory-mcp/SKILL.md +82 -0
  7. package/assets/.agent/skills/agent-memory-systems/SKILL.md +67 -0
  8. package/assets/.agent/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
  9. package/assets/.agent/skills/agent-tool-builder/SKILL.md +53 -0
  10. package/assets/.agent/skills/ai-agents-architect/SKILL.md +90 -0
  11. package/assets/.agent/skills/ai-engineer/SKILL.md +171 -0
  12. package/assets/.agent/skills/ai-product/SKILL.md +54 -0
  13. package/assets/.agent/skills/ai-wrapper-product/SKILL.md +273 -0
  14. package/assets/.agent/skills/airflow-dag-patterns/SKILL.md +41 -0
  15. package/assets/.agent/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  16. package/assets/.agent/skills/airtable-automation/SKILL.md +170 -0
  17. package/assets/.agent/skills/analytics-tracking/SKILL.md +404 -0
  18. package/assets/.agent/skills/api-design-principles/SKILL.md +37 -0
  19. package/assets/.agent/skills/api-design-principles/assets/__pycache__/rest-api-template.cpython-314.pyc +0 -0
  20. package/assets/.agent/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  21. package/assets/.agent/skills/api-design-principles/assets/rest-api-template.py +182 -0
  22. package/assets/.agent/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  23. package/assets/.agent/skills/api-design-principles/references/rest-best-practices.md +408 -0
  24. package/assets/.agent/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  25. package/assets/.agent/skills/api-designer/SKILL.md +22 -0
  26. package/assets/.agent/skills/api-designer/data/api_patterns.json +107 -0
  27. package/assets/.agent/skills/api-designer/scripts/__pycache__/api_gen.cpython-314.pyc +0 -0
  28. package/assets/.agent/skills/api-designer/scripts/api_gen.py +80 -0
  29. package/assets/.agent/skills/api-documentation-generator/SKILL.md +484 -0
  30. package/assets/.agent/skills/api-documenter/SKILL.md +184 -0
  31. package/assets/.agent/skills/api-fuzzing-bug-bounty/SKILL.md +433 -0
  32. package/assets/.agent/skills/api-patterns/SKILL.md +81 -0
  33. package/assets/.agent/skills/api-patterns/api-style.md +42 -0
  34. package/assets/.agent/skills/api-patterns/auth.md +24 -0
  35. package/assets/.agent/skills/api-patterns/documentation.md +26 -0
  36. package/assets/.agent/skills/api-patterns/graphql.md +41 -0
  37. package/assets/.agent/skills/api-patterns/rate-limiting.md +31 -0
  38. package/assets/.agent/skills/api-patterns/response.md +37 -0
  39. package/assets/.agent/skills/api-patterns/rest.md +40 -0
  40. package/assets/.agent/skills/api-patterns/scripts/__pycache__/api_validator.cpython-314.pyc +0 -0
  41. package/assets/.agent/skills/api-patterns/scripts/api_validator.py +211 -0
  42. package/assets/.agent/skills/api-patterns/security-testing.md +122 -0
  43. package/assets/.agent/skills/api-patterns/trpc.md +41 -0
  44. package/assets/.agent/skills/api-patterns/versioning.md +22 -0
  45. package/assets/.agent/skills/api-security-best-practices/SKILL.md +907 -0
  46. package/assets/.agent/skills/api-testing-observability-api-mock/SKILL.md +46 -0
  47. package/assets/.agent/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  48. package/assets/.agent/skills/app-store-optimization/HOW_TO_USE.md +281 -0
  49. package/assets/.agent/skills/app-store-optimization/README.md +430 -0
  50. package/assets/.agent/skills/app-store-optimization/SKILL.md +403 -0
  51. package/assets/.agent/skills/app-store-optimization/__pycache__/ab_test_planner.cpython-314.pyc +0 -0
  52. package/assets/.agent/skills/app-store-optimization/__pycache__/aso_scorer.cpython-314.pyc +0 -0
  53. package/assets/.agent/skills/app-store-optimization/__pycache__/competitor_analyzer.cpython-314.pyc +0 -0
  54. package/assets/.agent/skills/app-store-optimization/__pycache__/keyword_analyzer.cpython-314.pyc +0 -0
  55. package/assets/.agent/skills/app-store-optimization/__pycache__/launch_checklist.cpython-314.pyc +0 -0
  56. package/assets/.agent/skills/app-store-optimization/__pycache__/localization_helper.cpython-314.pyc +0 -0
  57. package/assets/.agent/skills/app-store-optimization/__pycache__/metadata_optimizer.cpython-314.pyc +0 -0
  58. package/assets/.agent/skills/app-store-optimization/__pycache__/review_analyzer.cpython-314.pyc +0 -0
  59. package/assets/.agent/skills/app-store-optimization/ab_test_planner.py +662 -0
  60. package/assets/.agent/skills/app-store-optimization/aso_scorer.py +482 -0
  61. package/assets/.agent/skills/app-store-optimization/competitor_analyzer.py +577 -0
  62. package/assets/.agent/skills/app-store-optimization/expected_output.json +170 -0
  63. package/assets/.agent/skills/app-store-optimization/keyword_analyzer.py +406 -0
  64. package/assets/.agent/skills/app-store-optimization/launch_checklist.py +739 -0
  65. package/assets/.agent/skills/app-store-optimization/localization_helper.py +588 -0
  66. package/assets/.agent/skills/app-store-optimization/metadata_optimizer.py +581 -0
  67. package/assets/.agent/skills/app-store-optimization/review_analyzer.py +714 -0
  68. package/assets/.agent/skills/app-store-optimization/sample_input.json +30 -0
  69. package/assets/.agent/skills/architecture-auditor/SKILL.md +35 -0
  70. package/assets/.agent/skills/architecture-auditor/data/standards.json +45 -0
  71. package/assets/.agent/skills/architecture-auditor/scripts/__pycache__/auditor.cpython-314.pyc +0 -0
  72. package/assets/.agent/skills/architecture-auditor/scripts/auditor.py +69 -0
  73. package/assets/.agent/skills/architecture-decision-records/SKILL.md +441 -0
  74. package/assets/.agent/skills/architecture-patterns/SKILL.md +37 -0
  75. package/assets/.agent/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  76. package/assets/.agent/skills/asana-automation/SKILL.md +171 -0
  77. package/assets/.agent/skills/attack-tree-construction/SKILL.md +38 -0
  78. package/assets/.agent/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
  79. package/assets/.agent/skills/auth-implementation-patterns/SKILL.md +39 -0
  80. package/assets/.agent/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
  81. package/assets/.agent/skills/autonomous-agent-patterns/SKILL.md +761 -0
  82. package/assets/.agent/skills/aws-penetration-testing/SKILL.md +405 -0
  83. package/assets/.agent/skills/aws-penetration-testing/references/advanced-aws-pentesting.md +469 -0
  84. package/assets/.agent/skills/aws-serverless/SKILL.md +323 -0
  85. package/assets/.agent/skills/backend-architect/SKILL.md +333 -0
  86. package/assets/.agent/skills/billing-automation/SKILL.md +42 -0
  87. package/assets/.agent/skills/billing-automation/resources/implementation-playbook.md +544 -0
  88. package/assets/.agent/skills/broken-authentication/SKILL.md +476 -0
  89. package/assets/.agent/skills/bullmq-specialist/SKILL.md +57 -0
  90. package/assets/.agent/skills/business-analyst/SKILL.md +182 -0
  91. package/assets/.agent/skills/cc-skill-backend-patterns/SKILL.md +584 -0
  92. package/assets/.agent/skills/cc-skill-clickhouse-io/SKILL.md +431 -0
  93. package/assets/.agent/skills/cc-skill-coding-standards/SKILL.md +522 -0
  94. package/assets/.agent/skills/cc-skill-continuous-learning/SKILL.md +10 -0
  95. package/assets/.agent/skills/cc-skill-continuous-learning/config.json +18 -0
  96. package/assets/.agent/skills/cc-skill-continuous-learning/evaluate-session.sh +60 -0
  97. package/assets/.agent/skills/cc-skill-frontend-patterns/SKILL.md +633 -0
  98. package/assets/.agent/skills/cc-skill-project-guidelines-example/SKILL.md +352 -0
  99. package/assets/.agent/skills/cc-skill-security-review/SKILL.md +496 -0
  100. package/assets/.agent/skills/cc-skill-strategic-compact/SKILL.md +10 -0
  101. package/assets/.agent/skills/cc-skill-strategic-compact/suggest-compact.sh +52 -0
  102. package/assets/.agent/skills/ci-cd-setup/SKILL.md +14 -0
  103. package/assets/.agent/skills/ci-cd-setup/data/pipeline_templates.json +42 -0
  104. package/assets/.agent/skills/ci-cd-setup/scripts/__pycache__/ci_gen.cpython-314.pyc +0 -0
  105. package/assets/.agent/skills/ci-cd-setup/scripts/ci_gen.py +75 -0
  106. package/assets/.agent/skills/claude-code-guide/SKILL.md +68 -0
  107. package/assets/.agent/skills/clean-code/SKILL.md +94 -0
  108. package/assets/.agent/skills/clickup-automation/SKILL.md +234 -0
  109. package/assets/.agent/skills/cloud-architect/SKILL.md +135 -0
  110. package/assets/.agent/skills/cloud-penetration-testing/SKILL.md +501 -0
  111. package/assets/.agent/skills/cloud-penetration-testing/references/advanced-cloud-scripts.md +318 -0
  112. package/assets/.agent/skills/code-reviewer/SKILL.md +31 -0
  113. package/assets/.agent/skills/code-reviewer/data/review_rules.json +172 -0
  114. package/assets/.agent/skills/code-reviewer/scripts/__pycache__/reviewer.cpython-314.pyc +0 -0
  115. package/assets/.agent/skills/code-reviewer/scripts/reviewer.py +192 -0
  116. package/assets/.agent/skills/codebase-navigator/SKILL.md +37 -0
  117. package/assets/.agent/skills/codebase-navigator/data/codebase_index.json +577 -0
  118. package/assets/.agent/skills/codebase-navigator/scripts/__pycache__/navigator.cpython-314.pyc +0 -0
  119. package/assets/.agent/skills/codebase-navigator/scripts/navigator.py +240 -0
  120. package/assets/.agent/skills/color-palette-generator/SKILL.md +26 -0
  121. package/assets/.agent/skills/color-palette-generator/data/palettes.json +37 -0
  122. package/assets/.agent/skills/color-palette-generator/scripts/__pycache__/palette.cpython-314.pyc +0 -0
  123. package/assets/.agent/skills/color-palette-generator/scripts/palette.py +57 -0
  124. package/assets/.agent/skills/competitive-landscape/SKILL.md +34 -0
  125. package/assets/.agent/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
  126. package/assets/.agent/skills/competitor-alternatives/SKILL.md +750 -0
  127. package/assets/.agent/skills/computer-use-agents/SKILL.md +315 -0
  128. package/assets/.agent/skills/content-creator/SKILL.md +248 -0
  129. package/assets/.agent/skills/content-creator/assets/content_calendar_template.md +99 -0
  130. package/assets/.agent/skills/content-creator/references/brand_guidelines.md +199 -0
  131. package/assets/.agent/skills/content-creator/references/content_frameworks.md +534 -0
  132. package/assets/.agent/skills/content-creator/references/social_media_optimization.md +317 -0
  133. package/assets/.agent/skills/content-creator/scripts/__pycache__/brand_voice_analyzer.cpython-314.pyc +0 -0
  134. package/assets/.agent/skills/content-creator/scripts/__pycache__/seo_optimizer.cpython-314.pyc +0 -0
  135. package/assets/.agent/skills/content-creator/scripts/brand_voice_analyzer.py +185 -0
  136. package/assets/.agent/skills/content-creator/scripts/seo_optimizer.py +419 -0
  137. package/assets/.agent/skills/content-marketer/SKILL.md +170 -0
  138. package/assets/.agent/skills/context-compression/SKILL.md +266 -0
  139. package/assets/.agent/skills/context-degradation/SKILL.md +238 -0
  140. package/assets/.agent/skills/context-driven-development/SKILL.md +400 -0
  141. package/assets/.agent/skills/context-fundamentals/SKILL.md +192 -0
  142. package/assets/.agent/skills/context-manager/SKILL.md +26 -0
  143. package/assets/.agent/skills/context-manager/scripts/__pycache__/minify.cpython-314.pyc +0 -0
  144. package/assets/.agent/skills/context-manager/scripts/minify.py +82 -0
  145. package/assets/.agent/skills/context-optimization/SKILL.md +186 -0
  146. package/assets/.agent/skills/context-router/SKILL.md +42 -0
  147. package/assets/.agent/skills/context-router/scripts/__pycache__/context_router.cpython-314.pyc +0 -0
  148. package/assets/.agent/skills/context-router/scripts/context_router.py +185 -0
  149. package/assets/.agent/skills/context-window-management/SKILL.md +53 -0
  150. package/assets/.agent/skills/conversation-memory/SKILL.md +61 -0
  151. package/assets/.agent/skills/copywriting/SKILL.md +225 -0
  152. package/assets/.agent/skills/cost-optimization/SKILL.md +286 -0
  153. package/assets/.agent/skills/cqrs-implementation/SKILL.md +35 -0
  154. package/assets/.agent/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
  155. package/assets/.agent/skills/crewai/SKILL.md +243 -0
  156. package/assets/.agent/skills/daily-news-report/SKILL.md +356 -0
  157. package/assets/.agent/skills/daily-news-report/cache.json +41 -0
  158. package/assets/.agent/skills/daily-news-report/sources.json +183 -0
  159. package/assets/.agent/skills/data-engineer/SKILL.md +224 -0
  160. package/assets/.agent/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
  161. package/assets/.agent/skills/data-engineering-data-pipeline/SKILL.md +201 -0
  162. package/assets/.agent/skills/data-quality-frameworks/SKILL.md +40 -0
  163. package/assets/.agent/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
  164. package/assets/.agent/skills/data-scientist/SKILL.md +199 -0
  165. package/assets/.agent/skills/data-storytelling/SKILL.md +465 -0
  166. package/assets/.agent/skills/database-admin/SKILL.md +165 -0
  167. package/assets/.agent/skills/database-architect/SKILL.md +268 -0
  168. package/assets/.agent/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
  169. package/assets/.agent/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  170. package/assets/.agent/skills/database-design/SKILL.md +52 -0
  171. package/assets/.agent/skills/database-design/database-selection.md +43 -0
  172. package/assets/.agent/skills/database-design/indexing.md +39 -0
  173. package/assets/.agent/skills/database-design/migrations.md +48 -0
  174. package/assets/.agent/skills/database-design/optimization.md +36 -0
  175. package/assets/.agent/skills/database-design/orm-selection.md +30 -0
  176. package/assets/.agent/skills/database-design/schema-design.md +56 -0
  177. package/assets/.agent/skills/database-design/scripts/__pycache__/schema_validator.cpython-314.pyc +0 -0
  178. package/assets/.agent/skills/database-design/scripts/schema_validator.py +172 -0
  179. package/assets/.agent/skills/database-migration/SKILL.md +436 -0
  180. package/assets/.agent/skills/database-migrations-migration-observability/SKILL.md +420 -0
  181. package/assets/.agent/skills/database-migrations-sql-migrations/SKILL.md +53 -0
  182. package/assets/.agent/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  183. package/assets/.agent/skills/database-optimizer/SKILL.md +167 -0
  184. package/assets/.agent/skills/datadog-automation/SKILL.md +235 -0
  185. package/assets/.agent/skills/db-designer/SKILL.md +22 -0
  186. package/assets/.agent/skills/db-designer/data/schema_patterns.json +156 -0
  187. package/assets/.agent/skills/db-designer/scripts/__pycache__/sql_gen.cpython-314.pyc +0 -0
  188. package/assets/.agent/skills/db-designer/scripts/sql_gen.py +90 -0
  189. package/assets/.agent/skills/dbt-transformation-patterns/SKILL.md +34 -0
  190. package/assets/.agent/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  191. package/assets/.agent/skills/debugger/SKILL.md +49 -0
  192. package/assets/.agent/skills/debugging-strategies/SKILL.md +34 -0
  193. package/assets/.agent/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
  194. package/assets/.agent/skills/deep-research/SKILL.md +114 -0
  195. package/assets/.agent/skills/deployment-engineer/SKILL.md +170 -0
  196. package/assets/.agent/skills/deployment-pipeline-design/SKILL.md +371 -0
  197. package/assets/.agent/skills/deployment-procedures/SKILL.md +241 -0
  198. package/assets/.agent/skills/diff-applier/SKILL.md +34 -0
  199. package/assets/.agent/skills/diff-applier/scripts/__pycache__/apply_patch.cpython-314.pyc +0 -0
  200. package/assets/.agent/skills/diff-applier/scripts/apply_patch.py +137 -0
  201. package/assets/.agent/skills/discord-automation/SKILL.md +187 -0
  202. package/assets/.agent/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
  203. package/assets/.agent/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
  204. package/assets/.agent/skills/distributed-tracing/SKILL.md +450 -0
  205. package/assets/.agent/skills/doc-generator/SKILL.md +14 -0
  206. package/assets/.agent/skills/doc-generator/data/doc_templates.json +40 -0
  207. package/assets/.agent/skills/doc-generator/scripts/__pycache__/doc_gen.cpython-314.pyc +0 -0
  208. package/assets/.agent/skills/doc-generator/scripts/doc_gen.py +48 -0
  209. package/assets/.agent/skills/docker-expert/SKILL.md +409 -0
  210. package/assets/.agent/skills/docker-wizard/SKILL.md +14 -0
  211. package/assets/.agent/skills/docker-wizard/data/docker_templates.json +93 -0
  212. package/assets/.agent/skills/docker-wizard/scripts/__pycache__/docker_gen.cpython-314.pyc +0 -0
  213. package/assets/.agent/skills/docker-wizard/scripts/docker_gen.py +86 -0
  214. package/assets/.agent/skills/docs-architect/SKILL.md +98 -0
  215. package/assets/.agent/skills/e2e-testing-patterns/SKILL.md +41 -0
  216. package/assets/.agent/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  217. package/assets/.agent/skills/email-sequence/SKILL.md +925 -0
  218. package/assets/.agent/skills/embedding-strategies/SKILL.md +491 -0
  219. package/assets/.agent/skills/employment-contract-templates/SKILL.md +39 -0
  220. package/assets/.agent/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
  221. package/assets/.agent/skills/env-manager/SKILL.md +33 -0
  222. package/assets/.agent/skills/env-manager/scripts/__pycache__/env_scanner.cpython-314.pyc +0 -0
  223. package/assets/.agent/skills/env-manager/scripts/env_scanner.py +181 -0
  224. package/assets/.agent/skills/error-detective/SKILL.md +53 -0
  225. package/assets/.agent/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
  226. package/assets/.agent/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
  227. package/assets/.agent/skills/error-diagnostics-error-trace/SKILL.md +48 -0
  228. package/assets/.agent/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
  229. package/assets/.agent/skills/error-handling-patterns/SKILL.md +35 -0
  230. package/assets/.agent/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  231. package/assets/.agent/skills/ethical-hacking-methodology/SKILL.md +466 -0
  232. package/assets/.agent/skills/event-sourcing-architect/SKILL.md +58 -0
  233. package/assets/.agent/skills/event-store-design/SKILL.md +449 -0
  234. package/assets/.agent/skills/exa-search/SKILL.md +36 -0
  235. package/assets/.agent/skills/fastapi-pro/SKILL.md +192 -0
  236. package/assets/.agent/skills/fastapi-router-py/SKILL.md +52 -0
  237. package/assets/.agent/skills/fastapi-templates/SKILL.md +32 -0
  238. package/assets/.agent/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  239. package/assets/.agent/skills/free-tool-strategy/SKILL.md +576 -0
  240. package/assets/.agent/skills/freshdesk-automation/SKILL.md +219 -0
  241. package/assets/.agent/skills/frontend-developer/SKILL.md +171 -0
  242. package/assets/.agent/skills/gcp-cloud-run/SKILL.md +288 -0
  243. package/assets/.agent/skills/gemini-api-dev/SKILL.md +127 -0
  244. package/assets/.agent/skills/geo-fundamentals/SKILL.md +156 -0
  245. package/assets/.agent/skills/geo-fundamentals/scripts/__pycache__/geo_checker.cpython-314.pyc +0 -0
  246. package/assets/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
  247. package/assets/.agent/skills/git-advanced-workflows/SKILL.md +412 -0
  248. package/assets/.agent/skills/git-manager/SKILL.md +22 -0
  249. package/assets/.agent/skills/git-manager/data/git_conventions.json +84 -0
  250. package/assets/.agent/skills/git-manager/scripts/__pycache__/commit.cpython-314.pyc +0 -0
  251. package/assets/.agent/skills/git-manager/scripts/__pycache__/log.cpython-314.pyc +0 -0
  252. package/assets/.agent/skills/git-manager/scripts/commit.py +70 -0
  253. package/assets/.agent/skills/git-manager/scripts/log.py +29 -0
  254. package/assets/.agent/skills/github-actions-templates/SKILL.md +345 -0
  255. package/assets/.agent/skills/github-automation/SKILL.md +227 -0
  256. package/assets/.agent/skills/gitlab-ci-patterns/SKILL.md +283 -0
  257. package/assets/.agent/skills/gitops-workflow/SKILL.md +303 -0
  258. package/assets/.agent/skills/gitops-workflow/references/argocd-setup.md +134 -0
  259. package/assets/.agent/skills/gitops-workflow/references/sync-policies.md +131 -0
  260. package/assets/.agent/skills/gmail-automation/SKILL.md +270 -0
  261. package/assets/.agent/skills/google-calendar-automation/SKILL.md +176 -0
  262. package/assets/.agent/skills/google-drive-automation/SKILL.md +193 -0
  263. package/assets/.agent/skills/googlesheets-automation/SKILL.md +197 -0
  264. package/assets/.agent/skills/grafana-dashboards/SKILL.md +381 -0
  265. package/assets/.agent/skills/graphql/SKILL.md +68 -0
  266. package/assets/.agent/skills/graphql-architect/SKILL.md +182 -0
  267. package/assets/.agent/skills/helm-chart-scaffolding/SKILL.md +34 -0
  268. package/assets/.agent/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
  269. package/assets/.agent/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
  270. package/assets/.agent/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
  271. package/assets/.agent/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
  272. package/assets/.agent/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
  273. package/assets/.agent/skills/hr-pro/SKILL.md +126 -0
  274. package/assets/.agent/skills/hubspot-automation/SKILL.md +178 -0
  275. package/assets/.agent/skills/hubspot-integration/SKILL.md +42 -0
  276. package/assets/.agent/skills/hybrid-search-implementation/SKILL.md +32 -0
  277. package/assets/.agent/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
  278. package/assets/.agent/skills/incident-responder/SKILL.md +213 -0
  279. package/assets/.agent/skills/incident-response-incident-response/SKILL.md +168 -0
  280. package/assets/.agent/skills/incident-response-smart-fix/SKILL.md +29 -0
  281. package/assets/.agent/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
  282. package/assets/.agent/skills/incident-runbook-templates/SKILL.md +395 -0
  283. package/assets/.agent/skills/infinite-gratitude/SKILL.md +26 -0
  284. package/assets/.agent/skills/inngest/SKILL.md +55 -0
  285. package/assets/.agent/skills/instagram-automation/SKILL.md +192 -0
  286. package/assets/.agent/skills/intercom-automation/SKILL.md +248 -0
  287. package/assets/.agent/skills/javascript-mastery/SKILL.md +645 -0
  288. package/assets/.agent/skills/javascript-testing-patterns/SKILL.md +35 -0
  289. package/assets/.agent/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  290. package/assets/.agent/skills/jira-automation/SKILL.md +185 -0
  291. package/assets/.agent/skills/k8s-manifest-generator/SKILL.md +35 -0
  292. package/assets/.agent/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
  293. package/assets/.agent/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
  294. package/assets/.agent/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
  295. package/assets/.agent/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
  296. package/assets/.agent/skills/k8s-manifest-generator/references/service-spec.md +724 -0
  297. package/assets/.agent/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
  298. package/assets/.agent/skills/k8s-security-policies/SKILL.md +346 -0
  299. package/assets/.agent/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
  300. package/assets/.agent/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
  301. package/assets/.agent/skills/knowledge-guide/SKILL.md +34 -0
  302. package/assets/.agent/skills/knowledge-guide/scripts/__pycache__/note_taker.cpython-314.pyc +0 -0
  303. package/assets/.agent/skills/knowledge-guide/scripts/note_taker.py +50 -0
  304. package/assets/.agent/skills/kpi-dashboard-design/SKILL.md +440 -0
  305. package/assets/.agent/skills/kubernetes-architect/SKILL.md +170 -0
  306. package/assets/.agent/skills/langchain-architecture/SKILL.md +350 -0
  307. package/assets/.agent/skills/langfuse/SKILL.md +238 -0
  308. package/assets/.agent/skills/langgraph/SKILL.md +287 -0
  309. package/assets/.agent/skills/launch-strategy/SKILL.md +344 -0
  310. package/assets/.agent/skills/legal-advisor/SKILL.md +70 -0
  311. package/assets/.agent/skills/linkedin-automation/SKILL.md +175 -0
  312. package/assets/.agent/skills/linux-privilege-escalation/SKILL.md +504 -0
  313. package/assets/.agent/skills/llm-app-patterns/SKILL.md +760 -0
  314. package/assets/.agent/skills/llm-evaluation/SKILL.md +483 -0
  315. package/assets/.agent/skills/mailchimp-automation/SKILL.md +231 -0
  316. package/assets/.agent/skills/market-sizing-analysis/SKILL.md +425 -0
  317. package/assets/.agent/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
  318. package/assets/.agent/skills/market-sizing-analysis/references/data-sources.md +360 -0
  319. package/assets/.agent/skills/marketing-ideas/SKILL.md +221 -0
  320. package/assets/.agent/skills/marketing-psychology/SKILL.md +255 -0
  321. package/assets/.agent/skills/mcp-builder/LICENSE.txt +202 -0
  322. package/assets/.agent/skills/mcp-builder/SKILL.md +236 -0
  323. package/assets/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
  324. package/assets/.agent/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
  325. package/assets/.agent/skills/mcp-builder/reference/node_mcp_server.md +970 -0
  326. package/assets/.agent/skills/mcp-builder/reference/python_mcp_server.md +719 -0
  327. package/assets/.agent/skills/mcp-builder/scripts/__pycache__/connections.cpython-314.pyc +0 -0
  328. package/assets/.agent/skills/mcp-builder/scripts/__pycache__/evaluation.cpython-314.pyc +0 -0
  329. package/assets/.agent/skills/mcp-builder/scripts/connections.py +151 -0
  330. package/assets/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
  331. package/assets/.agent/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  332. package/assets/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
  333. package/assets/.agent/skills/mermaid-expert/SKILL.md +59 -0
  334. package/assets/.agent/skills/meta-thinker/SKILL.md +41 -0
  335. package/assets/.agent/skills/meta-thinker/data/brainstorm_frameworks.json +614 -0
  336. package/assets/.agent/skills/meta-thinker/data/feature_ideas.json +352 -0
  337. package/assets/.agent/skills/meta-thinker/data/industry_database.json +1693 -0
  338. package/assets/.agent/skills/meta-thinker/data/monetization_models.json +570 -0
  339. package/assets/.agent/skills/meta-thinker/data/platform_guide.json +361 -0
  340. package/assets/.agent/skills/meta-thinker/data/product_archetypes.json +998 -0
  341. package/assets/.agent/skills/meta-thinker/scripts/__pycache__/idea_engine.cpython-314.pyc +0 -0
  342. package/assets/.agent/skills/meta-thinker/scripts/idea_engine.py +246 -0
  343. package/assets/.agent/skills/metasploit-framework/SKILL.md +478 -0
  344. package/assets/.agent/skills/micro-saas-launcher/SKILL.md +212 -0
  345. package/assets/.agent/skills/monday-automation/SKILL.md +233 -0
  346. package/assets/.agent/skills/multi-agent-patterns/SKILL.md +262 -0
  347. package/assets/.agent/skills/n8n-code-python/SKILL.md +750 -0
  348. package/assets/.agent/skills/n8n-mcp-tools-expert/SKILL.md +654 -0
  349. package/assets/.agent/skills/n8n-node-configuration/SKILL.md +796 -0
  350. package/assets/.agent/skills/neon-postgres/SKILL.md +56 -0
  351. package/assets/.agent/skills/nestjs-expert/SKILL.md +552 -0
  352. package/assets/.agent/skills/nextjs-best-practices/SKILL.md +203 -0
  353. package/assets/.agent/skills/nocobase-plugin-developer/SKILL.md +1289 -0
  354. package/assets/.agent/skills/nodejs-backend-patterns/SKILL.md +35 -0
  355. package/assets/.agent/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  356. package/assets/.agent/skills/nodejs-best-practices/SKILL.md +333 -0
  357. package/assets/.agent/skills/nosql-expert/SKILL.md +111 -0
  358. package/assets/.agent/skills/notion-automation/SKILL.md +215 -0
  359. package/assets/.agent/skills/observability-engineer/SKILL.md +237 -0
  360. package/assets/.agent/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
  361. package/assets/.agent/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
  362. package/assets/.agent/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
  363. package/assets/.agent/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
  364. package/assets/.agent/skills/on-call-handoff-patterns/SKILL.md +453 -0
  365. package/assets/.agent/skills/onboarding-cro/SKILL.md +433 -0
  366. package/assets/.agent/skills/openapi-spec-generation/SKILL.md +33 -0
  367. package/assets/.agent/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  368. package/assets/.agent/skills/page-cro/SKILL.md +343 -0
  369. package/assets/.agent/skills/paid-ads/SKILL.md +551 -0
  370. package/assets/.agent/skills/payment-integration/SKILL.md +77 -0
  371. package/assets/.agent/skills/paypal-integration/SKILL.md +479 -0
  372. package/assets/.agent/skills/paywall-upgrade-cro/SKILL.md +570 -0
  373. package/assets/.agent/skills/pentest-checklist/SKILL.md +334 -0
  374. package/assets/.agent/skills/pentest-commands/SKILL.md +438 -0
  375. package/assets/.agent/skills/pipedrive-automation/SKILL.md +224 -0
  376. package/assets/.agent/skills/plaid-fintech/SKILL.md +50 -0
  377. package/assets/.agent/skills/popup-cro/SKILL.md +346 -0
  378. package/assets/.agent/skills/postgresql/SKILL.md +230 -0
  379. package/assets/.agent/skills/postmortem-writing/SKILL.md +386 -0
  380. package/assets/.agent/skills/pricing-strategy/SKILL.md +356 -0
  381. package/assets/.agent/skills/prisma-expert/SKILL.md +355 -0
  382. package/assets/.agent/skills/product-manager-toolkit/SKILL.md +351 -0
  383. package/assets/.agent/skills/product-manager-toolkit/references/prd_templates.md +317 -0
  384. package/assets/.agent/skills/product-manager-toolkit/scripts/__pycache__/customer_interview_analyzer.cpython-314.pyc +0 -0
  385. package/assets/.agent/skills/product-manager-toolkit/scripts/__pycache__/rice_prioritizer.cpython-314.pyc +0 -0
  386. package/assets/.agent/skills/product-manager-toolkit/scripts/customer_interview_analyzer.py +441 -0
  387. package/assets/.agent/skills/product-manager-toolkit/scripts/rice_prioritizer.py +296 -0
  388. package/assets/.agent/skills/programmatic-seo/SKILL.md +351 -0
  389. package/assets/.agent/skills/project-scaffolder/SKILL.md +26 -0
  390. package/assets/.agent/skills/project-scaffolder/data/scaffold_templates.json +150 -0
  391. package/assets/.agent/skills/project-scaffolder/scripts/__pycache__/scaffold.cpython-314.pyc +0 -0
  392. package/assets/.agent/skills/project-scaffolder/scripts/scaffold.py +249 -0
  393. package/assets/.agent/skills/projection-patterns/SKILL.md +33 -0
  394. package/assets/.agent/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  395. package/assets/.agent/skills/prometheus-configuration/SKILL.md +404 -0
  396. package/assets/.agent/skills/prompt-caching/SKILL.md +61 -0
  397. package/assets/.agent/skills/prompt-engineer/README.md +659 -0
  398. package/assets/.agent/skills/prompt-engineer/SKILL.md +252 -0
  399. package/assets/.agent/skills/prompt-engineering/SKILL.md +171 -0
  400. package/assets/.agent/skills/prompt-engineering-patterns/SKILL.md +213 -0
  401. package/assets/.agent/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  402. package/assets/.agent/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
  403. package/assets/.agent/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
  404. package/assets/.agent/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
  405. package/assets/.agent/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
  406. package/assets/.agent/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
  407. package/assets/.agent/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
  408. package/assets/.agent/skills/prompt-engineering-patterns/scripts/__pycache__/optimize-prompt.cpython-314.pyc +0 -0
  409. package/assets/.agent/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  410. package/assets/.agent/skills/prompt-library/SKILL.md +322 -0
  411. package/assets/.agent/skills/rag-engineer/SKILL.md +90 -0
  412. package/assets/.agent/skills/rag-implementation/SKILL.md +421 -0
  413. package/assets/.agent/skills/react-patterns/SKILL.md +198 -0
  414. package/assets/.agent/skills/react-state-management/SKILL.md +441 -0
  415. package/assets/.agent/skills/react-ui-patterns/SKILL.md +289 -0
  416. package/assets/.agent/skills/readme-generator/SKILL.md +14 -0
  417. package/assets/.agent/skills/readme-generator/data/readme_templates.json +22 -0
  418. package/assets/.agent/skills/readme-generator/scripts/__pycache__/readme_gen.cpython-314.pyc +0 -0
  419. package/assets/.agent/skills/readme-generator/scripts/readme_gen.py +81 -0
  420. package/assets/.agent/skills/red-team-tactics/SKILL.md +199 -0
  421. package/assets/.agent/skills/red-team-tools/SKILL.md +310 -0
  422. package/assets/.agent/skills/reference-builder/SKILL.md +188 -0
  423. package/assets/.agent/skills/referral-program/SKILL.md +602 -0
  424. package/assets/.agent/skills/release-manager/SKILL.md +30 -0
  425. package/assets/.agent/skills/release-manager/scripts/__pycache__/release.cpython-314.pyc +0 -0
  426. package/assets/.agent/skills/release-manager/scripts/release.py +210 -0
  427. package/assets/.agent/skills/reliability-engineer/SKILL.md +30 -0
  428. package/assets/.agent/skills/reliability-engineer/data/reliability.json +57 -0
  429. package/assets/.agent/skills/reliability-engineer/scripts/__pycache__/sre.cpython-314.pyc +0 -0
  430. package/assets/.agent/skills/reliability-engineer/scripts/sre.py +94 -0
  431. package/assets/.agent/skills/saga-orchestration/SKILL.md +496 -0
  432. package/assets/.agent/skills/sales-automator/SKILL.md +55 -0
  433. package/assets/.agent/skills/salesforce-automation/SKILL.md +190 -0
  434. package/assets/.agent/skills/sast-configuration/SKILL.md +212 -0
  435. package/assets/.agent/skills/scanning-tools/SKILL.md +589 -0
  436. package/assets/.agent/skills/schema-markup/SKILL.md +360 -0
  437. package/assets/.agent/skills/search-specialist/SKILL.md +80 -0
  438. package/assets/.agent/skills/secrets-management/SKILL.md +364 -0
  439. package/assets/.agent/skills/security-auditor/SKILL.md +169 -0
  440. package/assets/.agent/skills/security-bluebook-builder/SKILL.md +22 -0
  441. package/assets/.agent/skills/security-requirement-extraction/SKILL.md +33 -0
  442. package/assets/.agent/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  443. package/assets/.agent/skills/security-scanner/SKILL.md +21 -0
  444. package/assets/.agent/skills/security-scanner/data/security_patterns.json +101 -0
  445. package/assets/.agent/skills/security-scanner/scripts/__pycache__/checklist_gen.cpython-314.pyc +0 -0
  446. package/assets/.agent/skills/security-scanner/scripts/__pycache__/vuln_scan.cpython-314.pyc +0 -0
  447. package/assets/.agent/skills/security-scanner/scripts/checklist_gen.py +49 -0
  448. package/assets/.agent/skills/security-scanner/scripts/vuln_scan.py +81 -0
  449. package/assets/.agent/skills/sendgrid-automation/SKILL.md +228 -0
  450. package/assets/.agent/skills/seo-audit/SKILL.md +487 -0
  451. package/assets/.agent/skills/seo-authority-builder/SKILL.md +136 -0
  452. package/assets/.agent/skills/seo-cannibalization-detector/SKILL.md +123 -0
  453. package/assets/.agent/skills/seo-content-auditor/SKILL.md +83 -0
  454. package/assets/.agent/skills/seo-content-planner/SKILL.md +108 -0
  455. package/assets/.agent/skills/seo-content-refresher/SKILL.md +118 -0
  456. package/assets/.agent/skills/seo-content-writer/SKILL.md +96 -0
  457. package/assets/.agent/skills/seo-fundamentals/SKILL.md +173 -0
  458. package/assets/.agent/skills/seo-fundamentals/scripts/__pycache__/seo_checker.cpython-314.pyc +0 -0
  459. package/assets/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
  460. package/assets/.agent/skills/seo-keyword-strategist/SKILL.md +95 -0
  461. package/assets/.agent/skills/seo-meta-optimizer/SKILL.md +92 -0
  462. package/assets/.agent/skills/seo-snippet-hunter/SKILL.md +114 -0
  463. package/assets/.agent/skills/seo-structure-architect/SKILL.md +108 -0
  464. package/assets/.agent/skills/service-mesh-observability/SKILL.md +395 -0
  465. package/assets/.agent/skills/shodan-reconnaissance/SKILL.md +503 -0
  466. package/assets/.agent/skills/shopify-apps/SKILL.md +42 -0
  467. package/assets/.agent/skills/shopify-automation/SKILL.md +168 -0
  468. package/assets/.agent/skills/signup-flow-cro/SKILL.md +355 -0
  469. package/assets/.agent/skills/similarity-search-patterns/SKILL.md +33 -0
  470. package/assets/.agent/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  471. package/assets/.agent/skills/skill-creator/LICENSE.txt +202 -0
  472. package/assets/.agent/skills/skill-creator/README.md +270 -0
  473. package/assets/.agent/skills/skill-creator/SKILL.md +593 -0
  474. package/assets/.agent/skills/skill-creator/references/output-patterns.md +82 -0
  475. package/assets/.agent/skills/skill-creator/references/workflows.md +28 -0
  476. package/assets/.agent/skills/skill-creator/scripts/__pycache__/init_skill.cpython-314.pyc +0 -0
  477. package/assets/.agent/skills/skill-creator/scripts/__pycache__/package_skill.cpython-314.pyc +0 -0
  478. package/assets/.agent/skills/skill-creator/scripts/__pycache__/quick_validate.cpython-314.pyc +0 -0
  479. package/assets/.agent/skills/skill-creator/scripts/init_skill.py +303 -0
  480. package/assets/.agent/skills/skill-creator/scripts/package_skill.py +110 -0
  481. package/assets/.agent/skills/skill-creator/scripts/quick_validate.py +95 -0
  482. package/assets/.agent/skills/skill-developer/ADVANCED.md +197 -0
  483. package/assets/.agent/skills/skill-developer/HOOK_MECHANISMS.md +306 -0
  484. package/assets/.agent/skills/skill-developer/PATTERNS_LIBRARY.md +152 -0
  485. package/assets/.agent/skills/skill-developer/SKILL.md +426 -0
  486. package/assets/.agent/skills/skill-developer/SKILL_RULES_REFERENCE.md +315 -0
  487. package/assets/.agent/skills/skill-developer/TRIGGER_TYPES.md +305 -0
  488. package/assets/.agent/skills/skill-developer/TROUBLESHOOTING.md +514 -0
  489. package/assets/.agent/skills/slack-automation/SKILL.md +189 -0
  490. package/assets/.agent/skills/slo-implementation/SKILL.md +341 -0
  491. package/assets/.agent/skills/social-content/SKILL.md +807 -0
  492. package/assets/.agent/skills/spark-optimization/SKILL.md +427 -0
  493. package/assets/.agent/skills/sql-injection-testing/SKILL.md +448 -0
  494. package/assets/.agent/skills/sql-optimization-patterns/SKILL.md +35 -0
  495. package/assets/.agent/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  496. package/assets/.agent/skills/sql-pro/SKILL.md +173 -0
  497. package/assets/.agent/skills/ssh-penetration-testing/SKILL.md +488 -0
  498. package/assets/.agent/skills/startup-analyst/SKILL.md +328 -0
  499. package/assets/.agent/skills/startup-business-analyst-business-case/SKILL.md +487 -0
  500. package/assets/.agent/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
  501. package/assets/.agent/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
  502. package/assets/.agent/skills/startup-financial-modeling/SKILL.md +467 -0
  503. package/assets/.agent/skills/startup-metrics-framework/SKILL.md +34 -0
  504. package/assets/.agent/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
  505. package/assets/.agent/skills/stride-analysis-patterns/SKILL.md +33 -0
  506. package/assets/.agent/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  507. package/assets/.agent/skills/stripe-automation/SKILL.md +198 -0
  508. package/assets/.agent/skills/stripe-integration/SKILL.md +454 -0
  509. package/assets/.agent/skills/supabase-postgres-best-practices/AGENTS.md +1490 -0
  510. package/assets/.agent/skills/supabase-postgres-best-practices/README.md +119 -0
  511. package/assets/.agent/skills/supabase-postgres-best-practices/SKILL.md +57 -0
  512. package/assets/.agent/skills/supabase-postgres-best-practices/metadata.json +13 -0
  513. package/assets/.agent/skills/supabase-postgres-best-practices/rules/_contributing.md +171 -0
  514. package/assets/.agent/skills/supabase-postgres-best-practices/rules/_sections.md +39 -0
  515. package/assets/.agent/skills/supabase-postgres-best-practices/rules/_template.md +34 -0
  516. package/assets/.agent/skills/supabase-postgres-best-practices/rules/advanced-full-text-search.md +55 -0
  517. package/assets/.agent/skills/supabase-postgres-best-practices/rules/advanced-jsonb-indexing.md +49 -0
  518. package/assets/.agent/skills/supabase-postgres-best-practices/rules/conn-idle-timeout.md +46 -0
  519. package/assets/.agent/skills/supabase-postgres-best-practices/rules/conn-limits.md +44 -0
  520. package/assets/.agent/skills/supabase-postgres-best-practices/rules/conn-pooling.md +41 -0
  521. package/assets/.agent/skills/supabase-postgres-best-practices/rules/conn-prepared-statements.md +46 -0
  522. package/assets/.agent/skills/supabase-postgres-best-practices/rules/data-batch-inserts.md +54 -0
  523. package/assets/.agent/skills/supabase-postgres-best-practices/rules/data-n-plus-one.md +53 -0
  524. package/assets/.agent/skills/supabase-postgres-best-practices/rules/data-pagination.md +50 -0
  525. package/assets/.agent/skills/supabase-postgres-best-practices/rules/data-upsert.md +50 -0
  526. package/assets/.agent/skills/supabase-postgres-best-practices/rules/lock-advisory.md +56 -0
  527. package/assets/.agent/skills/supabase-postgres-best-practices/rules/lock-deadlock-prevention.md +68 -0
  528. package/assets/.agent/skills/supabase-postgres-best-practices/rules/lock-short-transactions.md +50 -0
  529. package/assets/.agent/skills/supabase-postgres-best-practices/rules/lock-skip-locked.md +54 -0
  530. package/assets/.agent/skills/supabase-postgres-best-practices/rules/monitor-explain-analyze.md +45 -0
  531. package/assets/.agent/skills/supabase-postgres-best-practices/rules/monitor-pg-stat-statements.md +55 -0
  532. package/assets/.agent/skills/supabase-postgres-best-practices/rules/monitor-vacuum-analyze.md +55 -0
  533. package/assets/.agent/skills/supabase-postgres-best-practices/rules/query-composite-indexes.md +44 -0
  534. package/assets/.agent/skills/supabase-postgres-best-practices/rules/query-covering-indexes.md +40 -0
  535. package/assets/.agent/skills/supabase-postgres-best-practices/rules/query-index-types.md +45 -0
  536. package/assets/.agent/skills/supabase-postgres-best-practices/rules/query-missing-indexes.md +43 -0
  537. package/assets/.agent/skills/supabase-postgres-best-practices/rules/query-partial-indexes.md +45 -0
  538. package/assets/.agent/skills/supabase-postgres-best-practices/rules/schema-data-types.md +46 -0
  539. package/assets/.agent/skills/supabase-postgres-best-practices/rules/schema-foreign-key-indexes.md +59 -0
  540. package/assets/.agent/skills/supabase-postgres-best-practices/rules/schema-lowercase-identifiers.md +55 -0
  541. package/assets/.agent/skills/supabase-postgres-best-practices/rules/schema-partitioning.md +55 -0
  542. package/assets/.agent/skills/supabase-postgres-best-practices/rules/schema-primary-keys.md +61 -0
  543. package/assets/.agent/skills/supabase-postgres-best-practices/rules/security-privileges.md +54 -0
  544. package/assets/.agent/skills/supabase-postgres-best-practices/rules/security-rls-basics.md +50 -0
  545. package/assets/.agent/skills/supabase-postgres-best-practices/rules/security-rls-performance.md +57 -0
  546. package/assets/.agent/skills/system-diagrammer/SKILL.md +25 -0
  547. package/assets/.agent/skills/system-diagrammer/data/diagram_templates.json +69 -0
  548. package/assets/.agent/skills/system-diagrammer/scripts/__pycache__/diagram.cpython-314.pyc +0 -0
  549. package/assets/.agent/skills/system-diagrammer/scripts/diagram.py +81 -0
  550. package/assets/.agent/skills/system-strategist/SKILL.md +35 -0
  551. package/assets/.agent/skills/system-strategist/data/strategy_patterns.json +170 -0
  552. package/assets/.agent/skills/system-strategist/scripts/__pycache__/strategist.cpython-314.pyc +0 -0
  553. package/assets/.agent/skills/system-strategist/scripts/strategist.py +136 -0
  554. package/assets/.agent/skills/tavily-web/SKILL.md +36 -0
  555. package/assets/.agent/skills/team-composition-analysis/SKILL.md +413 -0
  556. package/assets/.agent/skills/tech-stack-advisor/SKILL.md +59 -0
  557. package/assets/.agent/skills/tech-stack-advisor/data/stacks.json +727 -0
  558. package/assets/.agent/skills/tech-stack-advisor/data/tech_data.json +1297 -0
  559. package/assets/.agent/skills/tech-stack-advisor/scripts/__pycache__/advisor.cpython-314.pyc +0 -0
  560. package/assets/.agent/skills/tech-stack-advisor/scripts/__pycache__/scanner.cpython-314.pyc +0 -0
  561. package/assets/.agent/skills/tech-stack-advisor/scripts/advisor.py +211 -0
  562. package/assets/.agent/skills/tech-stack-advisor/scripts/scanner.py +102 -0
  563. package/assets/.agent/skills/terraform-module-library/SKILL.md +261 -0
  564. package/assets/.agent/skills/terraform-module-library/references/aws-modules.md +63 -0
  565. package/assets/.agent/skills/terraform-skill/SKILL.md +517 -0
  566. package/assets/.agent/skills/terraform-specialist/SKILL.md +166 -0
  567. package/assets/.agent/skills/test-generator/SKILL.md +14 -0
  568. package/assets/.agent/skills/test-generator/data/test_patterns.json +39 -0
  569. package/assets/.agent/skills/test-generator/scripts/__pycache__/gen_skeleton.cpython-314.pyc +0 -0
  570. package/assets/.agent/skills/test-generator/scripts/gen_skeleton.py +61 -0
  571. package/assets/.agent/skills/testing-patterns/SKILL.md +259 -0
  572. package/assets/.agent/skills/threat-mitigation-mapping/SKILL.md +33 -0
  573. package/assets/.agent/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
  574. package/assets/.agent/skills/threat-modeling-expert/SKILL.md +60 -0
  575. package/assets/.agent/skills/tool-design/SKILL.md +318 -0
  576. package/assets/.agent/skills/top-web-vulnerabilities/SKILL.md +543 -0
  577. package/assets/.agent/skills/trello-automation/SKILL.md +181 -0
  578. package/assets/.agent/skills/trigger-dev/SKILL.md +67 -0
  579. package/assets/.agent/skills/tutorial-engineer/SKILL.md +139 -0
  580. package/assets/.agent/skills/twitter-automation/SKILL.md +231 -0
  581. package/assets/.agent/skills/typescript-pro/SKILL.md +55 -0
  582. package/assets/.agent/skills/ui-ux-pro-max/SKILL.md +30 -0
  583. package/assets/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -0
  584. package/assets/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -0
  585. package/assets/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -0
  586. package/assets/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -0
  587. package/assets/.agent/skills/ui-ux-pro-max/data/products.csv +97 -0
  588. package/assets/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  589. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
  590. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  591. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  592. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  593. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  594. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  595. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  596. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  597. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  598. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  599. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  600. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  601. package/assets/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  602. package/assets/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -0
  603. package/assets/.agent/skills/ui-ux-pro-max/data/typography.csv +58 -0
  604. package/assets/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  605. package/assets/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  606. package/assets/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  607. package/assets/.agent/skills/ui-ux-pro-max/scripts/__pycache__/core.cpython-314.pyc +0 -0
  608. package/assets/.agent/skills/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-314.pyc +0 -0
  609. package/assets/.agent/skills/ui-ux-pro-max/scripts/__pycache__/search.cpython-314.pyc +0 -0
  610. package/assets/.agent/skills/ui-ux-pro-max/scripts/core.py +253 -0
  611. package/assets/.agent/skills/ui-ux-pro-max/scripts/design_system.py +1110 -0
  612. package/assets/.agent/skills/ui-ux-pro-max/scripts/search.py +162 -0
  613. package/assets/.agent/skills/using-neon/SKILL.md +84 -0
  614. package/assets/.agent/skills/vector-database-engineer/SKILL.md +60 -0
  615. package/assets/.agent/skills/vector-index-tuning/SKILL.md +42 -0
  616. package/assets/.agent/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
  617. package/assets/.agent/skills/vercel-deployment/SKILL.md +79 -0
  618. package/assets/.agent/skills/voice-agents/SKILL.md +68 -0
  619. package/assets/.agent/skills/vulnerability-scanner/SKILL.md +276 -0
  620. package/assets/.agent/skills/vulnerability-scanner/checklists.md +121 -0
  621. package/assets/.agent/skills/vulnerability-scanner/scripts/__pycache__/security_scan.cpython-314.pyc +0 -0
  622. package/assets/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
  623. package/assets/.agent/skills/whatsapp-automation/SKILL.md +214 -0
  624. package/assets/.agent/skills/wiki-architect/SKILL.md +60 -0
  625. package/assets/.agent/skills/wiki-onboarding/SKILL.md +77 -0
  626. package/assets/.agent/skills/wiki-page-writer/SKILL.md +65 -0
  627. package/assets/.agent/skills/wiki-researcher/SKILL.md +65 -0
  628. package/assets/.agent/skills/windows-privilege-escalation/SKILL.md +496 -0
  629. package/assets/.agent/skills/wireshark-analysis/SKILL.md +497 -0
  630. package/assets/.agent/skills/wordpress-penetration-testing/SKILL.md +485 -0
  631. package/assets/.agent/skills/workflow-automation/SKILL.md +68 -0
  632. package/assets/.agent/skills/xss-html-injection/SKILL.md +499 -0
  633. package/assets/.agent/skills/zapier-make-patterns/SKILL.md +67 -0
  634. package/assets/.agent/skills/zendesk-automation/SKILL.md +215 -0
  635. package/assets/.agent/workflows/ai-agent-builder.md +93 -0
  636. package/assets/.agent/workflows/api-graphql-dev.md +45 -0
  637. package/assets/.agent/workflows/architect.md +43 -0
  638. package/assets/.agent/workflows/backend-dev.md +43 -0
  639. package/assets/.agent/workflows/claude-code-dev.md +51 -0
  640. package/assets/.agent/workflows/cloud-deployer.md +422 -0
  641. package/assets/.agent/workflows/code-reviewer.md +62 -0
  642. package/assets/.agent/workflows/context-data-eng.md +58 -0
  643. package/assets/.agent/workflows/database-eng.md +60 -0
  644. package/assets/.agent/workflows/deep-researcher.md +175 -0
  645. package/assets/.agent/workflows/designer.md +36 -0
  646. package/assets/.agent/workflows/devops.md +37 -0
  647. package/assets/.agent/workflows/doc-writer.md +211 -0
  648. package/assets/.agent/workflows/frontend-dev.md +63 -0
  649. package/assets/.agent/workflows/fullstack-coder.md +141 -0
  650. package/assets/.agent/workflows/image-creator.md +186 -0
  651. package/assets/.agent/workflows/knowledge-guide.md +48 -0
  652. package/assets/.agent/workflows/leader.md +238 -0
  653. package/assets/.agent/workflows/meta-thinker.md +204 -0
  654. package/assets/.agent/workflows/mobile-dev.md +26 -0
  655. package/assets/.agent/workflows/n8n-automator.md +114 -0
  656. package/assets/.agent/workflows/nocobase-plugin-build.md +291 -0
  657. package/assets/.agent/workflows/nocobase-plugin-expert.md +250 -0
  658. package/assets/.agent/workflows/observability-eng.md +54 -0
  659. package/assets/.agent/workflows/planner.md +48 -0
  660. package/assets/.agent/workflows/prompt-engineer.md +303 -0
  661. package/assets/.agent/workflows/qa-engineer.md +65 -0
  662. package/assets/.agent/workflows/quality-guardian.md +126 -0
  663. package/assets/.agent/workflows/quickstart.md +107 -0
  664. package/assets/.agent/workflows/release-manager.md +56 -0
  665. package/assets/.agent/workflows/research-analyst.md +483 -0
  666. package/assets/.agent/workflows/researcher.md +98 -0
  667. package/assets/.agent/workflows/saas-connector.md +86 -0
  668. package/assets/.agent/workflows/security-auditor.md +82 -0
  669. package/assets/.agent/workflows/security-engineer.md +48 -0
  670. package/assets/.agent/workflows/seo-marketer.md +91 -0
  671. package/assets/.agent/workflows/seo-specialist.md +27 -0
  672. package/assets/.agent/workflows/solution-architect.md +164 -0
  673. package/assets/.agent/workflows/startup-advisor.md +94 -0
  674. package/assets/.agent/workflows/tech-writer.md +43 -0
  675. package/assets/ide-adapters/cline/architect.md +43 -0
  676. package/assets/ide-adapters/cline/backend-dev.md +43 -0
  677. package/assets/ide-adapters/cline/designer.md +36 -0
  678. package/assets/ide-adapters/cline/devops.md +37 -0
  679. package/assets/ide-adapters/cline/frontend-dev.md +63 -0
  680. package/assets/ide-adapters/cline/knowledge-guide.md +48 -0
  681. package/assets/ide-adapters/cline/leader.md +88 -0
  682. package/assets/ide-adapters/cline/meta-thinker.md +87 -0
  683. package/assets/ide-adapters/cline/mobile-dev.md +26 -0
  684. package/assets/ide-adapters/cline/planner.md +48 -0
  685. package/assets/ide-adapters/cline/qa-engineer.md +65 -0
  686. package/assets/ide-adapters/cline/security-engineer.md +48 -0
  687. package/assets/ide-adapters/cline/seo-specialist.md +27 -0
  688. package/assets/ide-adapters/cline/tech-writer.md +43 -0
  689. package/assets/ide-adapters/copilot/architect.instructions.md +43 -0
  690. package/assets/ide-adapters/copilot/backend-dev.instructions.md +43 -0
  691. package/assets/ide-adapters/copilot/designer.instructions.md +36 -0
  692. package/assets/ide-adapters/copilot/devops.instructions.md +37 -0
  693. package/assets/ide-adapters/copilot/frontend-dev.instructions.md +63 -0
  694. package/assets/ide-adapters/copilot/knowledge-guide.instructions.md +48 -0
  695. package/assets/ide-adapters/copilot/leader.instructions.md +88 -0
  696. package/assets/ide-adapters/copilot/meta-thinker.instructions.md +87 -0
  697. package/assets/ide-adapters/copilot/mobile-dev.instructions.md +26 -0
  698. package/assets/ide-adapters/copilot/planner.instructions.md +48 -0
  699. package/assets/ide-adapters/copilot/qa-engineer.instructions.md +65 -0
  700. package/assets/ide-adapters/copilot/security-engineer.instructions.md +48 -0
  701. package/assets/ide-adapters/copilot/seo-specialist.instructions.md +27 -0
  702. package/assets/ide-adapters/copilot/tech-writer.instructions.md +43 -0
  703. package/assets/ide-adapters/cursor/architect.mdc +44 -0
  704. package/assets/ide-adapters/cursor/backend-dev.mdc +44 -0
  705. package/assets/ide-adapters/cursor/designer.mdc +37 -0
  706. package/assets/ide-adapters/cursor/devops.mdc +38 -0
  707. package/assets/ide-adapters/cursor/frontend-dev.mdc +64 -0
  708. package/assets/ide-adapters/cursor/knowledge-guide.mdc +49 -0
  709. package/assets/ide-adapters/cursor/leader.mdc +89 -0
  710. package/assets/ide-adapters/cursor/meta-thinker.mdc +88 -0
  711. package/assets/ide-adapters/cursor/mobile-dev.mdc +27 -0
  712. package/assets/ide-adapters/cursor/planner.mdc +49 -0
  713. package/assets/ide-adapters/cursor/qa-engineer.mdc +66 -0
  714. package/assets/ide-adapters/cursor/security-engineer.mdc +49 -0
  715. package/assets/ide-adapters/cursor/seo-specialist.mdc +28 -0
  716. package/assets/ide-adapters/cursor/tech-writer.mdc +44 -0
  717. package/assets/ide-adapters/kilocode/architect.md +43 -0
  718. package/assets/ide-adapters/kilocode/backend-dev.md +43 -0
  719. package/assets/ide-adapters/kilocode/designer.md +36 -0
  720. package/assets/ide-adapters/kilocode/devops.md +37 -0
  721. package/assets/ide-adapters/kilocode/frontend-dev.md +63 -0
  722. package/assets/ide-adapters/kilocode/knowledge-guide.md +48 -0
  723. package/assets/ide-adapters/kilocode/leader.md +88 -0
  724. package/assets/ide-adapters/kilocode/meta-thinker.md +87 -0
  725. package/assets/ide-adapters/kilocode/mobile-dev.md +26 -0
  726. package/assets/ide-adapters/kilocode/planner.md +48 -0
  727. package/assets/ide-adapters/kilocode/qa-engineer.md +65 -0
  728. package/assets/ide-adapters/kilocode/security-engineer.md +48 -0
  729. package/assets/ide-adapters/kilocode/seo-specialist.md +27 -0
  730. package/assets/ide-adapters/kilocode/tech-writer.md +43 -0
  731. package/assets/ide-adapters/kiro/hooks/auto-lint.json +8 -0
  732. package/assets/ide-adapters/kiro/hooks/auto-test.json +8 -0
  733. package/assets/ide-adapters/kiro/specs/.gitkeep +0 -0
  734. package/assets/ide-adapters/kiro/steering/product.md +23 -0
  735. package/assets/ide-adapters/kiro/steering/structure.md +23 -0
  736. package/assets/ide-adapters/kiro/steering/tech.md +27 -0
  737. package/assets/ide-adapters/windsurf/architect.md +41 -0
  738. package/assets/ide-adapters/windsurf/backend-dev.md +41 -0
  739. package/assets/ide-adapters/windsurf/designer.md +34 -0
  740. package/assets/ide-adapters/windsurf/devops.md +35 -0
  741. package/assets/ide-adapters/windsurf/frontend-dev.md +61 -0
  742. package/assets/ide-adapters/windsurf/knowledge-guide.md +46 -0
  743. package/assets/ide-adapters/windsurf/leader.md +86 -0
  744. package/assets/ide-adapters/windsurf/meta-thinker.md +85 -0
  745. package/assets/ide-adapters/windsurf/mobile-dev.md +24 -0
  746. package/assets/ide-adapters/windsurf/planner.md +46 -0
  747. package/assets/ide-adapters/windsurf/qa-engineer.md +63 -0
  748. package/assets/ide-adapters/windsurf/security-engineer.md +46 -0
  749. package/assets/ide-adapters/windsurf/seo-specialist.md +25 -0
  750. package/assets/ide-adapters/windsurf/tech-writer.md +41 -0
  751. package/assets/skill_groups.json +574 -0
  752. package/bin/cli.js +101 -0
  753. package/lib/commands.js +133 -0
  754. package/lib/constants.js +76 -0
  755. package/lib/download.js +165 -0
  756. package/lib/init.js +294 -0
  757. package/package.json +45 -0
  758. package/scripts/build-assets.js +177 -0
@@ -0,0 +1,618 @@
1
+ # Authentication and Authorization Implementation Patterns Implementation Playbook
2
+
3
+ This file contains detailed patterns, checklists, and code samples referenced by the skill.
4
+
5
+ ## Core Concepts
6
+
7
+ ### 1. Authentication vs Authorization
8
+
9
+ **Authentication (AuthN)**: Who are you?
10
+ - Verifying identity (username/password, OAuth, biometrics)
11
+ - Issuing credentials (sessions, tokens)
12
+ - Managing login/logout
13
+
14
+ **Authorization (AuthZ)**: What can you do?
15
+ - Permission checking
16
+ - Role-based access control (RBAC)
17
+ - Resource ownership validation
18
+ - Policy enforcement
19
+
20
+ ### 2. Authentication Strategies
21
+
22
+ **Session-Based:**
23
+ - Server stores session state
24
+ - Session ID in cookie
25
+ - Traditional, simple, stateful
26
+
27
+ **Token-Based (JWT):**
28
+ - Stateless, self-contained
29
+ - Scales horizontally
30
+ - Can store claims
31
+
32
+ **OAuth2/OpenID Connect:**
33
+ - Delegate authentication
34
+ - Social login (Google, GitHub)
35
+ - Enterprise SSO
36
+
37
+ ## JWT Authentication
38
+
39
+ ### Pattern 1: JWT Implementation
40
+
41
+ ```typescript
42
+ // JWT structure: header.payload.signature
43
+ import jwt from 'jsonwebtoken';
44
+ import { Request, Response, NextFunction } from 'express';
45
+
46
+ interface JWTPayload {
47
+ userId: string;
48
+ email: string;
49
+ role: string;
50
+ iat: number;
51
+ exp: number;
52
+ }
53
+
54
+ // Generate JWT
55
+ function generateTokens(userId: string, email: string, role: string) {
56
+ const accessToken = jwt.sign(
57
+ { userId, email, role },
58
+ process.env.JWT_SECRET!,
59
+ { expiresIn: '15m' } // Short-lived
60
+ );
61
+
62
+ const refreshToken = jwt.sign(
63
+ { userId },
64
+ process.env.JWT_REFRESH_SECRET!,
65
+ { expiresIn: '7d' } // Long-lived
66
+ );
67
+
68
+ return { accessToken, refreshToken };
69
+ }
70
+
71
+ // Verify JWT
72
+ function verifyToken(token: string): JWTPayload {
73
+ try {
74
+ return jwt.verify(token, process.env.JWT_SECRET!) as JWTPayload;
75
+ } catch (error) {
76
+ if (error instanceof jwt.TokenExpiredError) {
77
+ throw new Error('Token expired');
78
+ }
79
+ if (error instanceof jwt.JsonWebTokenError) {
80
+ throw new Error('Invalid token');
81
+ }
82
+ throw error;
83
+ }
84
+ }
85
+
86
+ // Middleware
87
+ function authenticate(req: Request, res: Response, next: NextFunction) {
88
+ const authHeader = req.headers.authorization;
89
+ if (!authHeader?.startsWith('Bearer ')) {
90
+ return res.status(401).json({ error: 'No token provided' });
91
+ }
92
+
93
+ const token = authHeader.substring(7);
94
+ try {
95
+ const payload = verifyToken(token);
96
+ req.user = payload; // Attach user to request
97
+ next();
98
+ } catch (error) {
99
+ return res.status(401).json({ error: 'Invalid token' });
100
+ }
101
+ }
102
+
103
+ // Usage
104
+ app.get('/api/profile', authenticate, (req, res) => {
105
+ res.json({ user: req.user });
106
+ });
107
+ ```
108
+
109
+ ### Pattern 2: Refresh Token Flow
110
+
111
+ ```typescript
112
+ interface StoredRefreshToken {
113
+ token: string;
114
+ userId: string;
115
+ expiresAt: Date;
116
+ createdAt: Date;
117
+ }
118
+
119
+ class RefreshTokenService {
120
+ // Store refresh token in database
121
+ async storeRefreshToken(userId: string, refreshToken: string) {
122
+ const expiresAt = new Date(Date.now() + 7 * 24 * 60 * 60 * 1000);
123
+ await db.refreshTokens.create({
124
+ token: await hash(refreshToken), // Hash before storing
125
+ userId,
126
+ expiresAt,
127
+ });
128
+ }
129
+
130
+ // Refresh access token
131
+ async refreshAccessToken(refreshToken: string) {
132
+ // Verify refresh token
133
+ let payload;
134
+ try {
135
+ payload = jwt.verify(
136
+ refreshToken,
137
+ process.env.JWT_REFRESH_SECRET!
138
+ ) as { userId: string };
139
+ } catch {
140
+ throw new Error('Invalid refresh token');
141
+ }
142
+
143
+ // Check if token exists in database
144
+ const storedToken = await db.refreshTokens.findOne({
145
+ where: {
146
+ token: await hash(refreshToken),
147
+ userId: payload.userId,
148
+ expiresAt: { $gt: new Date() },
149
+ },
150
+ });
151
+
152
+ if (!storedToken) {
153
+ throw new Error('Refresh token not found or expired');
154
+ }
155
+
156
+ // Get user
157
+ const user = await db.users.findById(payload.userId);
158
+ if (!user) {
159
+ throw new Error('User not found');
160
+ }
161
+
162
+ // Generate new access token
163
+ const accessToken = jwt.sign(
164
+ { userId: user.id, email: user.email, role: user.role },
165
+ process.env.JWT_SECRET!,
166
+ { expiresIn: '15m' }
167
+ );
168
+
169
+ return { accessToken };
170
+ }
171
+
172
+ // Revoke refresh token (logout)
173
+ async revokeRefreshToken(refreshToken: string) {
174
+ await db.refreshTokens.deleteOne({
175
+ token: await hash(refreshToken),
176
+ });
177
+ }
178
+
179
+ // Revoke all user tokens (logout all devices)
180
+ async revokeAllUserTokens(userId: string) {
181
+ await db.refreshTokens.deleteMany({ userId });
182
+ }
183
+ }
184
+
185
+ // API endpoints
186
+ app.post('/api/auth/refresh', async (req, res) => {
187
+ const { refreshToken } = req.body;
188
+ try {
189
+ const { accessToken } = await refreshTokenService
190
+ .refreshAccessToken(refreshToken);
191
+ res.json({ accessToken });
192
+ } catch (error) {
193
+ res.status(401).json({ error: 'Invalid refresh token' });
194
+ }
195
+ });
196
+
197
+ app.post('/api/auth/logout', authenticate, async (req, res) => {
198
+ const { refreshToken } = req.body;
199
+ await refreshTokenService.revokeRefreshToken(refreshToken);
200
+ res.json({ message: 'Logged out successfully' });
201
+ });
202
+ ```
203
+
204
+ ## Session-Based Authentication
205
+
206
+ ### Pattern 1: Express Session
207
+
208
+ ```typescript
209
+ import session from 'express-session';
210
+ import RedisStore from 'connect-redis';
211
+ import { createClient } from 'redis';
212
+
213
+ // Setup Redis for session storage
214
+ const redisClient = createClient({
215
+ url: process.env.REDIS_URL,
216
+ });
217
+ await redisClient.connect();
218
+
219
+ app.use(
220
+ session({
221
+ store: new RedisStore({ client: redisClient }),
222
+ secret: process.env.SESSION_SECRET!,
223
+ resave: false,
224
+ saveUninitialized: false,
225
+ cookie: {
226
+ secure: process.env.NODE_ENV === 'production', // HTTPS only
227
+ httpOnly: true, // No JavaScript access
228
+ maxAge: 24 * 60 * 60 * 1000, // 24 hours
229
+ sameSite: 'strict', // CSRF protection
230
+ },
231
+ })
232
+ );
233
+
234
+ // Login
235
+ app.post('/api/auth/login', async (req, res) => {
236
+ const { email, password } = req.body;
237
+
238
+ const user = await db.users.findOne({ email });
239
+ if (!user || !(await verifyPassword(password, user.passwordHash))) {
240
+ return res.status(401).json({ error: 'Invalid credentials' });
241
+ }
242
+
243
+ // Store user in session
244
+ req.session.userId = user.id;
245
+ req.session.role = user.role;
246
+
247
+ res.json({ user: { id: user.id, email: user.email, role: user.role } });
248
+ });
249
+
250
+ // Session middleware
251
+ function requireAuth(req: Request, res: Response, next: NextFunction) {
252
+ if (!req.session.userId) {
253
+ return res.status(401).json({ error: 'Not authenticated' });
254
+ }
255
+ next();
256
+ }
257
+
258
+ // Protected route
259
+ app.get('/api/profile', requireAuth, async (req, res) => {
260
+ const user = await db.users.findById(req.session.userId);
261
+ res.json({ user });
262
+ });
263
+
264
+ // Logout
265
+ app.post('/api/auth/logout', (req, res) => {
266
+ req.session.destroy((err) => {
267
+ if (err) {
268
+ return res.status(500).json({ error: 'Logout failed' });
269
+ }
270
+ res.clearCookie('connect.sid');
271
+ res.json({ message: 'Logged out successfully' });
272
+ });
273
+ });
274
+ ```
275
+
276
+ ## OAuth2 / Social Login
277
+
278
+ ### Pattern 1: OAuth2 with Passport.js
279
+
280
+ ```typescript
281
+ import passport from 'passport';
282
+ import { Strategy as GoogleStrategy } from 'passport-google-oauth20';
283
+ import { Strategy as GitHubStrategy } from 'passport-github2';
284
+
285
+ // Google OAuth
286
+ passport.use(
287
+ new GoogleStrategy(
288
+ {
289
+ clientID: process.env.GOOGLE_CLIENT_ID!,
290
+ clientSecret: process.env.GOOGLE_CLIENT_SECRET!,
291
+ callbackURL: '/api/auth/google/callback',
292
+ },
293
+ async (accessToken, refreshToken, profile, done) => {
294
+ try {
295
+ // Find or create user
296
+ let user = await db.users.findOne({
297
+ googleId: profile.id,
298
+ });
299
+
300
+ if (!user) {
301
+ user = await db.users.create({
302
+ googleId: profile.id,
303
+ email: profile.emails?.[0]?.value,
304
+ name: profile.displayName,
305
+ avatar: profile.photos?.[0]?.value,
306
+ });
307
+ }
308
+
309
+ return done(null, user);
310
+ } catch (error) {
311
+ return done(error, undefined);
312
+ }
313
+ }
314
+ )
315
+ );
316
+
317
+ // Routes
318
+ app.get('/api/auth/google', passport.authenticate('google', {
319
+ scope: ['profile', 'email'],
320
+ }));
321
+
322
+ app.get(
323
+ '/api/auth/google/callback',
324
+ passport.authenticate('google', { session: false }),
325
+ (req, res) => {
326
+ // Generate JWT
327
+ const tokens = generateTokens(req.user.id, req.user.email, req.user.role);
328
+ // Redirect to frontend with token
329
+ res.redirect(`${process.env.FRONTEND_URL}/auth/callback?token=${tokens.accessToken}`);
330
+ }
331
+ );
332
+ ```
333
+
334
+ ## Authorization Patterns
335
+
336
+ ### Pattern 1: Role-Based Access Control (RBAC)
337
+
338
+ ```typescript
339
+ enum Role {
340
+ USER = 'user',
341
+ MODERATOR = 'moderator',
342
+ ADMIN = 'admin',
343
+ }
344
+
345
+ const roleHierarchy: Record<Role, Role[]> = {
346
+ [Role.ADMIN]: [Role.ADMIN, Role.MODERATOR, Role.USER],
347
+ [Role.MODERATOR]: [Role.MODERATOR, Role.USER],
348
+ [Role.USER]: [Role.USER],
349
+ };
350
+
351
+ function hasRole(userRole: Role, requiredRole: Role): boolean {
352
+ return roleHierarchy[userRole].includes(requiredRole);
353
+ }
354
+
355
+ // Middleware
356
+ function requireRole(...roles: Role[]) {
357
+ return (req: Request, res: Response, next: NextFunction) => {
358
+ if (!req.user) {
359
+ return res.status(401).json({ error: 'Not authenticated' });
360
+ }
361
+
362
+ if (!roles.some(role => hasRole(req.user.role, role))) {
363
+ return res.status(403).json({ error: 'Insufficient permissions' });
364
+ }
365
+
366
+ next();
367
+ };
368
+ }
369
+
370
+ // Usage
371
+ app.delete('/api/users/:id',
372
+ authenticate,
373
+ requireRole(Role.ADMIN),
374
+ async (req, res) => {
375
+ // Only admins can delete users
376
+ await db.users.delete(req.params.id);
377
+ res.json({ message: 'User deleted' });
378
+ }
379
+ );
380
+ ```
381
+
382
+ ### Pattern 2: Permission-Based Access Control
383
+
384
+ ```typescript
385
+ enum Permission {
386
+ READ_USERS = 'read:users',
387
+ WRITE_USERS = 'write:users',
388
+ DELETE_USERS = 'delete:users',
389
+ READ_POSTS = 'read:posts',
390
+ WRITE_POSTS = 'write:posts',
391
+ }
392
+
393
+ const rolePermissions: Record<Role, Permission[]> = {
394
+ [Role.USER]: [Permission.READ_POSTS, Permission.WRITE_POSTS],
395
+ [Role.MODERATOR]: [
396
+ Permission.READ_POSTS,
397
+ Permission.WRITE_POSTS,
398
+ Permission.READ_USERS,
399
+ ],
400
+ [Role.ADMIN]: Object.values(Permission),
401
+ };
402
+
403
+ function hasPermission(userRole: Role, permission: Permission): boolean {
404
+ return rolePermissions[userRole]?.includes(permission) ?? false;
405
+ }
406
+
407
+ function requirePermission(...permissions: Permission[]) {
408
+ return (req: Request, res: Response, next: NextFunction) => {
409
+ if (!req.user) {
410
+ return res.status(401).json({ error: 'Not authenticated' });
411
+ }
412
+
413
+ const hasAllPermissions = permissions.every(permission =>
414
+ hasPermission(req.user.role, permission)
415
+ );
416
+
417
+ if (!hasAllPermissions) {
418
+ return res.status(403).json({ error: 'Insufficient permissions' });
419
+ }
420
+
421
+ next();
422
+ };
423
+ }
424
+
425
+ // Usage
426
+ app.get('/api/users',
427
+ authenticate,
428
+ requirePermission(Permission.READ_USERS),
429
+ async (req, res) => {
430
+ const users = await db.users.findAll();
431
+ res.json({ users });
432
+ }
433
+ );
434
+ ```
435
+
436
+ ### Pattern 3: Resource Ownership
437
+
438
+ ```typescript
439
+ // Check if user owns resource
440
+ async function requireOwnership(
441
+ resourceType: 'post' | 'comment',
442
+ resourceIdParam: string = 'id'
443
+ ) {
444
+ return async (req: Request, res: Response, next: NextFunction) => {
445
+ if (!req.user) {
446
+ return res.status(401).json({ error: 'Not authenticated' });
447
+ }
448
+
449
+ const resourceId = req.params[resourceIdParam];
450
+
451
+ // Admins can access anything
452
+ if (req.user.role === Role.ADMIN) {
453
+ return next();
454
+ }
455
+
456
+ // Check ownership
457
+ let resource;
458
+ if (resourceType === 'post') {
459
+ resource = await db.posts.findById(resourceId);
460
+ } else if (resourceType === 'comment') {
461
+ resource = await db.comments.findById(resourceId);
462
+ }
463
+
464
+ if (!resource) {
465
+ return res.status(404).json({ error: 'Resource not found' });
466
+ }
467
+
468
+ if (resource.userId !== req.user.userId) {
469
+ return res.status(403).json({ error: 'Not authorized' });
470
+ }
471
+
472
+ next();
473
+ };
474
+ }
475
+
476
+ // Usage
477
+ app.put('/api/posts/:id',
478
+ authenticate,
479
+ requireOwnership('post'),
480
+ async (req, res) => {
481
+ // User can only update their own posts
482
+ const post = await db.posts.update(req.params.id, req.body);
483
+ res.json({ post });
484
+ }
485
+ );
486
+ ```
487
+
488
+ ## Security Best Practices
489
+
490
+ ### Pattern 1: Password Security
491
+
492
+ ```typescript
493
+ import bcrypt from 'bcrypt';
494
+ import { z } from 'zod';
495
+
496
+ // Password validation schema
497
+ const passwordSchema = z.string()
498
+ .min(12, 'Password must be at least 12 characters')
499
+ .regex(/[A-Z]/, 'Password must contain uppercase letter')
500
+ .regex(/[a-z]/, 'Password must contain lowercase letter')
501
+ .regex(/[0-9]/, 'Password must contain number')
502
+ .regex(/[^A-Za-z0-9]/, 'Password must contain special character');
503
+
504
+ // Hash password
505
+ async function hashPassword(password: string): Promise<string> {
506
+ const saltRounds = 12; // 2^12 iterations
507
+ return bcrypt.hash(password, saltRounds);
508
+ }
509
+
510
+ // Verify password
511
+ async function verifyPassword(
512
+ password: string,
513
+ hash: string
514
+ ): Promise<boolean> {
515
+ return bcrypt.compare(password, hash);
516
+ }
517
+
518
+ // Registration with password validation
519
+ app.post('/api/auth/register', async (req, res) => {
520
+ try {
521
+ const { email, password } = req.body;
522
+
523
+ // Validate password
524
+ passwordSchema.parse(password);
525
+
526
+ // Check if user exists
527
+ const existingUser = await db.users.findOne({ email });
528
+ if (existingUser) {
529
+ return res.status(400).json({ error: 'Email already registered' });
530
+ }
531
+
532
+ // Hash password
533
+ const passwordHash = await hashPassword(password);
534
+
535
+ // Create user
536
+ const user = await db.users.create({
537
+ email,
538
+ passwordHash,
539
+ });
540
+
541
+ // Generate tokens
542
+ const tokens = generateTokens(user.id, user.email, user.role);
543
+
544
+ res.status(201).json({
545
+ user: { id: user.id, email: user.email },
546
+ ...tokens,
547
+ });
548
+ } catch (error) {
549
+ if (error instanceof z.ZodError) {
550
+ return res.status(400).json({ error: error.errors[0].message });
551
+ }
552
+ res.status(500).json({ error: 'Registration failed' });
553
+ }
554
+ });
555
+ ```
556
+
557
+ ### Pattern 2: Rate Limiting
558
+
559
+ ```typescript
560
+ import rateLimit from 'express-rate-limit';
561
+ import RedisStore from 'rate-limit-redis';
562
+
563
+ // Login rate limiter
564
+ const loginLimiter = rateLimit({
565
+ store: new RedisStore({ client: redisClient }),
566
+ windowMs: 15 * 60 * 1000, // 15 minutes
567
+ max: 5, // 5 attempts
568
+ message: 'Too many login attempts, please try again later',
569
+ standardHeaders: true,
570
+ legacyHeaders: false,
571
+ });
572
+
573
+ // API rate limiter
574
+ const apiLimiter = rateLimit({
575
+ windowMs: 60 * 1000, // 1 minute
576
+ max: 100, // 100 requests per minute
577
+ standardHeaders: true,
578
+ });
579
+
580
+ // Apply to routes
581
+ app.post('/api/auth/login', loginLimiter, async (req, res) => {
582
+ // Login logic
583
+ });
584
+
585
+ app.use('/api/', apiLimiter);
586
+ ```
587
+
588
+ ## Best Practices
589
+
590
+ 1. **Never Store Plain Passwords**: Always hash with bcrypt/argon2
591
+ 2. **Use HTTPS**: Encrypt data in transit
592
+ 3. **Short-Lived Access Tokens**: 15-30 minutes max
593
+ 4. **Secure Cookies**: httpOnly, secure, sameSite flags
594
+ 5. **Validate All Input**: Email format, password strength
595
+ 6. **Rate Limit Auth Endpoints**: Prevent brute force attacks
596
+ 7. **Implement CSRF Protection**: For session-based auth
597
+ 8. **Rotate Secrets Regularly**: JWT secrets, session secrets
598
+ 9. **Log Security Events**: Login attempts, failed auth
599
+ 10. **Use MFA When Possible**: Extra security layer
600
+
601
+ ## Common Pitfalls
602
+
603
+ - **Weak Passwords**: Enforce strong password policies
604
+ - **JWT in localStorage**: Vulnerable to XSS, use httpOnly cookies
605
+ - **No Token Expiration**: Tokens should expire
606
+ - **Client-Side Auth Checks Only**: Always validate server-side
607
+ - **Insecure Password Reset**: Use secure tokens with expiration
608
+ - **No Rate Limiting**: Vulnerable to brute force
609
+ - **Trusting Client Data**: Always validate on server
610
+
611
+ ## Resources
612
+
613
+ - **references/jwt-best-practices.md**: JWT implementation guide
614
+ - **references/oauth2-flows.md**: OAuth2 flow diagrams and examples
615
+ - **references/session-security.md**: Secure session management
616
+ - **assets/auth-security-checklist.md**: Security review checklist
617
+ - **assets/password-policy-template.md**: Password requirements template
618
+ - **scripts/token-validator.ts**: JWT validation utility