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
@@ -0,0 +1,513 @@
1
+ # Claude Code collection of practical examples
2
+
3
+ > **Actual working example code**
4
+ >
5
+ > Proven examples that can be copied and used immediately
6
+
7
+ ---
8
+
9
+ ## 📋 Table of Contents
10
+
11
+ 1. [Agent example](#1-agent-example)
12
+ 2. [Command example](#2-command-example)
13
+ 3. [Skill example](#3-skill-example)
14
+ 4. [Plugin example](#4-plugin-example)
15
+ 5. [Settings example](#5-settings-example)
16
+
17
+ ---
18
+
19
+ ## 1. Agent example
20
+
21
+ ### Example 1: spec-builder (MoAI-ADK)
22
+
23
+ **File**: `.claude/agents/alfred/spec-builder.md`
24
+
25
+ ```markdown
26
+ ---
27
+ name: spec-builder
28
+ description: "Use when: When writing SPEC, EARS specification, and requirements analysis are necessary."
29
+ tools: Read, Write, Edit, MultiEdit, Grep, Glob, Bash, TodoWrite
30
+ model: sonnet
31
+ ---
32
+
33
+ # SPEC Builder 🏗️ - System Architect
34
+
35
+ **MoAI-ADK SPEC writing expert**
36
+
37
+ ## 🎭 Agent Persona
38
+
39
+ **Icon**: 🏗️
40
+ **Job**: System Architect
41
+ **Area of ​​Expertise**: SPEC writing, EARS specification, requirements analysis
42
+ **Role**: Convert business requirements into structured SPECs
43
+ **Goal**: Create clear and testable SPEC documents.
44
+
45
+ ## 🎯 Key Role
46
+
47
+ ### 1. Create SPEC document
48
+ - Apply EARS 5 syntax
49
+ - YAML Front Matter 7 required fields
50
+ - HISTORY section management
51
+
52
+ ### 2. Auto-execution conditions
53
+ - When executing the `/alfred:1-plan` command
54
+ - When a new function requirement occurs
55
+ - When requesting improvement of the existing SPEC
56
+
57
+ ## 📐 Workflow
58
+
59
+ ### STEP 1: Project document analysis
60
+ \`\`\`bash
61
+ # read product.md
62
+ Read .moai/project/product.md
63
+
64
+ # Check existing SPEC
65
+ ls .moai/specs/SPEC-*/spec.md
66
+ \`\`\`
67
+
68
+ ### STEP 2: Draft SPEC
69
+ \`\`\`bash
70
+ Write .moai/specs/SPEC-{ID}/spec.md
71
+ \`\`\`
72
+
73
+ ## 💡 User Guide
74
+ \`\`\`bash
75
+ @agent-spec-builder "Create a user authentication function SPEC"
76
+ \`\`\`
77
+ ```
78
+
79
+ ### Example 2: code-analyzer (simple analysis agent)
80
+
81
+ **File**: `.claude/agents/code-analyzer.md`
82
+
83
+ ```markdown
84
+ ---
85
+ name: code-analyzer
86
+ description: Use when: code quality analysis is needed
87
+ tools: Read, Grep, Bash(rg:*)
88
+ model: haiku
89
+ ---
90
+
91
+ # Code Analyzer 🔍 - Quality Manager
92
+
93
+ Analyze code quality metrics and provide improvement suggestions.
94
+
95
+ ## 🎭 Agent Persona
96
+
97
+ **Icon**: 🔍
98
+ **Job**: Quality Manager
99
+ **Area of ​​Expertise**: Code quality analysis, linting, test coverage
100
+ **Role**: Measure code quality metrics and suggest improvements
101
+ **Goal**: Maintain high code quality
102
+
103
+ ## 🎯 Key Role
104
+
105
+ ### 1. Collect quality indicators
106
+ - Check test coverage
107
+ - Detect linting errors
108
+ - Complexity analysis
109
+
110
+ ### 2. Conditions for automatic execution
111
+ - When quality verification is requested before commit
112
+ - Automatic verification before creating PR
113
+
114
+ ## 📐 Workflow
115
+
116
+ ### STEP 1: Scan code
117
+ \`\`\`bash
118
+ rg "@TEST:" -n tests/
119
+ pytest --cov
120
+ \`\`\`
121
+
122
+ ### STEP 2: Generate report
123
+ - Coverage: {percentage}%
124
+ - Linting errors: {count}
125
+
126
+ ## 💡 User Guide
127
+ \`\`\`bash
128
+ @agent-code-analyzer "Analyze current project quality"
129
+ \`\`\`
130
+ ```
131
+
132
+ ---
133
+
134
+ ## 2. Command example
135
+
136
+ ### Example 1: /alfred:1-plan (MoAI-ADK)
137
+
138
+ **File**: `.claude/commands/alfred/1-spec.md`
139
+
140
+ ```markdown
141
+ ---
142
+ name: alfred:1-spec
143
+ description: Project document analysis and SPEC creation (EARS method)
144
+ argument-hint: [feature-description]
145
+ allowed-tools:
146
+ - Read
147
+ - Write
148
+ - Edit
149
+ - Task
150
+ - Grep
151
+ - Glob
152
+ - TodoWrite
153
+ - Bash(git:*)
154
+ ---
155
+
156
+ # 📋 MoAI-ADK Step 1: Write SPEC
157
+
158
+ ## 🎯 Command Purpose
159
+
160
+ Analyze project documents, create SPEC documents using the EARS method, and create Git branches.
161
+
162
+ ## 💡 Example of use
163
+ \`\`\`bash
164
+ /alfred:1-plan "User authentication function"
165
+ \`\`\`
166
+
167
+ ## 📋 Execution flow
168
+
169
+ 1. **Phase 1**: Analyze project document
170
+ - Read product.md
171
+ - Check existing SPEC
172
+
173
+ 2. **Phase 2**: SPEC creation
174
+ - EARS method specification
175
+ - Git branch creation
176
+
177
+ ## 🔗 Associated Agent
178
+
179
+ - **Primary**: spec-builder (🏗️ System Architect)
180
+ - **Secondary**: git-manager (🚀 Release Engineer)
181
+
182
+ ## ⚠️ Precautions
183
+
184
+ - SPEC ID duplication check required
185
+ - Compliance with EARS 5 phrases
186
+
187
+ ## 📋 Next steps
188
+
189
+ - `/alfred:2-run SPEC-{ID}` - Start TDD implementation
190
+ ```
191
+
192
+ ### Example 2: /deploy-api (deploy command)
193
+
194
+ **File**: `.claude/commands/deploy-api.md`
195
+
196
+ ```markdown
197
+ ---
198
+ name: deploy-api
199
+ description: Deploy API server to production environment
200
+ argument-hint: [environment]
201
+ allowed-tools:
202
+ - Read
203
+ - Bash(git:*)
204
+ - Bash(npm:*)
205
+ ---
206
+
207
+ # 🚀 API deployment command
208
+
209
+ Deploys the API server to the specified environment.
210
+
211
+ ## 🎯 Command Purpose
212
+
213
+ Automate Git tag creation and deployment by environment
214
+
215
+ ## 💡 Example of use
216
+ \`\`\`bash
217
+ /deploy-api production
218
+ /deploy-api staging
219
+ \`\`\`
220
+
221
+ ## 📋 Execution flow
222
+
223
+ 1. **Phase 1**: Check Git status
224
+ - Check current branch (main required)
225
+ - Create version tag
226
+
227
+ 2. **Phase 2**: Deployment execution
228
+ - npm run build
229
+ - Execute deployment script for each environment
230
+
231
+ ## ⚠️ Precautions
232
+
233
+ - Can only be run from the main branch
234
+ - Must pass all tests
235
+ ```
236
+
237
+ ---
238
+
239
+ ## 3. Skill example
240
+
241
+ ### Example 1: moai-alfred-tag-scanning
242
+
243
+ **File**: `.claude/skills/moai-alfred-tag-scanning/SKILL.md`
244
+
245
+ ```markdown
246
+ ---
247
+ name: moai-alfred-tag-scanning
248
+ description: Directly scan TAG markers and create inventory (CODE-FIRST principle)
249
+ model: haiku
250
+ allowed-tools:
251
+ - Grep
252
+ - Read
253
+ ---
254
+
255
+ # TAG scanner
256
+
257
+ > CODE-FIRST principle: scan code directly without intermediate cache
258
+
259
+ ## 🎯 Purpose
260
+
261
+ Scan `@SPEC`, `@TEST`, `@CODE`, and `@DOC` TAGs directly from your code.
262
+
263
+ ## 💡 How to use
264
+
265
+ “Check AUTH domain TAG list”
266
+
267
+ ## 📋 How to scan
268
+
269
+ \`\`\`bash
270
+ rg '@(SPEC|TEST|CODE|DOC):' -n .moai/specs/ tests/ src/ docs/
271
+ \`\`\`
272
+
273
+ ## ✅ Verification
274
+
275
+ - Does every `@CODE` TAG have a corresponding `@SPEC`?
276
+ - No orphan TAGs
277
+ ```
278
+
279
+ ### Example 2: moai-alfred-feature-selector
280
+
281
+ **File**: `.claude/skills/moai-alfred-feature-selector/SKILL.md`
282
+
283
+ ```markdown
284
+ ---
285
+ name: moai-alfred-feature-selector
286
+ description: Select optimal functions for each project type (37 skills → automatically filter 3 to 5)
287
+ model: haiku
288
+ allowed-tools:
289
+ - Read
290
+ ---
291
+
292
+ # MoAI Alfred Feature Selector
293
+
294
+ > Automatic selection of MoAI-ADK functions suitable for project characteristics
295
+
296
+ ## 🎯 Purpose
297
+
298
+ Analyze your project type and select only the features you need.
299
+
300
+ ## 📋 Project classification
301
+
302
+ ### By language
303
+ - **Python**: pytest, mypy, ruff
304
+ - **TypeScript**: Vitest, Biome
305
+
306
+ ### Domain-specific
307
+ - **CLI Tool**: Argument parsing, POSIX compliance
308
+ - **Web API**: REST/GraphQL, authentication
309
+
310
+ ## 💡 How to use
311
+
312
+ "Automatically called when running /alfred:0-project"
313
+ ```
314
+
315
+ ---
316
+
317
+ ## 4. Plugin example
318
+
319
+ ### Example 1: GitHub + Filesystem (default)
320
+
321
+ **FILE**: `.claude/settings.json` (mcpServers section)
322
+
323
+ ```json
324
+ {
325
+ "mcpServers": {
326
+ "github": {
327
+ "command": "npx",
328
+ "args": ["-y", "@modelcontextprotocol/server-github"],
329
+ "env": {
330
+ "GITHUB_TOKEN": "${GITHUB_TOKEN}"
331
+ }
332
+ },
333
+ "filesystem": {
334
+ "command": "npx",
335
+ "args": [
336
+ "-y",
337
+ "@modelcontextprotocol/server-filesystem",
338
+ "${CLAUDE_PROJECT_DIR}/src",
339
+ "${CLAUDE_PROJECT_DIR}/tests"
340
+ ]
341
+ }
342
+ }
343
+ }
344
+ ```
345
+
346
+ ### Example 2: Fully configured MoAI-ADK
347
+
348
+ ```json
349
+ {
350
+ "mcpServers": {
351
+ "github": {
352
+ "command": "npx",
353
+ "args": ["-y", "@modelcontextprotocol/server-github"],
354
+ "env": {
355
+ "GITHUB_TOKEN": "${GITHUB_TOKEN}"
356
+ }
357
+ },
358
+ "moai-filesystem": {
359
+ "command": "npx",
360
+ "args": [
361
+ "-y",
362
+ "@modelcontextprotocol/server-filesystem",
363
+ "${CLAUDE_PROJECT_DIR}/.moai",
364
+ "${CLAUDE_PROJECT_DIR}/src",
365
+ "${CLAUDE_PROJECT_DIR}/tests",
366
+ "${CLAUDE_PROJECT_DIR}/docs"
367
+ ]
368
+ },
369
+ "brave-search": {
370
+ "command": "npx",
371
+ "args": ["-y", "@modelcontextprotocol/server-brave-search"],
372
+ "env": {
373
+ "BRAVE_API_KEY": "${BRAVE_API_KEY}"
374
+ }
375
+ }
376
+ }
377
+ }
378
+ ```
379
+
380
+ ---
381
+
382
+ ## 5. Settings example
383
+
384
+ ### Example 1: Python project
385
+
386
+ **File**: `.claude/settings.json`
387
+
388
+ ```json
389
+ {
390
+ "permissions": {
391
+ "defaultMode": "default",
392
+ "allow": [
393
+ "Read",
394
+ "Write",
395
+ "Edit",
396
+ "Grep",
397
+ "Glob",
398
+ "Bash(git:*)",
399
+ "Bash(python:*)",
400
+ "Bash(pytest:*)",
401
+ "Bash(mypy:*)",
402
+ "Bash(ruff:*)"
403
+ ],
404
+ "ask": [
405
+ "Bash(pip install:*)",
406
+ "Bash(git push:*)"
407
+ ],
408
+ "deny": [
409
+ "Read(./.env)",
410
+ "Bash(sudo:*)",
411
+ "Bash(rm -rf:*)"
412
+ ]
413
+ }
414
+ }
415
+ ```
416
+
417
+ ### Example 2: TypeScript project
418
+
419
+ ```json
420
+ {
421
+ "permissions": {
422
+ "defaultMode": "default",
423
+ "allow": [
424
+ "Read",
425
+ "Write",
426
+ "Edit",
427
+ "Grep",
428
+ "Glob",
429
+ "Bash(git:*)",
430
+ "Bash(node:*)",
431
+ "Bash(npm:*)",
432
+ "Bash(pnpm:*)"
433
+ ],
434
+ "ask": [
435
+ "Bash(npm install:*)",
436
+ "Bash(pnpm install:*)",
437
+ "Bash(git push:*)"
438
+ ],
439
+ "deny": [
440
+ "Read(./.env)",
441
+ "Read(./secrets/**)",
442
+ "Bash(sudo:*)",
443
+ "Bash(rm -rf:*)"
444
+ ]
445
+ }
446
+ }
447
+ ```
448
+
449
+ ### Example 3: MoAI-ADK project (with hooks)
450
+
451
+ ```json
452
+ {
453
+ "permissions": {
454
+ "defaultMode": "default",
455
+ "allow": [
456
+ "Task",
457
+ "Read",
458
+ "Write",
459
+ "Edit",
460
+ "MultiEdit",
461
+ "Grep",
462
+ "Glob",
463
+ "TodoWrite",
464
+ "Bash(git:*)",
465
+ "Bash(python:*)",
466
+ "Bash(pytest:*)",
467
+ "Bash(mypy:*)",
468
+ "Bash(ruff:*)",
469
+ "Bash(moai-adk:*)",
470
+ "Bash(alfred:*)"
471
+ ],
472
+ "ask": [
473
+ "Bash(git push:*)",
474
+ "Bash(pip install:*)"
475
+ ],
476
+ "deny": [
477
+ "Read(./.env)",
478
+ "Read(./secrets/**)",
479
+ "Bash(sudo:*)",
480
+ "Bash(rm -rf:*)"
481
+ ]
482
+ },
483
+ "hooks": {
484
+ "SessionStart": [
485
+ {
486
+ "hooks": [
487
+ {
488
+ "command": "node $CLAUDE_PROJECT_DIR/.claude/hooks/alfred/session-notice.cjs",
489
+ "type": "command"
490
+ }
491
+ ],
492
+ "matcher": "*"
493
+ }
494
+ ],
495
+ "PreToolUse": [
496
+ {
497
+ "hooks": [
498
+ {
499
+ "command": "node $CLAUDE_PROJECT_DIR/.claude/hooks/alfred/pre-write-guard.cjs",
500
+ "type": "command"
501
+ }
502
+ ],
503
+ "matcher": "Edit|Write|MultiEdit"
504
+ }
505
+ ]
506
+ }
507
+ }
508
+ ```
509
+
510
+ ---
511
+
512
+ **Last update**: 2025-10-19
513
+ **Author**: @Alfred