moai-adk 0.10.1__py3-none-any.whl → 0.11.0__py3-none-any.whl

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.

Potentially problematic release.


This version of moai-adk might be problematic. Click here for more details.

Files changed (245) hide show
  1. moai_adk/core/project/phase_executor.py +4 -0
  2. moai_adk/core/tags/ci_validator.py +33 -3
  3. moai_adk/core/template_engine.py +6 -2
  4. moai_adk/templates/.github/workflows/moai-gitflow.yml +6 -1
  5. moai_adk/templates/.github/workflows/release.yml +6 -2
  6. moai_adk/templates/.github/workflows/tag-validation.yml +53 -8
  7. moai_adk/templates/CLAUDE.md +458 -67
  8. {moai_adk-0.10.1.dist-info → moai_adk-0.11.0.dist-info}/METADATA +28 -13
  9. moai_adk-0.11.0.dist-info/RECORD +77 -0
  10. moai_adk/templates/.claude/agents/alfred/cc-manager.md +0 -316
  11. moai_adk/templates/.claude/agents/alfred/debug-helper.md +0 -208
  12. moai_adk/templates/.claude/agents/alfred/doc-syncer.md +0 -214
  13. moai_adk/templates/.claude/agents/alfred/git-manager.md +0 -406
  14. moai_adk/templates/.claude/agents/alfred/implementation-planner.md +0 -350
  15. moai_adk/templates/.claude/agents/alfred/project-manager.md +0 -273
  16. moai_adk/templates/.claude/agents/alfred/quality-gate.md +0 -343
  17. moai_adk/templates/.claude/agents/alfred/skill-factory.md +0 -865
  18. moai_adk/templates/.claude/agents/alfred/spec-builder.md +0 -287
  19. moai_adk/templates/.claude/agents/alfred/tag-agent.md +0 -287
  20. moai_adk/templates/.claude/agents/alfred/tdd-implementer.md +0 -326
  21. moai_adk/templates/.claude/agents/alfred/trust-checker.md +0 -375
  22. moai_adk/templates/.claude/commands/alfred/0-project.md +0 -1189
  23. moai_adk/templates/.claude/commands/alfred/1-plan.md +0 -728
  24. moai_adk/templates/.claude/commands/alfred/2-run.md +0 -545
  25. moai_adk/templates/.claude/commands/alfred/3-sync.md +0 -683
  26. moai_adk/templates/.claude/commands/alfred/9-feedback.md +0 -149
  27. moai_adk/templates/.claude/hooks/alfred/alfred_hooks.py +0 -209
  28. moai_adk/templates/.claude/hooks/alfred/core/project.py +0 -750
  29. moai_adk/templates/.claude/hooks/alfred/core/version_cache.py +0 -198
  30. moai_adk/templates/.claude/hooks/alfred/notification__handle_events.py +0 -102
  31. moai_adk/templates/.claude/hooks/alfred/post_tool__log_changes.py +0 -102
  32. moai_adk/templates/.claude/hooks/alfred/pre_tool__auto_checkpoint.py +0 -108
  33. moai_adk/templates/.claude/hooks/alfred/session_end__cleanup.py +0 -102
  34. moai_adk/templates/.claude/hooks/alfred/session_start__show_project_info.py +0 -102
  35. moai_adk/templates/.claude/hooks/alfred/shared/core/__init__.py +0 -170
  36. moai_adk/templates/.claude/hooks/alfred/shared/core/checkpoint.py +0 -271
  37. moai_adk/templates/.claude/hooks/alfred/shared/core/context.py +0 -67
  38. moai_adk/templates/.claude/hooks/alfred/shared/core/project.py +0 -756
  39. moai_adk/templates/.claude/hooks/alfred/shared/core/tags.py +0 -198
  40. moai_adk/templates/.claude/hooks/alfred/shared/core/version_cache.py +0 -198
  41. moai_adk/templates/.claude/hooks/alfred/shared/handlers/__init__.py +0 -21
  42. moai_adk/templates/.claude/hooks/alfred/shared/handlers/notification.py +0 -25
  43. moai_adk/templates/.claude/hooks/alfred/shared/handlers/session.py +0 -175
  44. moai_adk/templates/.claude/hooks/alfred/shared/handlers/tool.py +0 -90
  45. moai_adk/templates/.claude/hooks/alfred/shared/handlers/user.py +0 -61
  46. moai_adk/templates/.claude/hooks/alfred/stop__handle_interrupt.py +0 -102
  47. moai_adk/templates/.claude/hooks/alfred/subagent_stop__handle_subagent_end.py +0 -102
  48. moai_adk/templates/.claude/hooks/alfred/user_prompt__jit_load_docs.py +0 -120
  49. moai_adk/templates/.claude/output-styles/alfred/agentic-coding.md +0 -640
  50. moai_adk/templates/.claude/output-styles/alfred/moai-adk-learning.md +0 -696
  51. moai_adk/templates/.claude/output-styles/alfred/study-with-alfred.md +0 -474
  52. moai_adk/templates/.claude/settings.json +0 -144
  53. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/SKILL.md +0 -113
  54. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/examples.md +0 -29
  55. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/reference.md +0 -28
  56. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/SKILL.md +0 -122
  57. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/examples.md +0 -29
  58. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/reference.md +0 -29
  59. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/SKILL.md +0 -237
  60. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/examples.md +0 -615
  61. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/reference.md +0 -653
  62. moai_adk/templates/.claude/skills/moai-alfred-language-detection/SKILL.md +0 -113
  63. moai_adk/templates/.claude/skills/moai-alfred-language-detection/examples.md +0 -29
  64. moai_adk/templates/.claude/skills/moai-alfred-language-detection/reference.md +0 -28
  65. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/SKILL.md +0 -113
  66. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/examples.md +0 -29
  67. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/reference.md +0 -28
  68. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/SKILL.md +0 -113
  69. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/examples.md +0 -29
  70. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/reference.md +0 -28
  71. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/SKILL.md +0 -113
  72. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/examples.md +0 -29
  73. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/reference.md +0 -28
  74. moai_adk/templates/.claude/skills/moai-cc-agents/SKILL.md +0 -269
  75. moai_adk/templates/.claude/skills/moai-cc-agents/templates/agent-template.md +0 -32
  76. moai_adk/templates/.claude/skills/moai-cc-claude-md/SKILL.md +0 -298
  77. moai_adk/templates/.claude/skills/moai-cc-claude-md/templates/CLAUDE-template.md +0 -26
  78. moai_adk/templates/.claude/skills/moai-cc-commands/SKILL.md +0 -307
  79. moai_adk/templates/.claude/skills/moai-cc-commands/templates/command-template.md +0 -21
  80. moai_adk/templates/.claude/skills/moai-cc-hooks/SKILL.md +0 -252
  81. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/pre-bash-check.sh +0 -19
  82. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/preserve-permissions.sh +0 -19
  83. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/validate-bash-command.py +0 -24
  84. moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/SKILL.md +0 -199
  85. moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/templates/settings-mcp-template.json +0 -39
  86. moai_adk/templates/.claude/skills/moai-cc-memory/SKILL.md +0 -316
  87. moai_adk/templates/.claude/skills/moai-cc-memory/templates/session-summary-template.md +0 -18
  88. moai_adk/templates/.claude/skills/moai-cc-settings/SKILL.md +0 -263
  89. moai_adk/templates/.claude/skills/moai-cc-settings/templates/settings-complete-template.json +0 -30
  90. moai_adk/templates/.claude/skills/moai-cc-skills/SKILL.md +0 -291
  91. moai_adk/templates/.claude/skills/moai-cc-skills/templates/SKILL-template.md +0 -15
  92. moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +0 -290
  93. moai_adk/templates/.claude/skills/moai-domain-backend/examples.md +0 -1633
  94. moai_adk/templates/.claude/skills/moai-domain-backend/reference.md +0 -660
  95. moai_adk/templates/.claude/skills/moai-domain-cli-tool/SKILL.md +0 -123
  96. moai_adk/templates/.claude/skills/moai-domain-cli-tool/examples.md +0 -29
  97. moai_adk/templates/.claude/skills/moai-domain-cli-tool/reference.md +0 -30
  98. moai_adk/templates/.claude/skills/moai-domain-data-science/SKILL.md +0 -123
  99. moai_adk/templates/.claude/skills/moai-domain-data-science/examples.md +0 -29
  100. moai_adk/templates/.claude/skills/moai-domain-data-science/reference.md +0 -30
  101. moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +0 -123
  102. moai_adk/templates/.claude/skills/moai-domain-database/examples.md +0 -29
  103. moai_adk/templates/.claude/skills/moai-domain-database/reference.md +0 -30
  104. moai_adk/templates/.claude/skills/moai-domain-devops/SKILL.md +0 -124
  105. moai_adk/templates/.claude/skills/moai-domain-devops/examples.md +0 -29
  106. moai_adk/templates/.claude/skills/moai-domain-devops/reference.md +0 -31
  107. moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +0 -124
  108. moai_adk/templates/.claude/skills/moai-domain-frontend/examples.md +0 -29
  109. moai_adk/templates/.claude/skills/moai-domain-frontend/reference.md +0 -31
  110. moai_adk/templates/.claude/skills/moai-domain-ml/SKILL.md +0 -123
  111. moai_adk/templates/.claude/skills/moai-domain-ml/examples.md +0 -29
  112. moai_adk/templates/.claude/skills/moai-domain-ml/reference.md +0 -30
  113. moai_adk/templates/.claude/skills/moai-domain-mobile-app/SKILL.md +0 -123
  114. moai_adk/templates/.claude/skills/moai-domain-mobile-app/examples.md +0 -29
  115. moai_adk/templates/.claude/skills/moai-domain-mobile-app/reference.md +0 -30
  116. moai_adk/templates/.claude/skills/moai-domain-security/SKILL.md +0 -123
  117. moai_adk/templates/.claude/skills/moai-domain-security/examples.md +0 -29
  118. moai_adk/templates/.claude/skills/moai-domain-security/reference.md +0 -30
  119. moai_adk/templates/.claude/skills/moai-domain-web-api/SKILL.md +0 -123
  120. moai_adk/templates/.claude/skills/moai-domain-web-api/examples.md +0 -29
  121. moai_adk/templates/.claude/skills/moai-domain-web-api/reference.md +0 -30
  122. moai_adk/templates/.claude/skills/moai-essentials-debug/SKILL.md +0 -303
  123. moai_adk/templates/.claude/skills/moai-essentials-debug/examples.md +0 -1064
  124. moai_adk/templates/.claude/skills/moai-essentials-debug/reference.md +0 -1047
  125. moai_adk/templates/.claude/skills/moai-essentials-perf/SKILL.md +0 -113
  126. moai_adk/templates/.claude/skills/moai-essentials-perf/examples.md +0 -29
  127. moai_adk/templates/.claude/skills/moai-essentials-perf/reference.md +0 -28
  128. moai_adk/templates/.claude/skills/moai-essentials-refactor/SKILL.md +0 -113
  129. moai_adk/templates/.claude/skills/moai-essentials-refactor/examples.md +0 -29
  130. moai_adk/templates/.claude/skills/moai-essentials-refactor/reference.md +0 -28
  131. moai_adk/templates/.claude/skills/moai-essentials-review/SKILL.md +0 -113
  132. moai_adk/templates/.claude/skills/moai-essentials-review/examples.md +0 -29
  133. moai_adk/templates/.claude/skills/moai-essentials-review/reference.md +0 -28
  134. moai_adk/templates/.claude/skills/moai-foundation-ears/SKILL.md +0 -116
  135. moai_adk/templates/.claude/skills/moai-foundation-ears/examples.md +0 -29
  136. moai_adk/templates/.claude/skills/moai-foundation-ears/reference.md +0 -28
  137. moai_adk/templates/.claude/skills/moai-foundation-git/SKILL.md +0 -122
  138. moai_adk/templates/.claude/skills/moai-foundation-git/examples.md +0 -29
  139. moai_adk/templates/.claude/skills/moai-foundation-git/reference.md +0 -29
  140. moai_adk/templates/.claude/skills/moai-foundation-langs/SKILL.md +0 -113
  141. moai_adk/templates/.claude/skills/moai-foundation-langs/examples.md +0 -29
  142. moai_adk/templates/.claude/skills/moai-foundation-langs/reference.md +0 -28
  143. moai_adk/templates/.claude/skills/moai-foundation-specs/SKILL.md +0 -113
  144. moai_adk/templates/.claude/skills/moai-foundation-specs/examples.md +0 -29
  145. moai_adk/templates/.claude/skills/moai-foundation-specs/reference.md +0 -28
  146. moai_adk/templates/.claude/skills/moai-foundation-tags/SKILL.md +0 -113
  147. moai_adk/templates/.claude/skills/moai-foundation-tags/examples.md +0 -29
  148. moai_adk/templates/.claude/skills/moai-foundation-tags/reference.md +0 -28
  149. moai_adk/templates/.claude/skills/moai-foundation-trust/SKILL.md +0 -307
  150. moai_adk/templates/.claude/skills/moai-foundation-trust/examples.md +0 -0
  151. moai_adk/templates/.claude/skills/moai-foundation-trust/reference.md +0 -1099
  152. moai_adk/templates/.claude/skills/moai-lang-c/SKILL.md +0 -124
  153. moai_adk/templates/.claude/skills/moai-lang-c/examples.md +0 -29
  154. moai_adk/templates/.claude/skills/moai-lang-c/reference.md +0 -31
  155. moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +0 -124
  156. moai_adk/templates/.claude/skills/moai-lang-cpp/examples.md +0 -29
  157. moai_adk/templates/.claude/skills/moai-lang-cpp/reference.md +0 -31
  158. moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +0 -123
  159. moai_adk/templates/.claude/skills/moai-lang-csharp/examples.md +0 -29
  160. moai_adk/templates/.claude/skills/moai-lang-csharp/reference.md +0 -30
  161. moai_adk/templates/.claude/skills/moai-lang-dart/SKILL.md +0 -123
  162. moai_adk/templates/.claude/skills/moai-lang-dart/examples.md +0 -29
  163. moai_adk/templates/.claude/skills/moai-lang-dart/reference.md +0 -30
  164. moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +0 -124
  165. moai_adk/templates/.claude/skills/moai-lang-go/examples.md +0 -29
  166. moai_adk/templates/.claude/skills/moai-lang-go/reference.md +0 -31
  167. moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +0 -124
  168. moai_adk/templates/.claude/skills/moai-lang-java/examples.md +0 -29
  169. moai_adk/templates/.claude/skills/moai-lang-java/reference.md +0 -31
  170. moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +0 -125
  171. moai_adk/templates/.claude/skills/moai-lang-javascript/examples.md +0 -29
  172. moai_adk/templates/.claude/skills/moai-lang-javascript/reference.md +0 -32
  173. moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +0 -124
  174. moai_adk/templates/.claude/skills/moai-lang-kotlin/examples.md +0 -29
  175. moai_adk/templates/.claude/skills/moai-lang-kotlin/reference.md +0 -31
  176. moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +0 -123
  177. moai_adk/templates/.claude/skills/moai-lang-php/examples.md +0 -29
  178. moai_adk/templates/.claude/skills/moai-lang-php/reference.md +0 -30
  179. moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +0 -431
  180. moai_adk/templates/.claude/skills/moai-lang-python/examples.md +0 -624
  181. moai_adk/templates/.claude/skills/moai-lang-python/reference.md +0 -316
  182. moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +0 -123
  183. moai_adk/templates/.claude/skills/moai-lang-r/examples.md +0 -29
  184. moai_adk/templates/.claude/skills/moai-lang-r/reference.md +0 -30
  185. moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +0 -124
  186. moai_adk/templates/.claude/skills/moai-lang-ruby/examples.md +0 -29
  187. moai_adk/templates/.claude/skills/moai-lang-ruby/reference.md +0 -31
  188. moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +0 -124
  189. moai_adk/templates/.claude/skills/moai-lang-rust/examples.md +0 -29
  190. moai_adk/templates/.claude/skills/moai-lang-rust/reference.md +0 -31
  191. moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +0 -123
  192. moai_adk/templates/.claude/skills/moai-lang-scala/examples.md +0 -29
  193. moai_adk/templates/.claude/skills/moai-lang-scala/reference.md +0 -30
  194. moai_adk/templates/.claude/skills/moai-lang-shell/SKILL.md +0 -123
  195. moai_adk/templates/.claude/skills/moai-lang-shell/examples.md +0 -29
  196. moai_adk/templates/.claude/skills/moai-lang-shell/reference.md +0 -30
  197. moai_adk/templates/.claude/skills/moai-lang-sql/SKILL.md +0 -124
  198. moai_adk/templates/.claude/skills/moai-lang-sql/examples.md +0 -29
  199. moai_adk/templates/.claude/skills/moai-lang-sql/reference.md +0 -31
  200. moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +0 -123
  201. moai_adk/templates/.claude/skills/moai-lang-swift/examples.md +0 -29
  202. moai_adk/templates/.claude/skills/moai-lang-swift/reference.md +0 -30
  203. moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +0 -127
  204. moai_adk/templates/.claude/skills/moai-lang-typescript/examples.md +0 -29
  205. moai_adk/templates/.claude/skills/moai-lang-typescript/reference.md +0 -34
  206. moai_adk/templates/.claude/skills/moai-skill-factory/CHECKLIST.md +0 -482
  207. moai_adk/templates/.claude/skills/moai-skill-factory/EXAMPLES.md +0 -278
  208. moai_adk/templates/.claude/skills/moai-skill-factory/INTERACTIVE-DISCOVERY.md +0 -524
  209. moai_adk/templates/.claude/skills/moai-skill-factory/METADATA.md +0 -477
  210. moai_adk/templates/.claude/skills/moai-skill-factory/PARALLEL-ANALYSIS-REPORT.md +0 -429
  211. moai_adk/templates/.claude/skills/moai-skill-factory/PYTHON-VERSION-MATRIX.md +0 -391
  212. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL-FACTORY-WORKFLOW.md +0 -431
  213. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL-UPDATE-ADVISOR.md +0 -577
  214. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL.md +0 -271
  215. moai_adk/templates/.claude/skills/moai-skill-factory/STEP-BY-STEP-GUIDE.md +0 -466
  216. moai_adk/templates/.claude/skills/moai-skill-factory/STRUCTURE.md +0 -583
  217. moai_adk/templates/.claude/skills/moai-skill-factory/WEB-RESEARCH.md +0 -526
  218. moai_adk/templates/.claude/skills/moai-skill-factory/reference.md +0 -465
  219. moai_adk/templates/.claude/skills/moai-skill-factory/scripts/generate-structure.sh +0 -328
  220. moai_adk/templates/.claude/skills/moai-skill-factory/scripts/validate-skill.sh +0 -312
  221. moai_adk/templates/.claude/skills/moai-skill-factory/templates/SKILL_TEMPLATE.md +0 -245
  222. moai_adk/templates/.claude/skills/moai-skill-factory/templates/examples-template.md +0 -285
  223. moai_adk/templates/.claude/skills/moai-skill-factory/templates/reference-template.md +0 -278
  224. moai_adk/templates/.claude/skills/moai-skill-factory/templates/scripts-template.sh +0 -303
  225. moai_adk/templates/.claude/skills/moai-spec-authoring/README.md +0 -137
  226. moai_adk/templates/.claude/skills/moai-spec-authoring/SKILL.md +0 -219
  227. moai_adk/templates/.claude/skills/moai-spec-authoring/examples/validate-spec.sh +0 -161
  228. moai_adk/templates/.claude/skills/moai-spec-authoring/examples.md +0 -541
  229. moai_adk/templates/.claude/skills/moai-spec-authoring/reference.md +0 -622
  230. moai_adk/templates/.moai/config.json +0 -113
  231. moai_adk/templates/.moai/memory/CLAUDE-AGENTS-GUIDE.md +0 -208
  232. moai_adk/templates/.moai/memory/CLAUDE-PRACTICES.md +0 -369
  233. moai_adk/templates/.moai/memory/CLAUDE-RULES.md +0 -539
  234. moai_adk/templates/.moai/memory/DEVELOPMENT-GUIDE.md +0 -344
  235. moai_adk/templates/.moai/memory/ISSUE-LABEL-MAPPING.md +0 -150
  236. moai_adk/templates/.moai/memory/SKILLS-DESCRIPTION-POLICY.md +0 -218
  237. moai_adk/templates/.moai/memory/gitflow-protection-policy.md +0 -330
  238. moai_adk/templates/.moai/memory/spec-metadata.md +0 -356
  239. moai_adk/templates/.moai/project/product.md +0 -161
  240. moai_adk/templates/.moai/project/structure.md +0 -156
  241. moai_adk/templates/.moai/project/tech.md +0 -227
  242. moai_adk-0.10.1.dist-info/RECORD +0 -309
  243. {moai_adk-0.10.1.dist-info → moai_adk-0.11.0.dist-info}/WHEEL +0 -0
  244. {moai_adk-0.10.1.dist-info → moai_adk-0.11.0.dist-info}/entry_points.txt +0 -0
  245. {moai_adk-0.10.1.dist-info → moai_adk-0.11.0.dist-info}/licenses/LICENSE +0 -0
