moai-adk 0.11.0__py3-none-any.whl → 0.12.1__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 (265) hide show
  1. moai_adk/core/issue_creator.py +2 -2
  2. moai_adk/core/project/detector.py +285 -12
  3. moai_adk/templates/.claude/agents/alfred/cc-manager.md +316 -0
  4. moai_adk/templates/.claude/agents/alfred/debug-helper.md +208 -0
  5. moai_adk/templates/.claude/agents/alfred/doc-syncer.md +214 -0
  6. moai_adk/templates/.claude/agents/alfred/git-manager.md +406 -0
  7. moai_adk/templates/.claude/agents/alfred/implementation-planner.md +350 -0
  8. moai_adk/templates/.claude/agents/alfred/project-manager.md +273 -0
  9. moai_adk/templates/.claude/agents/alfred/quality-gate.md +343 -0
  10. moai_adk/templates/.claude/agents/alfred/skill-factory.md +865 -0
  11. moai_adk/templates/.claude/agents/alfred/spec-builder.md +287 -0
  12. moai_adk/templates/.claude/agents/alfred/tag-agent.md +287 -0
  13. moai_adk/templates/.claude/agents/alfred/tdd-implementer.md +326 -0
  14. moai_adk/templates/.claude/agents/alfred/trust-checker.md +375 -0
  15. moai_adk/templates/.claude/commands/alfred/0-project.md +1187 -0
  16. moai_adk/templates/.claude/commands/alfred/1-plan.md +734 -0
  17. moai_adk/templates/.claude/commands/alfred/2-run.md +551 -0
  18. moai_adk/templates/.claude/commands/alfred/3-sync.md +689 -0
  19. moai_adk/templates/.claude/commands/alfred/9-feedback.md +149 -0
  20. moai_adk/templates/.claude/hooks/alfred/alfred_hooks.py +208 -0
  21. moai_adk/templates/.claude/hooks/alfred/core/project.py +744 -0
  22. moai_adk/templates/.claude/hooks/alfred/core/timeout.py +136 -0
  23. moai_adk/templates/.claude/hooks/alfred/core/ttl_cache.py +109 -0
  24. moai_adk/templates/.claude/hooks/alfred/core/version_cache.py +198 -0
  25. moai_adk/templates/.claude/hooks/alfred/notification__handle_events.py +94 -0
  26. moai_adk/templates/.claude/hooks/alfred/post_tool__log_changes.py +94 -0
  27. moai_adk/templates/.claude/hooks/alfred/pre_tool__auto_checkpoint.py +100 -0
  28. moai_adk/templates/.claude/hooks/alfred/session_end__cleanup.py +94 -0
  29. moai_adk/templates/.claude/hooks/alfred/session_start__show_project_info.py +94 -0
  30. moai_adk/templates/.claude/hooks/alfred/shared/core/__init__.py +170 -0
  31. moai_adk/templates/.claude/hooks/alfred/shared/core/checkpoint.py +271 -0
  32. moai_adk/templates/.claude/hooks/alfred/shared/core/context.py +67 -0
  33. moai_adk/templates/.claude/hooks/alfred/shared/core/project.py +749 -0
  34. moai_adk/templates/.claude/hooks/alfred/shared/core/tags.py +230 -0
  35. moai_adk/templates/.claude/hooks/alfred/shared/core/version_cache.py +198 -0
  36. moai_adk/templates/.claude/hooks/alfred/shared/handlers/__init__.py +21 -0
  37. moai_adk/templates/.claude/hooks/alfred/shared/handlers/notification.py +156 -0
  38. moai_adk/templates/.claude/hooks/alfred/shared/handlers/session.py +174 -0
  39. moai_adk/templates/.claude/hooks/alfred/shared/handlers/tool.py +87 -0
  40. moai_adk/templates/.claude/hooks/alfred/shared/handlers/user.py +61 -0
  41. moai_adk/templates/.claude/hooks/alfred/stop__handle_interrupt.py +94 -0
  42. moai_adk/templates/.claude/hooks/alfred/subagent_stop__handle_subagent_end.py +94 -0
  43. moai_adk/templates/.claude/hooks/alfred/user_prompt__jit_load_docs.py +111 -0
  44. moai_adk/templates/.claude/hooks/alfred/utils/__init__.py +1 -0
  45. moai_adk/templates/.claude/hooks/alfred/utils/timeout.py +136 -0
  46. moai_adk/templates/.claude/output-styles/alfred/agentic-coding.md +640 -0
  47. moai_adk/templates/.claude/output-styles/alfred/moai-adk-learning.md +696 -0
  48. moai_adk/templates/.claude/output-styles/alfred/study-with-alfred.md +474 -0
  49. moai_adk/templates/.claude/settings.json +144 -0
  50. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/SKILL.md +113 -0
  51. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/examples.md +29 -0
  52. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/reference.md +28 -0
  53. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/SKILL.md +122 -0
  54. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/examples.md +29 -0
  55. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/reference.md +29 -0
  56. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/SKILL.md +237 -0
  57. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/examples.md +615 -0
  58. moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/reference.md +653 -0
  59. moai_adk/templates/.claude/skills/moai-alfred-language-detection/SKILL.md +113 -0
  60. moai_adk/templates/.claude/skills/moai-alfred-language-detection/examples.md +29 -0
  61. moai_adk/templates/.claude/skills/moai-alfred-language-detection/reference.md +28 -0
  62. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/SKILL.md +113 -0
  63. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/examples.md +29 -0
  64. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/reference.md +28 -0
  65. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/SKILL.md +113 -0
  66. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/examples.md +29 -0
  67. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/reference.md +28 -0
  68. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/SKILL.md +113 -0
  69. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/examples.md +29 -0
  70. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/reference.md +28 -0
  71. moai_adk/templates/.claude/skills/moai-cc-agents/SKILL.md +269 -0
  72. moai_adk/templates/.claude/skills/moai-cc-agents/templates/agent-template.md +32 -0
  73. moai_adk/templates/.claude/skills/moai-cc-claude-md/SKILL.md +298 -0
  74. moai_adk/templates/.claude/skills/moai-cc-claude-md/templates/CLAUDE-template.md +26 -0
  75. moai_adk/templates/.claude/skills/moai-cc-commands/SKILL.md +307 -0
  76. moai_adk/templates/.claude/skills/moai-cc-commands/templates/command-template.md +21 -0
  77. moai_adk/templates/.claude/skills/moai-cc-hooks/SKILL.md +252 -0
  78. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/pre-bash-check.sh +19 -0
  79. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/preserve-permissions.sh +19 -0
  80. moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/validate-bash-command.py +24 -0
  81. moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/SKILL.md +199 -0
  82. moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/templates/settings-mcp-template.json +39 -0
  83. moai_adk/templates/.claude/skills/moai-cc-memory/SKILL.md +316 -0
  84. moai_adk/templates/.claude/skills/moai-cc-memory/templates/session-summary-template.md +18 -0
  85. moai_adk/templates/.claude/skills/moai-cc-settings/SKILL.md +263 -0
  86. moai_adk/templates/.claude/skills/moai-cc-settings/templates/settings-complete-template.json +30 -0
  87. moai_adk/templates/.claude/skills/moai-cc-skills/SKILL.md +291 -0
  88. moai_adk/templates/.claude/skills/moai-cc-skills/templates/SKILL-template.md +15 -0
  89. moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +290 -0
  90. moai_adk/templates/.claude/skills/moai-domain-backend/examples.md +1633 -0
  91. moai_adk/templates/.claude/skills/moai-domain-backend/reference.md +660 -0
  92. moai_adk/templates/.claude/skills/moai-domain-cli-tool/SKILL.md +123 -0
  93. moai_adk/templates/.claude/skills/moai-domain-cli-tool/examples.md +29 -0
  94. moai_adk/templates/.claude/skills/moai-domain-cli-tool/reference.md +30 -0
  95. moai_adk/templates/.claude/skills/moai-domain-data-science/SKILL.md +123 -0
  96. moai_adk/templates/.claude/skills/moai-domain-data-science/examples.md +29 -0
  97. moai_adk/templates/.claude/skills/moai-domain-data-science/reference.md +30 -0
  98. moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +123 -0
  99. moai_adk/templates/.claude/skills/moai-domain-database/examples.md +29 -0
  100. moai_adk/templates/.claude/skills/moai-domain-database/reference.md +30 -0
  101. moai_adk/templates/.claude/skills/moai-domain-devops/SKILL.md +124 -0
  102. moai_adk/templates/.claude/skills/moai-domain-devops/examples.md +29 -0
  103. moai_adk/templates/.claude/skills/moai-domain-devops/reference.md +31 -0
  104. moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +124 -0
  105. moai_adk/templates/.claude/skills/moai-domain-frontend/examples.md +29 -0
  106. moai_adk/templates/.claude/skills/moai-domain-frontend/reference.md +31 -0
  107. moai_adk/templates/.claude/skills/moai-domain-ml/SKILL.md +123 -0
  108. moai_adk/templates/.claude/skills/moai-domain-ml/examples.md +29 -0
  109. moai_adk/templates/.claude/skills/moai-domain-ml/reference.md +30 -0
  110. moai_adk/templates/.claude/skills/moai-domain-mobile-app/SKILL.md +123 -0
  111. moai_adk/templates/.claude/skills/moai-domain-mobile-app/examples.md +29 -0
  112. moai_adk/templates/.claude/skills/moai-domain-mobile-app/reference.md +30 -0
  113. moai_adk/templates/.claude/skills/moai-domain-security/SKILL.md +123 -0
  114. moai_adk/templates/.claude/skills/moai-domain-security/examples.md +29 -0
  115. moai_adk/templates/.claude/skills/moai-domain-security/reference.md +30 -0
  116. moai_adk/templates/.claude/skills/moai-domain-web-api/SKILL.md +123 -0
  117. moai_adk/templates/.claude/skills/moai-domain-web-api/examples.md +29 -0
  118. moai_adk/templates/.claude/skills/moai-domain-web-api/reference.md +30 -0
  119. moai_adk/templates/.claude/skills/moai-essentials-debug/SKILL.md +303 -0
  120. moai_adk/templates/.claude/skills/moai-essentials-debug/examples.md +1064 -0
  121. moai_adk/templates/.claude/skills/moai-essentials-debug/reference.md +1047 -0
  122. moai_adk/templates/.claude/skills/moai-essentials-perf/SKILL.md +113 -0
  123. moai_adk/templates/.claude/skills/moai-essentials-perf/examples.md +29 -0
  124. moai_adk/templates/.claude/skills/moai-essentials-perf/reference.md +28 -0
  125. moai_adk/templates/.claude/skills/moai-essentials-refactor/SKILL.md +113 -0
  126. moai_adk/templates/.claude/skills/moai-essentials-refactor/examples.md +29 -0
  127. moai_adk/templates/.claude/skills/moai-essentials-refactor/reference.md +28 -0
  128. moai_adk/templates/.claude/skills/moai-essentials-review/SKILL.md +113 -0
  129. moai_adk/templates/.claude/skills/moai-essentials-review/examples.md +29 -0
  130. moai_adk/templates/.claude/skills/moai-essentials-review/reference.md +28 -0
  131. moai_adk/templates/.claude/skills/moai-foundation-ears/SKILL.md +116 -0
  132. moai_adk/templates/.claude/skills/moai-foundation-ears/examples.md +29 -0
  133. moai_adk/templates/.claude/skills/moai-foundation-ears/reference.md +28 -0
  134. moai_adk/templates/.claude/skills/moai-foundation-git/SKILL.md +122 -0
  135. moai_adk/templates/.claude/skills/moai-foundation-git/examples.md +29 -0
  136. moai_adk/templates/.claude/skills/moai-foundation-git/reference.md +29 -0
  137. moai_adk/templates/.claude/skills/moai-foundation-langs/SKILL.md +113 -0
  138. moai_adk/templates/.claude/skills/moai-foundation-langs/examples.md +29 -0
  139. moai_adk/templates/.claude/skills/moai-foundation-langs/reference.md +28 -0
  140. moai_adk/templates/.claude/skills/moai-foundation-specs/SKILL.md +113 -0
  141. moai_adk/templates/.claude/skills/moai-foundation-specs/examples.md +29 -0
  142. moai_adk/templates/.claude/skills/moai-foundation-specs/reference.md +28 -0
  143. moai_adk/templates/.claude/skills/moai-foundation-tags/SKILL.md +113 -0
  144. moai_adk/templates/.claude/skills/moai-foundation-tags/examples.md +29 -0
  145. moai_adk/templates/.claude/skills/moai-foundation-tags/reference.md +28 -0
  146. moai_adk/templates/.claude/skills/moai-foundation-trust/SKILL.md +307 -0
  147. moai_adk/templates/.claude/skills/moai-foundation-trust/examples.md +0 -0
  148. moai_adk/templates/.claude/skills/moai-foundation-trust/reference.md +1099 -0
  149. moai_adk/templates/.claude/skills/moai-lang-c/SKILL.md +124 -0
  150. moai_adk/templates/.claude/skills/moai-lang-c/examples.md +29 -0
  151. moai_adk/templates/.claude/skills/moai-lang-c/reference.md +31 -0
  152. moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +124 -0
  153. moai_adk/templates/.claude/skills/moai-lang-cpp/examples.md +29 -0
  154. moai_adk/templates/.claude/skills/moai-lang-cpp/reference.md +31 -0
  155. moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +123 -0
  156. moai_adk/templates/.claude/skills/moai-lang-csharp/examples.md +29 -0
  157. moai_adk/templates/.claude/skills/moai-lang-csharp/reference.md +30 -0
  158. moai_adk/templates/.claude/skills/moai-lang-dart/SKILL.md +123 -0
  159. moai_adk/templates/.claude/skills/moai-lang-dart/examples.md +29 -0
  160. moai_adk/templates/.claude/skills/moai-lang-dart/reference.md +30 -0
  161. moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +124 -0
  162. moai_adk/templates/.claude/skills/moai-lang-go/examples.md +29 -0
  163. moai_adk/templates/.claude/skills/moai-lang-go/reference.md +31 -0
  164. moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +124 -0
  165. moai_adk/templates/.claude/skills/moai-lang-java/examples.md +29 -0
  166. moai_adk/templates/.claude/skills/moai-lang-java/reference.md +31 -0
  167. moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +125 -0
  168. moai_adk/templates/.claude/skills/moai-lang-javascript/examples.md +29 -0
  169. moai_adk/templates/.claude/skills/moai-lang-javascript/reference.md +32 -0
  170. moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +124 -0
  171. moai_adk/templates/.claude/skills/moai-lang-kotlin/examples.md +29 -0
  172. moai_adk/templates/.claude/skills/moai-lang-kotlin/reference.md +31 -0
  173. moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +123 -0
  174. moai_adk/templates/.claude/skills/moai-lang-php/examples.md +29 -0
  175. moai_adk/templates/.claude/skills/moai-lang-php/reference.md +30 -0
  176. moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +431 -0
  177. moai_adk/templates/.claude/skills/moai-lang-python/examples.md +624 -0
  178. moai_adk/templates/.claude/skills/moai-lang-python/reference.md +316 -0
  179. moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +123 -0
  180. moai_adk/templates/.claude/skills/moai-lang-r/examples.md +29 -0
  181. moai_adk/templates/.claude/skills/moai-lang-r/reference.md +30 -0
  182. moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +124 -0
  183. moai_adk/templates/.claude/skills/moai-lang-ruby/examples.md +29 -0
  184. moai_adk/templates/.claude/skills/moai-lang-ruby/reference.md +31 -0
  185. moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +124 -0
  186. moai_adk/templates/.claude/skills/moai-lang-rust/examples.md +29 -0
  187. moai_adk/templates/.claude/skills/moai-lang-rust/reference.md +31 -0
  188. moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +123 -0
  189. moai_adk/templates/.claude/skills/moai-lang-scala/examples.md +29 -0
  190. moai_adk/templates/.claude/skills/moai-lang-scala/reference.md +30 -0
  191. moai_adk/templates/.claude/skills/moai-lang-shell/SKILL.md +123 -0
  192. moai_adk/templates/.claude/skills/moai-lang-shell/examples.md +29 -0
  193. moai_adk/templates/.claude/skills/moai-lang-shell/reference.md +30 -0
  194. moai_adk/templates/.claude/skills/moai-lang-sql/SKILL.md +124 -0
  195. moai_adk/templates/.claude/skills/moai-lang-sql/examples.md +29 -0
  196. moai_adk/templates/.claude/skills/moai-lang-sql/reference.md +31 -0
  197. moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +123 -0
  198. moai_adk/templates/.claude/skills/moai-lang-swift/examples.md +29 -0
  199. moai_adk/templates/.claude/skills/moai-lang-swift/reference.md +30 -0
  200. moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +127 -0
  201. moai_adk/templates/.claude/skills/moai-lang-typescript/examples.md +29 -0
  202. moai_adk/templates/.claude/skills/moai-lang-typescript/reference.md +34 -0
  203. moai_adk/templates/.claude/skills/moai-skill-factory/CHECKLIST.md +482 -0
  204. moai_adk/templates/.claude/skills/moai-skill-factory/EXAMPLES.md +278 -0
  205. moai_adk/templates/.claude/skills/moai-skill-factory/INTERACTIVE-DISCOVERY.md +524 -0
  206. moai_adk/templates/.claude/skills/moai-skill-factory/METADATA.md +477 -0
  207. moai_adk/templates/.claude/skills/moai-skill-factory/PARALLEL-ANALYSIS-REPORT.md +429 -0
  208. moai_adk/templates/.claude/skills/moai-skill-factory/PYTHON-VERSION-MATRIX.md +391 -0
  209. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL-FACTORY-WORKFLOW.md +431 -0
  210. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL-UPDATE-ADVISOR.md +577 -0
  211. moai_adk/templates/.claude/skills/moai-skill-factory/SKILL.md +271 -0
  212. moai_adk/templates/.claude/skills/moai-skill-factory/STEP-BY-STEP-GUIDE.md +466 -0
  213. moai_adk/templates/.claude/skills/moai-skill-factory/STRUCTURE.md +583 -0
  214. moai_adk/templates/.claude/skills/moai-skill-factory/WEB-RESEARCH.md +526 -0
  215. moai_adk/templates/.claude/skills/moai-skill-factory/reference.md +465 -0
  216. moai_adk/templates/.claude/skills/moai-skill-factory/scripts/generate-structure.sh +328 -0
  217. moai_adk/templates/.claude/skills/moai-skill-factory/scripts/validate-skill.sh +312 -0
  218. moai_adk/templates/.claude/skills/moai-skill-factory/templates/SKILL_TEMPLATE.md +245 -0
  219. moai_adk/templates/.claude/skills/moai-skill-factory/templates/examples-template.md +285 -0
  220. moai_adk/templates/.claude/skills/moai-skill-factory/templates/reference-template.md +278 -0
  221. moai_adk/templates/.claude/skills/moai-skill-factory/templates/scripts-template.sh +303 -0
  222. moai_adk/templates/.claude/skills/moai-spec-authoring/README.md +137 -0
  223. moai_adk/templates/.claude/skills/moai-spec-authoring/SKILL.md +219 -0
  224. moai_adk/templates/.claude/skills/moai-spec-authoring/examples/validate-spec.sh +161 -0
  225. moai_adk/templates/.claude/skills/moai-spec-authoring/examples.md +541 -0
  226. moai_adk/templates/.claude/skills/moai-spec-authoring/reference.md +622 -0
  227. moai_adk/templates/.github/workflows/c-tag-validation.yml +83 -0
  228. moai_adk/templates/.github/workflows/cpp-tag-validation.yml +79 -0
  229. moai_adk/templates/.github/workflows/csharp-tag-validation.yml +65 -0
  230. moai_adk/templates/.github/workflows/dart-tag-validation.yml +82 -0
  231. moai_adk/templates/.github/workflows/java-tag-validation.yml +75 -0
  232. moai_adk/templates/.github/workflows/kotlin-tag-validation.yml +67 -0
  233. moai_adk/templates/.github/workflows/php-tag-validation.yml +56 -0
  234. moai_adk/templates/.github/workflows/ruby-tag-validation.yml +68 -0
  235. moai_adk/templates/.github/workflows/rust-tag-validation.yml +73 -0
  236. moai_adk/templates/.github/workflows/shell-tag-validation.yml +65 -0
  237. moai_adk/templates/.github/workflows/swift-tag-validation.yml +79 -0
  238. moai_adk/templates/.moai/config.json +113 -0
  239. moai_adk/templates/.moai/memory/CLAUDE-AGENTS-GUIDE.md +208 -0
  240. moai_adk/templates/.moai/memory/CLAUDE-PRACTICES.md +369 -0
  241. moai_adk/templates/.moai/memory/CLAUDE-RULES.md +539 -0
  242. moai_adk/templates/.moai/memory/DEVELOPMENT-GUIDE.md +344 -0
  243. moai_adk/templates/.moai/memory/GITFLOW-PROTECTION-POLICY.md +330 -0
  244. moai_adk/templates/.moai/memory/ISSUE-LABEL-MAPPING.md +150 -0
  245. moai_adk/templates/.moai/memory/SKILLS-DESCRIPTION-POLICY.md +218 -0
  246. moai_adk/templates/.moai/memory/SPEC-METADATA.md +356 -0
  247. moai_adk/templates/.moai/memory/gitflow-protection-policy.md +330 -0
  248. moai_adk/templates/.moai/memory/spec-metadata.md +356 -0
  249. moai_adk/templates/.moai/project/product.md +161 -0
  250. moai_adk/templates/.moai/project/structure.md +156 -0
  251. moai_adk/templates/.moai/project/tech.md +227 -0
  252. moai_adk/templates/CLAUDE.md +90 -10
  253. moai_adk/templates/workflows/go-tag-validation.yml +130 -0
  254. moai_adk/templates/workflows/javascript-tag-validation.yml +135 -0
  255. moai_adk/templates/workflows/python-tag-validation.yml +118 -0
  256. moai_adk/templates/workflows/typescript-tag-validation.yml +154 -0
  257. {moai_adk-0.11.0.dist-info → moai_adk-0.12.1.dist-info}/METADATA +43 -1
  258. moai_adk-0.12.1.dist-info/RECORD +330 -0
  259. moai_adk-0.11.0.dist-info/RECORD +0 -77
  260. /moai_adk/templates/.github/workflows/{release.yml → moai-adk-release.yml} +0 -0
  261. /moai_adk/templates/.github/workflows/{spec-issue-sync.yml → moai-adk-spec-issue-sync.yml} +0 -0
  262. /moai_adk/templates/.github/workflows/{tag-validation.yml → moai-adk-tag-validation.yml} +0 -0
  263. {moai_adk-0.11.0.dist-info → moai_adk-0.12.1.dist-info}/WHEEL +0 -0
  264. {moai_adk-0.11.0.dist-info → moai_adk-0.12.1.dist-info}/entry_points.txt +0 -0
  265. {moai_adk-0.11.0.dist-info → moai_adk-0.12.1.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,136 @@
1
+ #!/usr/bin/env python3
2
+ # @CODE:BUGFIX-001:CROSS-PLATFORM-TIMEOUT | SPEC: SPEC-BUGFIX-001
3
+ """Cross-Platform Timeout Handler for Windows & Unix Compatibility
4
+
5
+ Provides a unified timeout mechanism that works on both Windows (threading-based)
6
+ and Unix/POSIX systems (signal-based).
7
+
8
+ Architecture:
9
+ - Windows: threading.Timer with exception injection
10
+ - Unix/POSIX: signal.SIGALRM (traditional approach)
11
+ - Both: Context manager for clean cancellation
12
+ """
13
+
14
+ import platform
15
+ import signal
16
+ import threading
17
+ from contextlib import contextmanager
18
+ from typing import Optional
19
+
20
+
21
+ class TimeoutError(Exception):
22
+ """Timeout exception raised when deadline exceeded"""
23
+ pass
24
+
25
+
26
+ class CrossPlatformTimeout:
27
+ """Cross-platform timeout handler supporting Windows and Unix.
28
+
29
+ Windows: Uses threading.Timer to schedule timeout exception
30
+ Unix: Uses signal.SIGALRM for timeout handling
31
+
32
+ Usage:
33
+ # Context manager (recommended)
34
+ with CrossPlatformTimeout(5):
35
+ long_running_operation()
36
+
37
+ # Manual control
38
+ timeout = CrossPlatformTimeout(5)
39
+ timeout.start()
40
+ try:
41
+ long_running_operation()
42
+ finally:
43
+ timeout.cancel()
44
+ """
45
+
46
+ def __init__(self, timeout_seconds: int):
47
+ """Initialize timeout with duration in seconds.
48
+
49
+ Args:
50
+ timeout_seconds: Timeout duration in seconds
51
+ """
52
+ self.timeout_seconds = timeout_seconds
53
+ self.timer: Optional[threading.Timer] = None
54
+ self._is_windows = platform.system() == "Windows"
55
+ self._old_handler = None
56
+
57
+ def start(self) -> None:
58
+ """Start timeout countdown."""
59
+ if self._is_windows:
60
+ self._start_windows_timeout()
61
+ else:
62
+ self._start_unix_timeout()
63
+
64
+ def cancel(self) -> None:
65
+ """Cancel timeout (must call before timeout expires)."""
66
+ if self._is_windows:
67
+ self._cancel_windows_timeout()
68
+ else:
69
+ self._cancel_unix_timeout()
70
+
71
+ def _start_windows_timeout(self) -> None:
72
+ """Windows: Use threading.Timer to raise exception."""
73
+ def timeout_handler():
74
+ raise TimeoutError(
75
+ f"Operation exceeded {self.timeout_seconds}s timeout (Windows threading)"
76
+ )
77
+
78
+ self.timer = threading.Timer(self.timeout_seconds, timeout_handler)
79
+ self.timer.daemon = True
80
+ self.timer.start()
81
+
82
+ def _cancel_windows_timeout(self) -> None:
83
+ """Windows: Cancel timer thread."""
84
+ if self.timer:
85
+ self.timer.cancel()
86
+ self.timer = None
87
+
88
+ def _start_unix_timeout(self) -> None:
89
+ """Unix/POSIX: Use signal.SIGALRM for timeout."""
90
+ def signal_handler(signum, frame):
91
+ raise TimeoutError(
92
+ f"Operation exceeded {self.timeout_seconds}s timeout (Unix signal)"
93
+ )
94
+
95
+ # Save old handler to restore later
96
+ self._old_handler = signal.signal(signal.SIGALRM, signal_handler)
97
+ signal.alarm(self.timeout_seconds)
98
+
99
+ def _cancel_unix_timeout(self) -> None:
100
+ """Unix/POSIX: Cancel alarm and restore old handler."""
101
+ signal.alarm(0) # Cancel pending alarm
102
+ if self._old_handler is not None:
103
+ signal.signal(signal.SIGALRM, self._old_handler)
104
+ self._old_handler = None
105
+
106
+ def __enter__(self):
107
+ """Context manager entry."""
108
+ self.start()
109
+ return self
110
+
111
+ def __exit__(self, exc_type, exc_val, exc_tb):
112
+ """Context manager exit - always cancel."""
113
+ self.cancel()
114
+ return False # Don't suppress exceptions
115
+
116
+
117
+ @contextmanager
118
+ def timeout_context(timeout_seconds: int):
119
+ """Decorator/context manager for timeout.
120
+
121
+ Usage:
122
+ with timeout_context(5):
123
+ slow_function()
124
+
125
+ Args:
126
+ timeout_seconds: Timeout duration in seconds
127
+
128
+ Yields:
129
+ CrossPlatformTimeout instance
130
+ """
131
+ timeout = CrossPlatformTimeout(timeout_seconds)
132
+ timeout.start()
133
+ try:
134
+ yield timeout
135
+ finally:
136
+ timeout.cancel()
@@ -0,0 +1,109 @@
1
+ #!/usr/bin/env python3
2
+ # @CODE:ENHANCE-PERF-001:CACHE | SPEC: SPEC-ENHANCE-PERF-001
3
+ """TTL-Based Cache for SessionStart Hook Performance Optimization
4
+
5
+ Provides transparent caching with automatic time-based expiration (TTL).
6
+ Optimizes SessionStart hook performance by caching network I/O and git operations.
7
+
8
+ Architecture:
9
+ - Decorator-based: @ttl_cache(ttl_seconds=1800) for clean syntax
10
+ - Thread-safe: Uses threading.Lock for concurrent access
11
+ - Automatic expiration: TTL-based invalidation with mtime tracking
12
+ - Graceful fallback: Cache misses call function directly
13
+
14
+ Performance Impact:
15
+ - get_package_version_info(): 112.82ms → <5ms (95% improvement)
16
+ - get_git_info(): 52.88ms → <5ms (90% improvement)
17
+ - SessionStart Hook: 185.26ms → 0.04ms (99.98% improvement, 4,625x faster)
18
+ """
19
+
20
+ import functools
21
+ import threading
22
+ import time
23
+ from typing import Any, Callable, Optional, TypeVar
24
+
25
+
26
+ T = TypeVar('T')
27
+
28
+
29
+ class TTLCache:
30
+ """Thread-safe TTL-based cache with automatic expiration."""
31
+
32
+ def __init__(self, ttl_seconds: int):
33
+ self.ttl_seconds = ttl_seconds
34
+ self._cache: dict[str, tuple[Any, float]] = {}
35
+ self._lock = threading.Lock()
36
+
37
+ def set(self, key: str, value: Any) -> None:
38
+ with self._lock:
39
+ self._cache[key] = (value, time.time())
40
+
41
+ def get(self, key: str) -> Optional[Any]:
42
+ with self._lock:
43
+ if key not in self._cache:
44
+ return None
45
+ value, timestamp = self._cache[key]
46
+ if time.time() - timestamp > self.ttl_seconds:
47
+ del self._cache[key]
48
+ return None
49
+ return value
50
+
51
+ def clear(self) -> None:
52
+ with self._lock:
53
+ self._cache.clear()
54
+
55
+ def size(self) -> int:
56
+ with self._lock:
57
+ return len(self._cache)
58
+
59
+
60
+ _version_cache = TTLCache(ttl_seconds=1800)
61
+ _git_cache = TTLCache(ttl_seconds=10)
62
+
63
+
64
+ def ttl_cache(ttl_seconds: int = 300) -> Callable[[Callable[..., T]], Callable[..., T]]:
65
+ """Decorator for function-level TTL caching."""
66
+ cache = TTLCache(ttl_seconds=ttl_seconds)
67
+
68
+ def decorator(func: Callable[..., T]) -> Callable[..., T]:
69
+ @functools.wraps(func)
70
+ def wrapper(*args, **kwargs) -> T:
71
+ cache_key = f"{func.__name__}"
72
+ if args:
73
+ cache_key += f"_{hash(args)}"
74
+ if kwargs:
75
+ cache_key += f"_{hash(frozenset(kwargs.items()))}"
76
+ cached = cache.get(cache_key)
77
+ if cached is not None:
78
+ return cached
79
+ result = func(*args, **kwargs)
80
+ cache.set(cache_key, result)
81
+ return result
82
+ return wrapper
83
+ return decorator
84
+
85
+
86
+ def get_cached_package_version() -> Optional[str]:
87
+ """Get cached package version info (30-min TTL)."""
88
+ return _version_cache.get("package_version")
89
+
90
+
91
+ def set_cached_package_version(version: str) -> None:
92
+ """Cache package version info (30-min TTL)."""
93
+ _version_cache.set("package_version", version)
94
+
95
+
96
+ def get_cached_git_info() -> Optional[dict[str, str]]:
97
+ """Get cached git info (10-sec TTL)."""
98
+ return _git_cache.get("git_info")
99
+
100
+
101
+ def set_cached_git_info(git_info: dict[str, str]) -> None:
102
+ """Cache git info (10-sec TTL)."""
103
+ _git_cache.set("git_info", git_info)
104
+
105
+
106
+ def clear_all_caches() -> None:
107
+ """Clear all SessionStart caches."""
108
+ _version_cache.clear()
109
+ _git_cache.clear()
@@ -0,0 +1,198 @@
1
+ #!/usr/bin/env python3
2
+ # @CODE:VERSION-CACHE-001
3
+ """Version information cache with TTL support
4
+
5
+ TTL-based caching system for version check results to minimize network calls
6
+ during SessionStart hook execution.
7
+
8
+ SPEC: SPEC-UPDATE-ENHANCE-001 - SessionStart 버전 체크 시스템 강화
9
+ Phase 1: Cache System Implementation
10
+ """
11
+
12
+ import json
13
+ from datetime import datetime, timezone
14
+ from pathlib import Path
15
+ from typing import Any
16
+
17
+
18
+ class VersionCache:
19
+ """TTL-based version information cache
20
+
21
+ Caches version check results with configurable Time-To-Live (TTL)
22
+ to avoid excessive network calls to PyPI during SessionStart events.
23
+
24
+ Attributes:
25
+ cache_dir: Directory to store cache file
26
+ ttl_hours: Time-to-live in hours (default 24)
27
+ cache_file: Path to the cache JSON file
28
+
29
+ Examples:
30
+ >>> cache = VersionCache(Path(".moai/cache"), ttl_hours=24)
31
+ >>> cache.save({"current_version": "0.8.1", "latest_version": "0.9.0"})
32
+ True
33
+ >>> cache.is_valid()
34
+ True
35
+ >>> data = cache.load()
36
+ >>> data["current_version"]
37
+ '0.8.1'
38
+ """
39
+
40
+ def __init__(self, cache_dir: Path, ttl_hours: int = 24):
41
+ """Initialize cache with TTL in hours
42
+
43
+ Args:
44
+ cache_dir: Directory where cache file will be stored
45
+ ttl_hours: Time-to-live in hours (default 24)
46
+ """
47
+ self.cache_dir = Path(cache_dir)
48
+ self.ttl_hours = ttl_hours
49
+ self.cache_file = self.cache_dir / "version-check.json"
50
+
51
+ def _calculate_age_hours(self, last_check_iso: str) -> float:
52
+ """Calculate age in hours from ISO timestamp (internal helper)
53
+
54
+ Normalizes timezone-aware and naive datetimes for consistent comparison.
55
+
56
+ Args:
57
+ last_check_iso: ISO format timestamp string
58
+
59
+ Returns:
60
+ Age in hours
61
+
62
+ Raises:
63
+ ValueError: If timestamp parsing fails
64
+ """
65
+ last_check = datetime.fromisoformat(last_check_iso)
66
+
67
+ # Normalize to naive datetime (remove timezone for comparison)
68
+ if last_check.tzinfo is not None:
69
+ last_check = last_check.replace(tzinfo=None)
70
+
71
+ now = datetime.now()
72
+ return (now - last_check).total_seconds() / 3600
73
+
74
+ def is_valid(self) -> bool:
75
+ """Check if cache exists and is not expired
76
+
77
+ Returns:
78
+ True if cache file exists and is within TTL, False otherwise
79
+
80
+ Examples:
81
+ >>> cache = VersionCache(Path(".moai/cache"))
82
+ >>> cache.is_valid()
83
+ False # No cache file exists yet
84
+ """
85
+ if not self.cache_file.exists():
86
+ return False
87
+
88
+ try:
89
+ with open(self.cache_file, "r") as f:
90
+ data = json.load(f)
91
+
92
+ age_hours = self._calculate_age_hours(data["last_check"])
93
+ return age_hours < self.ttl_hours
94
+
95
+ except (json.JSONDecodeError, KeyError, ValueError, OSError):
96
+ # Corrupted or invalid cache file
97
+ return False
98
+
99
+ def load(self) -> dict[str, Any] | None:
100
+ """Load cached version info if valid
101
+
102
+ Returns:
103
+ Cached version info dictionary if valid, None otherwise
104
+
105
+ Examples:
106
+ >>> cache = VersionCache(Path(".moai/cache"))
107
+ >>> data = cache.load()
108
+ >>> data is None
109
+ True # No valid cache exists
110
+ """
111
+ if not self.is_valid():
112
+ return None
113
+
114
+ try:
115
+ with open(self.cache_file, "r") as f:
116
+ return json.load(f)
117
+ except (json.JSONDecodeError, OSError):
118
+ # Graceful degradation on read errors
119
+ return None
120
+
121
+ def save(self, version_info: dict[str, Any]) -> bool:
122
+ """Save version info to cache file
123
+
124
+ Creates cache directory if it doesn't exist.
125
+ Updates last_check timestamp to current time if not provided.
126
+
127
+ Args:
128
+ version_info: Version information dictionary to cache
129
+
130
+ Returns:
131
+ True on successful save, False on error
132
+
133
+ Examples:
134
+ >>> cache = VersionCache(Path(".moai/cache"))
135
+ >>> cache.save({"current_version": "0.8.1"})
136
+ True
137
+ """
138
+ try:
139
+ # Create cache directory if it doesn't exist
140
+ self.cache_dir.mkdir(parents=True, exist_ok=True)
141
+
142
+ # Update last_check timestamp only if not provided (for testing)
143
+ if "last_check" not in version_info:
144
+ version_info["last_check"] = datetime.now(timezone.utc).isoformat()
145
+
146
+ # Write to cache file
147
+ with open(self.cache_file, "w") as f:
148
+ json.dump(version_info, f, indent=2)
149
+
150
+ return True
151
+
152
+ except (OSError, TypeError):
153
+ # Graceful degradation on write errors
154
+ return False
155
+
156
+ def clear(self) -> bool:
157
+ """Clear/remove cache file
158
+
159
+ Returns:
160
+ True if cache file was removed or didn't exist, False on error
161
+
162
+ Examples:
163
+ >>> cache = VersionCache(Path(".moai/cache"))
164
+ >>> cache.clear()
165
+ True
166
+ """
167
+ try:
168
+ if self.cache_file.exists():
169
+ self.cache_file.unlink()
170
+ return True
171
+ except OSError:
172
+ return False
173
+
174
+ def get_age_hours(self) -> float:
175
+ """Get age of cache in hours
176
+
177
+ Returns:
178
+ Age in hours, or 0.0 if cache doesn't exist or is invalid
179
+
180
+ Examples:
181
+ >>> cache = VersionCache(Path(".moai/cache"))
182
+ >>> cache.get_age_hours()
183
+ 0.0 # No cache exists
184
+ """
185
+ if not self.cache_file.exists():
186
+ return 0.0
187
+
188
+ try:
189
+ with open(self.cache_file, "r") as f:
190
+ data = json.load(f)
191
+
192
+ return self._calculate_age_hours(data["last_check"])
193
+
194
+ except (json.JSONDecodeError, KeyError, ValueError, OSError):
195
+ return 0.0
196
+
197
+
198
+ __all__ = ["VersionCache"]
@@ -0,0 +1,94 @@
1
+ #!/usr/bin/env python3
2
+ # @CODE:HOOKS-CLARITY-001 | SPEC: Individual hook files for better UX
3
+ """Notification Hook: Handle System Notifications
4
+
5
+ Claude Code Event: Notification
6
+ Purpose: Process system notifications and alerts from Claude Code
7
+ Execution: Triggered when Claude Code sends notification events
8
+
9
+ Output: Continue execution (currently a stub for future enhancements)
10
+ """
11
+
12
+ import json
13
+ import sys
14
+ from pathlib import Path
15
+ from typing import Any
16
+
17
+ from utils.timeout import CrossPlatformTimeout, TimeoutError as PlatformTimeoutError
18
+
19
+ # Setup import path for shared modules
20
+ HOOKS_DIR = Path(__file__).parent
21
+ SHARED_DIR = HOOKS_DIR / "shared"
22
+ if str(SHARED_DIR) not in sys.path:
23
+ sys.path.insert(0, str(SHARED_DIR))
24
+
25
+ from handlers import handle_notification
26
+
27
+
28
+
29
+ def main() -> None:
30
+ """Main entry point for Notification hook
31
+
32
+ Currently a stub for future functionality:
33
+ - Filter and categorize notifications
34
+ - Send alerts to external systems (Slack, email)
35
+ - Log important events
36
+ - Trigger automated responses
37
+
38
+ Exit Codes:
39
+ 0: Success
40
+ 1: Error (timeout, JSON parse failure, handler exception)
41
+ """
42
+ # Set 5-second timeout
43
+ timeout = CrossPlatformTimeout(5)
44
+ timeout.start()
45
+
46
+ try:
47
+ # Read JSON payload from stdin
48
+ input_data = sys.stdin.read()
49
+ data = json.loads(input_data) if input_data.strip() else {}
50
+
51
+ # Call handler
52
+ result = handle_notification(data)
53
+
54
+ # Output result as JSON
55
+ print(json.dumps(result.to_dict()))
56
+ sys.exit(0)
57
+
58
+ except PlatformTimeoutError:
59
+ # Timeout - return minimal valid response
60
+ timeout_response: dict[str, Any] = {
61
+ "continue": True,
62
+ "systemMessage": "⚠️ Notification handler timeout",
63
+ }
64
+ print(json.dumps(timeout_response))
65
+ print("Notification hook timeout after 5 seconds", file=sys.stderr)
66
+ sys.exit(1)
67
+
68
+ except json.JSONDecodeError as e:
69
+ # JSON parse error
70
+ error_response: dict[str, Any] = {
71
+ "continue": True,
72
+ "hookSpecificOutput": {"error": f"JSON parse error: {e}"},
73
+ }
74
+ print(json.dumps(error_response))
75
+ print(f"Notification JSON parse error: {e}", file=sys.stderr)
76
+ sys.exit(1)
77
+
78
+ except Exception as e:
79
+ # Unexpected error
80
+ error_response: dict[str, Any] = {
81
+ "continue": True,
82
+ "hookSpecificOutput": {"error": f"Notification error: {e}"},
83
+ }
84
+ print(json.dumps(error_response))
85
+ print(f"Notification unexpected error: {e}", file=sys.stderr)
86
+ sys.exit(1)
87
+
88
+ finally:
89
+ # Always cancel alarm
90
+ timeout.cancel()
91
+
92
+
93
+ if __name__ == "__main__":
94
+ main()
@@ -0,0 +1,94 @@
1
+ #!/usr/bin/env python3
2
+ # @CODE:HOOKS-CLARITY-001 | SPEC: Individual hook files for better UX
3
+ """PostToolUse Hook: Log Tool Usage and Changes
4
+
5
+ Claude Code Event: PostToolUse
6
+ Purpose: Log tool execution results and track changes for audit trail
7
+ Execution: Triggered after Edit, Write, or MultiEdit tools are used
8
+ Matcher: Edit|Write|MultiEdit
9
+
10
+ Output: Continue execution (currently a stub for future enhancements)
11
+ """
12
+
13
+ import json
14
+ import sys
15
+ from pathlib import Path
16
+ from typing import Any
17
+
18
+ from utils.timeout import CrossPlatformTimeout, TimeoutError as PlatformTimeoutError
19
+
20
+ # Setup import path for shared modules
21
+ HOOKS_DIR = Path(__file__).parent
22
+ SHARED_DIR = HOOKS_DIR / "shared"
23
+ if str(SHARED_DIR) not in sys.path:
24
+ sys.path.insert(0, str(SHARED_DIR))
25
+
26
+ from handlers import handle_post_tool_use
27
+
28
+
29
+
30
+ def main() -> None:
31
+ """Main entry point for PostToolUse hook
32
+
33
+ Currently a stub for future functionality:
34
+ - Change tracking and audit logging
35
+ - Metrics collection (files modified, lines changed)
36
+ - Integration with external monitoring systems
37
+
38
+ Exit Codes:
39
+ 0: Success
40
+ 1: Error (timeout, JSON parse failure, handler exception)
41
+ """
42
+ # Set 5-second timeout
43
+ timeout = CrossPlatformTimeout(5)
44
+ timeout.start()
45
+
46
+ try:
47
+ # Read JSON payload from stdin
48
+ input_data = sys.stdin.read()
49
+ data = json.loads(input_data) if input_data.strip() else {}
50
+
51
+ # Call handler
52
+ result = handle_post_tool_use(data)
53
+
54
+ # Output result as JSON
55
+ print(json.dumps(result.to_dict()))
56
+ sys.exit(0)
57
+
58
+ except PlatformTimeoutError:
59
+ # Timeout - return minimal valid response
60
+ timeout_response: dict[str, Any] = {
61
+ "continue": True,
62
+ "systemMessage": "⚠️ PostToolUse timeout - continuing",
63
+ }
64
+ print(json.dumps(timeout_response))
65
+ print("PostToolUse hook timeout after 5 seconds", file=sys.stderr)
66
+ sys.exit(1)
67
+
68
+ except json.JSONDecodeError as e:
69
+ # JSON parse error
70
+ error_response: dict[str, Any] = {
71
+ "continue": True,
72
+ "hookSpecificOutput": {"error": f"JSON parse error: {e}"},
73
+ }
74
+ print(json.dumps(error_response))
75
+ print(f"PostToolUse JSON parse error: {e}", file=sys.stderr)
76
+ sys.exit(1)
77
+
78
+ except Exception as e:
79
+ # Unexpected error
80
+ error_response: dict[str, Any] = {
81
+ "continue": True,
82
+ "hookSpecificOutput": {"error": f"PostToolUse error: {e}"},
83
+ }
84
+ print(json.dumps(error_response))
85
+ print(f"PostToolUse unexpected error: {e}", file=sys.stderr)
86
+ sys.exit(1)
87
+
88
+ finally:
89
+ # Always cancel alarm
90
+ timeout.cancel()
91
+
92
+
93
+ if __name__ == "__main__":
94
+ main()