@byh3071/vhk 0.4.0 โ†’ 0.5.1

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 (3) hide show
  1. package/README.md +165 -28
  2. package/dist/index.js +1032 -316
  3. package/package.json +56 -55
package/README.md CHANGED
@@ -1,58 +1,195 @@
1
+ ---
2
+ id: vhk-readme
3
+ date: 2026-05-23
4
+ tags: [vhk, cli, readme, v0.5.1]
5
+ ---
6
+
1
7
  # ๐Ÿ”ง VHK โ€” Vibe Harness Kit
2
8
 
3
- > AI ์ฝ”๋”ฉ ์—์ด์ „ํŠธ๋ฅผ ๋ถ€๋ฆฌ๋Š” ์‚ฌ๋žŒ์„ ์œ„ํ•œ ํ’€์‚ฌ์ดํด CLI
9
+ > AI ์ฝ”๋”ฉ ์—์ด์ „ํŠธ๋ฅผ ๋ถ€๋ฆฌ๋Š” ์‚ฌ๋žŒ์„ ์œ„ํ•œ **ํ•œ๊ตญ์–ด ํ’€์‚ฌ์ดํด CLI** (v0.5.1)
10
+
11
+ ๋ช…๋ น์–ด๋ฅผ ์™ธ์šฐ์ง€ ์•Š์•„๋„ ๋ฉ๋‹ˆ๋‹ค. `vhk`๋งŒ ์น˜๋ฉด ๋ฉ”๋‰ด๊ฐ€ ๋‚˜์˜ค๊ณ , ํ•œ๊ตญ์–ด๋กœ ๋งํ•ด๋„ ์•Œ์•„๋“ฃ์Šต๋‹ˆ๋‹ค.
4
12
 
5
13
  ## ์„ค์น˜
6
14
 
7
15
  ```bash
8
- npm i -g vhk
16
+ npm install -g @byh3071/vhk
9
17
  ```
10
18
 
11
19
  ```bash
12
- # ๋˜๋Š”
13
- npx vhk init
20
+ # ํ•œ ๋ฒˆ๋งŒ ์“ธ ๋•Œ
21
+ npx @byh3071/vhk
22
+ ```
23
+
24
+ ๋กœ์ปฌ ๊ฐœ๋ฐœ ์ค‘:
25
+
26
+ ```powershell
27
+ cd vhk-cli
28
+ pnpm install
29
+ pnpm build
30
+ pnpm link --global
31
+ vhk --version
32
+ ```
33
+
34
+ ## ๋น ๋ฅธ ์‹œ์ž‘
35
+
36
+ ```bash
37
+ vhk
38
+ ```
39
+
40
+ ์ธ์ž ์—†์ด ์‹คํ–‰ํ•˜๋ฉด **ใ€Œ๋ญ˜ ๋„์™€๋“œ๋ฆด๊นŒ์š”?ใ€** ๋ฉ”๋‰ด๊ฐ€ ์—ด๋ฆฝ๋‹ˆ๋‹ค.
41
+
42
+ ```bash
43
+ # ์ž์—ฐ์–ด๋กœ๋„ ๊ฐ€๋Šฅ
44
+ vhk ํ”„๋กœ์ ํŠธ ๋งŒ๋“ค๊ณ  ์‹ถ์–ด
45
+ vhk ๊ธฐํš ๋๋‚ฌ๊ณ  ๋ฐ”๋กœ ์‹œ์ž‘
46
+ vhk ์˜ค๋Š˜ ํ•œ ์ผ ์ •๋ฆฌ
47
+ vhk ์ €์žฅํ•ด์ค˜
48
+ vhk ๋ณ€๊ฒฝ์‚ฌํ•ญ ๋ณด์—ฌ์ค˜
49
+ ```
50
+
51
+ ## ์›Œํฌํ”Œ๋กœ์šฐ (๊ถŒ์žฅ ์ˆœ์„œ)
52
+
53
+ ```text
54
+ vhk ๊ฒ€์ฆ (gate) โ†’ ์•„์ด๋””์–ด GO/๋‹ค๋“ฌ๊ธฐ/๋‹ค๋ฅธ ์•„์ด๋””์–ด
55
+ vhk ์‹œ์ž‘ (init) โ†’ ํ•˜๋„ค์Šค ํŒŒ์ผ ์ƒ์„ฑ (CLAUDE.md, PRD, ADR ํ…œํ”Œ๋ฆฟ ๋“ฑ)
56
+ ๊ฐœ๋ฐœ ...
57
+ vhk diff / ์ƒํƒœ โ†’ ๋ณ€๊ฒฝ ์š”์•ฝ ยท ๋ธŒ๋žœ์น˜ยท์›๊ฒฉ ํ˜„ํ™ฉ
58
+ vhk ์ €์žฅ (save) โ†’ git add ยท commit ยท push
59
+ vhk ์ •๋ฆฌ (recap) โ†’ ์„ธ์…˜ ๋กœ๊ทธ + ADR/ํŠธ๋Ÿฌ๋ธ”์ŠˆํŒ… ์ œ์•ˆ
60
+ vhk ์ ๊ฒ€ (check) โ†’ RULES.md ๊ทœ์น™ ๋ฆฐํŠธ
61
+ vhk ๋ณด์•ˆ โ†’ ์‹œํฌ๋ฆฟยทํ‚ค ์œ ์ถœ ๊ฒ€์‚ฌ (scan ๋ณ„์นญ ๋™์ผ)
62
+ vhk ๋ฐฐํฌ (ship) โ†’ ๋ฐฐํฌ ์ฒดํฌ๋ฆฌ์ŠคํŠธ + ํšŒ๊ณ  โ†’ docs/build-log/
14
63
  ```
