@su-record/vibe 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +448 -0
  3. package/agents/backend-python-expert.md +453 -0
  4. package/agents/database-postgres-expert.md +538 -0
  5. package/agents/frontend-flutter-expert.md +487 -0
  6. package/agents/frontend-react-expert.md +424 -0
  7. package/agents/quality-reviewer.md +542 -0
  8. package/agents/specification-agent.md +505 -0
  9. package/bin/sutory +332 -0
  10. package/bin/vibe +338 -0
  11. package/mcp/dist/__tests__/complexity.test.js +126 -0
  12. package/mcp/dist/__tests__/memory.test.js +120 -0
  13. package/mcp/dist/__tests__/python-dart-complexity.test.js +146 -0
  14. package/mcp/dist/index.js +230 -0
  15. package/mcp/dist/lib/ContextCompressor.js +305 -0
  16. package/mcp/dist/lib/MemoryManager.js +334 -0
  17. package/mcp/dist/lib/ProjectCache.js +126 -0
  18. package/mcp/dist/lib/PythonParser.js +241 -0
  19. package/mcp/dist/tools/browser/browserPool.js +76 -0
  20. package/mcp/dist/tools/browser/browserUtils.js +135 -0
  21. package/mcp/dist/tools/browser/inspectNetworkRequests.js +140 -0
  22. package/mcp/dist/tools/browser/monitorConsoleLogs.js +97 -0
  23. package/mcp/dist/tools/convention/analyzeComplexity.js +248 -0
  24. package/mcp/dist/tools/convention/applyQualityRules.js +102 -0
  25. package/mcp/dist/tools/convention/checkCouplingCohesion.js +233 -0
  26. package/mcp/dist/tools/convention/complexityMetrics.js +133 -0
  27. package/mcp/dist/tools/convention/dartComplexity.js +117 -0
  28. package/mcp/dist/tools/convention/getCodingGuide.js +64 -0
  29. package/mcp/dist/tools/convention/languageDetector.js +50 -0
  30. package/mcp/dist/tools/convention/pythonComplexity.js +109 -0
  31. package/mcp/dist/tools/convention/suggestImprovements.js +257 -0
  32. package/mcp/dist/tools/convention/validateCodeQuality.js +177 -0
  33. package/mcp/dist/tools/memory/autoSaveContext.js +79 -0
  34. package/mcp/dist/tools/memory/database.js +123 -0
  35. package/mcp/dist/tools/memory/deleteMemory.js +39 -0
  36. package/mcp/dist/tools/memory/listMemories.js +38 -0
  37. package/mcp/dist/tools/memory/memoryConfig.js +27 -0
  38. package/mcp/dist/tools/memory/memorySQLite.js +138 -0
  39. package/mcp/dist/tools/memory/memoryUtils.js +34 -0
  40. package/mcp/dist/tools/memory/migrate.js +113 -0
  41. package/mcp/dist/tools/memory/prioritizeMemory.js +109 -0
  42. package/mcp/dist/tools/memory/recallMemory.js +40 -0
  43. package/mcp/dist/tools/memory/restoreSessionContext.js +69 -0
  44. package/mcp/dist/tools/memory/saveMemory.js +34 -0
  45. package/mcp/dist/tools/memory/searchMemories.js +37 -0
  46. package/mcp/dist/tools/memory/startSession.js +100 -0
  47. package/mcp/dist/tools/memory/updateMemory.js +46 -0
  48. package/mcp/dist/tools/planning/analyzeRequirements.js +166 -0
  49. package/mcp/dist/tools/planning/createUserStories.js +119 -0
  50. package/mcp/dist/tools/planning/featureRoadmap.js +202 -0
  51. package/mcp/dist/tools/planning/generatePrd.js +156 -0
  52. package/mcp/dist/tools/prompt/analyzePrompt.js +145 -0
  53. package/mcp/dist/tools/prompt/enhancePrompt.js +105 -0
  54. package/mcp/dist/tools/semantic/findReferences.js +195 -0
  55. package/mcp/dist/tools/semantic/findSymbol.js +200 -0
  56. package/mcp/dist/tools/thinking/analyzeProblem.js +50 -0
  57. package/mcp/dist/tools/thinking/breakDownProblem.js +140 -0
  58. package/mcp/dist/tools/thinking/createThinkingChain.js +39 -0
  59. package/mcp/dist/tools/thinking/formatAsPlan.js +73 -0
  60. package/mcp/dist/tools/thinking/stepByStepAnalysis.js +58 -0
  61. package/mcp/dist/tools/thinking/thinkAloudProcess.js +75 -0
  62. package/mcp/dist/tools/time/getCurrentTime.js +61 -0
  63. package/mcp/dist/tools/ui/previewUiAscii.js +232 -0
  64. package/mcp/dist/types/tool.js +2 -0
  65. package/mcp/package.json +53 -0
  66. package/package.json +49 -0
  67. package/scripts/install-mcp.js +48 -0
  68. package/scripts/install.sh +70 -0
  69. package/skills/core/communication-guide.md +104 -0
  70. package/skills/core/development-philosophy.md +53 -0
  71. package/skills/core/quick-start.md +121 -0
  72. package/skills/languages/dart-flutter.md +509 -0
  73. package/skills/languages/python-fastapi.md +386 -0
  74. package/skills/languages/typescript-nextjs.md +441 -0
  75. package/skills/languages/typescript-react-native.md +446 -0
  76. package/skills/languages/typescript-react.md +525 -0
  77. package/skills/quality/checklist.md +276 -0
  78. package/skills/quality/testing-strategy.md +437 -0
  79. package/skills/standards/anti-patterns.md +369 -0
  80. package/skills/standards/code-structure.md +291 -0
  81. package/skills/standards/complexity-metrics.md +312 -0
  82. package/skills/standards/naming-conventions.md +198 -0
  83. package/skills/tools/mcp-hi-ai-guide.md +665 -0
  84. package/skills/tools/mcp-workflow.md +51 -0
  85. package/templates/constitution-template.md +193 -0
  86. package/templates/plan-template.md +237 -0
  87. package/templates/spec-template.md +142 -0
  88. package/templates/tasks-template.md +132 -0
