@mandujs/mcp 0.12.2 → 0.13.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 (141) hide show
  1. package/README.md +367 -367
  2. package/package.json +2 -2
  3. package/src/activity-monitor.ts +847 -847
  4. package/src/adapters/index.ts +20 -20
  5. package/src/adapters/monitor-adapter.ts +100 -100
  6. package/src/adapters/tool-adapter.ts +88 -88
  7. package/src/executor/error-handler.ts +250 -250
  8. package/src/executor/index.ts +22 -22
  9. package/src/executor/tool-executor.ts +148 -148
  10. package/src/hooks/config-watcher.ts +174 -174
  11. package/src/hooks/index.ts +23 -23
  12. package/src/hooks/mcp-hooks.ts +227 -227
  13. package/src/index.ts +106 -106
  14. package/src/logging/index.ts +15 -15
  15. package/src/logging/mcp-transport.ts +134 -134
  16. package/src/registry/index.ts +13 -13
  17. package/src/registry/mcp-tool-registry.ts +298 -298
  18. package/src/resources/skills/guides.ts +1136 -1136
  19. package/src/resources/skills/index.ts +12 -12
  20. package/src/resources/skills/loader.ts +218 -218
  21. package/src/resources/skills/mandu-composition/SKILL.md +91 -91
  22. package/src/resources/skills/mandu-composition/metadata.json +13 -13
  23. package/src/resources/skills/mandu-composition/rules/_sections.md +26 -26
  24. package/src/resources/skills/mandu-composition/rules/_template.md +77 -77
  25. package/src/resources/skills/mandu-composition/rules/comp-arch-avoid-boolean-props.md +146 -146
  26. package/src/resources/skills/mandu-composition/rules/comp-arch-compound-components.md +164 -164
  27. package/src/resources/skills/mandu-composition/rules/comp-island-event.md +161 -161
  28. package/src/resources/skills/mandu-composition/rules/comp-island-slot-split.md +167 -167
  29. package/src/resources/skills/mandu-composition/rules/comp-pattern-children.md +149 -149
  30. package/src/resources/skills/mandu-composition/rules/comp-state-context-interface.md +148 -148
  31. package/src/resources/skills/mandu-composition/rules/comp-state-lift-state.md +150 -150
  32. package/src/resources/skills/mandu-deployment/SKILL.md +92 -92
  33. package/src/resources/skills/mandu-deployment/_sections.md +41 -41
  34. package/src/resources/skills/mandu-deployment/_template.md +38 -38
  35. package/src/resources/skills/mandu-deployment/metadata.json +13 -13
  36. package/src/resources/skills/mandu-deployment/rules/deploy-build-bun.md +109 -109
  37. package/src/resources/skills/mandu-deployment/rules/deploy-build-output.md +115 -115
  38. package/src/resources/skills/mandu-deployment/rules/deploy-cicd-github.md +219 -219
  39. package/src/resources/skills/mandu-deployment/rules/deploy-docker-bun.md +150 -150
  40. package/src/resources/skills/mandu-deployment/rules/deploy-docker-compose.md +223 -223
  41. package/src/resources/skills/mandu-deployment/rules/deploy-platform-fly.md +152 -152
  42. package/src/resources/skills/mandu-deployment/rules/deploy-platform-render.md +179 -179
  43. package/src/resources/skills/mandu-deployment/rules/deploy-platform-supabase.md +323 -323
  44. package/src/resources/skills/mandu-deployment/rules/deploy-platform-vercel.md +140 -140
  45. package/src/resources/skills/mandu-fs-routes/SKILL.md +82 -82
  46. package/src/resources/skills/mandu-fs-routes/metadata.json +12 -12
  47. package/src/resources/skills/mandu-fs-routes/rules/_sections.md +36 -36
  48. package/src/resources/skills/mandu-fs-routes/rules/_template.md +69 -69
  49. package/src/resources/skills/mandu-fs-routes/rules/routes-api-methods.md +65 -65
  50. package/src/resources/skills/mandu-fs-routes/rules/routes-dynamic-param.md +93 -93
  51. package/src/resources/skills/mandu-fs-routes/rules/routes-naming-page.md +55 -55
  52. package/src/resources/skills/mandu-guard/SKILL.md +129 -129
  53. package/src/resources/skills/mandu-guard/metadata.json +12 -12
  54. package/src/resources/skills/mandu-guard/rules/_sections.md +36 -36
  55. package/src/resources/skills/mandu-guard/rules/_template.md +82 -82
  56. package/src/resources/skills/mandu-guard/rules/guard-config-rules.md +100 -100
  57. package/src/resources/skills/mandu-guard/rules/guard-layer-direction.md +76 -76
  58. package/src/resources/skills/mandu-guard/rules/guard-preset-mandu.md +81 -81
  59. package/src/resources/skills/mandu-guard/rules/guard-validate-import.md +80 -80
  60. package/src/resources/skills/mandu-hydration/SKILL.md +91 -91
  61. package/src/resources/skills/mandu-hydration/metadata.json +12 -12
  62. package/src/resources/skills/mandu-hydration/rules/_sections.md +31 -31
  63. package/src/resources/skills/mandu-hydration/rules/_template.md +72 -72
  64. package/src/resources/skills/mandu-hydration/rules/hydration-data-event.md +109 -109
  65. package/src/resources/skills/mandu-hydration/rules/hydration-directive-use-client.md +55 -55
  66. package/src/resources/skills/mandu-hydration/rules/hydration-island-setup.md +113 -113
  67. package/src/resources/skills/mandu-hydration/rules/hydration-priority-visible.md +68 -68
  68. package/src/resources/skills/mandu-performance/SKILL.md +85 -85
  69. package/src/resources/skills/mandu-performance/metadata.json +14 -14
  70. package/src/resources/skills/mandu-performance/rules/_sections.md +31 -31
  71. package/src/resources/skills/mandu-performance/rules/_template.md +64 -64
  72. package/src/resources/skills/mandu-performance/rules/perf-async-defer-await.md +103 -103
  73. package/src/resources/skills/mandu-performance/rules/perf-async-parallel.md +95 -95
  74. package/src/resources/skills/mandu-performance/rules/perf-bun-file.md +124 -124
  75. package/src/resources/skills/mandu-performance/rules/perf-bun-serve.md +125 -125
  76. package/src/resources/skills/mandu-performance/rules/perf-bundle-imports.md +80 -80
  77. package/src/resources/skills/mandu-performance/rules/perf-bundle-island-lazy.md +145 -145
  78. package/src/resources/skills/mandu-performance/rules/perf-cache-react.md +98 -98
  79. package/src/resources/skills/mandu-performance/rules/perf-render-transitions.md +154 -154
  80. package/src/resources/skills/mandu-security/SKILL.md +87 -87
  81. package/src/resources/skills/mandu-security/metadata.json +13 -13
  82. package/src/resources/skills/mandu-security/rules/_sections.md +31 -31
  83. package/src/resources/skills/mandu-security/rules/_template.md +74 -74
  84. package/src/resources/skills/mandu-security/rules/sec-auth-guard.md +127 -127
  85. package/src/resources/skills/mandu-security/rules/sec-env-management.md +133 -133
  86. package/src/resources/skills/mandu-security/rules/sec-input-validate.md +148 -148
  87. package/src/resources/skills/mandu-security/rules/sec-protect-csrf.md +146 -146
  88. package/src/resources/skills/mandu-security/rules/sec-protect-headers.md +138 -138
  89. package/src/resources/skills/mandu-slot/SKILL.md +85 -85
  90. package/src/resources/skills/mandu-slot/metadata.json +12 -12
  91. package/src/resources/skills/mandu-slot/rules/_sections.md +36 -36
  92. package/src/resources/skills/mandu-slot/rules/_template.md +63 -63
  93. package/src/resources/skills/mandu-slot/rules/slot-basic-structure.md +38 -38
  94. package/src/resources/skills/mandu-slot/rules/slot-ctx-response.md +56 -56
  95. package/src/resources/skills/mandu-slot/rules/slot-guard-auth.md +59 -59
  96. package/src/resources/skills/mandu-slot/rules/slot-http-methods.md +64 -64
  97. package/src/resources/skills/mandu-styling/SKILL.md +154 -154
  98. package/src/resources/skills/mandu-styling/_sections.md +43 -43
  99. package/src/resources/skills/mandu-styling/_template.md +32 -32
  100. package/src/resources/skills/mandu-styling/metadata.json +15 -15
  101. package/src/resources/skills/mandu-styling/rules/style-component-compound.md +235 -235
  102. package/src/resources/skills/mandu-styling/rules/style-component-slots.md +255 -255
  103. package/src/resources/skills/mandu-styling/rules/style-component-tokens.md +205 -205
  104. package/src/resources/skills/mandu-styling/rules/style-island-animations.md +272 -272
  105. package/src/resources/skills/mandu-styling/rules/style-island-scoping.md +167 -167
  106. package/src/resources/skills/mandu-styling/rules/style-island-variants.md +221 -221
  107. package/src/resources/skills/mandu-styling/rules/style-perf-critical.md +209 -209
  108. package/src/resources/skills/mandu-styling/rules/style-perf-purge.md +192 -192
  109. package/src/resources/skills/mandu-styling/rules/style-setup-modules.md +162 -162
  110. package/src/resources/skills/mandu-styling/rules/style-setup-panda.md +164 -164
  111. package/src/resources/skills/mandu-styling/rules/style-setup-tailwind.md +170 -170
  112. package/src/resources/skills/mandu-styling/rules/style-tailwind-v4-gotchas.md +179 -179
  113. package/src/resources/skills/mandu-styling/rules/style-theme-darkmode.md +229 -229
  114. package/src/resources/skills/mandu-testing/SKILL.md +99 -99
  115. package/src/resources/skills/mandu-testing/metadata.json +13 -13
  116. package/src/resources/skills/mandu-testing/rules/_sections.md +26 -26
  117. package/src/resources/skills/mandu-testing/rules/_template.md +65 -65
  118. package/src/resources/skills/mandu-testing/rules/test-component-island.md +195 -195
  119. package/src/resources/skills/mandu-testing/rules/test-e2e-playwright.md +196 -196
  120. package/src/resources/skills/mandu-testing/rules/test-mock-fetch.md +219 -219
  121. package/src/resources/skills/mandu-testing/rules/test-slot-unit.md +192 -192
  122. package/src/resources/skills/mandu-ui/SKILL.md +117 -117
  123. package/src/resources/skills/mandu-ui/_sections.md +23 -23
  124. package/src/resources/skills/mandu-ui/_template.md +32 -32
  125. package/src/resources/skills/mandu-ui/metadata.json +13 -13
  126. package/src/resources/skills/mandu-ui/rules/ui-accessibility-aria.md +232 -232
  127. package/src/resources/skills/mandu-ui/rules/ui-accessibility-focus.md +238 -238
  128. package/src/resources/skills/mandu-ui/rules/ui-composition-patterns.md +259 -259
  129. package/src/resources/skills/mandu-ui/rules/ui-island-integration.md +258 -258
  130. package/src/resources/skills/mandu-ui/rules/ui-radix-patterns.md +213 -213
  131. package/src/resources/skills/mandu-ui/rules/ui-shadcn-setup.md +209 -209
  132. package/src/resources/skills/recipes.ts +932 -932
  133. package/src/tools/generate.ts +7 -4
  134. package/src/tools/guard.ts +17 -4
  135. package/src/tools/hydration.ts +10 -10
  136. package/src/tools/project.ts +334 -334
  137. package/src/tools/runtime.ts +497 -497
  138. package/src/tools/seo.ts +417 -417
  139. package/src/tools/spec.ts +80 -159
  140. package/src/utils/project.ts +22 -12
  141. package/src/utils/withWarnings.ts +83 -83