15
64
 
16
- ## ์ปค๋งจ๋“œ
65
+ ๊ธฐํš์ด ์ด๋ฏธ ๋๋‚ฌ๋‹ค๋ฉด:
17
66
 
18
- | ์ปค๋งจ๋“œ | ์„ค๋ช… |
67
+ ```bash
68
+ vhk ์‹œ์ž‘ --skip-gate
69
+ # ๋˜๋Š”
70
+ vhk ๊ธฐํš ๋๋‚ฌ๊ณ  ๋ฐ”๋กœ ์‹œ์ž‘
71
+ ```
72
+
73
+ ## ์ „์ฒด ์ปค๋งจ๋“œ
74
+
75
+ | ์˜์–ด | ํ•œ๊ตญ์–ด ๋ณ„์นญ | ์„ค๋ช… |
76
+ |------|-------------|------|
77
+ | `vhk` | โ€” | ์‹œ์ž‘ ๋ฉ”๋‰ด (๋ช…๋ น ์—†์Œ) |
78
+ | `vhk gate` | `๊ฒ€์ฆ`, `์•„์ด๋””์–ด` | ์•„์ด๋””์–ด ๊ฒ€์ฆ (ํ€ต 5๋ฌธํ•ญ / ํ’€ 13๋ฌธํ•ญ / ์Šคํ‚ต) |
79
+ | `vhk init` | `์‹œ์ž‘`, `๋งŒ๋“ค๊ธฐ` | ํ”„๋กœ์ ํŠธ ์ดˆ๊ธฐํ™” + ํ•˜๋„ค์Šค ์ƒ์„ฑ |
80
+ | `vhk recap` | `์ •๋ฆฌ`, `์˜ค๋Š˜` | Git ๋ณ€๊ฒฝ โ†’ `docs/log/` ์„ธ์…˜ ๋กœ๊ทธ |
81
+ | `vhk sync` | `๊ทœ์น™`, `๋งž์ถ”๊ธฐ` | RULES.md โ†’ `.cursorrules` + CLAUDE.md |
82
+ | `vhk check` | `์ ๊ฒ€`, `๋ฆฐํŠธ` | RULES.md ๊ทœ์น™ ์œ„๋ฐ˜ ๊ฒ€์‚ฌ |
83
+ | `vhk secure` | `๋ณด์•ˆ` | ์‹œํฌ๋ฆฟยทํ‚ค ์œ ์ถœ ์Šค์บ” (`scan` / `์Šค์บ”` ๋™์ผ). **CRITICAL/HIGH ๋ฐœ๊ฒฌ ์‹œ exit code 1** (CI์šฉ) |
84
+ | `vhk ship` | `๋ฐฐํฌ`, `๋ฆด๋ฆฌ์ฆˆ` | ๋ฐฐํฌ ์ฒดํฌ๋ฆฌ์ŠคํŠธ + ํšŒ๊ณ  + ๋นŒ๋“œ ๋กœ๊ทธ |
85
+ | `vhk doctor` | `ํ™˜๊ฒฝ`, `์ง„๋‹จ` | Node / npm / pnpm / Git ํ™˜๊ฒฝ ์ ๊ฒ€ |
86
+ | `vhk save` | `์ €์žฅ`, `์ปค๋ฐ‹` | git add ยท commit ยท push ํ•œ ๋ฒˆ์— |
87
+ | `vhk undo` | `๋˜๋Œ๋ฆฌ๊ธฐ`, `์ทจ์†Œ` | ์ตœ๊ทผ ์ปค๋ฐ‹ soft reset (๋ณ€๊ฒฝ์€ staged ์œ ์ง€) |
88
+ | `vhk diff` | `๋ณ€๊ฒฝ`, `์ฐจ์ด` | staged / unstaged / ์ƒˆ ํŒŒ์ผ ์š”์•ฝ (์ค„ ์ˆ˜ ํ•ฉ๊ณ„๋Š” trackedยทHEAD ๊ธฐ์ค€) |
89
+ | `vhk status` | `์ƒํƒœ`, `ํ˜„ํ™ฉ` | ๋ธŒ๋žœ์น˜ยท๋ณ€๊ฒฝยท์ปค๋ฐ‹ยท์›๊ฒฉยท๋ฒ„์ „ ๋Œ€์‹œ๋ณด๋“œ |
90
+
91
+ ### init ์˜ต์…˜
92
+
93
+ | ์˜ต์…˜ | ์„ค๋ช… |
94
+ |------|------|
95
+ | `--skip-gate` | ์•„์ด๋””์–ด ๊ฒ€์ฆ(gate) ์ƒ๋žต |
96
+ | `--from-notion <url>` | Notion PRD ํŽ˜์ด์ง€์—์„œ import |
97
+ | `--name`, `--description`, `--type` | ๋น„๋Œ€ํ™”ํ˜• ์ž…๋ ฅ |
98
+ | `-y, --yes` | ์Šคํƒ ํ™•์ธ ์Šคํ‚ต |
99
+
100
+ ### recap ์˜ต์…˜
101
+
102
+ | ์˜ต์…˜ | ์„ค๋ช… |
103
+ |------|------|
104
+ | `--since YYYY-MM-DD` | ๋ถ„์„ ์‹œ์ž‘์ผ (๊ธฐ๋ณธ: ์˜ค๋Š˜) |
105
+
106
+ ## v0.5.0 ํ•˜์ด๋ผ์ดํŠธ
107
+
108
+ | ๊ธฐ๋Šฅ | ์„ค๋ช… |
109
+ |------|------|
110
+ | **save** | ๋ณ€๊ฒฝ ๋ชฉ๋ก ํ™•์ธ โ†’ ์ปค๋ฐ‹ โ†’ push (์›๊ฒฉ ์—†์œผ๋ฉด ๋กœ์ปฌ๋งŒ) |
111
+ | **undo** | ์ตœ๊ทผ 1~5์ปค๋ฐ‹ soft reset, ์›๊ฒฉ push ์‹œ ๊ฒฝ๊ณ ยทํ™•์ธ |
112
+ | **diff** | staged / unstaged / untracked + HEAD ๋Œ€๋น„ ์ค„ ์ˆ˜ |
113
+ | **status** | ๋ธŒ๋žœ์น˜, ๋ณ€๊ฒฝ ๊ฐœ์ˆ˜, ์ตœ๊ทผ ์ปค๋ฐ‹, upstream sync |
114
+ | **๋ณด์•ˆ ๊ฒฝ๊ณ ** | save / init / recap ์ „ `.env`ยท๋ฏผ๊ฐ ํŒŒ์ผ ๋…ธ์ถœ ์•ˆ๋‚ด |
115
+
116
+ ## v0.4.0 ํ•˜์ด๋ผ์ดํŠธ
117
+
118
+ | ๊ธฐ๋Šฅ | ์„ค๋ช… |
119
+ |------|------|
120
+ | **์‹œ์ž‘ ๋ฉ”๋‰ด** | `vhk`๋งŒ ์ž…๋ ฅํ•ด๋„ ๋‹ค์Œ ์ž‘์—… ์„ ํƒ |
121
+ | **ํ•œ๊ตญ์–ด ๋ณ„์นญ** | `vhk ๊ฒ€์ฆ`, `vhk ์‹œ์ž‘`, `vhk ์ •๋ฆฌ` ๋“ฑ |
122
+ | **์ž์—ฐ์–ด ๋ผ์šฐํŒ…** | `vhk "ํ”„๋กœ์ ํŠธ ๋งŒ๋“ค๊ณ  ์‹ถ์–ด"` โ†’ init ์‹คํ–‰ |
123
+ | **doctor** | Node / npm / pnpm / Git + ํ”„๋กœ์ ํŠธ ํŒŒ์ผ ์ ๊ฒ€ |
124
+ | **ship** | ๋ฐฐํฌ ์ „ ์ฒดํฌ๋ฆฌ์ŠคํŠธ, ํšŒ๊ณ , `docs/build-log/` ์ƒ์„ฑ |
125
+ | **๋‹ค์Œ์— ์ด๊ฒƒ๋งŒ ํ•˜์„ธ์š”** | ๊ฐ ๋ช…๋ น ๋์— ๋ณต๋ถ™ ๋ช…๋ น + Cursor ํžŒํŠธ |
126
+ | **check / secure** | RULES ๋ฆฐํŠธ, ์‹œํฌ๋ฆฟ ์Šค์บ” (๋Œ€ํ˜• lockยทnode_modules ์ œ์™ธ) |
127
+
128
+ ## init์ด ๋งŒ๋“œ๋Š” ๊ฒƒ (์š”์•ฝ)
129
+
130
+ - `CLAUDE.md`, `.cursorrules`
131
+ - `docs/PRD.md`, `docs/ARCHITECTURE.md`
132
+ - `docs/adr/`, `docs/log/`, `docs/troubleshooting/`
133
+ - `COMMANDS.md`, `BACKLOG.md` (ํ”„๋กœ์ ํŠธ ์œ ํ˜•์— ๋”ฐ๋ผ)
134
+ - `package.json` scripts: `save`, `check`, `scan`, `recap`, `ship`, `doctor` โ†’ `vhk` ํ˜ธ์ถœ
135
+
136
+ ## ์ž์—ฐ์–ด ์˜ˆ์‹œ
137
+
138
+ | ๋งํ•˜๋ฉด | ์‹คํ–‰ |
19
139
  |--------|------|