@@ -1,290 +0,0 @@
1
- ---
2
- name: moai-domain-backend
3
- description: Provides backend architecture and scaling guidance; use when the project targets server-side APIs or infrastructure design decisions.
4
- allowed-tools:
5
- - Read
6
- - Bash
7
- ---
8
-
9
- # Backend Expert
10
-
11
- ## Skill Metadata
12
- | Field | Value |
13
- | ----- | ----- |
14
- | Version | 2.0.0 |
15
- | Created | 2025-10-22 |
16
- | Updated | 2025-10-22 |
17
- | Allowed tools | Read (read_file), Bash (terminal) |
18
- | Auto-load | On demand for backend architecture requests |
19
- | Trigger cues | Service layering, API orchestration, caching, background job design, cloud-native patterns, Kubernetes, Istio, observability, microservices, serverless, event-driven architecture. |
20
- | Tier | 4 |
21
-
22
- ## What it does
23
-
24
- Provides expertise in backend server architecture, RESTful API design, caching strategies, database optimization, cloud-native patterns, observability, and horizontal/vertical scalability patterns with modern tooling (Kubernetes, Istio, OpenTelemetry, Prometheus).
25
-
26
- ## When to use
27
-
28
- - Engages when backend or service-architecture questions come up.
29
- - "Backend architecture", "API design", "Caching strategy", "Scalability", "Kubernetes", "Observability"
30
- - Automatically invoked when working with backend projects
31
- - Backend SPEC implementation (`/alfred:2-run`)
32
- - Cloud-native architecture planning
33
- - Microservices design and orchestration
34
-
35
- ## How it works
36
-
37
- ### Server Architecture Patterns
38
-
39
- **Layered Architecture**:
40
- - **Controller → Service → Repository** pattern
41
- - Clear separation of concerns
42
- - Testable business logic
43
- - Database abstraction layer
44
-
45
- **Microservices**:
46
- - **Service decomposition**: Domain-driven design boundaries
47
- - **Container orchestration**: Kubernetes 1.31.x
48
- - **Service mesh**: Istio 1.21.x for traffic management, security, observability
49
- - **Inter-service communication**: REST, gRPC, message queues
50
- - **API Gateway**: Kong, Ambassador, Traefik
51
- - **Service discovery**: Kubernetes DNS, Consul
52
-
53
- **Monoliths**:
54
- - When appropriate (small team, low complexity, rapid prototyping)
55
- - Modular monolith patterns
56
- - Clear internal boundaries for future extraction
57
-
58
- **Serverless**:
59
- - **AWS Lambda**: Event-driven functions
60
- - **Google Cloud Functions**: HTTP and event triggers
61
- - **Azure Functions**: Durable Functions for workflows
62
- - Cold start mitigation strategies
63
- - Stateless design principles
64
-
65
- **Event-Driven Architecture**:
66
- - **CQRS**: Command Query Responsibility Segregation
67
- - **Event Sourcing**: Immutable event logs
68
- - **Apache Kafka 3.7.x**: Distributed streaming platform
69
- - **RabbitMQ 3.13.x**: Message broker
70
- - **Event versioning**: Schema evolution strategies
71
-
72
- ### API Design
73
-
74
- **RESTful APIs**:
75
- - **Resource-based**: Nouns over verbs
76
- - **HTTP methods**: GET, POST, PUT, PATCH, DELETE
77
- - **Stateless**: No server-side session
78
- - **HATEOAS**: Hypermedia as the Engine of Application State
79
- - **Pagination**: Cursor-based or offset-based
80
- - **Filtering**: Query parameters for resource selection
81
-
82
- **GraphQL**:
83
- - **Schema-first**: Type definitions drive development
84
- - **Resolver patterns**: Efficient data fetching
85
- - **DataLoader**: Batching and caching
86
- - **Subscriptions**: Real-time updates via WebSockets
87
-
88
- **gRPC**:
89
- - **Protocol Buffers**: Strongly-typed contracts
90
- - **HTTP/2**: Multiplexing, server push
91
- - **Streaming**: Unary, server-streaming, client-streaming, bidirectional
92
-
93
- **WebSockets**:
94
- - **Bidirectional communication**: Real-time updates
95
- - **Connection management**: Heartbeats, reconnection
96
- - **Authentication**: Token-based or session-based
97
-
98
- ### Security (OWASP API Security Top 10 2023)
99
-
100
- - **API1:2023 Broken Object Level Authorization**: Verify user permissions
101
- - **API2:2023 Broken Authentication**: Strong auth mechanisms
102
- - **API3:2023 Broken Object Property Level Authorization**: Filter sensitive fields
103
- - **API4:2023 Unrestricted Resource Consumption**: Rate limiting, pagination
104
- - **API5:2023 Broken Function Level Authorization**: Role-based access control
105
- - **API6:2023 Unrestricted Access to Sensitive Business Flows**: Anti-automation
106
- - **API7:2023 Server Side Request Forgery**: Validate URLs, whitelist
107
- - **API8:2023 Security Misconfiguration**: Secure defaults, hardening
108
- - **API9:2023 Improper Inventory Management**: API versioning, documentation
109
- - **API10:2023 Unsafe Consumption of APIs**: Validate external API responses
110
-
111
- ### Caching Strategies
112
-
113
- **Redis 7.2.x**:
114
- - **In-memory data store**: Key-value, hashes, lists, sets
115
- - **Pub/Sub**: Real-time messaging
116
- - **Lua scripting**: Atomic operations
117
- - **Redis Cluster**: Horizontal scaling
118
- - **Persistence**: RDB snapshots, AOF logs
119
-
120
- **Memcached 1.6.x**:
121
- - **Distributed caching**: Simple key-value store
122
- - **LRU eviction**: Automatic memory management
123
- - **Multi-threaded**: High concurrency
124
-
125
- **Cache Patterns**:
126
- - **Cache-aside**: Application manages cache
127
- - **Write-through**: Write to cache and database
128
- - **Write-behind**: Asynchronous database writes
129
- - **Refresh-ahead**: Proactive cache warming
130
-
131
- **CDN Caching**:
132
- - **CloudFlare**, **CloudFront**, **Fastly**
133
- - **Edge caching**: Geographically distributed
134
- - **Cache invalidation**: Purge, TTL
135
-
136
- ### Database Optimization
137
-
138
- **PostgreSQL 16.x**:
139
- - **EXPLAIN ANALYZE**: Query plan analysis
140
- - **Connection pooling**: PgBouncer, pgpool-II
141
- - **Read replicas**: Streaming replication
142
- - **Partitioning**: Table partitioning for large datasets
143
- - **JSONB indexing**: GIN, GiST indexes
144
-
145
- **MongoDB 8.0.x**:
146
- - **Aggregation pipeline**: Complex queries
147
- - **Sharding**: Horizontal scaling
148
- - **Read concern/Write concern**: Consistency tuning
149
- - **Change streams**: Real-time data feeds
150
-
151
- **Cassandra 4.1.x**:
152
- - **Wide-column store**: Time-series data
153
- - **Tunable consistency**: CAP theorem trade-offs
154
- - **Data modeling**: Partition keys, clustering columns
155
-
156
- **Redis 7.2.x** (as database):
157
- - **RediSearch**: Full-text search
158
- - **RedisJSON**: Native JSON support
159
- - **RedisTimeSeries**: Time-series data
160
-
161
- ### Cloud-Native Patterns
162
-
163
- **Kubernetes 1.31.x**:
164
- - **Deployments**: Rolling updates, rollbacks
165
- - **StatefulSets**: Persistent storage for databases
166
- - **Services**: ClusterIP, NodePort, LoadBalancer
167
- - **Ingress**: HTTP/HTTPS routing
168
- - **ConfigMaps/Secrets**: Configuration management
169
- - **Horizontal Pod Autoscaler**: CPU/memory-based scaling
170
- - **Vertical Pod Autoscaler**: Resource request optimization
171
-
172
- **Istio 1.21.x Service Mesh**:
173
- - **Traffic management**: Canary deployments, A/B testing
174
- - **Security**: mTLS, authorization policies
175
- - **Observability**: Distributed tracing, metrics
176
- - **Resilience**: Circuit breaking, retries, timeouts
177
-
178
- **Docker 27.0+**:
179
- - **Multi-stage builds**: Smaller images
180
- - **BuildKit**: Efficient caching
181
- - **Docker Compose**: Local development
182
- - **Image scanning**: Vulnerability detection
183
-
184
- ### Observability Stack (2025-10-22)
185
-
186
- **OpenTelemetry 1.24.0**:
187
- - **Unified telemetry**: Traces, metrics, logs
188
- - **Language SDKs**: Auto-instrumentation
189
- - **Collector**: Vendor-agnostic pipeline
190
- - **Context propagation**: Distributed tracing
191
-
192
- **Prometheus 2.48.x**:
193
- - **Metrics collection**: Pull-based
194
- - **PromQL**: Query language
195
- - **Alertmanager**: Alert routing
196
- - **Service discovery**: Kubernetes integration
197
-
198
- **Jaeger 1.51.x**:
199
- - **Distributed tracing**: Request flow visualization
200
- - **Span analysis**: Latency breakdown
201
- - **Service dependency graph**: Architecture mapping
202
-
203
- **ELK Stack**:
204
- - **Elasticsearch 8.x**: Log search and analytics
205
- - **Logstash 8.x**: Log aggregation and transformation
206
- - **Kibana 8.x**: Visualization and dashboards
207
- - **Filebeat 8.x**: Log shipping
208
-
209
- **Grafana 10.x**:
210
- - **Unified dashboards**: Metrics, logs, traces
211
- - **Data source plugins**: Prometheus, Loki, Tempo
212
- - **Alerting**: Multi-channel notifications
213
-
214
- ### Scalability Patterns
215
-
216
- **Horizontal Scaling**:
217
- - **Load balancers**: NGINX, HAProxy, AWS ALB
218
- - **Stateless services**: No local state
219
- - **Session management**: Redis, database
220
-
221
- **Vertical Scaling**:
222
- - **Resource limits**: CPU, memory allocation
223
- - **Database connection pooling**: Reduce overhead
224
-
225
- **Async Processing**:
226
- - **Apache Kafka 3.7.x**: Event streaming
227
- - **RabbitMQ 3.13.x**: Task queues
228
- - **Celery**: Python task queue
229
- - **Bull/BullMQ**: Node.js job queues
230
-
231
- **Rate Limiting**:
232
- - **Token bucket**: Fixed rate with burst
233
- - **Sliding window**: Time-based limits
234
- - **Distributed rate limiting**: Redis-based
235
-
236
- ## Examples
237
-
238
- See `examples.md` for production-ready patterns:
239
- - Microservices with Kubernetes 1.31 + Istio 1.21
240
- - Event-driven with Kafka 3.7
241
- - Serverless with AWS Lambda
242
- - Observability with OpenTelemetry 1.24 + Prometheus 2.48
243
-
244
- ## Inputs
245
- - Domain-specific design documents and user requirements.
246
- - Project technology stack and operational constraints.
247
- - Performance, scalability, and availability requirements.
248
-
249
- ## Outputs
250
- - Domain-specific architecture or implementation guidelines.
251
- - Recommended list of associated sub-agents/skills.
252
- - Tool version recommendations and deployment strategies.
253
-
254
- ## Failure Modes
255
- - When the domain document does not exist or is ambiguous.
256
- - When the project strategy is unconfirmed and cannot be specified.
257
- - When performance/scalability requirements are not quantified.
258
-
259
- ## Dependencies
260
- - `.moai/project/` document and latest technical briefing are required.
261
- - `reference.md` for architecture decision matrices.
262
- - `examples.md` for production patterns.
263
-
264
- ## References
265
- - AWS. "AWS Well-Architected Framework." https://docs.aws.amazon.com/wellarchitected/latest/framework/ (accessed 2025-10-22).
266
- - Heroku. "The Twelve-Factor App." https://12factor.net/ (accessed 2025-10-22).
267
- - OWASP. "API Security Top 10 2023." https://owasp.org/API-Security/editions/2023/en/0x11-t10/ (accessed 2025-10-22).
268
- - Kubernetes. "Kubernetes Documentation." https://kubernetes.io/docs/ (accessed 2025-10-22).
269
- - OpenTelemetry. "OpenTelemetry Documentation." https://opentelemetry.io/docs/ (accessed 2025-10-22).
270
- - Istio. "Istio Documentation." https://istio.io/latest/docs/ (accessed 2025-10-22).
271
-
272
- ## Changelog
273
- - 2025-10-22: v2.0.0 - Added cloud-native patterns (Kubernetes 1.31, Istio 1.21), observability stack (OpenTelemetry 1.24, Prometheus 2.48, Jaeger 1.51), OWASP API Security Top 10 2023, latest database versions (PostgreSQL 16, MongoDB 8, Redis 7.2, Cassandra 4.1).
274
- - 2025-03-29: v1.0.0 - Codified input/output and failure responses for domain skills.
275
-
276
- ## Works well with
277
-
278
- - moai-alfred-trust-validation (backend testing)
279
- - moai-domain-web-api (API design)
280
- - moai-domain-database (database optimization)
281
- - moai-domain-devops (CI/CD, infrastructure)
282
- - moai-domain-security (OWASP, SAST)
283
-
284
- ## Best Practices
285
- - Record supporting documentation (version/link) for each domain decision.
286
- - Review performance, security, and operational requirements simultaneously at an early stage.
287
- - Use observability stack from day one (OpenTelemetry + Prometheus + Jaeger).
288
- - Apply OWASP API Security Top 10 2023 guidelines.
289
- - Choose architecture patterns based on team size, complexity, and operational maturity.
290
- - Test scalability patterns with realistic load (k6, Gatling).