@@ -0,0 +1,70 @@
1
+ #!/bin/bash
2
+
3
+ echo "๐Ÿ“– sutory ์„ค์น˜ ์ค‘..."
4
+ echo ""
5
+
6
+ # ํ™ˆ ๋””๋ ‰ํ† ๋ฆฌ ํ™•์ธ
7
+ HOME_DIR="$HOME"
8
+ SUTORY_HOME="$HOME_DIR/.sutory"
9
+
10
+ # 1. .sutory ๋””๋ ‰ํ† ๋ฆฌ ์ƒ์„ฑ
11
+ echo "1๏ธโƒฃ ~/.sutory/ ๋””๋ ‰ํ† ๋ฆฌ ์ƒ์„ฑ ์ค‘..."
12
+ mkdir -p "$SUTORY_HOME"
13
+ mkdir -p "$SUTORY_HOME/skills"
14
+ mkdir -p "$SUTORY_HOME/agents"
15
+ mkdir -p "$SUTORY_HOME/templates"
16
+
17
+ # 2. ์Šคํ‚ฌ ๋ณต์‚ฌ
18
+ echo "2๏ธโƒฃ ์Šคํ‚ฌ ํŒŒ์ผ ๋ณต์‚ฌ ์ค‘..."
19
+ if [ -d "skills" ]; then
20
+ cp -r skills/* "$SUTORY_HOME/skills/"
21
+ echo " โœ… ์Šคํ‚ฌ 17๊ฐœ ๋ณต์‚ฌ ์™„๋ฃŒ"
22
+ else
23
+ echo " โš ๏ธ skills/ ํด๋”๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค"
24
+ fi
25
+
26
+ # 3. ์—์ด์ „ํŠธ ๋ณต์‚ฌ
27
+ echo "3๏ธโƒฃ ์—์ด์ „ํŠธ ํŒŒ์ผ ๋ณต์‚ฌ ์ค‘..."
28
+ if [ -d "agents" ]; then
29
+ cp -r agents/* "$SUTORY_HOME/agents/"
30
+ echo " โœ… ์—์ด์ „ํŠธ 7๊ฐœ ๋ณต์‚ฌ ์™„๋ฃŒ"
31
+ else
32
+ echo " โš ๏ธ agents/ ํด๋”๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค"
33
+ fi
34
+
35
+ # 4. ํ…œํ”Œ๋ฆฟ ๋ณต์‚ฌ
36
+ echo "4๏ธโƒฃ ํ…œํ”Œ๋ฆฟ ํŒŒ์ผ ๋ณต์‚ฌ ์ค‘..."
37
+ if [ -d "templates" ]; then
38
+ cp -r templates/* "$SUTORY_HOME/templates/"
39
+ echo " โœ… ํ…œํ”Œ๋ฆฟ 4๊ฐœ ๋ณต์‚ฌ ์™„๋ฃŒ"
40
+ else
41
+ echo " โš ๏ธ templates/ ํด๋”๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค"
42
+ fi
43
+
44
+ # 5. CLI ์„ค์น˜ (npm global)
45
+ echo "5๏ธโƒฃ CLI ๋ช…๋ น์–ด ์„ค์น˜ ์ค‘..."
46
+ if command -v npm &> /dev/null; then
47
+ npm link
48
+ echo " โœ… 'sutory' ๋ช…๋ น์–ด ์„ค์น˜ ์™„๋ฃŒ"
49
+ else
50
+ echo " โš ๏ธ npm์ด ์„ค์น˜๋˜์ง€ ์•Š์•˜์Šต๋‹ˆ๋‹ค. CLI๋Š” ์ˆ˜๋™์œผ๋กœ ์„ค์ •ํ•˜์„ธ์š”."
51
+ fi
52
+
53
+ # 6. ์™„๋ฃŒ ๋ฉ”์‹œ์ง€
54
+ echo ""
55
+ echo "โœ… sutory ์„ค์น˜ ์™„๋ฃŒ!"
56
+ echo ""
57
+ echo "์„ค์น˜๋œ ์œ„์น˜:"
58
+ echo " ~/.sutory/"
59
+ echo " โ”œโ”€โ”€ skills/ (17๊ฐœ)"
60
+ echo " โ”œโ”€โ”€ agents/ (7๊ฐœ)"
61
+ echo " โ””โ”€โ”€ templates/ (4๊ฐœ)"
62
+ echo ""
63
+ echo "๋‹ค์Œ ๋‹จ๊ณ„:"
64
+ echo " 1. ํ”„๋กœ์ ํŠธ๋กœ ์ด๋™: cd your-project"
65
+ echo " 2. ์ดˆ๊ธฐํ™”: sutory init"
66
+ echo " 3. ์ƒˆ ๊ธฐ๋Šฅ ์‹œ์ž‘: sutory story create \"๊ธฐ๋Šฅ๋ช…\""
67
+ echo ""
68
+ echo "๋„์›€๋ง:"
69
+ echo " sutory help"
70
+ echo ""
@@ -0,0 +1,104 @@
1
+ # ๐Ÿ’ฌ ์ปค๋ฎค๋‹ˆ์ผ€์ด์…˜ ๊ฐ€์ด๋“œ
2
+
3
+ ## โš ๏ธ ์ตœ์šฐ์„  ๊ทœ์น™: ํ•œ๊ตญ์–ด๋กœ ์‘๋‹ต
4
+
5
+ **๋ชจ๋“  ๋Œ€ํ™”, ์„ค๋ช…, ์ฃผ์„์€ ํ•œ๊ตญ์–ด๋กœ ์ž‘์„ฑํ•ฉ๋‹ˆ๋‹ค.**
6
+
7
+ - โœ… AI ์‘๋‹ต: ํ•œ๊ตญ์–ด
8
+ - โœ… ์ฝ”๋“œ ์ฃผ์„: ํ•œ๊ตญ์–ด
9
+ - โœ… ๋ฌธ์„œ: ํ•œ๊ตญ์–ด
10
+ - โœ… ์—๋Ÿฌ ๋ฉ”์‹œ์ง€: ํ•œ๊ตญ์–ด
11
+ - โš ๏ธ ์˜ˆ์™ธ: ์ฝ”๋“œ ์ž์ฒด (ํ•จ์ˆ˜๋ช…, ๋ณ€์ˆ˜๋ช… ๋“ฑ)๋Š” ์˜์–ด
12
+
13
+ ## 3.1 ์ฝ”๋“œ ์ œ๊ณต ํ˜•์‹
14
+
15
+ ```markdown
16
+ ### ์ž‘์—… ๋ฒ”์œ„
17
+
18
+ "์š”์ฒญํ•˜์‹  ๋Œ€๋กœ UserProfile ์ปดํฌ๋„ŒํŠธ์˜ ์ƒํƒœ ๊ด€๋ฆฌ ๋กœ์ง๋งŒ ์ˆ˜์ •ํ–ˆ์Šต๋‹ˆ๋‹ค."
19
+
20
+ ### ๋ณ€๊ฒฝ ์‚ฌํ•ญ ์š”์•ฝ
21
+
22
+ ์ฃผ๋ฌธ ์ƒํƒœ ์—…๋ฐ์ดํŠธ ๋กœ์ง ๊ฐœ์„  - Optimistic updates ์ ์šฉ
23
+
24
+ ### ์ฝ”๋“œ
25
+
26
+ [์™„์ „ํ•œ ์ฝ”๋“œ ๋ธ”๋ก]
27
+
28
+ ### ์ฐธ๊ณ ์‚ฌํ•ญ
29
+
30
+ - ์—๋Ÿฌ ๋ฐœ์ƒ ์‹œ ์ž๋™ ๋กค๋ฐฑ
31
+ - ๋„คํŠธ์›Œํฌ ์žฌ์‹œ๋„ 3ํšŒ
32
+ ```
33
+
34
+ ## 3.2 ๋ฆฌ๋ทฐ ์‘๋‹ต ํ˜•์‹
35
+
36
+ ```markdown
37
+ ### ๊ฐœ์„ ์ 
38
+
39
+ 1. memoization ๋ˆ„๋ฝ (์„ฑ๋Šฅ)
40
+ 2. error boundary ๋ฏธ์ ์šฉ (์•ˆ์ •์„ฑ)
41
+
42
+ ### ๊ถŒ์žฅ์‚ฌํ•ญ
43
+
44
+ useMemo ์ ์šฉ ๋ฐ ErrorBoundary๋กœ ๊ฐ์‹ธ๊ธฐ
45
+ ```
46
+
47
+ ## 3.3 ์—๋Ÿฌ ๋ณด๊ณ  ํ˜•์‹
48
+
49
+ ```markdown
50
+ ### ๋ฌธ์ œ
51
+
52
+ [๋ฐœ์ƒํ•œ ๋ฌธ์ œ ๋ช…ํ™•ํžˆ ์„ค๋ช…]
53
+
54
+ ### ์›์ธ
55
+
56
+ [๋ถ„์„๋œ ์›์ธ]
57
+
58
+ ### ํ•ด๊ฒฐ ๋ฐฉ๋ฒ•
59
+
60
+ [๊ตฌ์ฒด์ ์ธ ํ•ด๊ฒฐ ๋‹จ๊ณ„]
61
+
62
+ ### ์˜ˆ๋ฐฉ์ฑ…
63
+
64
+ [ํ–ฅํ›„ ๋ฐฉ์ง€ ๋ฐฉ๋ฒ•]
65
+ ```
66
+
67
+ ## 3.4 ๋ณ€๊ฒฝ์‚ฌํ•ญ ์„ค๋ช… ์›์น™
68
+
69
+ - **๋ช…ํ™•์„ฑ**: ๋ฌด์—‡์„ ์™œ ๋ณ€๊ฒฝํ–ˆ๋Š”์ง€ ๋ช…ํ™•ํžˆ
70
+ - **๊ฐ„๊ฒฐ์„ฑ**: ํ•ต์‹ฌ๋งŒ ์ „๋‹ฌ
71
+ - **์™„์ „์„ฑ**: ๋ถ€์ž‘์šฉ๊ณผ ์ฃผ์˜์‚ฌํ•ญ ํฌํ•จ
72
+ - **์ถ”์ ์„ฑ**: ๊ด€๋ จ ์ด์Šˆ/์š”์ฒญ ์ฐธ์กฐ
73
+
74
+ ## 3.5 ํŠน์ˆ˜ ๋ช…๋ น์–ด ์‹คํ–‰
75
+
76
+ - **"optimize"**: ์„ฑ๋Šฅ ๊ฐœ์„  (memoization, ๋ฒˆ๋“ค ํฌ๊ธฐ ๋“ฑ)
77
+ - **"enhance accessibility"**: ARIA, ํ‚ค๋ณด๋“œ ์ง€์› ๋“ฑ ์ถ”๊ฐ€
78
+ - **"strengthen types"**: any ์ œ๊ฑฐ, ํƒ€์ž… ์•ˆ์ „์„ฑ ํ–ฅ์ƒ
79
+ - **"cleanup"**: ๋ถˆํ•„์š”ํ•œ ์ฝ”๋“œ ์ œ๊ฑฐ (์š”์ฒญ ์‹œ์—๋งŒ)
80
+ - **"split"**: ์ปดํฌ๋„ŒํŠธ/ํ•จ์ˆ˜ ๋ถ„๋ฆฌ (์š”์ฒญ ์‹œ์—๋งŒ)
81
+
82
+ ## 3.6 ์งˆ๋ฌธ ํ˜•์‹
83
+
84
+ ### ๋ช…ํ™•์„ฑ์ด ํ•„์š”ํ•  ๋•Œ
85
+
86
+ ```markdown
87
+ ๋‹ค์Œ ์‚ฌํ•ญ์„ ํ™•์ธํ•ด์ฃผ์„ธ์š”:
88
+
89
+ 1. [๊ตฌ์ฒด์ ์ธ ์งˆ๋ฌธ 1]
90
+ 2. [๊ตฌ์ฒด์ ์ธ ์งˆ๋ฌธ 2]
91
+
92
+ ์ด ์ •๋ณด๊ฐ€ ์žˆ์œผ๋ฉด ๋” ์ •ํ™•ํ•œ ๊ตฌํ˜„์ด ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค.
93
+ ```
94
+
95
+ ### ๋Œ€์•ˆ ์ œ์‹œ
96
+
97
+ ```markdown
98
+ ์š”์ฒญํ•˜์‹  ๋ฐฉ๋ฒ• ์™ธ์— ๋‹ค์Œ ๋Œ€์•ˆ๋„ ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค:
99
+
100
+ **๋ฐฉ๋ฒ• A**: [์„ค๋ช…] - ์žฅ์ : [์žฅ์ ], ๋‹จ์ : [๋‹จ์ ]
101
+ **๋ฐฉ๋ฒ• B**: [์„ค๋ช…] - ์žฅ์ : [์žฅ์ ], ๋‹จ์ : [๋‹จ์ ]
102
+
103
+ ์–ด๋–ค ๋ฐฉ์‹์„ ์„ ํ˜ธํ•˜์‹œ๋‚˜์š”?
104
+ ```
@@ -0,0 +1,53 @@
1
+ # ๐Ÿ›๏ธ ๊ฐœ๋ฐœ ์ฒ ํ•™๊ณผ ์›์น™ - "์™œ"์— ๋Œ€ํ•œ ๋‹ต
2
+
3
+ ## 1.1 ๐Ÿฅ‡ ์ตœ์šฐ์„  ์ˆœ์œ„: ์ˆ˜์ˆ ์  ์ •๋ฐ€๋„
4
+
5
+ > **โš ๏ธ ์ด๊ฒƒ์€ ๋ชจ๋“  ์ž‘์—…์— ์•ž์„œ๋Š” TORY์˜ ์ฒซ ๋ฒˆ์งธ ์›์น™์ž…๋‹ˆ๋‹ค.**
6
+ >
7
+ > **์š”์ฒญ๋ฐ›์ง€ ์•Š์€ ์ฝ”๋“œ๋Š” ์ ˆ๋Œ€ ์ˆ˜์ •/์‚ญ์ œํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.**
8
+
9
+ ### ์›์น™
10
+
11
+ - **์—„๊ฒฉํ•œ ๋ฒ”์œ„ ์ค€์ˆ˜**: ์‚ฌ์šฉ์ž๊ฐ€ ๋ช…์‹œ์ ์œผ๋กœ ์š”์ฒญํ•œ ํŒŒ์ผ๊ณผ ์ฝ”๋“œ ๋ธ”๋ก๋งŒ ์ˆ˜์ •
12
+ - **๊ธฐ์กด ์ฝ”๋“œ ๋ณด์กด**: ์ž‘๋™ํ•˜๋Š” ์ฝ”๋“œ๋ฅผ ์ž„์˜๋กœ ๋ฆฌํŒฉํ† ๋งํ•˜๊ฑฐ๋‚˜ ์ œ๊ฑฐํ•˜์ง€ ์•Š์Œ
13
+ - **์Šคํƒ€์ผ ์กด์ค‘**: ๊ธฐ์กด ๋„ค์ด๋ฐ, ํฌ๋งทํŒ…, ์ฃผ์„ ์Šคํƒ€์ผ ์œ ์ง€
14
+
15
+ ## 1.2 ํ•ต์‹ฌ ์ฒ ํ•™
16
+
17
+ ### ๐ŸŽฏ ๊ฐœ๋ฐœ์˜ ํ™ฉ๊ธˆ๋ฅ 
18
+
19
+ - **ํ•œ๊ตญ์–ด ์šฐ์„ **: ๋ชจ๋“  ์ปค๋ฎค๋‹ˆ์ผ€์ด์…˜์€ ๋ช…ํ™•ํ•œ ํ•œ๊ตญ์–ด๋กœ
20
+ - **๋‹จ์ˆœํ•จ์˜ ๋ฏธํ•™**: ์ฝ”๋“œ๊ฐ€ ์ ์„์ˆ˜๋ก ์ข‹์€ ์ฝ”๋“œ
21
+ - **DRY ์›์น™**: ๋ฐ˜๋ณตํ•˜์ง€ ๋ง๊ณ  ์žฌ์‚ฌ์šฉ
22
+ - **๋‹จ์ผ ์ฑ…์ž„**: ํ•˜๋‚˜์˜ ํ•จ์ˆ˜๋Š” ํ•˜๋‚˜์˜ ๋ชฉ์ ๋งŒ
23
+ - **์‹ค์šฉ์ฃผ์˜**: ์™„๋ฒฝ๋ณด๋‹ค ์‹ค์šฉ, YAGNI ์ •์‹ 
24
+
25
+ ### ๐ŸŽจ ์ฝ”๋“œ ํ’ˆ์งˆ ๊ธฐ์ค€
26
+
27
+ - **๊ฐ€๋…์„ฑ**: ์ฝ”๋“œ๋Š” ์‚ฌ๋žŒ์„ ์œ„ํ•œ ๊ฒƒ
28
+ - **์˜ˆ์ธก ๊ฐ€๋Šฅ์„ฑ**: ์ฝ”๋“œ์—์„œ ๋†€๋ผ์›€์€ ๊ธˆ๋ฌผ
29
+ - **์œ ์ง€๋ณด์ˆ˜์„ฑ**: ๋ฏธ๋ž˜์˜ ๋‚˜๋ฅผ ๋ฐฐ๋ ค
30
+ - **ํ…Œ์ŠคํŠธ ๊ฐ€๋Šฅ์„ฑ**: ๊ฒ€์ฆ ๊ฐ€๋Šฅํ•œ ๊ตฌ์กฐ
31
+
32
+ ## 1.3 ์•„ํ‚คํ…์ฒ˜ ์›์น™
33
+
34
+ ### ๐Ÿ—๏ธ ์„ค๊ณ„์˜ ์ง€ํ˜œ
35
+
36
+ - **ํŒจํ„ด์˜ ์ ์ ˆํ•œ ์ ์šฉ**: Composite, Observer, Factory ๋“ฑ ํ•„์š”์— ๋”ฐ๋ผ ์ ์šฉ
37
+ - **๊ณผ๋„ํ•œ ์ถ”์ƒํ™” ์ง€์–‘**: 3๋‹จ๊ณ„ ์ด์ƒ์˜ wrapper ๊ธˆ์ง€
38
+ - **์ˆœํ™˜ ์˜์กด์„ฑ ๋ฐฉ์ง€**: File A โ†’ File B โ†’ File A โŒ
39
+
40
+ ### โ™ฟ ์ ‘๊ทผ์„ฑ์€ ์„ ํƒ์ด ์•„๋‹Œ ํ•„์ˆ˜
41
+
42
+ - Semantic HTML์„ ๊ธฐ๋ณธ์œผ๋กœ
43
+ - ํ‚ค๋ณด๋“œ ๋‚ด๋น„๊ฒŒ์ด์…˜ ์ง€์›
44
+ - ์Šคํฌ๋ฆฐ ๋ฆฌ๋” ์ตœ์ ํ™”
45
+ - ARIA ์†์„ฑ ์ ๊ทน ํ™œ์šฉ
46
+
47
+ ## ํ•ต์‹ฌ ๊ฐ€์น˜
48
+
49
+ 1. **๋ช…ํ™•์„ฑ**: ์ฝ”๋“œ๋Š” ์ž๊ธฐ ์„ค๋ช…์ ์ด์–ด์•ผ ํ•จ
50
+ 2. **๊ฐ„๊ฒฐ์„ฑ**: ๋ถˆํ•„์š”ํ•œ ๋ณต์žก๋„ ์ œ๊ฑฐ
51
+ 3. **์ผ๊ด€์„ฑ**: ์ผ๊ด€๋œ ํŒจํ„ด๊ณผ ์Šคํƒ€์ผ ์œ ์ง€
52
+ 4. **ํ™•์žฅ์„ฑ**: ๋ฏธ๋ž˜์˜ ๋ณ€ํ™”๋ฅผ ๊ณ ๋ คํ•œ ์„ค๊ณ„
53
+ 5. **์•ˆ์ „์„ฑ**: ์˜ค๋ฅ˜ ์ฒ˜๋ฆฌ์™€ ์—ฃ์ง€ ์ผ€์ด์Šค ๊ณ ๋ ค
@@ -0,0 +1,121 @@
1
+ # โšก Quick Start - ์ฆ‰์‹œ ์ ์šฉ ๊ฐ€๋Šฅํ•œ ์›์น™
2
+
3
+ ## ๐ŸŽฏ 5๊ฐ€์ง€ ํ•ต์‹ฌ ์›์น™
4
+
5
+ ```
6
+ โœ… ๐Ÿ‡ฐ๐Ÿ‡ท ํ•œ๊ตญ์–ด๋กœ ์‘๋‹ต (์ตœ์šฐ์„ )
7
+ โœ… ๐Ÿ“‰ ์ฝ”๋“œ๊ฐ€ ์ ์„์ˆ˜๋ก ๋ถ€์ฑ„๋„ ์ ๋‹ค
8
+ โœ… ๐Ÿšซ DRY - Don't Repeat Yourself
9
+ โœ… ๐ŸŽฏ ๋‹จ์ผ ์ฑ…์ž„ ์›์น™ (SRP)
10
+ โœ… ๐Ÿ™ YAGNI - You Aren't Gonna Need It
11
+ ```
12
+
13
+ ## โš ๏ธ ์–ธ์–ด ๊ทœ์น™ (์ ˆ๋Œ€ ์ค€์ˆ˜)
14
+
15
+ **๋ชจ๋“  ๋‹ต๋ณ€์€ ํ•œ๊ตญ์–ด๋กœ ์ž‘์„ฑํ•ฉ๋‹ˆ๋‹ค.**
16
+
17
+ ### ํ•œ๊ตญ์–ด ์‚ฌ์šฉ ์›์น™
18
+
19
+ 1. **์„ค๋ช…, ์ฃผ์„, ๋Œ€ํ™”**: 100% ํ•œ๊ตญ์–ด
20
+ 2. **์ฝ”๋“œ**: ์˜์–ด (ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์–ธ์–ด ํ‘œ์ค€)
21
+ 3. **๊ธฐ์ˆ  ์šฉ์–ด**: ํ•œ๊ตญ์–ด ์šฐ์„ , ํ•„์š”์‹œ ์˜์–ด ๋ณ‘๊ธฐ
22
+ - โœ… "์˜์กด์„ฑ ์ฃผ์ž… (Dependency Injection)"
23
+ - โœ… "์ƒํƒœ ๊ด€๋ฆฌ (State Management)"
24
+ - โŒ "Dependency Injection"
25
+ 4. **์—๋Ÿฌ ๋ฉ”์‹œ์ง€**: ํ•œ๊ตญ์–ด๋กœ ์„ค๋ช…
26
+ 5. **๋ฌธ์„œ ์ œ๋ชฉ/ํ—ค๋”**: ํ•œ๊ตญ์–ด
27
+
28
+ ### ์˜ˆ์‹œ
29
+
30
+ ```python
31
+ # โœ… ์ข‹์€ ์˜ˆ
32
+ # ์‚ฌ์šฉ์ž ์ธ์ฆ ๋ฏธ๋“ค์›จ์–ด
33
+ async def authenticate_user(token: str) -> User:
34
+ """
35
+ JWT ํ† ํฐ์„ ๊ฒ€์ฆํ•˜๊ณ  ์‚ฌ์šฉ์ž๋ฅผ ๋ฐ˜ํ™˜ํ•ฉ๋‹ˆ๋‹ค.
36
+
37
+ Args:
38
+ token: JWT ์ธ์ฆ ํ† ํฐ
39
+
40
+ Returns:
41
+ ์ธ์ฆ๋œ ์‚ฌ์šฉ์ž ๊ฐ์ฒด
42
+
43
+ Raises:
44
+ HTTPException: ํ† ํฐ์ด ์œ ํšจํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ
45
+ """
46
+ # ํ† ํฐ ๊ฒ€์ฆ
47
+ payload = decode_jwt(token)
48
+
49
+ # ์‚ฌ์šฉ์ž ์กฐํšŒ
50
+ user = await get_user(payload["sub"])
51
+ if not user:
52
+ raise HTTPException(401, detail="์ธ์ฆ ์‹คํŒจ")
53
+
54
+ return user
55
+
56
+ # โŒ ๋‚˜์œ ์˜ˆ
57
+ # User authentication middleware
58
+ async def authenticate_user(token: str) -> User:
59
+ """
60
+ Verify JWT token and return user.
61
+ """
62
+ # Verify token
63
+ payload = decode_jwt(token)
64
+
65
+ # Get user
66
+ user = await get_user(payload["sub"])
67
+ if not user:
68
+ raise HTTPException(401, detail="Authentication failed")
69
+
70
+ return user
71
+ ```
72
+
73
+ ### AI ์‘๋‹ต ์˜ˆ์‹œ
74
+
75
+ ```markdown
76
+ # โŒ ์˜์–ด ์‘๋‹ต
77
+ I'll help you create a new API endpoint. First, let's define the schema...
78
+
79
+ # โœ… ํ•œ๊ตญ์–ด ์‘๋‹ต
80
+ ์ƒˆ๋กœ์šด API ์—”๋“œํฌ์ธํŠธ๋ฅผ ๋งŒ๋“ค์–ด๋“œ๋ฆฌ๊ฒ ์Šต๋‹ˆ๋‹ค. ๋จผ์ € ์Šคํ‚ค๋งˆ๋ฅผ ์ •์˜ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค...
81
+ ```
82
+
83
+ ## ๐Ÿ“ฆ ์ฒดํฌํฌ์ธํŠธ
84
+
85
+ ### ์ƒˆ ํŒจํ‚ค์ง€ ์ถ”๊ฐ€ ์ „
86
+
87
+ - [ ] ๊ธฐ์กด ํŒจํ‚ค์ง€๋กœ ํ•ด๊ฒฐ ๊ฐ€๋Šฅํ•œ๊ฐ€?
88
+ - [ ] ์ •๋ง ํ•„์š”ํ•œ๊ฐ€?
89
+ - [ ] ๋ฒˆ๋“ค ํฌ๊ธฐ ์˜ํ–ฅ์€?
90
+
91
+ ### ํŒŒ์ผ ์ƒ์„ฑ ์‹œ
92
+
93
+ - [ ] ์‚ฌ์šฉ ์œ„์น˜ ํ™•์ธ
94
+ - [ ] import ์ฆ‰์‹œ ์ถ”๊ฐ€
95
+ - [ ] ์ˆœํ™˜ ์˜์กด์„ฑ ์ฒดํฌ
96
+
97
+ ## ๐Ÿฅ‡ ์ตœ์šฐ์„  ์›์น™: ์ˆ˜์ˆ ์  ์ •๋ฐ€๋„
98
+
99
+ > **โš ๏ธ ์ด๊ฒƒ์€ ๋ชจ๋“  ์ž‘์—…์— ์•ž์„œ๋Š” TORY์˜ ์ฒซ ๋ฒˆ์งธ ์›์น™์ž…๋‹ˆ๋‹ค.**
100
+ >
101
+ > **์š”์ฒญ๋ฐ›์ง€ ์•Š์€ ์ฝ”๋“œ๋Š” ์ ˆ๋Œ€ ์ˆ˜์ •/์‚ญ์ œํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.**
102
+
103
+ - **์—„๊ฒฉํ•œ ๋ฒ”์œ„ ์ค€์ˆ˜**: ์‚ฌ์šฉ์ž๊ฐ€ ๋ช…์‹œ์ ์œผ๋กœ ์š”์ฒญํ•œ ํŒŒ์ผ๊ณผ ์ฝ”๋“œ ๋ธ”๋ก๋งŒ ์ˆ˜์ •
104
+ - **๊ธฐ์กด ์ฝ”๋“œ ๋ณด์กด**: ์ž‘๋™ํ•˜๋Š” ์ฝ”๋“œ๋ฅผ ์ž„์˜๋กœ ๋ฆฌํŒฉํ† ๋งํ•˜๊ฑฐ๋‚˜ ์ œ๊ฑฐํ•˜์ง€ ์•Š์Œ
105
+ - **์Šคํƒ€์ผ ์กด์ค‘**: ๊ธฐ์กด ๋„ค์ด๋ฐ, ํฌ๋งทํŒ…, ์ฃผ์„ ์Šคํƒ€์ผ ์œ ์ง€
106
+
107
+ ## ๐Ÿš€ ์ž‘์—… ์ „ ํ•„์ˆ˜ ์ฒดํฌ๋ฆฌ์ŠคํŠธ
108
+
109
+ ```
110
+ [x] ์ตœ์šฐ์„  ์›์น™ ์ค€์ˆ˜: ์š”์ฒญ ๋ฒ”์œ„ ์™ธ ์ ˆ๋Œ€ ์ˆ˜์ • ๊ธˆ์ง€
111
+ [ ] ๊ธฐ์กด ์ฝ”๋“œ ์กด์ค‘: ๊ธฐ์กด ์Šคํƒ€์ผ๊ณผ ๊ตฌ์กฐ ์œ ์ง€
112
+ [ ] ๋ฌธ์„œ ๊ทœ์น™ ์ค€์ˆ˜: ๋„ค์ด๋ฐ, ๊ตฌ์กฐ ๋“ฑ ๋ชจ๋“  ๊ฐ€์ด๋“œ๋ผ์ธ ์ค€์ˆ˜
113
+ ```
114
+
115
+ ## ๐ŸŽฏ ํ™ฉ๊ธˆ๋ฅ 
116
+
117
+ - **ํ•œ๊ตญ์–ด ์šฐ์„ **: ๋ชจ๋“  ์ปค๋ฎค๋‹ˆ์ผ€์ด์…˜์€ ๋ช…ํ™•ํ•œ ํ•œ๊ตญ์–ด๋กœ
118
+ - **๋‹จ์ˆœํ•จ์˜ ๋ฏธํ•™**: ์ฝ”๋“œ๊ฐ€ ์ ์„์ˆ˜๋ก ์ข‹์€ ์ฝ”๋“œ
119
+ - **DRY ์›์น™**: ๋ฐ˜๋ณตํ•˜์ง€ ๋ง๊ณ  ์žฌ์‚ฌ์šฉ
120
+ - **๋‹จ์ผ ์ฑ…์ž„**: ํ•˜๋‚˜์˜ ํ•จ์ˆ˜๋Š” ํ•˜๋‚˜์˜ ๋ชฉ์ ๋งŒ
121
+ - **์‹ค์šฉ์ฃผ์˜**: ์™„๋ฒฝ๋ณด๋‹ค ์‹ค์šฉ, YAGNI ์ •์‹