20
- | `vhk gate` | ์•„์ด๋””์–ด 13๋‹จ๊ณ„ ๊ฒ€์ฆ โ†’ GO/REFINE/DROP |
21
- | `vhk init` | ํ”„๋กœ์ ํŠธ ์ดˆ๊ธฐํ™” + ํ•˜๋„ค์Šค ํŒŒ์ผ ์ž๋™ ์ƒ์„ฑ |
22
- | `vhk recap` | Git diff โ†’ ์„ธ์…˜ ๋กœ๊ทธ ์ž๋™ ์ƒ์„ฑ |
23
- | `vhk sync` | RULES.md โ†’ `.cursorrules` + `CLAUDE.md` ๋™๊ธฐํ™” |
140
+ | ํ”„๋กœ์ ํŠธ ๋งŒ๋“ค๊ณ  ์‹ถ์–ด | `vhk ์‹œ์ž‘` |
141
+ | ๊ธฐํš ๋๋‚ฌ๊ณ  ๋ฐ”๋กœ ์‹œ์ž‘ | `vhk ์‹œ์ž‘ --skip-gate` |
142
+ | ์˜ค๋Š˜ ํ•œ ์ผ ์ •๋ฆฌ | `vhk ์ •๋ฆฌ` |
143
+ | ์ €์žฅํ•ด์ค˜ / ํ‘ธ์‹œ ์˜ฌ๋ ค | `vhk ์ €์žฅ` |
144
+ | ์ปค๋ฐ‹ ์ทจ์†Œ / ๋กค๋ฐฑ | `vhk ๋˜๋Œ๋ฆฌ๊ธฐ` |
145
+ | ๋ญ ๋ฐ”๋€Œ์—ˆ์–ด | `vhk diff` |
146
+ | ํ”„๋กœ์ ํŠธ ํ˜„ํ™ฉ | `vhk ์ƒํƒœ` |
147
+ | ๋ณด์•ˆ ์Šค์บ” ๋Œ๋ ค | `vhk ๋ณด์•ˆ` |
148
+ | ๋ฐฐํฌํ•˜๊ณ  ์‹ถ์–ด | `vhk ๋ฐฐํฌ` |
149
+ | ๋ญ”๊ฐ€ ์•ˆ ๋ผ | `vhk doctor` |
24
150
 