@@ -1,92 +1,92 @@
1
- ---
2
- name: Mandu Deployment
3
- description: Production deployment patterns for Mandu applications
4
- metadata:
5
- version: "1.0.0"
6
- author: mandu
7
- globs:
8
- - "render.yaml"
9
- - "Dockerfile"
10
- - "docker-compose.yml"
11
- - ".github/workflows/*.yml"
12
- - "bunfig.toml"
13
- ---
14
-
15
- # Mandu Deployment Skill
16
-
17
- Mandu 앱을 프로덕션 환경에 안전하고 효율적으로 배포하기 위한 가이드입니다.
18
-
19
- ## 핵심 원칙
20
-
21
- 1. **Bun 네이티브**: Bun 런타임과 번들러를 최대한 활용
22
- 2. **환경 분리**: 개발/스테이징/프로덕션 환경 명확히 구분
23
- 3. **자동화**: CI/CD를 통한 일관된 배포 프로세스
24
- 4. **보안 우선**: 민감 정보는 환경 변수로 관리
25
-
26
- ## 빠른 시작
27
-
28
- ### Render 배포 (권장)
29
-
30
- ```yaml
31
- # render.yaml
32
- services:
33
- - type: web
34
- name: mandu-app
35
- runtime: node
36
- buildCommand: bun install && bun run build
37
- startCommand: bun run start
38
- envVars:
39
- - key: NODE_ENV
40
- value: production
41
- - key: BUN_ENV
42
- value: production
43
- ```
44
-
45
- ### Docker 배포
46
-
47
- ```dockerfile
48
- FROM oven/bun:1.0
49
-
50
- WORKDIR /app
51
- COPY package.json bun.lockb ./
52
- RUN bun install --frozen-lockfile --production
53
-
54
- COPY . .
55
- RUN bun run build
56
-
57
- EXPOSE 3000
58
- CMD ["bun", "run", "start"]
59
- ```
60
-
61
- ## 배포 체크리스트
62
-
63
- ### 빌드 준비
64
- - [ ] `bun run build` 성공 확인
65
- - [ ] 번들 크기 최적화 (tree-shaking, code-splitting)
66
- - [ ] 환경 변수 설정 완료
67
-
68
- ### 플랫폼 설정
69
- - [ ] Render/Docker 설정 파일 작성
70
- - [ ] 헬스체크 엔드포인트 구현
71
- - [ ] 로깅 설정 완료
72
-
73
- ### 보안
74
- - [ ] 민감 정보 환경 변수로 분리
75
- - [ ] HTTPS 강제 적용
76
- - [ ] 보안 헤더 설정
77
-
78
- ### 모니터링
79
- - [ ] 에러 트래킹 설정
80
- - [ ] 성능 모니터링 구성
81
- - [ ] 알림 설정
82
-
83
- ## 규칙 카테고리
84
-
85
- | Category | Description | Rules |
86
- |----------|-------------|-------|
87
- | Build | 프로덕션 빌드 최적화 | 2 |
88
- | Platform | 플랫폼별 배포 설정 | 3 |
89
- | Container | Docker 컨테이너화 | 2 |
90
- | CI/CD | 자동화 파이프라인 | 1 |
91
-
92
- → 세부 규칙은 `rules/` 폴더 참조
1
+ ---
2
+ name: Mandu Deployment
3
+ description: Production deployment patterns for Mandu applications
4
+ metadata:
5
+ version: "1.0.0"
6
+ author: mandu
7
+ globs:
8
+ - "render.yaml"
9
+ - "Dockerfile"
10
+ - "docker-compose.yml"
11
+ - ".github/workflows/*.yml"
12
+ - "bunfig.toml"
13
+ ---
14
+
15
+ # Mandu Deployment Skill
16
+
17
+ Mandu 앱을 프로덕션 환경에 안전하고 효율적으로 배포하기 위한 가이드입니다.
18
+
19
+ ## 핵심 원칙
20
+
21
+ 1. **Bun 네이티브**: Bun 런타임과 번들러를 최대한 활용
22
+ 2. **환경 분리**: 개발/스테이징/프로덕션 환경 명확히 구분
23
+ 3. **자동화**: CI/CD를 통한 일관된 배포 프로세스
24
+ 4. **보안 우선**: 민감 정보는 환경 변수로 관리
25
+
26
+ ## 빠른 시작
27
+
28
+ ### Render 배포 (권장)
29
+
30
+ ```yaml
31
+ # render.yaml
32
+ services:
33
+ - type: web
34
+ name: mandu-app
35
+ runtime: node
36
+ buildCommand: bun install && bun run build
37
+ startCommand: bun run start
38
+ envVars:
39
+ - key: NODE_ENV
40
+ value: production
41
+ - key: BUN_ENV
42
+ value: production
43
+ ```
44
+
45
+ ### Docker 배포
46
+
47
+ ```dockerfile
48
+ FROM oven/bun:1.0
49
+
50
+ WORKDIR /app
51
+ COPY package.json bun.lockb ./
52
+ RUN bun install --frozen-lockfile --production
53
+
54
+ COPY . .
55
+ RUN bun run build
56
+
57
+ EXPOSE 3000
58
+ CMD ["bun", "run", "start"]
59
+ ```
60
+
61
+ ## 배포 체크리스트
62
+
63
+ ### 빌드 준비
64
+ - [ ] `bun run build` 성공 확인
65
+ - [ ] 번들 크기 최적화 (tree-shaking, code-splitting)
66
+ - [ ] 환경 변수 설정 완료
67
+
68
+ ### 플랫폼 설정
69
+ - [ ] Render/Docker 설정 파일 작성
70
+ - [ ] 헬스체크 엔드포인트 구현
71
+ - [ ] 로깅 설정 완료
72
+
73
+ ### 보안
74
+ - [ ] 민감 정보 환경 변수로 분리
75
+ - [ ] HTTPS 강제 적용
76
+ - [ ] 보안 헤더 설정
77
+
78
+ ### 모니터링
79
+ - [ ] 에러 트래킹 설정
80
+ - [ ] 성능 모니터링 구성
81
+ - [ ] 알림 설정
82
+
83
+ ## 규칙 카테고리
84
+
85
+ | Category | Description | Rules |
86
+ |----------|-------------|-------|
87
+ | Build | 프로덕션 빌드 최적화 | 2 |
88
+ | Platform | 플랫폼별 배포 설정 | 3 |
89
+ | Container | Docker 컨테이너화 | 2 |
90
+ | CI/CD | 자동화 파이프라인 | 1 |
91
+
92
+ → 세부 규칙은 `rules/` 폴더 참조
@@ -1,41 +1,41 @@
1
- # Mandu Deployment - Rule Categories
2
-
3
- ## Build
4
- 프로덕션 빌드 최적화 및 번들링 설정
5
-
6
- | Impact | Description |
7
- |--------|-------------|
8
- | CRITICAL | 빌드 실패 시 배포 불가 |
9
- | HIGH | 번들 크기, 빌드 시간에 큰 영향 |
10
-
11
- ## Platform
12
- 배포 플랫폼별 설정 및 최적화
13
-
14
- | Impact | Description |
15
- |--------|-------------|
16
- | CRITICAL | 플랫폼 호환성 필수 |
17
- | HIGH | 성능, 비용에 큰 영향 |
18
-
19
- ## Container
20
- Docker 컨테이너화 및 오케스트레이션
21
-
22
- | Impact | Description |
23
- |--------|-------------|
24
- | HIGH | 일관된 배포 환경 보장 |
25
- | MEDIUM | 개발/프로덕션 환경 일치 |
26
-
27
- ## CI/CD
28
- 지속적 통합 및 배포 파이프라인
29
-
30
- | Impact | Description |
31
- |--------|-------------|
32
- | HIGH | 자동화된 품질 보증 |
33
- | MEDIUM | 배포 속도 및 안정성 향상 |
34
-
35
- ## Environment
36
- 환경 변수 및 설정 관리
37
-
38
- | Impact | Description |
39
- |--------|-------------|
40
- | CRITICAL | 보안 민감 정보 보호 |
41
- | HIGH | 환경별 설정 분리 |
1
+ # Mandu Deployment - Rule Categories
2
+
3
+ ## Build
4
+ 프로덕션 빌드 최적화 및 번들링 설정
5
+
6
+ | Impact | Description |
7
+ |--------|-------------|
8
+ | CRITICAL | 빌드 실패 시 배포 불가 |
9
+ | HIGH | 번들 크기, 빌드 시간에 큰 영향 |
10
+
11
+ ## Platform
12
+ 배포 플랫폼별 설정 및 최적화
13
+
14
+ | Impact | Description |
15
+ |--------|-------------|
16
+ | CRITICAL | 플랫폼 호환성 필수 |
17
+ | HIGH | 성능, 비용에 큰 영향 |
18
+
19
+ ## Container
20
+ Docker 컨테이너화 및 오케스트레이션
21
+
22
+ | Impact | Description |
23
+ |--------|-------------|
24
+ | HIGH | 일관된 배포 환경 보장 |
25
+ | MEDIUM | 개발/프로덕션 환경 일치 |
26
+
27
+ ## CI/CD
28
+ 지속적 통합 및 배포 파이프라인
29
+
30
+ | Impact | Description |
31
+ |--------|-------------|
32
+ | HIGH | 자동화된 품질 보증 |
33
+ | MEDIUM | 배포 속도 및 안정성 향상 |
34
+
35
+ ## Environment
36
+ 환경 변수 및 설정 관리
37
+
38
+ | Impact | Description |
39
+ |--------|-------------|
40
+ | CRITICAL | 보안 민감 정보 보호 |
41
+ | HIGH | 환경별 설정 분리 |
@@ -1,38 +1,38 @@
1
- ---
2
- title: Rule Title Here
3
- impact: CRITICAL | HIGH | MEDIUM | LOW
4
- impactDescription: One-line description of why this matters
5
- tags: deployment, tag2, tag3
6
- ---
7
-
8
- ## Rule Title Here
9
-
10
- **Impact: LEVEL (Impact description)**
11
-
12
- 규칙에 대한 간단한 설명.
13
-
14
- **설정 예시:**
15
-
16
- ```yaml
17
- # 설정 파일 예시
18
- key: value
19
- ```
20
-
21
- **구현 예시:**
22
-
23
- ```typescript
24
- // 코드 예시
25
- ```
26
-
27
- ## 추가 설정
28
-
29
- ```bash
30
- # 명령어 예시
31
- ```
32
-
33
- ## 주의사항
34
-
35
- - 첫 번째 주의사항
36
- - 두 번째 주의사항
37
-
38
- Reference: [문서 링크](https://example.com)
1
+ ---
2
+ title: Rule Title Here
3
+ impact: CRITICAL | HIGH | MEDIUM | LOW
4
+ impactDescription: One-line description of why this matters
5
+ tags: deployment, tag2, tag3
6
+ ---
7
+
8
+ ## Rule Title Here
9
+
10
+ **Impact: LEVEL (Impact description)**
11
+
12
+ 규칙에 대한 간단한 설명.
13
+
14
+ **설정 예시:**
15
+
16
+ ```yaml
17
+ # 설정 파일 예시
18
+ key: value
19
+ ```
20
+
21
+ **구현 예시:**
22
+
23
+ ```typescript
24
+ // 코드 예시
25
+ ```
26
+
27
+ ## 추가 설정
28
+
29
+ ```bash
30
+ # 명령어 예시
31
+ ```
32
+
33
+ ## 주의사항
34
+
35
+ - 첫 번째 주의사항
36
+ - 두 번째 주의사항
37
+
38
+ Reference: [문서 링크](https://example.com)
@@ -1,13 +1,13 @@
1
- {
2
- "id": "mandu-deployment",
3
- "name": "Mandu Deployment",
4
- "version": "1.0.0",
5
- "description": "Production deployment patterns for Mandu applications",
6
- "author": "mandu",
7
- "references": [
8
- "https://bun.sh/docs/bundler",
9
- "https://render.com/docs",
10
- "https://docs.docker.com/"
11
- ],
12
- "abstract": "Mandu 앱을 프로덕션 환경에 배포하기 위한 패턴과 가이드. Bun 빌드 최적화, Render/Docker 배포, CI/CD 파이프라인, 환경 설정을 다룹니다."
13
- }
1
+ {
2
+ "id": "mandu-deployment",
3
+ "name": "Mandu Deployment",
4
+ "version": "1.0.0",
5
+ "description": "Production deployment patterns for Mandu applications",
6
+ "author": "mandu",
7
+ "references": [
8
+ "https://bun.sh/docs/bundler",
9
+ "https://render.com/docs",
10
+ "https://docs.docker.com/"
11
+ ],
12
+ "abstract": "Mandu 앱을 프로덕션 환경에 배포하기 위한 패턴과 가이드. Bun 빌드 최적화, Render/Docker 배포, CI/CD 파이프라인, 환경 설정을 다룹니다."
13
+ }
@@ -1,109 +1,109 @@
1
- ---
2
- title: Bun Production Build
3
- impact: CRITICAL
4
- impactDescription: Build failure blocks deployment
5
- tags: deployment, build, bun, bundler
6
- ---
7
-
8
- ## Bun Production Build
9
-
10
- **Impact: CRITICAL (Build failure blocks deployment)**
11
-
12
- Bun 번들러를 사용하여 프로덕션 최적화된 빌드를 생성하세요.
13
-
14
- **bunfig.toml 설정:**
15
-
16
- ```toml
17
- [build]
18
- target = "bun"
19
- minify = true
20
- sourcemap = "external"
21
-
22
- [build.define]
23
- "process.env.NODE_ENV" = "'production'"
24
- ```
25
-
26
- **빌드 스크립트:**
27
-
28
- ```typescript
29
- // scripts/build.ts
30
- import { $ } from "bun";
31
-
32
- // 클린 빌드
33
- await $`rm -rf dist`;
34
-
35
- // 서버 빌드
36
- await Bun.build({
37
- entrypoints: ["./src/server.ts"],
38
- outdir: "./dist",
39
- target: "bun",
40
- minify: true,
41
- sourcemap: "external",
42
- define: {
43
- "process.env.NODE_ENV": JSON.stringify("production"),
44
- },
45
- });
46
-
47
- // 클라이언트 빌드 (Islands)
48
- await Bun.build({
49
- entrypoints: ["./app/**/client.tsx"],
50
- outdir: "./dist/public",
51
- target: "browser",
52
- minify: true,
53
- splitting: true,
54
- sourcemap: "external",
55
- });
56
-
57
- console.log("✅ Build complete");
58
- ```
59
-
60
- ## package.json 스크립트
61
-
62
- ```json
63
- {
64
- "scripts": {
65
- "build": "bun run scripts/build.ts",
66
- "start": "NODE_ENV=production bun run dist/server.js",
67
- "preview": "bun run build && bun run start"
68
- }
69
- }
70
- ```
71
-
72
- ## 빌드 최적화 옵션
73
-
74
- ```typescript
75
- await Bun.build({
76
- entrypoints: ["./src/index.ts"],
77
- outdir: "./dist",
78
-
79
- // 필수 최적화
80
- minify: true, // 코드 압축
81
- splitting: true, // 코드 분할
82
-
83
- // 선택적 최적화
84
- treeshaking: true, // 미사용 코드 제거 (기본값)
85
-
86
- // 외부 패키지 처리
87
- external: ["better-sqlite3"], // 네이티브 모듈 제외
88
-
89
- // 환경 변수 주입
90
- define: {
91
- "process.env.API_URL": JSON.stringify(process.env.API_URL),
92
- },
93
- });
94
- ```
95
-
96
- ## 빌드 검증
97
-
98
- ```bash
99
- # 빌드 크기 확인
100
- du -sh dist/
101
-
102
- # 번들 분석
103
- bun build --analyze ./src/server.ts
104
-
105
- # 빌드 테스트
106
- bun run dist/server.js
107
- ```
108
-
109
- Reference: [Bun Bundler](https://bun.sh/docs/bundler)
1
+ ---
2
+ title: Bun Production Build
3
+ impact: CRITICAL
4
+ impactDescription: Build failure blocks deployment
5
+ tags: deployment, build, bun, bundler
6
+ ---
7
+
8
+ ## Bun Production Build
9
+
10
+ **Impact: CRITICAL (Build failure blocks deployment)**
11
+
12
+ Bun 번들러를 사용하여 프로덕션 최적화된 빌드를 생성하세요.
13
+
14
+ **bunfig.toml 설정:**
15
+
16
+ ```toml
17
+ [build]
18
+ target = "bun"
19
+ minify = true
20
+ sourcemap = "external"
21
+
22
+ [build.define]
23
+ "process.env.NODE_ENV" = "'production'"
24
+ ```
25
+
26
+ **빌드 스크립트:**
27
+
28
+ ```typescript
29
+ // scripts/build.ts
30
+ import { $ } from "bun";
31
+
32
+ // 클린 빌드
33
+ await $`rm -rf dist`;
34
+
35
+ // 서버 빌드
36
+ await Bun.build({
37
+ entrypoints: ["./src/server.ts"],
38
+ outdir: "./dist",
39
+ target: "bun",
40
+ minify: true,
41
+ sourcemap: "external",
42
+ define: {
43
+ "process.env.NODE_ENV": JSON.stringify("production"),
44
+ },
45
+ });
46
+
47
+ // 클라이언트 빌드 (Islands)
48
+ await Bun.build({
49
+ entrypoints: ["./app/**/client.tsx"],
50
+ outdir: "./dist/public",
51
+ target: "browser",
52
+ minify: true,
53
+ splitting: true,
54
+ sourcemap: "external",
55
+ });
56
+
57
+ console.log("✅ Build complete");
58
+ ```
59
+
60
+ ## package.json 스크립트
61
+
62
+ ```json
63
+ {
64
+ "scripts": {
65
+ "build": "bun run scripts/build.ts",
66
+ "start": "NODE_ENV=production bun run dist/server.js",
67
+ "preview": "bun run build && bun run start"
68
+ }
69
+ }
70
+ ```
71
+
72
+ ## 빌드 최적화 옵션
73
+
74
+ ```typescript
75
+ await Bun.build({
76
+ entrypoints: ["./src/index.ts"],
77
+ outdir: "./dist",
78
+
79
+ // 필수 최적화
80
+ minify: true, // 코드 압축
81
+ splitting: true, // 코드 분할
82
+
83
+ // 선택적 최적화
84
+ treeshaking: true, // 미사용 코드 제거 (기본값)
85
+
86
+ // 외부 패키지 처리
87
+ external: ["better-sqlite3"], // 네이티브 모듈 제외
88
+
89
+ // 환경 변수 주입
90
+ define: {
91
+ "process.env.API_URL": JSON.stringify(process.env.API_URL),
92
+ },
93
+ });
94
+ ```
95
+
96
+ ## 빌드 검증
97
+
98
+ ```bash
99
+ # 빌드 크기 확인
100
+ du -sh dist/
101
+
102
+ # 번들 분석
103
+ bun build --analyze ./src/server.ts
104
+
105
+ # 빌드 테스트
106
+ bun run dist/server.js
107
+ ```
108
+
109
+ Reference: [Bun Bundler](https://bun.sh/docs/bundler)