moai-adk 0.3.13__py3-none-any.whl → 0.4.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 (141) hide show
  1. moai_adk/__init__.py +1 -1
  2. moai_adk/__main__.py +1 -1
  3. moai_adk/cli/commands/__init__.py +1 -1
  4. moai_adk/cli/commands/doctor.py +2 -2
  5. moai_adk/cli/commands/init.py +10 -5
  6. moai_adk/cli/commands/status.py +1 -1
  7. moai_adk/cli/commands/update.py +210 -8
  8. moai_adk/cli/prompts/init_prompts.py +15 -19
  9. moai_adk/core/__init__.py +1 -1
  10. moai_adk/core/diagnostics/slash_commands.py +1 -1
  11. moai_adk/core/git/branch.py +1 -1
  12. moai_adk/core/git/manager.py +1 -1
  13. moai_adk/core/project/backup_utils.py +1 -0
  14. moai_adk/core/project/phase_executor.py +3 -1
  15. moai_adk/core/project/validator.py +3 -2
  16. moai_adk/core/quality/__init__.py +1 -1
  17. moai_adk/core/quality/trust_checker.py +1 -1
  18. moai_adk/core/quality/validators/__init__.py +1 -1
  19. moai_adk/core/quality/validators/base_validator.py +1 -1
  20. moai_adk/core/template/__init__.py +1 -1
  21. moai_adk/core/template/backup.py +12 -3
  22. moai_adk/core/template/config.py +24 -0
  23. moai_adk/core/template/languages.py +1 -1
  24. moai_adk/core/template/merger.py +74 -4
  25. moai_adk/core/template/processor.py +62 -14
  26. moai_adk/templates/.claude/agents/alfred/cc-manager.md +765 -191
  27. moai_adk/templates/.claude/agents/alfred/debug-helper.md +116 -103
  28. moai_adk/templates/.claude/agents/alfred/doc-syncer.md +130 -116
  29. moai_adk/templates/.claude/agents/alfred/git-manager.md +186 -174
  30. moai_adk/templates/.claude/agents/alfred/implementation-planner.md +227 -213
  31. moai_adk/templates/.claude/agents/alfred/project-manager.md +205 -125
  32. moai_adk/templates/.claude/agents/alfred/quality-gate.md +224 -209
  33. moai_adk/templates/.claude/agents/alfred/spec-builder.md +174 -160
  34. moai_adk/templates/.claude/agents/alfred/tag-agent.md +151 -139
  35. moai_adk/templates/.claude/agents/alfred/tdd-implementer.md +209 -196
  36. moai_adk/templates/.claude/agents/alfred/trust-checker.md +247 -233
  37. moai_adk/templates/.claude/commands/alfred/0-project.md +856 -355
  38. moai_adk/templates/.claude/commands/alfred/1-plan.md +572 -0
  39. moai_adk/templates/.claude/commands/alfred/2-run.md +470 -0
  40. moai_adk/templates/.claude/commands/alfred/3-sync.md +366 -356
  41. moai_adk/templates/.claude/hooks/alfred/README.md +52 -52
  42. moai_adk/templates/.claude/hooks/alfred/alfred_hooks.py +44 -48
  43. moai_adk/templates/.claude/hooks/alfred/core/__init__.py +17 -17
  44. moai_adk/templates/.claude/hooks/alfred/core/checkpoint.py +59 -59
  45. moai_adk/templates/.claude/hooks/alfred/core/context.py +19 -19
  46. moai_adk/templates/.claude/hooks/alfred/core/project.py +52 -52
  47. moai_adk/templates/.claude/hooks/alfred/handlers/__init__.py +1 -1
  48. moai_adk/templates/.claude/hooks/alfred/handlers/notification.py +4 -4
  49. moai_adk/templates/.claude/hooks/alfred/handlers/session.py +30 -51
  50. moai_adk/templates/.claude/hooks/alfred/handlers/tool.py +16 -17
  51. moai_adk/templates/.claude/hooks/alfred/handlers/user.py +11 -11
  52. moai_adk/templates/.claude/output-styles/alfred/agentic-coding.md +308 -307
  53. moai_adk/templates/.claude/output-styles/alfred/moai-adk-learning.md +297 -296
  54. moai_adk/templates/.claude/output-styles/alfred/study-with-alfred.md +191 -190
  55. moai_adk/templates/.claude/skills/moai-alfred-code-reviewer/SKILL.md +112 -0
  56. moai_adk/templates/.claude/skills/moai-alfred-debugger-pro/SKILL.md +103 -0
  57. moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/SKILL.md +103 -0
  58. moai_adk/templates/.claude/skills/moai-alfred-git-workflow/SKILL.md +95 -0
  59. moai_adk/templates/.claude/skills/moai-alfred-language-detection/SKILL.md +99 -0
  60. moai_adk/templates/.claude/skills/moai-alfred-performance-optimizer/SKILL.md +105 -0
  61. moai_adk/templates/.claude/skills/moai-alfred-refactoring-coach/SKILL.md +97 -0
  62. moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/SKILL.md +97 -0
  63. moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/SKILL.md +90 -0
  64. moai_adk/templates/.claude/skills/moai-alfred-trust-validation/SKILL.md +99 -0
  65. moai_adk/templates/.claude/skills/moai-alfred-tui-survey/SKILL.md +87 -0
  66. moai_adk/templates/.claude/skills/moai-alfred-tui-survey/examples.md +62 -0
  67. moai_adk/templates/.claude/skills/moai-claude-code/SKILL.md +94 -0
  68. moai_adk/templates/.claude/skills/moai-claude-code/examples.md +513 -0
  69. moai_adk/templates/.claude/skills/moai-claude-code/reference.md +433 -0
  70. moai_adk/templates/.claude/skills/moai-claude-code/templates/agent-full.md +332 -0
  71. moai_adk/templates/.claude/skills/moai-claude-code/templates/command-full.md +384 -0
  72. moai_adk/templates/.claude/skills/moai-claude-code/templates/plugin-full.json +363 -0
  73. moai_adk/templates/.claude/skills/moai-claude-code/templates/settings-full.json +595 -0
  74. moai_adk/templates/.claude/skills/moai-claude-code/templates/skill-full.md +496 -0
  75. moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +99 -0
  76. moai_adk/templates/.claude/skills/moai-domain-cli-tool/SKILL.md +95 -0
  77. moai_adk/templates/.claude/skills/moai-domain-data-science/SKILL.md +98 -0
  78. moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +100 -0
  79. moai_adk/templates/.claude/skills/moai-domain-devops/SKILL.md +100 -0
  80. moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +99 -0
  81. moai_adk/templates/.claude/skills/moai-domain-ml/SKILL.md +99 -0
  82. moai_adk/templates/.claude/skills/moai-domain-mobile-app/SKILL.md +93 -0
  83. moai_adk/templates/.claude/skills/moai-domain-security/SKILL.md +105 -0
  84. moai_adk/templates/.claude/skills/moai-domain-web-api/SKILL.md +97 -0
  85. moai_adk/templates/.claude/skills/moai-essentials-debug/SKILL.md +102 -0
  86. moai_adk/templates/.claude/skills/moai-essentials-perf/SKILL.md +104 -0
  87. moai_adk/templates/.claude/skills/moai-essentials-refactor/SKILL.md +96 -0
  88. moai_adk/templates/.claude/skills/moai-essentials-review/SKILL.md +112 -0
  89. moai_adk/templates/.claude/skills/moai-foundation-ears/SKILL.md +98 -0
  90. moai_adk/templates/.claude/skills/moai-foundation-git/SKILL.md +90 -0
  91. moai_adk/templates/.claude/skills/moai-foundation-langs/SKILL.md +94 -0
  92. moai_adk/templates/.claude/skills/moai-foundation-specs/SKILL.md +93 -0
  93. moai_adk/templates/.claude/skills/moai-foundation-tags/SKILL.md +86 -0
  94. moai_adk/templates/.claude/skills/moai-foundation-trust/SKILL.md +86 -0
  95. moai_adk/templates/.claude/skills/moai-lang-c/SKILL.md +100 -0
  96. moai_adk/templates/.claude/skills/moai-lang-clojure/SKILL.md +100 -0
  97. moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +102 -0
  98. moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +100 -0
  99. moai_adk/templates/.claude/skills/moai-lang-dart/SKILL.md +98 -0
  100. moai_adk/templates/.claude/skills/moai-lang-elixir/SKILL.md +99 -0
  101. moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +100 -0
  102. moai_adk/templates/.claude/skills/moai-lang-haskell/SKILL.md +100 -0
  103. moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +98 -0
  104. moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +96 -0
  105. moai_adk/templates/.claude/skills/moai-lang-julia/SKILL.md +98 -0
  106. moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +99 -0
  107. moai_adk/templates/.claude/skills/moai-lang-lua/SKILL.md +98 -0
  108. moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +98 -0
  109. moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +96 -0
  110. moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +99 -0
  111. moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +99 -0
  112. moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +100 -0
  113. moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +100 -0
  114. moai_adk/templates/.claude/skills/moai-lang-shell/SKILL.md +100 -0
  115. moai_adk/templates/.claude/skills/moai-lang-sql/SKILL.md +100 -0
  116. moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +99 -0
  117. moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +96 -0
  118. moai_adk/templates/.github/PULL_REQUEST_TEMPLATE.md +44 -43
  119. moai_adk/templates/.github/workflows/moai-gitflow.yml +36 -35
  120. moai_adk/templates/.moai/config.json +9 -6
  121. moai_adk/templates/.moai/memory/development-guide.md +220 -221
  122. moai_adk/templates/.moai/memory/gitflow-protection-policy.md +85 -85
  123. moai_adk/templates/.moai/memory/spec-metadata.md +149 -150
  124. moai_adk/templates/.moai/project/product.md +90 -90
  125. moai_adk/templates/.moai/project/structure.md +85 -85
  126. moai_adk/templates/.moai/project/tech.md +117 -117
  127. moai_adk/templates/CLAUDE.md +354 -573
  128. moai_adk/templates/__init__.py +1 -1
  129. moai_adk/utils/__init__.py +1 -1
  130. moai_adk/utils/banner.py +7 -7
  131. moai_adk/utils/logger.py +1 -1
  132. moai_adk-0.4.1.dist-info/METADATA +303 -0
  133. moai_adk-0.4.1.dist-info/RECORD +152 -0
  134. moai_adk/templates/.claude/commands/alfred/1-spec.md +0 -532
  135. moai_adk/templates/.claude/commands/alfred/2-build.md +0 -432
  136. moai_adk/templates/.moai/hooks/pre-push.sample +0 -88
  137. moai_adk-0.3.13.dist-info/METADATA +0 -1586
  138. moai_adk-0.3.13.dist-info/RECORD +0 -90
  139. {moai_adk-0.3.13.dist-info → moai_adk-0.4.1.dist-info}/WHEEL +0 -0
  140. {moai_adk-0.3.13.dist-info → moai_adk-0.4.1.dist-info}/entry_points.txt +0 -0
  141. {moai_adk-0.3.13.dist-info → moai_adk-0.4.1.dist-info}/licenses/LICENSE +0 -0