25
151
  ## ํŠน์ง•
26
152
 
27
- - ๐Ÿ‡ฐ๐Ÿ‡ท **ํ•œ๊ตญ์–ด ํผ์ŠคํŠธ** โ€” ํ„ฐ๋ฏธ๋„ ์ „์ฒด๊ฐ€ ํ•œ๊ตญ์–ด๋กœ ๋™์ž‘
28
- - โšก **์ œ๋กœ ์„ค์ •** โ€” `npx vhk init` ํ•œ ๋ฐฉ์ด๋ฉด ๋
29
- - ๐Ÿ“ **๋กœ์ปฌ ํผ์ŠคํŠธ** โ€” ๋ฐ์ดํ„ฐ๋Š” ํ”„๋กœ์ ํŠธ ํด๋”์— ์ €์žฅ
30
- - ๐Ÿ• **๋…ํ‘ธ๋”ฉ** โ€” VHK ์ž์ฒด๊ฐ€ VHK๋กœ ๋งŒ๋“ค์–ด์ง
153
+ - ๐Ÿ‡ฐ๐Ÿ‡ท **ํ•œ๊ตญ์–ด ํผ์ŠคํŠธ** โ€” ์งˆ๋ฌธยทํŒ์ •ยท๋‹ค์Œ ๋‹จ๊ณ„ ์•ˆ๋‚ด๊ฐ€ ํ•œ๊ตญ์–ด
154
+ - ๐Ÿ—ฃ๏ธ **์ž์—ฐ์–ด ์นœํ™”** โ€” ๋ช…๋ น์–ด ๋ชฐ๋ผ๋„ ๋ฌธ์žฅ์œผ๋กœ ์‹œ์ž‘
155
+ - ๐Ÿ“ **๋กœ์ปฌ ํผ์ŠคํŠธ** โ€” ๋กœ๊ทธยทADRยท๋นŒ๋“œ ๋กœ๊ทธ๋Š” ํ”„๋กœ์ ํŠธ ํด๋”์— ์ €์žฅ
156
+ - ๐Ÿ”’ **๋ณด์•ˆ ๊ธฐ๋ณธ** โ€” `.gitignore`ยท์‹œํฌ๋ฆฟ ์Šค์บ”ยท๋ฏผ๊ฐ ํŒŒ์ผ ๊ฒฝ๊ณ 
31
157
 
