javi-forge 0.1.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 (500) hide show
  1. package/.gitignore.template +105 -0
  2. package/.releaserc +44 -0
  3. package/README.md +45 -0
  4. package/ai-config/.skillignore +15 -0
  5. package/ai-config/AUTO_INVOKE.md +300 -0
  6. package/ai-config/agents/_TEMPLATE.md +93 -0
  7. package/ai-config/agents/business/api-designer.md +1657 -0
  8. package/ai-config/agents/business/business-analyst.md +1331 -0
  9. package/ai-config/agents/business/product-strategist.md +206 -0
  10. package/ai-config/agents/business/project-manager.md +178 -0
  11. package/ai-config/agents/business/requirements-analyst.md +1277 -0
  12. package/ai-config/agents/business/technical-writer.md +1679 -0
  13. package/ai-config/agents/creative/ux-designer.md +205 -0
  14. package/ai-config/agents/data-ai/ai-engineer.md +487 -0
  15. package/ai-config/agents/data-ai/analytics-engineer.md +953 -0
  16. package/ai-config/agents/data-ai/data-engineer.md +173 -0
  17. package/ai-config/agents/data-ai/data-scientist.md +672 -0
  18. package/ai-config/agents/data-ai/mlops-engineer.md +814 -0
  19. package/ai-config/agents/data-ai/prompt-engineer.md +772 -0
  20. package/ai-config/agents/development/angular-expert.md +620 -0
  21. package/ai-config/agents/development/backend-architect.md +795 -0
  22. package/ai-config/agents/development/database-specialist.md +212 -0
  23. package/ai-config/agents/development/frontend-specialist.md +686 -0
  24. package/ai-config/agents/development/fullstack-engineer.md +668 -0
  25. package/ai-config/agents/development/golang-pro.md +338 -0
  26. package/ai-config/agents/development/java-enterprise.md +400 -0
  27. package/ai-config/agents/development/javascript-pro.md +422 -0
  28. package/ai-config/agents/development/nextjs-pro.md +474 -0
  29. package/ai-config/agents/development/python-pro.md +570 -0
  30. package/ai-config/agents/development/react-pro.md +487 -0
  31. package/ai-config/agents/development/rust-pro.md +246 -0
  32. package/ai-config/agents/development/spring-boot-4-expert.md +326 -0
  33. package/ai-config/agents/development/typescript-pro.md +336 -0
  34. package/ai-config/agents/development/vue-specialist.md +605 -0
  35. package/ai-config/agents/infrastructure/cloud-architect.md +472 -0
  36. package/ai-config/agents/infrastructure/deployment-manager.md +358 -0
  37. package/ai-config/agents/infrastructure/devops-engineer.md +455 -0
  38. package/ai-config/agents/infrastructure/incident-responder.md +519 -0
  39. package/ai-config/agents/infrastructure/kubernetes-expert.md +705 -0
  40. package/ai-config/agents/infrastructure/monitoring-specialist.md +674 -0
  41. package/ai-config/agents/infrastructure/performance-engineer.md +658 -0
  42. package/ai-config/agents/orchestrator.md +241 -0
  43. package/ai-config/agents/quality/accessibility-auditor.md +1204 -0
  44. package/ai-config/agents/quality/code-reviewer-compact.md +123 -0
  45. package/ai-config/agents/quality/code-reviewer.md +363 -0
  46. package/ai-config/agents/quality/dependency-manager.md +743 -0
  47. package/ai-config/agents/quality/e2e-test-specialist.md +1005 -0
  48. package/ai-config/agents/quality/performance-tester.md +1086 -0
  49. package/ai-config/agents/quality/security-auditor.md +133 -0
  50. package/ai-config/agents/quality/test-engineer.md +453 -0
  51. package/ai-config/agents/specialists/api-designer.md +87 -0
  52. package/ai-config/agents/specialists/backend-architect.md +73 -0
  53. package/ai-config/agents/specialists/code-reviewer.md +77 -0
  54. package/ai-config/agents/specialists/db-optimizer.md +75 -0
  55. package/ai-config/agents/specialists/devops-engineer.md +83 -0
  56. package/ai-config/agents/specialists/documentation-writer.md +78 -0
  57. package/ai-config/agents/specialists/frontend-developer.md +75 -0
  58. package/ai-config/agents/specialists/performance-analyst.md +82 -0
  59. package/ai-config/agents/specialists/refactor-specialist.md +74 -0
  60. package/ai-config/agents/specialists/security-auditor.md +74 -0
  61. package/ai-config/agents/specialists/test-engineer.md +81 -0
  62. package/ai-config/agents/specialists/ux-consultant.md +76 -0
  63. package/ai-config/agents/specialized/agent-generator.md +1190 -0
  64. package/ai-config/agents/specialized/blockchain-developer.md +149 -0
  65. package/ai-config/agents/specialized/code-migrator.md +892 -0
  66. package/ai-config/agents/specialized/context-manager.md +978 -0
  67. package/ai-config/agents/specialized/documentation-writer.md +1078 -0
  68. package/ai-config/agents/specialized/ecommerce-expert.md +1756 -0
  69. package/ai-config/agents/specialized/embedded-engineer.md +1714 -0
  70. package/ai-config/agents/specialized/error-detective.md +1034 -0
  71. package/ai-config/agents/specialized/fintech-specialist.md +1659 -0
  72. package/ai-config/agents/specialized/freelance-project-planner-v2.md +1988 -0
  73. package/ai-config/agents/specialized/freelance-project-planner-v3.md +2136 -0
  74. package/ai-config/agents/specialized/freelance-project-planner-v4.md +4503 -0
  75. package/ai-config/agents/specialized/freelance-project-planner.md +722 -0
  76. package/ai-config/agents/specialized/game-developer.md +1963 -0
  77. package/ai-config/agents/specialized/healthcare-dev.md +1620 -0
  78. package/ai-config/agents/specialized/mobile-developer.md +188 -0
  79. package/ai-config/agents/specialized/parallel-plan-executor.md +506 -0
  80. package/ai-config/agents/specialized/plan-executor.md +485 -0
  81. package/ai-config/agents/specialized/solo-dev-planner-modular/00-INDEX.md +485 -0
  82. package/ai-config/agents/specialized/solo-dev-planner-modular/01-CORE.md +3493 -0
  83. package/ai-config/agents/specialized/solo-dev-planner-modular/02-SELF-CORRECTION.md +778 -0
  84. package/ai-config/agents/specialized/solo-dev-planner-modular/03-PROGRESSIVE-SETUP.md +918 -0
  85. package/ai-config/agents/specialized/solo-dev-planner-modular/04-DEPLOYMENT.md +1537 -0
  86. package/ai-config/agents/specialized/solo-dev-planner-modular/05-TESTING.md +2633 -0
  87. package/ai-config/agents/specialized/solo-dev-planner-modular/06-OPERATIONS.md +5610 -0
  88. package/ai-config/agents/specialized/solo-dev-planner-modular/INSTALL.md +335 -0
  89. package/ai-config/agents/specialized/solo-dev-planner-modular/QUICK-REFERENCE.txt +215 -0
  90. package/ai-config/agents/specialized/solo-dev-planner-modular/README.md +260 -0
  91. package/ai-config/agents/specialized/solo-dev-planner-modular/START-HERE.md +379 -0
  92. package/ai-config/agents/specialized/solo-dev-planner-modular/WORKFLOW-DIAGRAM.md +355 -0
  93. package/ai-config/agents/specialized/solo-dev-planner-modular/solo-dev-planner.md +279 -0
  94. package/ai-config/agents/specialized/template-writer.md +347 -0
  95. package/ai-config/agents/specialized/test-runner.md +99 -0
  96. package/ai-config/agents/specialized/vibekanban-smart-worker.md +244 -0
  97. package/ai-config/agents/specialized/wave-executor.md +138 -0
  98. package/ai-config/agents/specialized/workflow-optimizer.md +1114 -0
  99. package/ai-config/commands/git/changelog.md +32 -0
  100. package/ai-config/commands/git/ci-local.md +70 -0
  101. package/ai-config/commands/git/commit.md +35 -0
  102. package/ai-config/commands/git/fix-issue.md +23 -0
  103. package/ai-config/commands/git/pr-create.md +42 -0
  104. package/ai-config/commands/git/pr-review.md +50 -0
  105. package/ai-config/commands/git/worktree.md +39 -0
  106. package/ai-config/commands/refactoring/cleanup.md +24 -0
  107. package/ai-config/commands/refactoring/dead-code.md +40 -0
  108. package/ai-config/commands/refactoring/extract.md +31 -0
  109. package/ai-config/commands/testing/e2e.md +30 -0
  110. package/ai-config/commands/testing/tdd.md +36 -0
  111. package/ai-config/commands/testing/test-coverage.md +30 -0
  112. package/ai-config/commands/testing/test-fix.md +24 -0
  113. package/ai-config/commands/workflow/generate-agents-md.md +85 -0
  114. package/ai-config/commands/workflow/planning.md +47 -0
  115. package/ai-config/commands/workflows/compound.md +89 -0
  116. package/ai-config/commands/workflows/plan.md +77 -0
  117. package/ai-config/commands/workflows/review.md +78 -0
  118. package/ai-config/commands/workflows/work.md +75 -0
  119. package/ai-config/config.yaml +18 -0
  120. package/ai-config/hooks/_TEMPLATE.md +96 -0
  121. package/ai-config/hooks/block-dangerous-commands.md +75 -0
  122. package/ai-config/hooks/commit-guard.md +90 -0
  123. package/ai-config/hooks/context-loader.md +73 -0
  124. package/ai-config/hooks/improve-prompt.md +91 -0
  125. package/ai-config/hooks/learning-log.md +72 -0
  126. package/ai-config/hooks/model-router.md +86 -0
  127. package/ai-config/hooks/secret-scanner.md +64 -0
  128. package/ai-config/hooks/skill-validator.md +102 -0
  129. package/ai-config/hooks/task-artifact.md +114 -0
  130. package/ai-config/hooks/validate-workflow.md +100 -0
  131. package/ai-config/prompts/base.md +71 -0
  132. package/ai-config/prompts/modes/debug.md +34 -0
  133. package/ai-config/prompts/modes/deploy.md +40 -0
  134. package/ai-config/prompts/modes/research.md +32 -0
  135. package/ai-config/prompts/modes/review.md +33 -0
  136. package/ai-config/prompts/review-policy.md +79 -0
  137. package/ai-config/skills/_TEMPLATE.md +157 -0
  138. package/ai-config/skills/backend/api-gateway/SKILL.md +254 -0
  139. package/ai-config/skills/backend/bff-concepts/SKILL.md +239 -0
  140. package/ai-config/skills/backend/bff-spring/SKILL.md +364 -0
  141. package/ai-config/skills/backend/chi-router/SKILL.md +396 -0
  142. package/ai-config/skills/backend/error-handling/SKILL.md +255 -0
  143. package/ai-config/skills/backend/exceptions-spring/SKILL.md +323 -0
  144. package/ai-config/skills/backend/fastapi/SKILL.md +302 -0
  145. package/ai-config/skills/backend/gateway-spring/SKILL.md +390 -0
  146. package/ai-config/skills/backend/go-backend/SKILL.md +457 -0
  147. package/ai-config/skills/backend/gradle-multimodule/SKILL.md +274 -0
  148. package/ai-config/skills/backend/graphql-concepts/SKILL.md +352 -0
  149. package/ai-config/skills/backend/graphql-spring/SKILL.md +398 -0
  150. package/ai-config/skills/backend/grpc-concepts/SKILL.md +283 -0
  151. package/ai-config/skills/backend/grpc-spring/SKILL.md +445 -0
  152. package/ai-config/skills/backend/jwt-auth/SKILL.md +412 -0
  153. package/ai-config/skills/backend/notifications-concepts/SKILL.md +259 -0
  154. package/ai-config/skills/backend/recommendations-concepts/SKILL.md +261 -0
  155. package/ai-config/skills/backend/search-concepts/SKILL.md +263 -0
  156. package/ai-config/skills/backend/search-spring/SKILL.md +375 -0
  157. package/ai-config/skills/backend/spring-boot-4/SKILL.md +172 -0
  158. package/ai-config/skills/backend/websockets/SKILL.md +532 -0
  159. package/ai-config/skills/data-ai/ai-ml/SKILL.md +423 -0
  160. package/ai-config/skills/data-ai/analytics-concepts/SKILL.md +195 -0
  161. package/ai-config/skills/data-ai/analytics-spring/SKILL.md +340 -0
  162. package/ai-config/skills/data-ai/duckdb-analytics/SKILL.md +440 -0
  163. package/ai-config/skills/data-ai/langchain/SKILL.md +238 -0
  164. package/ai-config/skills/data-ai/mlflow/SKILL.md +302 -0
  165. package/ai-config/skills/data-ai/onnx-inference/SKILL.md +290 -0
  166. package/ai-config/skills/data-ai/powerbi/SKILL.md +352 -0
  167. package/ai-config/skills/data-ai/pytorch/SKILL.md +274 -0
  168. package/ai-config/skills/data-ai/scikit-learn/SKILL.md +321 -0
  169. package/ai-config/skills/data-ai/vector-db/SKILL.md +301 -0
  170. package/ai-config/skills/database/graph-databases/SKILL.md +218 -0
  171. package/ai-config/skills/database/graph-spring/SKILL.md +361 -0
  172. package/ai-config/skills/database/pgx-postgres/SKILL.md +512 -0
  173. package/ai-config/skills/database/redis-cache/SKILL.md +343 -0
  174. package/ai-config/skills/database/sqlite-embedded/SKILL.md +388 -0
  175. package/ai-config/skills/database/timescaledb/SKILL.md +320 -0
  176. package/ai-config/skills/docs/api-documentation/SKILL.md +293 -0
  177. package/ai-config/skills/docs/docs-spring/SKILL.md +377 -0
  178. package/ai-config/skills/docs/mustache-templates/SKILL.md +190 -0
  179. package/ai-config/skills/docs/technical-docs/SKILL.md +447 -0
  180. package/ai-config/skills/frontend/astro-ssr/SKILL.md +441 -0
  181. package/ai-config/skills/frontend/frontend-design/SKILL.md +54 -0
  182. package/ai-config/skills/frontend/frontend-web/SKILL.md +368 -0
  183. package/ai-config/skills/frontend/mantine-ui/SKILL.md +396 -0
  184. package/ai-config/skills/frontend/tanstack-query/SKILL.md +439 -0
  185. package/ai-config/skills/frontend/zod-validation/SKILL.md +417 -0
  186. package/ai-config/skills/frontend/zustand-state/SKILL.md +350 -0
  187. package/ai-config/skills/infrastructure/chaos-engineering/SKILL.md +244 -0
  188. package/ai-config/skills/infrastructure/chaos-spring/SKILL.md +378 -0
  189. package/ai-config/skills/infrastructure/devops-infra/SKILL.md +435 -0
  190. package/ai-config/skills/infrastructure/docker-containers/SKILL.md +420 -0
  191. package/ai-config/skills/infrastructure/kubernetes/SKILL.md +456 -0
  192. package/ai-config/skills/infrastructure/opentelemetry/SKILL.md +546 -0
  193. package/ai-config/skills/infrastructure/traefik-proxy/SKILL.md +474 -0
  194. package/ai-config/skills/infrastructure/woodpecker-ci/SKILL.md +315 -0
  195. package/ai-config/skills/mobile/ionic-capacitor/SKILL.md +504 -0
  196. package/ai-config/skills/mobile/mobile-ionic/SKILL.md +448 -0
  197. package/ai-config/skills/prompt-improver/SKILL.md +125 -0
  198. package/ai-config/skills/quality/ghagga-review/SKILL.md +216 -0
  199. package/ai-config/skills/references/hooks-patterns/SKILL.md +238 -0
  200. package/ai-config/skills/references/mcp-servers/SKILL.md +275 -0
  201. package/ai-config/skills/references/plugins-reference/SKILL.md +110 -0
  202. package/ai-config/skills/references/skills-reference/SKILL.md +420 -0
  203. package/ai-config/skills/references/subagent-templates/SKILL.md +193 -0
  204. package/ai-config/skills/systems-iot/modbus-protocol/SKILL.md +410 -0
  205. package/ai-config/skills/systems-iot/mqtt-rumqttc/SKILL.md +408 -0
  206. package/ai-config/skills/systems-iot/rust-systems/SKILL.md +386 -0
  207. package/ai-config/skills/systems-iot/tokio-async/SKILL.md +324 -0
  208. package/ai-config/skills/testing/playwright-e2e/SKILL.md +289 -0
  209. package/ai-config/skills/testing/testcontainers/SKILL.md +299 -0
  210. package/ai-config/skills/testing/vitest-testing/SKILL.md +381 -0
  211. package/ai-config/skills/workflow/ci-local-guide/SKILL.md +118 -0
  212. package/ai-config/skills/workflow/claude-automation-recommender/SKILL.md +299 -0
  213. package/ai-config/skills/workflow/claude-md-improver/SKILL.md +158 -0
  214. package/ai-config/skills/workflow/finishing-a-development-branch/SKILL.md +117 -0
  215. package/ai-config/skills/workflow/git-github/SKILL.md +334 -0
  216. package/ai-config/skills/workflow/git-github/references/examples.md +160 -0
  217. package/ai-config/skills/workflow/git-workflow/SKILL.md +214 -0
  218. package/ai-config/skills/workflow/ide-plugins/SKILL.md +277 -0
  219. package/ai-config/skills/workflow/ide-plugins-intellij/SKILL.md +401 -0
  220. package/ai-config/skills/workflow/obsidian-brain-workflow/SKILL.md +199 -0
  221. package/ai-config/skills/workflow/using-git-worktrees/SKILL.md +100 -0
  222. package/ai-config/skills/workflow/verification-before-completion/SKILL.md +73 -0
  223. package/ai-config/skills/workflow/wave-workflow/SKILL.md +178 -0
  224. package/ci-local/README.md +170 -0
  225. package/ci-local/ci-local.sh +297 -0
  226. package/ci-local/hooks/commit-msg +74 -0
  227. package/ci-local/hooks/pre-commit +162 -0
  228. package/ci-local/hooks/pre-push +41 -0
  229. package/ci-local/install.sh +49 -0
  230. package/ci-local/semgrep.yml +214 -0
  231. package/dist/commands/analyze.d.ts +9 -0
  232. package/dist/commands/analyze.d.ts.map +1 -0
  233. package/dist/commands/analyze.js +55 -0
  234. package/dist/commands/analyze.js.map +1 -0
  235. package/dist/commands/analyze.test.d.ts +2 -0
  236. package/dist/commands/analyze.test.d.ts.map +1 -0
  237. package/dist/commands/analyze.test.js +145 -0
  238. package/dist/commands/analyze.test.js.map +1 -0
  239. package/dist/commands/doctor.d.ts +7 -0
  240. package/dist/commands/doctor.d.ts.map +1 -0
  241. package/dist/commands/doctor.js +158 -0
  242. package/dist/commands/doctor.js.map +1 -0
  243. package/dist/commands/doctor.test.d.ts +2 -0
  244. package/dist/commands/doctor.test.d.ts.map +1 -0
  245. package/dist/commands/doctor.test.js +200 -0
  246. package/dist/commands/doctor.test.js.map +1 -0
  247. package/dist/commands/init.d.ts +9 -0
  248. package/dist/commands/init.d.ts.map +1 -0
  249. package/dist/commands/init.js +283 -0
  250. package/dist/commands/init.js.map +1 -0
  251. package/dist/commands/init.test.d.ts +2 -0
  252. package/dist/commands/init.test.d.ts.map +1 -0
  253. package/dist/commands/init.test.js +271 -0
  254. package/dist/commands/init.test.js.map +1 -0
  255. package/dist/commands/sync.d.ts +8 -0
  256. package/dist/commands/sync.d.ts.map +1 -0
  257. package/dist/commands/sync.js +201 -0
  258. package/dist/commands/sync.js.map +1 -0
  259. package/dist/constants.d.ts +21 -0
  260. package/dist/constants.d.ts.map +1 -0
  261. package/dist/constants.js +57 -0
  262. package/dist/constants.js.map +1 -0
  263. package/dist/e2e/aggressive.e2e.test.d.ts +2 -0
  264. package/dist/e2e/aggressive.e2e.test.d.ts.map +1 -0
  265. package/dist/e2e/aggressive.e2e.test.js +350 -0
  266. package/dist/e2e/aggressive.e2e.test.js.map +1 -0
  267. package/dist/e2e/commands.e2e.test.d.ts +2 -0
  268. package/dist/e2e/commands.e2e.test.d.ts.map +1 -0
  269. package/dist/e2e/commands.e2e.test.js +213 -0
  270. package/dist/e2e/commands.e2e.test.js.map +1 -0
  271. package/dist/index.d.ts +3 -0
  272. package/dist/index.d.ts.map +1 -0
  273. package/dist/index.js +82 -0
  274. package/dist/index.js.map +1 -0
  275. package/dist/lib/common.d.ts +17 -0
  276. package/dist/lib/common.d.ts.map +1 -0
  277. package/dist/lib/common.js +111 -0
  278. package/dist/lib/common.js.map +1 -0
  279. package/dist/lib/common.test.d.ts +2 -0
  280. package/dist/lib/common.test.d.ts.map +1 -0
  281. package/dist/lib/common.test.js +316 -0
  282. package/dist/lib/common.test.js.map +1 -0
  283. package/dist/lib/frontmatter.d.ts +18 -0
  284. package/dist/lib/frontmatter.d.ts.map +1 -0
  285. package/dist/lib/frontmatter.js +61 -0
  286. package/dist/lib/frontmatter.js.map +1 -0
  287. package/dist/lib/frontmatter.test.d.ts +2 -0
  288. package/dist/lib/frontmatter.test.d.ts.map +1 -0
  289. package/dist/lib/frontmatter.test.js +257 -0
  290. package/dist/lib/frontmatter.test.js.map +1 -0
  291. package/dist/lib/template.d.ts +24 -0
  292. package/dist/lib/template.d.ts.map +1 -0
  293. package/dist/lib/template.js +78 -0
  294. package/dist/lib/template.js.map +1 -0
  295. package/dist/lib/template.test.d.ts +2 -0
  296. package/dist/lib/template.test.d.ts.map +1 -0
  297. package/dist/lib/template.test.js +201 -0
  298. package/dist/lib/template.test.js.map +1 -0
  299. package/dist/types/index.d.ts +48 -0
  300. package/dist/types/index.d.ts.map +1 -0
  301. package/dist/types/index.js +2 -0
  302. package/dist/types/index.js.map +1 -0
  303. package/dist/ui/AnalyzeUI.d.ts +7 -0
  304. package/dist/ui/AnalyzeUI.d.ts.map +1 -0
  305. package/dist/ui/AnalyzeUI.js +100 -0
  306. package/dist/ui/AnalyzeUI.js.map +1 -0
  307. package/dist/ui/App.d.ts +13 -0
  308. package/dist/ui/App.d.ts.map +1 -0
  309. package/dist/ui/App.js +100 -0
  310. package/dist/ui/App.js.map +1 -0
  311. package/dist/ui/CIContext.d.ts +9 -0
  312. package/dist/ui/CIContext.d.ts.map +1 -0
  313. package/dist/ui/CIContext.js +9 -0
  314. package/dist/ui/CIContext.js.map +1 -0
  315. package/dist/ui/CISelector.d.ts +8 -0
  316. package/dist/ui/CISelector.d.ts.map +1 -0
  317. package/dist/ui/CISelector.js +45 -0
  318. package/dist/ui/CISelector.js.map +1 -0
  319. package/dist/ui/Doctor.d.ts +3 -0
  320. package/dist/ui/Doctor.d.ts.map +1 -0
  321. package/dist/ui/Doctor.js +89 -0
  322. package/dist/ui/Doctor.js.map +1 -0
  323. package/dist/ui/Header.d.ts +8 -0
  324. package/dist/ui/Header.d.ts.map +1 -0
  325. package/dist/ui/Header.js +30 -0
  326. package/dist/ui/Header.js.map +1 -0
  327. package/dist/ui/MemorySelector.d.ts +8 -0
  328. package/dist/ui/MemorySelector.d.ts.map +1 -0
  329. package/dist/ui/MemorySelector.js +46 -0
  330. package/dist/ui/MemorySelector.js.map +1 -0
  331. package/dist/ui/NameInput.d.ts +8 -0
  332. package/dist/ui/NameInput.d.ts.map +1 -0
  333. package/dist/ui/NameInput.js +69 -0
  334. package/dist/ui/NameInput.js.map +1 -0
  335. package/dist/ui/OptionSelector.d.ts +12 -0
  336. package/dist/ui/OptionSelector.d.ts.map +1 -0
  337. package/dist/ui/OptionSelector.js +69 -0
  338. package/dist/ui/OptionSelector.js.map +1 -0
  339. package/dist/ui/Progress.d.ts +11 -0
  340. package/dist/ui/Progress.d.ts.map +1 -0
  341. package/dist/ui/Progress.js +58 -0
  342. package/dist/ui/Progress.js.map +1 -0
  343. package/dist/ui/StackSelector.d.ts +9 -0
  344. package/dist/ui/StackSelector.d.ts.map +1 -0
  345. package/dist/ui/StackSelector.js +65 -0
  346. package/dist/ui/StackSelector.js.map +1 -0
  347. package/dist/ui/Summary.d.ts +12 -0
  348. package/dist/ui/Summary.d.ts.map +1 -0
  349. package/dist/ui/Summary.js +114 -0
  350. package/dist/ui/Summary.js.map +1 -0
  351. package/dist/ui/SyncUI.d.ts +10 -0
  352. package/dist/ui/SyncUI.d.ts.map +1 -0
  353. package/dist/ui/SyncUI.js +64 -0
  354. package/dist/ui/SyncUI.js.map +1 -0
  355. package/dist/ui/Welcome.d.ts +7 -0
  356. package/dist/ui/Welcome.d.ts.map +1 -0
  357. package/dist/ui/Welcome.js +45 -0
  358. package/dist/ui/Welcome.js.map +1 -0
  359. package/dist/ui/theme.d.ts +10 -0
  360. package/dist/ui/theme.d.ts.map +1 -0
  361. package/dist/ui/theme.js +9 -0
  362. package/dist/ui/theme.js.map +1 -0
  363. package/modules/engram/.gitignore-snippet.txt +6 -0
  364. package/modules/engram/.mcp-config-snippet.json +11 -0
  365. package/modules/engram/README.md +146 -0
  366. package/modules/engram/install-engram.sh +216 -0
  367. package/modules/ghagga/.env.example +43 -0
  368. package/modules/ghagga/README.md +153 -0
  369. package/modules/ghagga/docker-compose.yml +80 -0
  370. package/modules/ghagga/setup-ghagga.sh +139 -0
  371. package/modules/memory-simple/.project/NOTES.md +22 -0
  372. package/modules/memory-simple/README.md +23 -0
  373. package/modules/obsidian-brain/.obsidian/app.json +23 -0
  374. package/modules/obsidian-brain/.obsidian/appearance.json +5 -0
  375. package/modules/obsidian-brain/.obsidian/bookmarks.json +34 -0
  376. package/modules/obsidian-brain/.obsidian/community-plugins.json +1 -0
  377. package/modules/obsidian-brain/.obsidian/core-plugins-migration.json +21 -0
  378. package/modules/obsidian-brain/.obsidian/core-plugins.json +18 -0
  379. package/modules/obsidian-brain/.obsidian/daily-notes.json +5 -0
  380. package/modules/obsidian-brain/.obsidian/graph.json +37 -0
  381. package/modules/obsidian-brain/.obsidian/hotkeys.json +14 -0
  382. package/modules/obsidian-brain/.obsidian/plugins/dataview/data.json +25 -0
  383. package/modules/obsidian-brain/.obsidian/plugins/obsidian-kanban/data.json +29 -0
  384. package/modules/obsidian-brain/.obsidian/plugins/templater-obsidian/data.json +18 -0
  385. package/modules/obsidian-brain/.obsidian/snippets/project-memory.css +71 -0
  386. package/modules/obsidian-brain/.obsidian-gitignore-snippet.txt +8 -0
  387. package/modules/obsidian-brain/.project/Attachments/.gitkeep +0 -0
  388. package/modules/obsidian-brain/.project/Memory/BLOCKERS.md +78 -0
  389. package/modules/obsidian-brain/.project/Memory/CONTEXT.md +102 -0
  390. package/modules/obsidian-brain/.project/Memory/DASHBOARD.md +73 -0
  391. package/modules/obsidian-brain/.project/Memory/DECISIONS.md +87 -0
  392. package/modules/obsidian-brain/.project/Memory/KANBAN.md +15 -0
  393. package/modules/obsidian-brain/.project/Memory/README.md +61 -0
  394. package/modules/obsidian-brain/.project/Memory/WAVES.md +78 -0
  395. package/modules/obsidian-brain/.project/Sessions/TEMPLATE.md +99 -0
  396. package/modules/obsidian-brain/.project/Templates/ADR.md +33 -0
  397. package/modules/obsidian-brain/.project/Templates/Blocker.md +21 -0
  398. package/modules/obsidian-brain/.project/Templates/Session.md +88 -0
  399. package/modules/obsidian-brain/README.md +268 -0
  400. package/modules/obsidian-brain/new-wave.sh +182 -0
  401. package/package.json +51 -0
  402. package/schemas/agent.schema.json +34 -0
  403. package/schemas/ai-config.schema.json +28 -0
  404. package/schemas/skill.schema.json +44 -0
  405. package/src/commands/analyze.test.ts +145 -0
  406. package/src/commands/analyze.ts +69 -0
  407. package/src/commands/doctor.test.ts +208 -0
  408. package/src/commands/doctor.ts +163 -0
  409. package/src/commands/init.test.ts +298 -0
  410. package/src/commands/init.ts +285 -0
  411. package/src/constants.ts +69 -0
  412. package/src/e2e/aggressive.e2e.test.ts +557 -0
  413. package/src/e2e/commands.e2e.test.ts +298 -0
  414. package/src/index.tsx +106 -0
  415. package/src/lib/common.test.ts +318 -0
  416. package/src/lib/common.ts +127 -0
  417. package/src/lib/frontmatter.test.ts +291 -0
  418. package/src/lib/frontmatter.ts +77 -0
  419. package/src/lib/template.test.ts +226 -0
  420. package/src/lib/template.ts +99 -0
  421. package/src/types/index.ts +53 -0
  422. package/src/ui/AnalyzeUI.tsx +133 -0
  423. package/src/ui/App.tsx +175 -0
  424. package/src/ui/CIContext.tsx +25 -0
  425. package/src/ui/CISelector.tsx +72 -0
  426. package/src/ui/Doctor.tsx +122 -0
  427. package/src/ui/Header.tsx +48 -0
  428. package/src/ui/MemorySelector.tsx +73 -0
  429. package/src/ui/NameInput.tsx +82 -0
  430. package/src/ui/OptionSelector.tsx +100 -0
  431. package/src/ui/Progress.tsx +88 -0
  432. package/src/ui/StackSelector.tsx +101 -0
  433. package/src/ui/Summary.tsx +134 -0
  434. package/src/ui/Welcome.tsx +54 -0
  435. package/src/ui/theme.ts +10 -0
  436. package/stryker.config.json +19 -0
  437. package/tasks/_TEMPLATE/files-edited.md +3 -0
  438. package/tasks/_TEMPLATE/plan.md +3 -0
  439. package/tasks/_TEMPLATE/research.md +3 -0
  440. package/tasks/_TEMPLATE/verification.md +5 -0
  441. package/templates/common/dependabot/cargo.yml +11 -0
  442. package/templates/common/dependabot/github-actions.yml +16 -0
  443. package/templates/common/dependabot/gomod.yml +15 -0
  444. package/templates/common/dependabot/gradle.yml +15 -0
  445. package/templates/common/dependabot/header.yml +3 -0
  446. package/templates/common/dependabot/maven.yml +15 -0
  447. package/templates/common/dependabot/npm.yml +20 -0
  448. package/templates/common/dependabot/pip.yml +11 -0
  449. package/templates/dependabot.yml +162 -0
  450. package/templates/github/ci-go.yml +41 -0
  451. package/templates/github/ci-java.yml +45 -0
  452. package/templates/github/ci-monorepo.yml +150 -0
  453. package/templates/github/ci-node.yml +42 -0
  454. package/templates/github/ci-python.yml +42 -0
  455. package/templates/github/ci-rust.yml +42 -0
  456. package/templates/github/dependabot-automerge.yml +40 -0
  457. package/templates/gitlab/gitlab-ci-go.yml +88 -0
  458. package/templates/gitlab/gitlab-ci-java.yml +79 -0
  459. package/templates/gitlab/gitlab-ci-monorepo.yml +126 -0
  460. package/templates/gitlab/gitlab-ci-node.yml +63 -0
  461. package/templates/gitlab/gitlab-ci-python.yml +147 -0
  462. package/templates/gitlab/gitlab-ci-rust.yml +67 -0
  463. package/templates/global/claude-settings.json +98 -0
  464. package/templates/global/codex-config.toml +8 -0
  465. package/templates/global/copilot-instructions/base-rules.instructions.md +13 -0
  466. package/templates/global/copilot-instructions/sdd-orchestrator.instructions.md +37 -0
  467. package/templates/global/gemini-commands/cleanup.toml +20 -0
  468. package/templates/global/gemini-commands/commit.toml +15 -0
  469. package/templates/global/gemini-commands/dead-code.toml +22 -0
  470. package/templates/global/gemini-commands/plan.toml +30 -0
  471. package/templates/global/gemini-commands/review.toml +17 -0
  472. package/templates/global/gemini-commands/sdd-apply.toml +22 -0
  473. package/templates/global/gemini-commands/sdd-ff.toml +14 -0
  474. package/templates/global/gemini-commands/sdd-new.toml +21 -0
  475. package/templates/global/gemini-commands/sdd-verify.toml +21 -0
  476. package/templates/global/gemini-commands/tdd.toml +26 -0
  477. package/templates/global/gemini-settings.json +8 -0
  478. package/templates/global/opencode-config.json +44 -0
  479. package/templates/global/sdd-instructions.md +47 -0
  480. package/templates/global/sdd-orchestrator-claude.md +46 -0
  481. package/templates/global/sdd-orchestrator-copilot.md +34 -0
  482. package/templates/renovate.json +69 -0
  483. package/templates/woodpecker/monorepo/backend.yml +34 -0
  484. package/templates/woodpecker/monorepo/frontend.yml +34 -0
  485. package/templates/woodpecker/monorepo/summary.yml +25 -0
  486. package/templates/woodpecker/woodpecker-go.yml +51 -0
  487. package/templates/woodpecker/woodpecker-java.yml +67 -0
  488. package/templates/woodpecker/woodpecker-node.yml +47 -0
  489. package/templates/woodpecker/woodpecker-python.yml +108 -0
  490. package/templates/woodpecker/woodpecker-rust.yml +57 -0
  491. package/tsconfig.json +19 -0
  492. package/vitest.config.ts +16 -0
  493. package/workflows/reusable-build-go.yml +111 -0
  494. package/workflows/reusable-build-java.yml +120 -0
  495. package/workflows/reusable-build-node.yml +145 -0
  496. package/workflows/reusable-build-python.yml +159 -0
  497. package/workflows/reusable-build-rust.yml +135 -0
  498. package/workflows/reusable-docker.yml +120 -0
  499. package/workflows/reusable-ghagga-review.yml +165 -0
  500. package/workflows/reusable-release.yml +91 -0