@@ -1,1586 +0,0 @@
1
- Metadata-Version: 2.4
2
- Name: moai-adk
3
- Version: 0.3.13
4
- Summary: MoAI Agentic Development Kit - SPEC-First TDD with Alfred SuperAgent
5
- Project-URL: Homepage, https://github.com/modu-ai/moai-adk
6
- Project-URL: Repository, https://github.com/modu-ai/moai-adk
7
- Project-URL: Issues, https://github.com/modu-ai/moai-adk/issues
8
- Project-URL: Changelog, https://github.com/modu-ai/moai-adk/releases
9
- Author-email: MoAI Team <support@moduai.kr>
10
- License: MIT
11
- License-File: LICENSE
12
- Keywords: agentic,ai,alfred,claude,development,spec-first,tdd,toolkit
13
- Classifier: Development Status :: 4 - Beta
14
- Classifier: Intended Audience :: Developers
15
- Classifier: License :: OSI Approved :: MIT License
16
- Classifier: Programming Language :: Python :: 3
17
- Classifier: Programming Language :: Python :: 3.13
18
- Classifier: Topic :: Software Development :: Libraries :: Python Modules
19
- Classifier: Topic :: Software Development :: Quality Assurance
20
- Classifier: Topic :: Software Development :: Testing
21
- Requires-Python: >=3.13
22
- Requires-Dist: click>=8.1.0
23
- Requires-Dist: gitpython>=3.1.45
24
- Requires-Dist: packaging>=21.0
25
- Requires-Dist: pyfiglet>=1.0.2
26
- Requires-Dist: questionary>=2.0.0
27
- Requires-Dist: rich>=13.0.0
28
- Provides-Extra: dev
29
- Requires-Dist: mypy>=1.7.0; extra == 'dev'
30
- Requires-Dist: pytest-cov>=7.0.0; extra == 'dev'
31
- Requires-Dist: pytest-xdist>=3.8.0; extra == 'dev'
32
- Requires-Dist: pytest>=8.4.2; extra == 'dev'
33
- Requires-Dist: ruff>=0.1.0; extra == 'dev'
34
- Provides-Extra: security
35
- Requires-Dist: bandit>=1.8.0; extra == 'security'
36
- Requires-Dist: pip-audit>=2.7.0; extra == 'security'
37
- Description-Content-Type: text/markdown
38
-
39
- # MoAI-ADK (Agentic Development Kit)
40
-
41
- [![PyPI version](https://img.shields.io/pypi/v/moai-adk)](https://pypi.org/project/moai-adk/)
42
- [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
43
- [![Python](https://img.shields.io/badge/Python-3.13+-blue)](https://www.python.org/)
44
- [![Tests](https://github.com/modu-ai/moai-adk/actions/workflows/moai-gitflow.yml/badge.svg)](https://github.com/modu-ai/moai-adk/actions/workflows/moai-gitflow.yml)
45
- [![codecov](https://codecov.io/gh/modu-ai/moai-adk/branch/develop/graph/badge.svg)](https://codecov.io/gh/modu-ai/moai-adk)
46
- [![Coverage](https://img.shields.io/badge/coverage-87.66%25-brightgreen)](https://github.com/modu-ai/moai-adk)
47
-
48
- ## MoAI-ADK: 모두의AI 에이전틱 코딩 개발 프레임워크
49
-
50
- **안내**: MoAI-ADK는 모두의AI 연구실에서 집필 중인 "(가칭) 에이전틱 코딩" 서적의 별책 부록 오픈 소스 프로젝트입니다.
51
-
52
- ![MoAI-ADK CLI Interface](https://github.com/modu-ai/moai-adk/raw/main/docs/public/MoAI-ADK-cli_screen.png)
53
-
54
- > **"SPEC이 없으면 CODE도 없다."**
55
-
56
- ---
57
-
58
- ## 목차
59
-
60
- - [이런 문제 겪고 계신가요?](#이런-문제-겪고-계신가요)
61
- - [Meet Alfred](#meet-alfred---12개-ai-에이전트-팀)
62
- - [5분 만에 이해하는 핵심 개념](#5분-만에-이해하는-핵심-개념)
63
- - [Quick Start](#quick-start-3분-실전)
64
- - [첫 번째 프로젝트: Todo API](#첫-번째-프로젝트-todo-api-만들기)
65
- - [3단계 워크플로우](#3단계-워크플로우)
66
- - [실전 시나리오](#실전-시나리오)
67
- - [AI 모델 선택 가이드](#ai-모델-선택-가이드)
68
- - [CLI Reference](#cli-reference)
69
- - [출력 스타일](#alfreds-output-styles)
70
- - [언어 지원](#universal-language-support)
71
- - [TRUST 5원칙](#trust-5원칙)
72
- - [FAQ](#faq)
73
- - [문제 해결](#문제-해결)
74
-
75
- ---
76
-
77
- ## ■ 이런 문제 겪고 계신가요?
78
-
79
- ### AI 코딩의 현실
80
-
81
- - **"AI가 만든 코드, 나중에 유지보수 불가능..."**
82
- - 같은 기능을 매번 다르게 구현
83
- - 코드 스타일이 파일마다 제각각
84
- - 테스트 코드는 없고 버그는 많음
85
-
86
- - **"같은 질문 반복해도 매번 다른 답변..."**
87
- - 이전 대화 내용을 기억하지 못함
88
- - 일관된 아키텍처를 유지하기 어려움
89
- - 프로젝트 전체 맥락을 놓침
90
-
91
- - **"코드는 많은데 문서는 없고, 추적 불가능..."**
92
- - 왜 이렇게 만들었는지 알 수 없음
93
- - 코드 변경 이력 추적 불가
94
- - 요구사항과 코드가 따로 놈
95
-
96
- - **"프롬프트 엔지니어링에만 하루가 다 갔어요..."**
97
- - 완벽한 프롬프트를 찾기 위해 수십 번 시도
98
- - AI에게 매번 같은 제약사항을 반복 설명
99
- - 코드 품질을 수동으로 검증
100
-
101
- ### MoAI-ADK는 이렇게 해결합니다
102
-
103
- ```mermaid
104
- %%{init: {'theme':'neutral'}}%%
105
- flowchart TD
106
- Problem["■ 문제: 플랑켄슈타인 코드"] --> Solution["MoAI-ADK"]
107
- Solution --> SPEC["SPEC 우선<br/>명세 없으면 코드 없다"]
108
- Solution --> TDD["TDD 강제<br/>테스트 없으면 구현 없다"]
109
- Solution --> TAG["@TAG 추적<br/>모든 코드가 SPEC과 연결"]
110
-
111
- SPEC --> Result["결과"]
112
- TDD --> Result
113
- TAG --> Result
114
-
115
- Result --> Quality["높은 품질<br/>TRUST 5원칙 자동 검증"]
116
- Result --> Track["완벽한 추적성<br/>SPEC→TEST→CODE→DOC"]
117
- Result --> Maintain["쉬운 유지보수<br/>코드 변경 이력 완전 기록"]
118
- ```
119
-
120
- ---
121
-
122
- ## ■ Meet Alfred - AI 에이전트 팀
123
-
124
- 안녕하세요, 모두의AI SuperAgent **Alfred**입니다!
125
-
126
- ![Alfred Logo](https://github.com/modu-ai/moai-adk/raw/main/docs/public/alfred_logo.png)
127
-
128
- 저는 MoAI-ADK의 SuperAgent이자 중앙 오케스트레이터 AI입니다. **AI 에이전트 팀**(Alfred + 다수 전문 에이전트)을 조율하여 Claude Code 환경에서 완벽한 개발 지원을 제공합니다.
129
-
130
- ### ▶ 흥미로운 사실: AI가 만든 AI 개발 도구
131
-
132
- 이 프로젝트의 모든 코드는 **100% AI에 의해 작성**되었습니다.
133
-
134
- - **AI 협업 설계**: GPT-5 Pro와 Claude 4.1 Opus가 함께 아키텍처를 설계
135
- - **Agentic Coding 적용**: AI 에이전트 팀(Alfred + 다수 전문 에이전트)이 자율적으로 SPEC 작성, TDD 구현, 문서 동기화 수행
136
- - **투명성**: 완벽하지 않은 부분을 숨기지 않고, 커뮤니티와 함께 개선해나가는 오픈소스
137
-
138
- ### Alfred가 제공하는 4가지 핵심 가치
139
-
140
- ```mermaid
141
- %%{init: {'theme':'neutral'}}%%
142
- mindmap
143
- root((Alfred))
144
- 일관성
145
- SPEC-First
146
- TDD 강제
147
- 플랑켄슈타인 코드 방지
148
- 품질
149
- TRUST 5원칙
150
- 자동 검증
151
- 85%+ 커버리지
152
- 추적성
153
- @TAG 시스템
154
- SPEC→TEST→CODE→DOC
155
- 완벽한 연결
156
- 범용성
157
- 17개 언어 지원
158
- Python TypeScript Java Go
159
- 모바일 Flutter Swift
160
- ```
161
-
162
- #### 1. 일관성 (Consistency)
163
-
164
- **SPEC → TDD → Sync** 3단계 파이프라인으로 플랑켄슈타인 코드 방지
165
-
166
- #### 2. 품질 (Quality)
167
-
168
- **TRUST 5원칙** 자동 적용 및 검증 (Test First, Readable, Unified, Secured, Trackable)
169
-
170
- #### 3. 추적성 (Traceability)
171
-
172
- **@TAG 시스템**으로 `@SPEC → @TEST → @CODE → @DOC` 완벽 연결
173
-
174
- #### 4. 범용성 (Universality)
175
-
176
- **모든 주요 언어 지원** (Python, TypeScript, Java, Go, Rust, Dart, Swift, Kotlin 등)
177
-
178
- ---
179
-
180
- ## ■ 5분 만에 이해하는 핵심 개념
181
-
182
- ### 1. SPEC-First: 설계도 먼저 그리기
183
-
184
- **비유**: 집을 짓기 전에 설계도를 그리듯이, 코드를 쓰기 전에 SPEC을 작성합니다.
185
-
186
- ```mermaid
187
- %%{init: {'theme':'neutral'}}%%
188
- graph LR
189
- A["SPEC 작성<br/>(설계도)"] --> B["RED<br/>(실패하는 테스트)"]
190
- B --> C["GREEN<br/>(최소 구현)"]
191
- C --> D["REFACTOR<br/>(품질 개선)"]
192
- D --> E["SYNC<br/>(문서화)"]
193
- ```
194
-
195
- #### EARS 구문으로 명세 작성 (실제 예시)
196
-
197
- **EARS (Easy Approach to Requirements Syntax)**: 체계적인 요구사항 작성 방법론
198
-
199
- ```markdown
200
- # @SPEC:AUTH-001: JWT 인증 시스템
201
-
202
- ## Ubiquitous (기본 기능)
203
- - 시스템은 사용자 인증 기능을 제공해야 한다
204
-
205
- ## Event-driven (이벤트 기반)
206
- - WHEN 사용자가 유효한 자격증명으로 로그인하면,
207
- 시스템은 JWT 토큰을 발급해야 한다
208
- - WHEN 토큰이 만료되면,
209
- 시스템은 401 에러를 반환해야 한다
210
-
211
- ## State-driven (상태 기반)
212
- - WHILE 사용자가 인증된 상태일 때,
213
- 시스템은 보호된 리소스 접근을 허용해야 한다
214
-
215
- ## Optional (선택적 기능)
216
- - WHERE 리프레시 토큰이 제공되면,
217
- 시스템은 새로운 액세스 토큰을 발급할 수 있다
218
-
219
- ## Constraints (제약사항)
220
- - IF 잘못된 토큰이 제공되면,
221
- 시스템은 접근을 거부해야 한다
222
- - 액세스 토큰 만료시간은 15분을 초과하지 않아야 한다
223
- ```
224
-
225
- **실습**: Claude Code에서 직접 해보기
226
-
227
- ```bash
228
- /alfred:1-spec "JWT 기반 사용자 로그인 API"
229
- # Alfred가 위 형식으로 SPEC을 자동 생성합니다
230
- ```
231
-
232
- ---
233
-
234
- ### 2. @TAG 추적: 코드와 문서를 실로 엮기
235
-
236
- **비유**: 책의 색인처럼, 모든 코드를 SPEC과 연결합니다.
237
-
238
- ```mermaid
239
- %%{init: {'theme':'neutral'}}%%
240
- graph TD
241
- SPEC["@SPEC:AUTH-001<br/>.moai/specs/SPEC-AUTH-001/spec.md"] --> TEST["@TEST:AUTH-001<br/>tests/test_auth_login.py"]
242
- TEST --> CODE["@CODE:AUTH-001<br/>src/auth/service.py"]
243
- CODE --> DOC["@DOC:AUTH-001<br/>docs/api/auth.md"]
244
- ```
245
-
246
- #### 실제 코드 예시
247
-
248
- ```python
249
- # tests/test_auth_login.py
250
- # @TEST:AUTH-001 | SPEC: SPEC-AUTH-001.md
251
-
252
- def test_login_success():
253
- """사용자가 유효한 자격증명으로 로그인하면 JWT 토큰을 발급해야 한다"""
254
- response = login(username="user@example.com", password="valid_pass")
255
- assert response.status_code == 200
256
- assert "access_token" in response.json()
257
- ```
258
-
259
- ```python
260
- # src/auth/service.py
261
- # @CODE:AUTH-001 | SPEC: SPEC-AUTH-001.md | TEST: tests/test_auth_login.py
262
-
263
- def login(username: str, password: str) -> TokenResponse:
264
- """JWT 토큰 발급 로직"""
265
- if not validate_credentials(username, password):
266
- raise UnauthorizedError()
267
-
268
- token = generate_jwt_token(username)
269
- return TokenResponse(access_token=token)
270
- ```
271
-
272
- #### TAG 검증 실습 (실제로 해볼 수 있는 명령어)
273
-
274
- ```bash
275
- # 1. 모든 TAG 스캔
276
- rg '@(SPEC|TEST|CODE|DOC):' -n .moai/specs/ tests/ src/ docs/
277
-
278
- # 2. 특정 도메인 TAG 확인
279
- rg '@SPEC:AUTH' -n .moai/specs/
280
-
281
- # 3. 고아 TAG 탐지 (CODE는 있는데 SPEC이 없는 경우)
282
- rg '@CODE:AUTH-001' -n src/ # CODE 있음
283
- rg '@SPEC:AUTH-001' -n .moai/specs/ # SPEC 있는지 확인
284
- ```
285
-
286
- ---
287
-
288
- ### 3. TRUST 품질: 5가지 원칙으로 코드 품질 보장
289
-
290
- **비유**: 자동차 안전검사처럼, 코드도 5가지 기준으로 검사합니다.
291
-
292
- ```mermaid
293
- %%{init: {'theme':'neutral'}}%%
294
- mindmap
295
- root((TRUST 5원칙))
296
- Test First
297
- 테스트 커버리지 ≥85%
298
- pytest Vitest JUnit
299
- SPEC 기반 테스트 케이스
300
- Readable
301
- 파일 ≤300 LOC
302
- 함수 ≤50 LOC
303
- 매개변수 ≤5개
304
- 복잡도 ≤10
305
- Unified
306
- 타입 안전성
307
- 아키텍처 일관성
308
- 코딩 스타일 통일
309
- Secured
310
- 입력 검증
311
- 로깅 감사
312
- 비밀 관리
313
- 정적 분석
314
- Trackable
315
- @TAG 체계
316
- CODE-FIRST 스캔
317
- HISTORY 기록
318
- ```
319
-
320
- #### 코드 제약 구체적 예시
321
-
322
- ```python
323
- # ✅ 좋은 예: 함수 ≤50 LOC, 매개변수 ≤5개
324
- def create_user(
325
- username: str,
326
- email: str,
327
- password: str,
328
- role: str = "user",
329
- is_active: bool = True
330
- ) -> User:
331
- """사용자 생성 (40 LOC)"""
332
- # 입력 검증
333
- if not username or len(username) < 3:
334
- raise ValueError("Username must be at least 3 characters")
335
-
336
- if not email or "@" not in email:
337
- raise ValueError("Invalid email address")
338
-
339
- # 비밀번호 해싱
340
- hashed_password = hash_password(password)
341
-
342
- # 사용자 생성
343
- user = User(
344
- username=username,
345
- email=email,
346
- password=hashed_password,
347
- role=role,
348
- is_active=is_active
349
- )
350
-
351
- # DB 저장
352
- db.session.add(user)
353
- db.session.commit()
354
-
355
- return user
356
-
357
-
358
- # ❌ 나쁜 예: 함수 > 50 LOC, 매개변수 > 5개
359
- def create_user_with_profile_and_settings_and_notifications(
360
- username, email, password, role, is_active, profile_data,
361
- settings_data, notification_preferences, theme, language
362
- ):
363
- """100 LOC 넘는 거대 함수..."""
364
- # ... 너무 많은 책임 ...
365
- ```
366
-
367
- ---
368
-
369
- ## ■ Quick Start (3분 실전)
370
-
371
- ### ▶ 준비물
372
-
373
- - ✅ Python 3.13+
374
- - ✅ **uv** (필수 - pip보다 10-100배 빠름)
375
- - ✅ Claude Code 실행 중
376
- - ✅ Git 설치 (선택사항)
377
-
378
- ### ▶ 3단계로 시작하기
379
-
380
- #### 1. uv 설치 (필수)
381
-
382
- **uv는 pip보다 10-100배 빠른 Python 패키지 관리자입니다** (Rust 기반).
383
-
384
- ```bash
385
- # macOS/Linux
386
- curl -LsSf https://astral.sh/uv/install.sh | sh
387
-
388
- # Windows (PowerShell)
389
- powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
390
-
391
- # 설치 확인
392
- uv --version
393
- ```
394
-
395
- #### 2. moai-adk 설치 (10초)
396
-
397
- ```bash
398
- # 권장: uv tool 모드 (샌드박스 격리, 전역 접근)
399
- uv tool install moai-adk
400
-
401
- # 대안: 현재 가상 환경에 설치
402
- uv pip install moai-adk
403
-
404
- # 설치 확인
405
- moai-adk --version
406
- ```
407
-
408
- #### 3. 프로젝트 시작 (1분)
409
-
410
- **새 프로젝트:**
411
-
412
- ```bash
413
- moai-adk init my-project
414
- cd my-project
415
- claude
416
- ```
417
-
418
- **기존 프로젝트:**
419
-
420
- ```bash
421
- cd existing-project
422
- moai-adk init .
423
- claude
424
- ```
425
-
426
- **Claude Code에서 초기화:**
427
-
428
- ```text
429
- /alfred:0-project
430
- ```
431
-
432
- **첫 기능 개발:**
433
-
434
- ```text
435
- /alfred:1-spec "사용자 인증 기능"
436
- /alfred:2-build AUTH-001
437
- /alfred:3-sync
438
- ```
439
-
440
- ### ▶ 완료!
441
-
442
- **생성된 것들:**
443
-
444
- - ✅ `.moai/specs/SPEC-AUTH-001/spec.md` (명세)
445
- - ✅ `tests/test_auth_login.py` (테스트)
446
- - ✅ `src/auth/service.py` (구현)
447
- - ✅ `docs/api/auth.md` (문서)
448
- - ✅ `@SPEC → @TEST → @CODE → @DOC` TAG 체인
449
-
450
- ---
451
-
452
- ## ■ 첫 번째 프로젝트: Todo API 만들기
453
-
454
- ### Step 1: SPEC 작성 (5분)
455
-
456
- **Alfred에게 요청**:
457
-
458
- ```bash
459
- /alfred:1-spec "할 일 추가, 조회, 수정, 삭제 API"
460
- ```
461
-
462
- **Alfred가 생성하는 것**:
463
-
464
- - `.moai/specs/SPEC-TODO-001/spec.md` (EARS 구문)
465
- - `.moai/specs/SPEC-TODO-001/plan.md` (구현 계획)
466
- - `feature/SPEC-TODO-001` 브랜치 (Team 모드)
467
- - Draft PR (Team 모드)
468
-
469
- **생성된 SPEC 예시**:
470
-
471
- ```yaml
472
- ---
473
- id: TODO-001
474
- version: 0.0.1
475
- status: draft
476
- created: 2025-10-17
477
- updated: 2025-10-17
478
- author: @Goos
479
- priority: high
480
- ---
481
-
482
- # @SPEC:TODO-001: Todo API
483
-
484
- ## Ubiquitous
485
- - 시스템은 할 일 CRUD 기능을 제공해야 한다
486
-
487
- ## Event-driven
488
- - WHEN 사용자가 새 할 일을 생성하면, 시스템은 고유 ID를 부여해야 한다
489
- - WHEN 사용자가 할 일을 완료 처리하면, 시스템은 completed_at 타임스탬프를 기록해야 한다
490
-
491
- ## Constraints
492
- - 할 일 제목은 1-200자여야 한다
493
- - 할 일은 작성자만 수정/삭제할 수 있어야 한다
494
- ```
495
-
496
- ---
497
-
498
- ### Step 2: TDD 구현 (10분)
499
-
500
- **Alfred에게 요청**:
501
-
502
- ```bash
503
- /alfred:2-build TODO-001
504
- ```
505
-
506
- **Alfred의 3단계 TDD 프로세스**:
507
-
508
- ```mermaid
509
- %%{init: {'theme':'neutral'}}%%
510
- stateDiagram-v2
511
- [*] --> Phase1: SPEC 분석
512
- Phase1 --> Phase2: 계획 수립
513
-
514
- Phase2 --> RED: TDD 시작
515
- RED --> GREEN: 테스트 통과
516
- GREEN --> REFACTOR: 품질 개선
517
-
518
- REFACTOR --> Phase3: 품질 검증
519
- Phase3 --> [*]: 완료
520
-
521
- note right of RED
522
- RED
523
- - 실패하는 테스트 작성
524
- - @TEST:TODO-001 TAG 추가
525
- end note
526
-
527
- note right of GREEN
528
- GREEN
529
- - 최소 구현으로 테스트 통과
530
- - @CODE:TODO-001 TAG 추가
531
- end note
532
-
533
- note right of REFACTOR
534
- REFACTOR
535
- - 코드 품질 개선
536
- - 중복 제거, 가독성 향상
537
- end note
538
-
539
- note right of Phase3
540
- 품질 게이트
541
- - TRUST 5원칙 검증
542
- - 테스트 커버리지 확인
543
- end note
544
- ```
545
-
546
- **생성된 파일들**:
547
-
548
- ```text
549
- tests/test_todo_api.py # @TEST:TODO-001
550
- src/todo/service.py # @CODE:TODO-001:DOMAIN
551
- src/todo/models.py # @CODE:TODO-001:DATA
552
- src/todo/routes.py # @CODE:TODO-001:API
553
- ```
554
-
555
- ---
556
-
557
- ### Step 3: 문서 동기화 (2분)
558
-
559
- **Alfred에게 요청**:
560
-
561
- ```bash
562
- /alfred:3-sync
563
- ```
564
-
565
- **Alfred가 자동 수행**:
566
-
567
- 1. **품질 검증** (Haiku 에이전트)
568
- - TRUST 5원칙 준수 확인
569
- - TAG 체인 무결성 검증
570
-
571
- 2. **문서 동기화** (Haiku 에이전트)
572
- - API 문서 자동 생성 (`docs/api/todo.md`)
573
- - @DOC:TODO-001 TAG 추가
574
-
575
- 3. **PR 준비** (Team 모드)
576
- - Draft → Ready 전환
577
- - CI/CD 확인
578
- - (선택) `--auto-merge`로 자동 병합
579
-
580
- **생성된 문서**:
581
-
582
- ```markdown
583
- # @DOC:TODO-001: Todo API
584
-
585
- ## API Endpoints
586
-
587
- ### POST /api/todos
588
-
589
- 할 일 생성
590
-
591
- **Request**:
592
-
593
- ```json
594
- {
595
- "title": "장보기",
596
- "description": "우유, 빵"
597
- }
598
- ```
599
-
600
- **Response**:
601
-
602
- ```json
603
- {
604
- "id": "uuid-123",
605
- "title": "장보기",
606
- "completed": false,
607
- "created_at": "2025-10-17T10:00:00Z"
608
- }
609
- ```
610
-
611
- ---
612
-
613
- ### ▶ 완료! 15분 만에 Todo API 완성
614
-
615
- **생성된 것들**:
616
-
617
- - ✅ `.moai/specs/SPEC-TODO-001/` (명세, 계획, 수락 기준)
618
- - ✅ `tests/test_todo_api.py` (테스트 - 커버리지 87%)
619
- - ✅ `src/todo/` (구현 - 3개 파일, 총 180 LOC)
620
- - ✅ `docs/api/todo.md` (API 문서)
621
- - ✅ `@SPEC → @TEST → @CODE → @DOC` TAG 체인
622
-
623
- **검증 명령어**:
624
-
625
- ```bash
626
- # TAG 체인 확인
627
- rg '@(SPEC|TEST|CODE|DOC):TODO-001' -n
628
-
629
- # 테스트 실행
630
- pytest tests/test_todo_api.py -v
631
-
632
- # API 문서 확인
633
- cat docs/api/todo.md
634
- ```
635
-
636
- ---
637
-
638
- ## ■ 3단계 워크플로우
639
-
640
- Alfred의 핵심은 **체계적인 3단계 워크플로우**입니다.
641
-
642
- ```mermaid
643
- %%{init: {'theme':'neutral'}}%%
644
- graph TD
645
- Start([사용자 요청]) --> Spec[1. SPEC 작성<br/>/alfred:1-spec]
646
- Spec --> Build[2. TDD 구현<br/>/alfred:2-build]
647
- Build --> Sync[3. 문서 동기화<br/>/alfred:3-sync]
648
- Sync --> End([완료])
649
- Sync -.-> Spec
650
- ```
651
-
652
- ### 1. SPEC - 명세 작성
653
-
654
- **명령어**: `/alfred:1-spec "JWT 기반 사용자 로그인 API"`
655
-
656
- **Alfred가 자동 수행:**
657
-
658
- - EARS 형식 명세 자동 생성
659
- - `@SPEC:ID` TAG 부여
660
- - Git 브랜치 자동 생성 (Team 모드)
661
- - Draft PR 생성 (Team 모드)
662
- - HISTORY 섹션 자동 추가
663
-
664
- **산출물:**
665
-
666
- - `.moai/specs/SPEC-AUTH-001/spec.md`
667
- - `.moai/specs/SPEC-AUTH-001/plan.md`
668
- - `.moai/specs/SPEC-AUTH-001/acceptance.md`
669
-
670
- ### 2. BUILD - TDD 구현
671
-
672
- **명령어**: `/alfred:2-build AUTH-001`
673
-
674
- **Alfred가 자동 수행 (3개 에이전트 협업):**
675
-
676
- - **Phase 1 (implementation-planner)**: SPEC 분석, 라이브러리 선정, TAG 체인 설계
677
- - **Phase 2 (tdd-implementer)**: RED → GREEN → REFACTOR TDD 사이클
678
- - **RED**: 실패하는 테스트 작성 (@TEST:ID)
679
- - **GREEN**: 최소 구현으로 테스트 통과 (@CODE:ID)
680
- - **REFACTOR**: 코드 품질 개선
681
- - **Phase 3 (quality-gate)**: TRUST 5원칙 자동 검증 (Pass/Warning/Critical)
682
- - **Phase 4 (git-manager)**: 단계별 Git 커밋 (TDD 완료 시 1회)
683
-
684
- **산출물:**
685
-
686
- - `tests/test_auth_login.py` (테스트 코드)
687
- - `src/auth/service.py` (구현 코드)
688
- - `@TEST:AUTH-001` → `@CODE:AUTH-001` TAG 체인
689
- - 품질 검증 리포트
690
-
691
- ### 3. SYNC - 문서 동기화
692
-
693
- **명령어**: `/alfred:3-sync`
694
-
695
- **Alfred가 자동 수행:**
696
-
697
- - **Phase 1 (quality-gate)**: 동기화 전 빠른 품질 검증 (조건부, 변경 라인 >50줄)
698
- - **Phase 2 (doc-syncer)**: Living Document 업데이트
699
- - **Phase 3 (tag-agent)**: TAG 시스템 무결성 검증
700
- - **Phase 4 (git-manager)**: sync-report.md 생성, PR Ready 전환 (Team 모드)
701
- - **선택적 자동 머지** (`--auto-merge`): CI/CD 확인 후 자동 병합
702
-
703
- **산출물:**
704
-
705
- - `docs/api/auth.md` (API 문서)
706
- - `.moai/reports/sync-report.md`
707
- - `@DOC:AUTH-001` TAG 추가
708
-
709
- ---
710
-
711
- ## ■ 실전 시나리오
712
-
713
- ### 시나리오 1: 긴급 버그 수정 (Hotfix)
714
-
715
- **상황**: 프로덕션에서 로그인 에러 발생!
716
-
717
- ```bash
718
- # 옵션 1: 표준 방식 (권장)
719
- git checkout develop
720
- git checkout -b hotfix/auth-error
721
- # ... 수정 ...
722
- git push origin hotfix/auth-error
723
- # PR 생성: hotfix -> develop -> main
724
-
725
- # 옵션 2: 직접 main 수정 (허용, 하지만 권장 안 함)
726
- git checkout main
727
- # ... 수정 ...
728
- git commit -m "Fix critical auth bug"
729
- git push origin main # ⚠️ Advisory 경고 표시되지만 진행됨
730
- ```
731
-
732
- **Alfred의 Advisory 경고**:
733
-
734
- ```text
735
- ⚠️ ADVISORY: Non-standard GitFlow detected
736
-
737
- Current branch: hotfix/auth-error
738
- Target branch: main
739
-
740
- Recommended GitFlow workflow:
741
- 1. Push to hotfix and create PR to develop
742
- 2. Merge into develop after code review
743
- 3. When develop is stable, create PR from develop to main
744
- 4. Release manager merges develop -> main with tag
745
-
746
- ✓ Push will proceed (flexibility mode enabled)
747
- ```
748
-
749
- ---
750
-
751
- ### 시나리오 2: 새 기능 개발 (Feature)
752
-
753
- ```bash
754
- # 1. develop에서 최신 코드 받기
755
- git checkout develop
756
- git pull origin develop
757
-
758
- # 2. Claude Code에서 SPEC 작성
759
- /alfred:1-spec "사용자 프로필 이미지 업로드"
760
- # → feature/SPEC-PROFILE-001 브랜치 자동 생성
761
- # → Draft PR 자동 생성 (feature → develop)
762
-
763
- # 3. TDD 구현
764
- /alfred:2-build PROFILE-001
765
-
766
- # 4. 문서 동기화 + 자동 머지
767
- /alfred:3-sync --auto-merge
768
- # → 문서 동기화
769
- # → PR Ready 전환
770
- # → CI/CD 확인
771
- # → PR 자동 머지 (squash)
772
- # → develop 체크아웃
773
- # → 다음 작업 준비 완료 ✅
774
- ```
775
-
776
- ---
777
-
778
- ## ■ AI 모델 선택 가이드
779
-
780
- MoAI-ADK는 **Haiku 4.5**와 **Sonnet 4.5** 두 가지 AI 모델을 전략적으로 활용하여 **최적의 성능과 비용 효율**을 제공합니다.
781
-
782
- ### 패스트 모드 vs 스마트 모드
783
-
784
- Claude Code에서 `/model` 명령어로 전체 세션의 기본 모델을 변경할 수 있습니다:
785
-
786
- ```text
787
- # 패스트 모드 (빠른 응답, 반복 작업)
788
- /model haiku
789
-
790
- # 스마트 모드 (복잡한 판단, 설계)
791
- /model sonnet
792
- ```
793
-
794
- ### 12개 에이전트의 모델 배치 전략
795
-
796
- Alfred는 **작업 특성**에 따라 각 에이전트에 최적 모델을 할당합니다:
797
-
798
- #### ▶ Haiku 에이전트 (6개) - 패스트 모드
799
-
800
- **빠른 응답이 필요한 반복 작업 및 패턴 매칭**
801
-
802
- | 에이전트 | 역할 | 왜 Haiku? |
803
- | ------------------- | --------------- | -------------------------------------------- |
804
- | **doc-syncer** 📖 | 문서 동기화 | 패턴화된 문서 업데이트, Living Document 생성 |
805
- | **tag-agent** 🏷️ | TAG 시스템 관리 | 반복적 패턴 매칭, TAG 체인 검증 |
806
- | **git-manager** 🚀 | Git 워크플로우 | 정형화된 Git 명령어 실행, 브랜치/PR 생성 |
807
- | **trust-checker** ✅ | TRUST 원칙 검증 | 규칙 기반 체크리스트 확인 |
808
- | **quality-gate** 🛡️ | 품질 검증 | TRUST 원칙 자동 검증, 빠른 품질 게이트 |
809
- | **Explore** 🔍 | 코드베이스 탐색 | 대량 파일 스캔, 키워드 검색 |
810
-
811
- **장점**:
812
-
813
- - **속도 2~5배 향상**: 실시간 응답 (수 초 → 1초 이내)
814
- - **비용 67% 절감**: 반복 작업이 많은 프로젝트에 효과적
815
- - **높은 정확도**: 패턴화된 작업에서 Sonnet과 동등한 품질
816
-
817
- #### ▶ Sonnet 에이전트 (6개) - 스마트 모드
818
-
819
- **복잡한 판단과 창의적 설계가 필요한 작업**
820
-
821
- | 에이전트 | 역할 | 왜 Sonnet? |
822
- | ---------------------------- | ---------------- | ------------------------------------ |
823
- | **spec-builder** 🏗️ | SPEC 작성 | EARS 구조 설계, 복잡한 요구사항 분석 |
824
- | **implementation-planner** 📋 | 구현 전략 수립 | 아키텍처 설계, 라이브러리 선정 |
825
- | **tdd-implementer** 🔬 | TDD 구현 | RED-GREEN-REFACTOR, 복잡한 리팩토링 |
826
- | **debug-helper** 🔍 | 디버깅 | 런타임 오류 분석, 해결 방법 도출 |
827
- | **cc-manager** 🛠️ | Claude Code 설정 | 워크플로우 최적화, 복잡한 설정 |
828
- | **project-manager** 📂 | 프로젝트 초기화 | 전략 수립, 복잡한 의사결정 |
829
-
830
- **장점**:
831
-
832
- - **높은 품질**: 복잡한 코드 품질 보장
833
- - **깊은 이해**: 맥락 파악 및 창의적 해결책 제시
834
- - **정확한 판단**: 아키텍처 결정, 설계 선택
835
-
836
- ### 사용 시나리오별 권장 모델
837
-
838
- | 시나리오 | 권장 모델 | 이유 |
839
- | ------------------ | --------- | ----------------------------- |
840
- | **새 프로젝트 시작** | Sonnet | SPEC 설계, 아키텍처 결정 필요 |
841
- | **반복 개발** | Haiku | 이미 정해진 패턴 반복 구현 |
842
- | **버그 수정** | Sonnet | 원인 분석 및 해결 방법 도출 |
843
- | **문서 작성** | Haiku | Living Document 동기화 |
844
- | **코드 탐색** | Haiku | 파일 검색, TAG 조회 |
845
- | **리팩토링** | Sonnet | 구조 개선, 복잡한 변경 |
846
-
847
- ### 모델 전환 팁
848
-
849
- ```text
850
- # 새 기능 설계 시작
851
- /model sonnet
852
- /alfred:1-spec "사용자 인증 시스템"
853
-
854
- # SPEC 승인 후 TDD 구현
855
- /alfred:2-build AUTH-001
856
-
857
- # 구현 완료 후 문서 동기화 (자동으로 Haiku 사용)
858
- /alfred:3-sync
859
-
860
- # 다음 기능 설계
861
- /model sonnet
862
- /alfred:1-spec "결제 시스템"
863
- ```
864
-
865
- **Pro Tip**: Alfred는 각 에이전트를 호출할 때 자동으로 최적 모델을 사용하므로, **세션 전체 모델 변경은 선택사항**입니다. 기본 설정(Sonnet)으로도 충분히 효율적입니다.
866
-
867
- ---
868
-
869
- ## ■ CLI Reference
870
-
871
- ### 프로젝트 관리
872
-
873
- ```bash
874
- # 새 프로젝트 생성
875
- moai-adk init project-name
876
-
877
- # 기존 프로젝트에 설치
878
- moai-adk init .
879
-
880
- # 프로젝트 상태 확인
881
- moai-adk status
882
-
883
- # 프로젝트 업데이트
884
- moai-adk update
885
-
886
- # 시스템 진단
887
- moai-adk doctor
888
-
889
- # 버전 확인
890
- moai-adk --version
891
-
892
- # 도움말
893
- moai-adk --help
894
- ```
895
-
896
- ### Alfred 커맨드 (Claude Code 내)
897
-
898
- #### 기본 커맨드
899
-
900
- ```text
901
- # 프로젝트 초기화
902
- /alfred:0-project
903
-
904
- # SPEC 작성
905
- /alfred:1-spec "기능 설명"
906
- /alfred:1-spec SPEC-001 "수정 내용"
907
-
908
- # TDD 구현
909
- /alfred:2-build SPEC-001
910
- /alfred:2-build all
911
-
912
- # 문서 동기화
913
- /alfred:3-sync
914
- /alfred:3-sync --auto-merge
915
- /alfred:3-sync force
916
- ```
917
-
918
- #### 커맨드별 에이전트 & 모델 매핑
919
-
920
- 각 Alfred 커맨드는 적절한 에이전트를 호출하며, **자동으로 최적 모델**을 사용합니다:
921
-
922
- | 커맨드 | 에이전트 (Phase) | 모델 | 작업 특성 | 예상 시간 |
923
- | ------------------- | ------------------------------------------------------------- | -------------------------- | ---------------------------------------- | --------- |
924
- | `/alfred:0-project` | project-manager 📂 | 세션 기본 모델 | 프로젝트 전략 수립, 복잡한 의사결정 | 1~2분 |
925
- | `/alfred:1-spec` | spec-builder 🏗️ | 세션 기본 모델 | EARS 명세 설계, 요구사항 분석 | 2~3분 |
926
- | `/alfred:2-build` | implementation-planner 📋 → tdd-implementer 🔬 → quality-gate 🛡️ | 세션 기본 모델 + **Haiku** | SPEC 분석 → TDD 구현 → 품질 검증 (3단계) | 3~5분 |
927
- | `/alfred:3-sync` | quality-gate 🛡️ → doc-syncer 📖 → tag-agent 🏷️ | **Haiku 지정** | 사전 검증 → 문서 동기화 → TAG 검증 | 30초~1분 |
928
-
929
- #### 온디맨드 에이전트 호출
930
-
931
- 특정 에이전트를 직접 호출할 수도 있습니다:
932
-
933
- ```text
934
- # Haiku 에이전트 (빠른 작업)
935
- @agent-tag-agent "AUTH 도메인 TAG 목록 조회"
936
- @agent-git-manager "브랜치 생성 및 PR 생성"
937
- @agent-trust-checker "TRUST 원칙 준수 여부 확인"
938
- @agent-quality-gate "코드 품질 검증 실행"
939
- @agent-Explore "JWT 인증 관련 코드 위치 탐색"
940
-
941
- # Sonnet 에이전트 (복잡한 작업)
942
- @agent-spec-builder "SPEC-AUTH-001 메타데이터 검증"
943
- @agent-implementation-planner "AUTH-001 구현 계획 수립"
944
- @agent-tdd-implementer "AUTH-001 TDD 구현 실행"
945
- @agent-debug-helper "TypeError 런타임 오류 원인 분석"
946
- @agent-cc-manager "Claude Code 설정 최적화"
947
- ```
948
-
949
- #### 모델별 성능 비교
950
-
951
- | 작업 유형 | Haiku (패스트) | Sonnet (스마트) | 실제 적용 |
952
- | --------------- | -------------- | --------------- | -------------------------- |
953
- | **SPEC 작성** | 1분 | 2~3분 | 세션 기본 모델 사용 |
954
- | **TDD 구현** | 2분 | 3~5분 | 세션 기본 모델 사용 |
955
- | **문서 동기화** | 30초 | 1~2분 | ✅ Haiku 지정 (3-sync) |
956
- | **TAG 검증** | 10초 | 30초 | ✅ Haiku 지정 (tag-agent) |
957
- | **Git 작업** | 5초 | 15초 | ✅ Haiku 지정 (git-manager) |
958
- | **디버깅** | 1분 | 2~3분 | 세션 기본 모델 사용 |
959
-
960
- **핵심 설계**:
961
-
962
- - `/alfred:0-project`, `/alfred:1-spec`, `/alfred:2-build`: **사용자가 선택한 세션 기본 모델** 사용
963
- - `/model sonnet` (기본값): 높은 품질, 복잡한 판단
964
- - `/model haiku`: 빠른 속도, 반복 작업
965
- - `/alfred:3-sync` 및 Haiku 에이전트: **자동으로 Haiku 모델** 사용 (패턴화된 작업)
966
-
967
- **사용자 제어**: `/model` 명령어로 0~2번 커맨드의 품질과 속도를 자유롭게 조절할 수 있습니다.
968
-
969
- ---
970
-
971
- ## ■ Alfred's Output Styles
972
-
973
- Alfred는 작업 특성과 사용자 경험 수준에 따라 **3가지 출력 스타일**을 제공합니다. Claude Code에서 `/output-style` 명령어로 언제든지 전환할 수 있습니다.
974
-
975
- ### 3가지 표준 스타일
976
-
977
- #### 1. Agentic Coding (기본값)
978
-
979
- **대상**: 실무 개발자, 팀 리더, 아키텍트
980
-
981
- Alfred SuperAgent가 11개 전문 에이전트를 조율하여 빠른 개발과 협업을 자동으로 전환하는 통합 코딩 모드입니다.
982
-
983
- **두 가지 작업 방식**:
984
-
985
- - **Fast Mode (기본)**: 빠른 개발, 구현 위주 작업
986
- - SPEC → TDD → SYNC 자동화
987
- - 간결한 기술 커뮤니케이션
988
- - 최소 설명, 최대 효율
989
- - TRUST 5원칙 자동 검증
990
- - **Collab Mode (자동 전환)**: "협업", "브레인스토밍", "설계", "리뷰" 키워드 감지 시
991
- - 질문 기반 대화
992
- - 트레이드오프 분석
993
- - 아키텍처 다이어그램 제공
994
- - 실시간 코드 리뷰
995
-
996
- **핵심 원칙**:
997
-
998
- - SPEC 우선: 모든 작업은 @SPEC:ID부터 시작
999
- - TAG 무결성: `rg` 스캔 기반 실시간 검증
1000
- - TRUST 준수: 5원칙 자동 검증 및 품질 게이트
1001
- - 다중 언어: 17개 언어 지원 (Python, TypeScript, JavaScript, Java, Go, Rust, Dart, Swift, Kotlin, PHP, Ruby, C++, C, C#, Haskell, Shell, Lua)
1002
-
1003
- **사용**:
1004
-
1005
- ```text
1006
- /output-style agentic-coding
1007
- ```
1008
-
1009
- ---
1010
-
1011
- #### 2. MoAI ADK Learning
1012
-
1013
- **대상**: MoAI-ADK를 처음 사용하는 개발자
1014
-
1015
- MoAI-ADK의 핵심 개념과 3단계 워크플로우를 친절하게 설명하여 빠르게 익힐 수 있도록 돕는 학습 모드입니다.
1016
-
1017
- **핵심 철학**: "명세 없으면 코드 없다, 테스트 없으면 구현 없다"
1018
-
1019
- **3가지 핵심 개념**:
1020
-
1021
- 1. **SPEC-First**: 코드 작성 전 명세를 먼저 작성
1022
- - EARS 구문 (5가지 패턴)으로 요구사항 작성
1023
- - Ubiquitous, Event-driven, State-driven, Optional, Constraints
1024
- 2. **@TAG 추적성**: 모든 코드를 SPEC과 연결
1025
- - `@SPEC → @TEST → @CODE → @DOC` 체계
1026
- - CODE-FIRST 원칙 (코드 직접 스캔)
1027
- 3. **TRUST 품질**: 5가지 원칙으로 코드 품질 보장
1028
- - Test First, Readable, Unified, Secured, Trackable
1029
-
1030
- **학습 내용**:
1031
-
1032
- - 각 개념을 실생활 비유로 쉽게 설명
1033
- - 3단계 워크플로우 단계별 학습
1034
- - 실제 예시로 SPEC 작성 연습
1035
- - FAQ로 자주 묻는 질문 해결
1036
-
1037
- **사용**:
1038
-
1039
- ```text
1040
- /output-style moai-adk-learning
1041
- ```
1042
-
1043
- ---
1044
-
1045
- #### 3. Study with Alfred
1046
-
1047
- **대상**: 새로운 기술/언어/프레임워크를 배우려는 개발자
1048
-
1049
- Alfred가 함께 배우는 친구처럼 새로운 기술을 쉽게 설명하고, 실습을 도와주는 학습 모드입니다.
1050
-
1051
- **학습 4단계**:
1052
-
1053
- 1. **What (이게 뭐야?)** → 기본 개념 이해
1054
- - 한 줄 요약
1055
- - 실생활 비유
1056
- - 핵심 개념 3가지
1057
-
1058
- 2. **Why (왜 필요해?)** → 사용 이유와 장점
1059
- - 문제 상황
1060
- - 해결 방법
1061
- - 실제 사용 사례
1062
-
1063
- 3. **How (어떻게 써?)** → 실습 중심 학습
1064
- - 최소 예제 (Hello World)
1065
- - 실용적 예제 (CRUD API)
1066
- - 자주 묻는 질문
1067
-
1068
- 4. **Practice (실전 적용)** → MoAI-ADK와 통합
1069
- - SPEC → TEST → CODE 흐름으로 실습
1070
- - Alfred가 단계별 안내
1071
- - 완성된 코드 품질 검증
1072
-
1073
- **특징**:
1074
-
1075
- - 복잡한 개념을 쉽게 풀어서 설명
1076
- - 실생활 비유로 이해도 향상
1077
- - 단계별로 함께 실습
1078
- - 자주 묻는 질문에 답변
1079
-
1080
- **사용**:
1081
-
1082
- ```text
1083
- /output-style study-with-alfred
1084
- ```
1085
-
1086
- ---
1087
-
1088
- ### 스타일 전환 가이드
1089
-
1090
- **언제 전환할까요?**
1091
-
1092
- | 상황 | 권장 스타일 | 이유 |
1093
- | ------------------- | ----------------------- | -------------------------------- |
1094
- | **실무 개발** | Agentic Coding | Fast/Collab 자동 전환, 효율 중심 |
1095
- | **MoAI-ADK 학습** | MoAI ADK Learning | SPEC-First, TAG, TRUST 개념 이해 |
1096
- | **새 기술 학습** | Study with Alfred | What-Why-How-Practice 4단계 |
1097
- | **반복 작업** | Agentic Coding (Fast) | 최소 설명, 빠른 실행 |
1098
- | **팀 협업** | Agentic Coding (Collab) | 트레이드오프 분석, 브레인스토밍 |
1099
-
1100
- **스타일 전환 예시**:
1101
-
1102
- ```text
1103
- # MoAI-ADK 처음 시작 시
1104
- /output-style moai-adk-learning
1105
-
1106
- # 새로운 프레임워크 배울 때
1107
- /output-style study-with-alfred
1108
- "FastAPI를 배우고 싶어요"
1109
-
1110
- # 실무 개발 시작
1111
- /output-style agentic-coding
1112
- /alfred:1-spec "사용자 인증 시스템"
1113
- ```
1114
-
1115
- ---
1116
-
1117
- ## ■ Universal Language Support
1118
-
1119
- Alfred는 **17개 주요 프로그래밍 언어**를 지원하며, 각 언어에 최적화된 도구 체인을 자동으로 선택합니다.
1120
-
1121
- ### 지원 언어 & 도구 (17개 언어)
1122
-
1123
- #### 백엔드 & 시스템 (8개)
1124
-
1125
- | 언어 | 테스트 프레임워크 | 린터/포매터 | 빌드 도구 | 타입 시스템 |
1126
- | -------------- | ----------------- | --------------- | -------------- | ----------- |
1127
- | **Python** | pytest | ruff, black | uv, pip | mypy |
1128
- | **TypeScript** | Vitest, Jest | Biome, ESLint | npm, pnpm, bun | Built-in |
1129
- | **Java** | JUnit | Checkstyle | Maven, Gradle | Built-in |
1130
- | **Go** | go test | gofmt, golint | go build | Built-in |
1131
- | **Rust** | cargo test | rustfmt, clippy | cargo | Built-in |
1132
- | **Kotlin** | JUnit | ktlint | Gradle | Built-in |
1133
- | **PHP** | PHPUnit | PHP CS Fixer | Composer | PHPStan |
1134
- | **Ruby** | RSpec | RuboCop | Bundler | Sorbet |
1135
-
1136
- #### 모바일 & 프론트엔드 (3개)
1137
-
1138
- | 언어/프레임워크 | 테스트 프레임워크 | 린터/포매터 | 빌드 도구 | 플랫폼 |
1139
- | ------------------ | ----------------- | ---------------- | ------------- | ----------------- |
1140
- | **Dart (Flutter)** | flutter test | dart analyze | flutter | iOS, Android, Web |
1141
- | **Swift** | XCTest | SwiftLint | xcodebuild | iOS, macOS |
1142
- | **JavaScript** | Jest, Vitest | ESLint, Prettier | webpack, Vite | Web, Node.js |
1143
-
1144
- #### 시스템 & 스크립트 (6개)
1145
-
1146
- | 언어 | 테스트 프레임워크 | 린터/포매터 | 빌드 도구 | 특징 |
1147
- | ----------- | ----------------- | --------------- | --------------- | ----------------- |
1148
- | **C++** | Google Test | clang-format | CMake | 고성능 시스템 |
1149
- | **C** | CUnit | clang-format | Make, CMake | 임베디드, 시스템 |
1150
- | **C#** | NUnit, xUnit | StyleCop | MSBuild, dotnet | .NET 생태계 |
1151
- | **Haskell** | HUnit | stylish-haskell | Cabal, Stack | 함수형 프로그래밍 |
1152
- | **Shell** | Bats | shellcheck | - | 자동화 스크립트 |
1153
- | **Lua** | busted | luacheck | - | 임베디드 스크립팅 |
1154
-
1155
- ### 자동 언어 감지
1156
-
1157
- Alfred는 프로젝트 루트의 설정 파일을 자동으로 감지하여 언어와 도구 체인을 선택합니다:
1158
-
1159
- | 감지 파일 | 언어 | 추가 감지 |
1160
- | ------------------------------------ | ------------ | ------------------------------------- |
1161
- | `pyproject.toml`, `requirements.txt` | Python | `setup.py`, `poetry.lock` |
1162
- | `package.json` + `tsconfig.json` | TypeScript | `yarn.lock`, `pnpm-lock.yaml` |
1163
- | `package.json` (tsconfig 없음) | JavaScript | `webpack.config.js`, `vite.config.js` |
1164
- | `pom.xml`, `build.gradle` | Java | `settings.gradle`, `build.gradle.kts` |
1165
- | `go.mod` | Go | `go.sum` |
1166
- | `Cargo.toml` | Rust | `Cargo.lock` |
1167
- | `pubspec.yaml` | Dart/Flutter | `flutter/packages/` |
1168
- | `Package.swift` | Swift | `Podfile`, `Cartfile` |
1169
- | `build.gradle.kts` + `kotlin` | Kotlin | `settings.gradle.kts` |
1170
- | `composer.json` | PHP | `composer.lock` |
1171
- | `Gemfile` | Ruby | `Gemfile.lock` |
1172
- | `CMakeLists.txt` | C++ | `conanfile.txt` |
1173
- | `Makefile` | C | `*.c`, `*.h` |
1174
- | `*.csproj` | C# | `*.sln` |
1175
- | `*.cabal` | Haskell | `stack.yaml` |
1176
- | `*.sh` | Shell | `.bashrc`, `.zshrc` |
1177
- | `*.lua` | Lua | `luarocks` |
1178
-
1179
- ### 언어별 TRUST 5원칙 적용
1180
-
1181
- 모든 언어는 동일한 TRUST 5원칙을 따르며, 언어별 최적 도구를 자동 사용합니다:
1182
-
1183
- #### 주요 언어 TRUST 도구
1184
-
1185
- | 원칙 | Python | TypeScript | Java | Go | Rust | Ruby |
1186
- | -------------- | ----------- | ---------------------- | ---------- | -------- | ----------- | -------- |
1187
- | **T**est First | pytest | Vitest/Jest | JUnit | go test | cargo test | RSpec |
1188
- | **R**eadable | ruff, black | Biome, ESLint | Checkstyle | gofmt | rustfmt | RuboCop |
1189
- | **U**nified | mypy | Built-in | Built-in | Built-in | Built-in | Sorbet |
1190
- | **S**ecured | bandit | eslint-plugin-security | SpotBugs | gosec | cargo-audit | Brakeman |
1191
- | **T**rackable | @TAG | @TAG | @TAG | @TAG | @TAG | @TAG |
1192
-
1193
- #### 추가 언어 TRUST 도구
1194
-
1195
- | 원칙 | PHP | C++ | C# |
1196
- | -------------- | ------------ | ------------ | ------------------ |
1197
- | **T**est First | PHPUnit | Google Test | NUnit |
1198
- | **R**eadable | PHP CS Fixer | clang-format | StyleCop |
1199
- | **U**nified | PHPStan | Built-in | Built-in |
1200
- | **S**ecured | RIPS | cppcheck | Security Code Scan |
1201
- | **T**rackable | @TAG | @TAG | @TAG |
1202
-
1203
- **공통 원칙**:
1204
-
1205
- - 모든 언어는 `@TAG 시스템`으로 SPEC→TEST→CODE→DOC 추적성 보장
1206
- - 언어별 표준 도구 체인을 자동 감지 및 적용
1207
- - TRUST 5원칙은 모든 프로젝트에 일관되게 적용
1208
-
1209
- ### 다중 언어 프로젝트 지원
1210
-
1211
- **Monorepo 및 혼합 언어 프로젝트**도 완벽 지원:
1212
-
1213
- ```text
1214
- my-project/
1215
- ├── backend/ # Python (FastAPI)
1216
- │ ├── pyproject.toml
1217
- │ └── src/
1218
- ├── frontend/ # TypeScript (React)
1219
- │ ├── package.json
1220
- │ └── src/
1221
- └── mobile/ # Dart (Flutter)
1222
- ├── pubspec.yaml
1223
- └── lib/
1224
- ```
1225
-
1226
- Alfred는 각 디렉토리의 언어를 자동 감지하고 적절한 도구 체인을 사용합니다.
1227
-
1228
- ---
1229
-
1230
- ## ■ TRUST 5원칙
1231
-
1232
- Alfred가 모든 코드에 자동으로 적용하는 품질 기준입니다.
1233
-
1234
- ### T - Test First (테스트 우선)
1235
-
1236
- - SPEC 기반 테스트 케이스 작성
1237
- - TDD RED → GREEN → REFACTOR 사이클
1238
- - 테스트 커버리지 ≥ 85%
1239
-
1240
- ### R - Readable (가독성)
1241
-
1242
- - 파일 ≤ 300 LOC
1243
- - 함수 ≤ 50 LOC
1244
- - 매개변수 ≤ 5개
1245
- - 복잡도 ≤ 10
1246
-
1247
- ### U - Unified (통일성)
1248
-
1249
- - 타입 안전성 또는 런타임 검증
1250
- - 아키텍처 일관성
1251
- - 코딩 스타일 통일
1252
-
1253
- ### S - Secured (보안)
1254
-
1255
- - 입력 검증
1256
- - 로깅 및 감사
1257
- - 비밀 관리
1258
- - 정적 분석
1259
-
1260
- ### T - Trackable (추적성)
1261
-
1262
- - `@SPEC → @TEST → @CODE → @DOC` TAG 체인
1263
- - CODE-FIRST 원칙 (코드 직접 스캔)
1264
- - HISTORY 섹션 기록
1265
-
1266
- ### 자동 검증
1267
-
1268
- ```text
1269
- # TDD 구현 완료 후 자동 실행
1270
- /alfred:2-build AUTH-001
1271
-
1272
- # 또는 수동 실행
1273
- /alfred:3-sync
1274
-
1275
- # trust-checker 에이전트가 자동으로 검증:
1276
- # ✅ Test Coverage: 87% (목표: 85%)
1277
- # ✅ Code Constraints: 모든 파일 300 LOC 이하
1278
- # ✅ TAG Chain: 무결성 확인 완료
1279
- ```
1280
-
1281
- ---
1282
-
1283
- ## ■ 업그레이드 가이드
1284
-
1285
- ### 1단계: 패키지 업데이트
1286
-
1287
- ```bash
1288
- moai-adk update
1289
-
1290
- # 또는 (tool 모드 - 권장)
1291
- uv tool upgrade moai-adk
1292
-
1293
- # 또는 (pip 모드 - 레거시)
1294
- uv pip install --upgrade moai-adk
1295
- ```
1296
-
1297
- ### 2단계: 프로젝트 업데이트
1298
-
1299
- ```bash
1300
- cd your-project
1301
- moai-adk init .
1302
- ```
1303
-
1304
- **자동 백업**: 업데이트 전 `.moai-backups/{timestamp}/`에 자동 백업 생성
1305
-
1306
- ### 3단계: Claude Code 최적화
1307
-
1308
- ```text
1309
- $ claude
1310
- > /alfred:0-project
1311
- ```
1312
-
1313
- 병합 프롬프트에서 **Merge** 선택 → 기존 문서 유지 + 새 템플릿 추가
1314
-
1315
- ### 검증 체크리스트
1316
-
1317
- ```bash
1318
- # 상태 확인
1319
- moai-adk status
1320
-
1321
- ## 출력 예시:
1322
- ╭────── Project Status ──────╮
1323
- │ Mode team │
1324
- │ Locale ko │
1325
- │ SPECs 23 │
1326
- │ Branch develop │
1327
- │ Git Status Clean │
1328
- ╰────────────────────────────╯
1329
- ```
1330
-
1331
- ```bash
1332
- # 시스템 진단
1333
- moai-adk doctor
1334
-
1335
- ## 출력 예시:
1336
- Running system diagnostics...
1337
- ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┓
1338
- ┃ Check ┃ Status ┃
1339
- ┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━┩
1340
- │ Python >= 3.13 │ ✓ │
1341
- │ Git installed │ ✓ │
1342
- │ Project structure (.moai/) │ ✓ │
1343
- │ Config file (.moai/config.json) │ ✓ │
1344
- └──────────────────────────────────────────┴────────┘
1345
- ```
1346
-
1347
- ---
1348
-
1349
- ## ■ FAQ
1350
-
1351
- ### Q1: MoAI-ADK는 어떤 프로젝트에 적합한가요?
1352
-
1353
- **A**: 다음과 같은 프로젝트에 적합합니다:
1354
-
1355
- - ✅ 새로운 프로젝트 (그린필드)
1356
- - ✅ 기존 프로젝트 (레거시 도입)
1357
- - ✅ 개인 프로젝트 (Personal 모드)
1358
- - ✅ 팀 프로젝트 (Team 모드, GitFlow 지원)
1359
- - ✅ 모든 주요 프로그래밍 언어
1360
-
1361
- ### Q2: Claude Code가 필수인가요?
1362
-
1363
- **A**: 네, MoAI-ADK는 Claude Code 환경에서 동작하도록 설계되었습니다. Claude Code는 Anthropic의 공식 CLI 도구로, AI 에이전트 시스템을 완벽하게 지원합니다.
1364
-
1365
- ### Q3: 기존 프로젝트에 도입할 수 있나요?
1366
-
1367
- **A**: 네, `moai-adk init .` 명령으로 기존 프로젝트에 안전하게 설치할 수 있습니다. Alfred는 기존 코드 구조를 분석하여 `.moai/` 폴더에 문서와 설정만 추가합니다.
1368
-
1369
- ### Q4: Personal 모드와 Team 모드의 차이는?
1370
-
1371
- **A**:
1372
-
1373
- - **Personal 모드**: 로컬 작업 중심, 체크포인트만 생성
1374
- - **Team 모드**: GitFlow 지원, Draft PR 자동 생성, develop 브랜치 기반
1375
-
1376
- ### Q5: SPEC 메타데이터는 어떻게 관리하나요?
1377
-
1378
- **A**: `.moai/memory/spec-metadata.md`에 전체 가이드가 있습니다.
1379
-
1380
- - **필수 7개**: id, version, status, created, updated, author, priority
1381
- - **선택 9개**: category, labels, depends_on, blocks, related_specs, related_issue, scope
1382
- - **HISTORY 섹션**: 모든 변경 이력 기록 (필수)
1383
-
1384
- ### Q6: TDD 단계별로 커밋하나요?
1385
-
1386
- **A**: 아니요, v0.3.0부터 **TDD 전체 사이클(RED→GREEN→REFACTOR) 완료 후 1회만 커밋**합니다. 이전처럼 각 단계별로 3번 커밋하지 않습니다.
1387
-
1388
- ### Q7: Context Engineering이란?
1389
-
1390
- **A**:
1391
-
1392
- - **JIT Retrieval**: 필요한 순간에만 문서 로드 (초기 컨텍스트 최소화)
1393
- - **Explore 에이전트**: 대규모 코드베이스 효율적 탐색
1394
-
1395
- ### Q8: 자동 백업은 어떻게 작동하나요?
1396
-
1397
- **A**:
1398
-
1399
- - **Template Processor**: 업데이트 전 `.moai-backups/alfred-{timestamp}/` 자동 백업
1400
- - **Event-Driven Checkpoint**: 위험한 작업 전 자동 checkpoint 생성
1401
- - **보존 정책**: 최대 10개 유지, 7일 후 자동 정리
1402
-
1403
- ### Q9: /model 명령어를 사용해야 하나요?
1404
-
1405
- **A**: **선택사항**입니다. Alfred는 이미 각 에이전트에 최적 모델을 할당했으므로:
1406
-
1407
- - ✅ **기본 설정 유지** (권장): Alfred가 자동으로 작업별 최적 모델 사용
1408
- - ⚡ **패스트 모드**: `/model haiku` - 반복 작업 시 전체 세션을 Haiku로
1409
- - 🧠 **스마트 모드**: `/model sonnet` - 복잡한 판단이 계속 필요할 때
1410
-
1411
- **Pro Tip**: 기본 설정으로도 Haiku/Sonnet이 혼합 사용되므로 성능과 비용이 이미 최적화되어 있습니다.
1412
-
1413
- ### Q10: Haiku와 Sonnet의 비용 차이는?
1414
-
1415
- **A**:
1416
-
1417
- - **Haiku**: $1 / 1M 입력 토큰, $5 / 1M 출력 토큰
1418
- - **Sonnet**: $3 / 1M 입력 토큰, $15 / 1M 출력 토큰
1419
- - **절감 효과**: Haiku 에이전트 사용 시 **비용 67% 절감**
1420
-
1421
- **예시 (100만 토큰 기준)**:
1422
-
1423
- - 100% Sonnet: $18 (입력 + 출력)
1424
- - MoAI-ADK (혼합): $6~$9 (작업 특성에 따라)
1425
- - **절감액**: $9~$12 (50~67%)
1426
-
1427
- ---
1428
-
1429
- ## ■ 문제 해결
1430
-
1431
- ### 설치 문제
1432
-
1433
- ```bash
1434
- # Python 버전 확인 (3.13+ 필요)
1435
- python --version
1436
-
1437
- # uv 설치 확인
1438
- uv --version
1439
-
1440
- # uv가 없다면 먼저 설치 (필수)
1441
- # macOS/Linux:
1442
- curl -LsSf https://astral.sh/uv/install.sh | sh
1443
-
1444
- # Windows:
1445
- powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
1446
-
1447
- # moai-adk 재설치 (tool 모드 - 권장)
1448
- uv tool uninstall moai-adk
1449
- uv tool install moai-adk
1450
-
1451
- # 또는 (pip 모드 - 레거시)
1452
- uv pip install moai-adk --force-reinstall
1453
- ```
1454
-
1455
- ### 초기화 문제
1456
-
1457
- ```bash
1458
- # 프로젝트 상태 확인
1459
- moai-adk status
1460
- ```
1461
-
1462
- **출력 예시**:
1463
-
1464
- ```text
1465
- ╭────── Project Status ──────╮
1466
- │ Mode team │
1467
- │ Locale ko │
1468
- │ SPECs 23 │
1469
- │ Branch develop │
1470
- │ Git Status Clean │
1471
- ╰────────────────────────────╯
1472
- ```
1473
-
1474
- ```bash
1475
- # 시스템 진단
1476
- moai-adk doctor
1477
- ```
1478
-
1479
- **출력 예시**:
1480
-
1481
- ```text
1482
- Running system diagnostics...
1483
-
1484
- ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┓
1485
- ┃ Check ┃ Status ┃
1486
- ┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━┩
1487
- │ Python >= 3.13 │ ✓ │
1488
- │ Git installed │ ✓ │
1489
- │ Project structure (.moai/) │ ✓ │
1490
- │ Config file (.moai/config.json) │ ✓ │
1491
- └──────────────────────────────────────────┴────────┘
1492
- ```
1493
-
1494
- ```bash
1495
- # 강제 재초기화 (문제가 있을 경우)
1496
- moai-adk init . --force
1497
- ```
1498
-
1499
- ### Claude Code 문제
1500
-
1501
- ```text
1502
- # 설정 확인
1503
- ls -la .claude/
1504
-
1505
- # Alfred 커맨드 확인
1506
- ls -la .claude/commands/alfred/
1507
-
1508
- # 출력 스타일 확인
1509
- /output-style agentic-coding
1510
- ```
1511
-
1512
- ### 일반적인 에러
1513
-
1514
- #### 에러: "moai-adk: command not found"
1515
-
1516
- ```bash
1517
- # PATH 확인 및 전체 경로 사용
1518
- ~/.local/bin/moai-adk --version
1519
-
1520
- # 또는 pip로 재설치
1521
- pip install --force-reinstall moai-adk
1522
- ```
1523
-
1524
- #### 에러: ".moai/ 디렉토리를 찾을 수 없습니다"
1525
-
1526
- ```bash
1527
- # 초기화 실행
1528
- moai-adk init .
1529
-
1530
- # 또는 Claude Code에서
1531
- /alfred:0-project
1532
- ```
1533
-
1534
- #### 에러: "SPEC ID 중복"
1535
-
1536
- ```bash
1537
- # 기존 SPEC 확인
1538
- rg "@SPEC:" -n .moai/specs/
1539
-
1540
- # 새로운 ID 사용
1541
- /alfred:1-spec "새 기능 설명"
1542
- ```
1543
-
1544
- ---
1545
-
1546
- ## ■ 문서 및 지원
1547
-
1548
- ### 공식 문서
1549
-
1550
- - **GitHub Repository**: https://github.com/modu-ai/moai-adk
1551
- - **PyPI Package**: https://pypi.org/project/moai-adk/
1552
- - **Issue Tracker**: https://github.com/modu-ai/moai-adk/issues
1553
- - **Discussions**: https://github.com/modu-ai/moai-adk/discussions
1554
-
1555
- ### 커뮤니티
1556
-
1557
- - **GitHub Discussions**: 질문, 아이디어, 피드백 공유
1558
- - **Issue Tracker**: 버그 리포트, 기능 요청
1559
-
1560
- ### 기여하기
1561
-
1562
- MoAI-ADK는 오픈소스 프로젝트입니다. 여러분의 기여를 환영합니다!
1563
-
1564
- 1. Fork the repository
1565
- 2. Create your feature branch (`git checkout -b feature/amazing-feature`)
1566
- 3. Commit your changes (`git commit -m 'Add amazing feature'`)
1567
- 4. Push to the branch (`git push origin feature/amazing-feature`)
1568
- 5. Open a Pull Request
1569
-
1570
- ### 라이선스
1571
-
1572
- MIT License - 자유롭게 사용하실 수 있습니다.
1573
-
1574
- ---
1575
-
1576
- ## ■ 감사의 말
1577
-
1578
- MoAI-ADK는 다음 프로젝트와 커뮤니티의 도움으로 만들어졌습니다:
1579
-
1580
- - **모두의AI Community**: 지속적인 피드백과 개선 아이디어
1581
-
1582
- ---
1583
-
1584
- **Made with ❤️ by MoAI Team**
1585
-
1586
- **🎩 Alfred**: "여러분의 개발 여정을 함께하겠습니다!"