32
158
  ## ์š”๊ตฌ ์‚ฌํ•ญ
33
159
 
34
160
  - Node.js >= 20
161
+ - Git (recapยทsaveยทship ๊ถŒ์žฅ)
162
+
163
+ ## ๊ฐœ๋ฐœ
164
+
165
+ ```powershell
166
+ pnpm install
167
+ pnpm build
168
+ pnpm test --run
169
+ pnpm dev
170
+ pnpm dev ๊ฒ€์ฆ
171
+ ```
172
+
173
+ > Windows PowerShell 5.x: `&&` ๋Œ€์‹  `;` ์‚ฌ์šฉ (`pnpm build; pnpm test --run`)
174
+ > ์‹คํ–‰ ์ •์ฑ…์œผ๋กœ `pnpm`์ด ๋ง‰ํžˆ๋ฉด **`pnpm.cmd`** ์‚ฌ์šฉ: `pnpm.cmd install`, `pnpm.cmd test --run`
175
+
176
+ ### CI์—์„œ secure
177
+
178
+ `vhk ๋ณด์•ˆ` / `vhk secure scan`์€ **CRITICAL ๋˜๋Š” HIGH** ํŒจํ„ด์ด ์žˆ์œผ๋ฉด **exit code 1**์ž…๋‹ˆ๋‹ค. MEDIUM๋งŒ ์žˆ์œผ๋ฉด 0์ž…๋‹ˆ๋‹ค.
35
179
 
36
180
  ## ๋ผ์ด์„ ์Šค
37
181
 
38
- MIT
182
+ MIT โ€” [LICENSE](LICENSE)
39
183
 
40
184
  ## ๋ฐฐํฌ (maintainers)
41
185
 
42
186
  ```bash
43
- # 1. npm ๋กœ๊ทธ์ธ (์ตœ์ดˆ 1ํšŒ)
44
187
  npm login
45
-
46
- # 2. ๋นŒ๋“œ + ํ…Œ์ŠคํŠธ
47
- pnpm build
48
- pnpm test
49
-
50
- # 3. ๋ฐฐํฌ
51
- npm publish
52
-
53
- # 4. ํ™•์ธ
54
- npm info vhk
55
- npx vhk --help
188
+ pnpm run prepublishOnly
189
+ npm publish --access public
190
+ npm info @byh3071/vhk
56
191
  ```
57
192
 
58
- `package.json`์˜ `prepublishOnly` ์Šคํฌ๋ฆฝํŠธ๊ฐ€ publish ์ „์— ๋นŒ๋“œยทํ…Œ์ŠคํŠธ๋ฅผ ์ž๋™ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.
193
+ `prepublishOnly`๊ฐ€ publish ์ „์— `pnpm build && pnpm test:run`์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.
194
+
195
+ Repository: https://github.com/byh3071-cpu/vhk