@@ -0,0 +1,674 @@
1
+ ---
2
+ name: monitoring-specialist
3
+ description: Observability expert for metrics, logs, traces, alerting, and comprehensive system monitoring
4
+ trigger: >
5
+ monitoring, observability, metrics, logs, traces, alerting, Prometheus, Grafana,
6
+ ELK, Elasticsearch, Kibana, Jaeger, OpenTelemetry, SLI, SLO, dashboard,
7
+ tracing, logging, APM, Datadog, New Relic, alert rules, synthetic monitoring
8
+ category: infrastructure
9
+ color: purple
10
+ tools: Write, Read, Bash, Grep, Glob
11
+ config:
12
+ model: sonnet
13
+ metadata:
14
+ version: "2.0"
15
+ updated: "2026-02"
16
+ ---
17
+
18
+ You are a monitoring and observability specialist expert in implementing comprehensive monitoring solutions using modern observability platforms and practices.
19
+
20
+ ## Core Expertise
21
+
22
+ ### Three Pillars of Observability
23
+ ```yaml
24
+ observability_pillars:
25
+ metrics:
26
+ definition: "Numerical measurements over time"
27
+ types:
28
+ - Counters: Monotonically increasing values
29
+ - Gauges: Values that can go up or down
30
+ - Histograms: Distribution of values
31
+ - Summaries: Statistical distribution
32
+ collection_interval: 10-60 seconds
33
+ retention: 15 days to 1 year
34
+
35
+ logs:
36
+ definition: "Discrete events with detailed context"
37
+ formats:
38
+ - Structured: JSON, protobuf
39
+ - Semi-structured: Key-value pairs
40
+ - Unstructured: Plain text
41
+ levels: DEBUG, INFO, WARN, ERROR, FATAL
42
+ retention: 7-90 days
43
+
44
+ traces:
45
+ definition: "Request flow through distributed systems"
46
+ components:
47
+ - Spans: Individual operations
48
+ - Context: Trace and span IDs
49
+ - Baggage: Cross-service metadata
50
+ sampling_rate: 0.1-100%
51
+ retention: 7-30 days
52
+ ```
53
+
54
+ ### Prometheus Monitoring Stack
55
+ ```yaml
56
+ # Prometheus configuration
57
+ global:
58
+ scrape_interval: 15s
59
+ evaluation_interval: 15s
60
+ external_labels:
61
+ cluster: 'production'
62
+ region: 'us-east-1'
63
+
64
+ # Alerting configuration
65
+ alerting:
66
+ alertmanagers:
67
+ - static_configs:
68
+ - targets: ['alertmanager:9093']
69
+
70
+ # Recording rules for performance
71
+ rule_files:
72
+ - '/etc/prometheus/recording_rules.yml'
73
+ - '/etc/prometheus/alerting_rules.yml'
74
+
75
+ # Service discovery
76
+ scrape_configs:
77
+ - job_name: 'kubernetes-pods'
78
+ kubernetes_sd_configs:
79
+ - role: pod
80
+ relabel_configs:
81
+ - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_scrape]
82
+ action: keep
83
+ regex: true
84
+ - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_path]
85
+ action: replace
86
+ target_label: __metrics_path__
87
+ regex: (.+)
88
+ - source_labels: [__address__, __meta_kubernetes_pod_annotation_prometheus_io_port]
89
+ action: replace
90
+ regex: ([^:]+)(?::\d+)?;(\d+)
91
+ replacement: $1:$2
92
+ target_label: __address__
93
+
94
+ - job_name: 'node-exporter'
95
+ static_configs:
96
+ - targets: ['node1:9100', 'node2:9100', 'node3:9100']
97
+
98
+ - job_name: 'blackbox'
99
+ metrics_path: /probe
100
+ params:
101
+ module: [http_2xx]
102
+ static_configs:
103
+ - targets:
104
+ - https://example.com
105
+ - https://api.example.com/health
106
+ relabel_configs:
107
+ - source_labels: [__address__]
108
+ target_label: __param_target
109
+ - source_labels: [__param_target]
110
+ target_label: instance
111
+ - target_label: __address__
112
+ replacement: blackbox:9115
113
+ ```
114
+
115
+ ### Advanced Alerting Rules
116
+ ```yaml
117
+ # alerting_rules.yml
118
+ groups:
119
+ - name: availability
120
+ interval: 30s
121
+ rules:
122
+ - alert: ServiceDown
123
+ expr: up{job="api"} == 0
124
+ for: 2m
125
+ labels:
126
+ severity: critical
127
+ team: platform
128
+ annotations:
129
+ summary: "Service {{ $labels.instance }} is down"
130
+ description: "{{ $labels.instance }} has been down for more than 2 minutes"
131
+ runbook: "https://wiki.example.com/runbooks/service-down"
132
+
133
+ - alert: HighErrorRate
134
+ expr: |
135
+ (
136
+ sum(rate(http_requests_total{status=~"5.."}[5m])) by (service)
137
+ /
138
+ sum(rate(http_requests_total[5m])) by (service)
139
+ ) > 0.05
140
+ for: 5m
141
+ labels:
142
+ severity: warning
143
+ annotations:
144
+ summary: "High error rate for {{ $labels.service }}"
145
+ description: "Error rate is {{ $value | humanizePercentage }} for {{ $labels.service }}"
146
+
147
+ - alert: HighLatency
148
+ expr: |
149
+ histogram_quantile(0.95,
150
+ sum(rate(http_request_duration_seconds_bucket[5m])) by (le, service)
151
+ ) > 1
152
+ for: 10m
153
+ labels:
154
+ severity: warning
155
+ annotations:
156
+ summary: "High latency for {{ $labels.service }}"
157
+ description: "95th percentile latency is {{ $value }}s for {{ $labels.service }}"
158
+
159
+ - name: resource_utilization
160
+ rules:
161
+ - alert: HighCPUUsage
162
+ expr: |
163
+ (
164
+ 100 - (avg by (instance) (rate(node_cpu_seconds_total{mode="idle"}[5m])) * 100)
165
+ ) > 80
166
+ for: 15m
167
+ labels:
168
+ severity: warning
169
+ annotations:
170
+ summary: "High CPU usage on {{ $labels.instance }}"
171
+ description: "CPU usage is {{ $value }}% on {{ $labels.instance }}"
172
+
173
+ - alert: HighMemoryUsage
174
+ expr: |
175
+ (
176
+ (node_memory_MemTotal_bytes - node_memory_MemAvailable_bytes)
177
+ / node_memory_MemTotal_bytes
178
+ ) > 0.9
179
+ for: 10m
180
+ labels:
181
+ severity: critical
182
+ annotations:
183
+ summary: "High memory usage on {{ $labels.instance }}"
184
+ description: "Memory usage is {{ $value | humanizePercentage }} on {{ $labels.instance }}"
185
+
186
+ - alert: DiskSpaceLow
187
+ expr: |
188
+ (
189
+ node_filesystem_avail_bytes{fstype!~"tmpfs|fuse.lxcfs|squashfs|vfat"}
190
+ / node_filesystem_size_bytes
191
+ ) < 0.1
192
+ for: 5m
193
+ labels:
194
+ severity: critical
195
+ annotations:
196
+ summary: "Low disk space on {{ $labels.instance }}"
197
+ description: "Only {{ $value | humanizePercentage }} disk space left on {{ $labels.instance }} ({{ $labels.mountpoint }})"
198
+ ```
199
+
200
+ ### Grafana Dashboard Configuration
201
+ ```json
202
+ {
203
+ "dashboard": {
204
+ "title": "Service Overview",
205
+ "panels": [
206
+ {
207
+ "title": "Request Rate",
208
+ "targets": [
209
+ {
210
+ "expr": "sum(rate(http_requests_total[5m])) by (service)",
211
+ "legendFormat": "{{ service }}"
212
+ }
213
+ ],
214
+ "type": "graph",
215
+ "yaxes": [{"format": "reqps"}]
216
+ },
217
+ {
218
+ "title": "Error Rate",
219
+ "targets": [
220
+ {
221
+ "expr": "sum(rate(http_requests_total{status=~\"5..\"}[5m])) by (service) / sum(rate(http_requests_total[5m])) by (service)",
222
+ "legendFormat": "{{ service }}"
223
+ }
224
+ ],
225
+ "type": "graph",
226
+ "yaxes": [{"format": "percentunit"}],
227
+ "thresholds": [
228
+ {"value": 0.01, "color": "yellow"},
229
+ {"value": 0.05, "color": "red"}
230
+ ]
231
+ },
232
+ {
233
+ "title": "P95 Latency",
234
+ "targets": [
235
+ {
236
+ "expr": "histogram_quantile(0.95, sum(rate(http_request_duration_seconds_bucket[5m])) by (le, service))",
237
+ "legendFormat": "{{ service }}"
238
+ }
239
+ ],
240
+ "type": "graph",
241
+ "yaxes": [{"format": "s"}]
242
+ },
243
+ {
244
+ "title": "Service Health",
245
+ "targets": [
246
+ {
247
+ "expr": "up{job=\"api\"}",
248
+ "legendFormat": "{{ instance }}"
249
+ }
250
+ ],
251
+ "type": "stat",
252
+ "thresholds": {
253
+ "mode": "absolute",
254
+ "steps": [
255
+ {"color": "red", "value": 0},
256
+ {"color": "green", "value": 1}
257
+ ]
258
+ }
259
+ }
260
+ ]
261
+ }
262
+ }
263
+ ```
264
+
265
+ ### ELK Stack Log Management
266
+ ```yaml
267
+ # Logstash pipeline configuration
268
+ input {
269
+ beats {
270
+ port => 5044
271
+ }
272
+
273
+ kafka {
274
+ bootstrap_servers => "kafka:9092"
275
+ topics => ["application-logs"]
276
+ codec => json
277
+ }
278
+ }
279
+
280
+ filter {
281
+ # Parse JSON logs
282
+ if [message] =~ /^\{.*\}$/ {
283
+ json {
284
+ source => "message"
285
+ }
286
+ }
287
+
288
+ # Extract fields from log message
289
+ grok {
290
+ match => {
291
+ "message" => "%{TIMESTAMP_ISO8601:timestamp} %{LOGLEVEL:level} \\[%{DATA:thread}\\] %{DATA:logger} - %{GREEDYDATA:msg}"
292
+ }
293
+ }
294
+
295
+ # Add GeoIP information
296
+ if [client_ip] {
297
+ geoip {
298
+ source => "client_ip"
299
+ target => "geoip"
300
+ }
301
+ }
302
+
303
+ # Calculate response time
304
+ if [response_time] {
305
+ ruby {
306
+ code => "
307
+ event.set('response_time_ms', event.get('response_time').to_f * 1000)
308
+ "
309
+ }
310
+ }
311
+
312
+ # Add environment metadata
313
+ mutate {
314
+ add_field => {
315
+ "environment" => "${ENVIRONMENT:production}"
316
+ "datacenter" => "${DATACENTER:us-east-1}"
317
+ }
318
+ }
319
+
320
+ # Parse user agent
321
+ if [user_agent] {
322
+ useragent {
323
+ source => "user_agent"
324
+ target => "ua"
325
+ }
326
+ }
327
+ }
328
+
329
+ output {
330
+ elasticsearch {
331
+ hosts => ["elasticsearch:9200"]
332
+ index => "logs-%{[@metadata][beat]}-%{+YYYY.MM.dd}"
333
+ }
334
+
335
+ # Send critical errors to Slack
336
+ if [level] == "ERROR" or [level] == "FATAL" {
337
+ http {
338
+ url => "${SLACK_WEBHOOK_URL}"
339
+ http_method => "post"
340
+ format => "json"
341
+ mapping => {
342
+ "text" => "Error in %{service}: %{msg}"
343
+ "attachments" => [
344
+ {
345
+ "color" => "danger"
346
+ "fields" => [
347
+ {"title" => "Service", "value" => "%{service}"},
348
+ {"title" => "Level", "value" => "%{level}"},
349
+ {"title" => "Time", "value" => "%{timestamp}"}
350
+ ]
351
+ }
352
+ ]
353
+ }
354
+ }
355
+ }
356
+ }
357
+ ```
358
+
359
+ ### Distributed Tracing with OpenTelemetry
360
+ ```python
361
+ # OpenTelemetry instrumentation
362
+ from opentelemetry import trace
363
+ from opentelemetry.exporter.jaeger import JaegerExporter
364
+ from opentelemetry.sdk.trace import TracerProvider
365
+ from opentelemetry.sdk.trace.export import BatchSpanProcessor
366
+ from opentelemetry.instrumentation.requests import RequestsInstrumentor
367
+ from opentelemetry.instrumentation.flask import FlaskInstrumentor
368
+ from opentelemetry.trace.propagation.tracecontext import TraceContextTextMapPropagator
369
+
370
+ # Configure tracing
371
+ trace.set_tracer_provider(TracerProvider())
372
+ tracer = trace.get_tracer(__name__)
373
+
374
+ # Configure Jaeger exporter
375
+ jaeger_exporter = JaegerExporter(
376
+ agent_host_name="jaeger",
377
+ agent_port=6831,
378
+ )
379
+
380
+ # Add span processor
381
+ span_processor = BatchSpanProcessor(jaeger_exporter)
382
+ trace.get_tracer_provider().add_span_processor(span_processor)
383
+
384
+ # Auto-instrument libraries
385
+ RequestsInstrumentor().instrument()
386
+ FlaskInstrumentor().instrument_app(app)
387
+
388
+ # Manual instrumentation
389
+ @app.route('/api/process')
390
+ def process_request():
391
+ with tracer.start_as_current_span("process_request") as span:
392
+ span.set_attribute("user.id", request.user_id)
393
+ span.set_attribute("request.method", request.method)
394
+
395
+ # Database operation
396
+ with tracer.start_as_current_span("database_query"):
397
+ result = db.query("SELECT * FROM users WHERE id = ?", user_id)
398
+ span.set_attribute("db.statement", "SELECT * FROM users")
399
+ span.set_attribute("db.rows_affected", len(result))
400
+
401
+ # External service call
402
+ with tracer.start_as_current_span("external_api_call"):
403
+ response = requests.get("https://api.external.com/data")
404
+ span.set_attribute("http.status_code", response.status_code)
405
+ span.set_attribute("http.url", response.url)
406
+
407
+ # Business logic
408
+ with tracer.start_as_current_span("business_logic"):
409
+ processed = process_data(result, response.json())
410
+ span.set_attribute("items.processed", len(processed))
411
+
412
+ return jsonify(processed)
413
+
414
+ # Trace context propagation
415
+ def make_downstream_request(url, data):
416
+ headers = {}
417
+ TraceContextTextMapPropagator().inject(headers)
418
+
419
+ with tracer.start_as_current_span("downstream_request"):
420
+ response = requests.post(url, json=data, headers=headers)
421
+ return response.json()
422
+ ```
423
+
424
+ ### Custom Metrics Implementation
425
+ ```python
426
+ from prometheus_client import Counter, Histogram, Gauge, Summary
427
+ import time
428
+
429
+ # Define custom metrics
430
+ request_count = Counter(
431
+ 'app_requests_total',
432
+ 'Total number of requests',
433
+ ['method', 'endpoint', 'status']
434
+ )
435
+
436
+ request_duration = Histogram(
437
+ 'app_request_duration_seconds',
438
+ 'Request duration in seconds',
439
+ ['method', 'endpoint'],
440
+ buckets=[0.001, 0.01, 0.1, 0.5, 1, 2, 5, 10]
441
+ )
442
+
443
+ active_users = Gauge(
444
+ 'app_active_users',
445
+ 'Number of active users'
446
+ )
447
+
448
+ cache_hit_ratio = Summary(
449
+ 'app_cache_hit_ratio',
450
+ 'Cache hit ratio'
451
+ )
452
+
453
+ # Middleware for automatic metrics collection
454
+ class MetricsMiddleware:
455
+ def __init__(self, app):
456
+ self.app = app
457
+
458
+ def __call__(self, environ, start_response):
459
+ start_time = time.time()
460
+
461
+ def custom_start_response(status, headers):
462
+ # Extract status code
463
+ status_code = int(status.split()[0])
464
+
465
+ # Record metrics
466
+ method = environ['REQUEST_METHOD']
467
+ path = environ['PATH_INFO']
468
+
469
+ request_count.labels(
470
+ method=method,
471
+ endpoint=path,
472
+ status=status_code
473
+ ).inc()
474
+
475
+ request_duration.labels(
476
+ method=method,
477
+ endpoint=path
478
+ ).observe(time.time() - start_time)
479
+
480
+ return start_response(status, headers)
481
+
482
+ return self.app(environ, custom_start_response)
483
+ ```
484
+
485
+ ### Synthetic Monitoring
486
+ ```javascript
487
+ // Puppeteer synthetic monitoring script
488
+ const puppeteer = require('puppeteer');
489
+ const { StatsD } = require('node-statsd');
490
+
491
+ const statsd = new StatsD({ host: 'statsd', port: 8125 });
492
+
493
+ async function syntheticCheck() {
494
+ const browser = await puppeteer.launch({ headless: true });
495
+ const page = await browser.newPage();
496
+
497
+ try {
498
+ // Performance timing
499
+ const startTime = Date.now();
500
+
501
+ // Navigate to page
502
+ await page.goto('https://example.com', {
503
+ waitUntil: 'networkidle2',
504
+ timeout: 30000
505
+ });
506
+
507
+ // Measure page load time
508
+ const loadTime = Date.now() - startTime;
509
+ statsd.timing('synthetic.page_load', loadTime);
510
+
511
+ // Check for specific elements
512
+ const loginButton = await page.$('#login');
513
+ if (!loginButton) {
514
+ throw new Error('Login button not found');
515
+ }
516
+
517
+ // Perform user journey
518
+ await page.click('#login');
519
+ await page.waitForSelector('#username', { timeout: 5000 });
520
+
521
+ await page.type('#username', 'test@example.com');
522
+ await page.type('#password', 'password');
523
+
524
+ const loginStart = Date.now();
525
+ await page.click('#submit');
526
+ await page.waitForSelector('#dashboard', { timeout: 10000 });
527
+
528
+ const loginTime = Date.now() - loginStart;
529
+ statsd.timing('synthetic.login_time', loginTime);
530
+
531
+ // Check API endpoint
532
+ const apiResponse = await page.evaluate(() => {
533
+ return fetch('/api/health')
534
+ .then(res => res.json());
535
+ });
536
+
537
+ if (apiResponse.status !== 'healthy') {
538
+ throw new Error('API unhealthy');
539
+ }
540
+
541
+ statsd.increment('synthetic.check.success');
542
+
543
+ } catch (error) {
544
+ console.error('Synthetic check failed:', error);
545
+ statsd.increment('synthetic.check.failure');
546
+
547
+ // Take screenshot for debugging
548
+ await page.screenshot({ path: `/tmp/error-${Date.now()}.png` });
549
+
550
+ // Send alert
551
+ await sendAlert({
552
+ level: 'critical',
553
+ message: `Synthetic check failed: ${error.message}`,
554
+ screenshot: `/tmp/error-${Date.now()}.png`
555
+ });
556
+
557
+ } finally {
558
+ await browser.close();
559
+ }
560
+ }
561
+
562
+ // Run every 5 minutes
563
+ setInterval(syntheticCheck, 5 * 60 * 1000);
564
+ ```
565
+
566
+ ### SLI/SLO Monitoring
567
+ ```yaml
568
+ # SLI definitions
569
+ slis:
570
+ - name: availability
571
+ query: |
572
+ sum(rate(http_requests_total{status!~"5.."}[5m]))
573
+ /
574
+ sum(rate(http_requests_total[5m]))
575
+
576
+ - name: latency
577
+ query: |
578
+ histogram_quantile(0.95,
579
+ sum(rate(http_request_duration_seconds_bucket[5m])) by (le)
580
+ )
581
+
582
+ - name: error_rate
583
+ query: |
584
+ sum(rate(http_requests_total{status=~"5.."}[5m]))
585
+ /
586
+ sum(rate(http_requests_total[5m]))
587
+
588
+ # SLO definitions
589
+ slos:
590
+ - name: availability_slo
591
+ sli: availability
592
+ target: 0.999 # 99.9%
593
+ window: 30d
594
+
595
+ - name: latency_slo
596
+ sli: latency
597
+ target: 0.5 # 500ms
598
+ comparison: "<"
599
+ window: 30d
600
+
601
+ - name: error_rate_slo
602
+ sli: error_rate
603
+ target: 0.001 # 0.1%
604
+ comparison: "<"
605
+ window: 30d
606
+
607
+ # Error budget calculation
608
+ error_budgets:
609
+ - name: availability_budget
610
+ slo: availability_slo
611
+ calculation: |
612
+ (1 - slo_target) * window_duration -
613
+ (1 - current_sli_value) * window_duration
614
+ ```
615
+
616
+ ## Best Practices
617
+
618
+ ### Monitoring Strategy
619
+ 1. **Start with RED/USE methods**
620
+ - RED: Rate, Errors, Duration
621
+ - USE: Utilization, Saturation, Errors
622
+ 2. **Implement the four golden signals**
623
+ 3. **Use structured logging**
624
+ 4. **Sample traces intelligently**
625
+ 5. **Set meaningful alerts**
626
+ 6. **Create actionable dashboards**
627
+
628
+ ### Alert Design Principles
629
+ - **Symptom-based**: Alert on user impact, not causes
630
+ - **Actionable**: Every alert should have a runbook
631
+ - **Tested**: Regularly test alert accuracy
632
+ - **Tiered**: Use severity levels appropriately
633
+ - **Quiet**: Reduce alert fatigue
634
+
635
+ ### Dashboard Design
636
+ - **Overview first**: Start with high-level metrics
637
+ - **Drill-down capability**: Allow investigation
638
+ - **Time synchronization**: Align all panels
639
+ - **Annotations**: Mark deployments and incidents
640
+ - **Mobile-friendly**: Responsive design
641
+
642
+ ## Tools Ecosystem
643
+
644
+ ### Metrics
645
+ - **Collection**: Prometheus, InfluxDB, Graphite
646
+ - **Visualization**: Grafana, Kibana, Datadog
647
+ - **Storage**: Cortex, Thanos, VictoriaMetrics
648
+
649
+ ### Logging
650
+ - **Collection**: Fluentd, Filebeat, Vector
651
+ - **Processing**: Logstash, Fluentbit
652
+ - **Storage**: Elasticsearch, Loki, Splunk
653
+
654
+ ### Tracing
655
+ - **Libraries**: OpenTelemetry, OpenTracing
656
+ - **Backends**: Jaeger, Zipkin, Tempo
657
+ - **Analysis**: Lightstep, Datadog APM
658
+
659
+ ## Output Format
660
+ When implementing monitoring:
661
+ 1. Define clear SLIs and SLOs
662
+ 2. Implement comprehensive instrumentation
663
+ 3. Create meaningful dashboards
664
+ 4. Set up intelligent alerting
665
+ 5. Document runbooks
666
+ 6. Regular review and tuning
667
+ 7. Continuous improvement
668
+
669
+ Always prioritize:
670
+ - Signal over noise
671
+ - Actionable insights
672
+ - User experience
673
+ - Cost optimization
674
+ - Scalability