@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.
- package/README.md +367 -367
- package/package.json +2 -2
- package/src/activity-monitor.ts +847 -847
- package/src/adapters/index.ts +20 -20
- package/src/adapters/monitor-adapter.ts +100 -100
- package/src/adapters/tool-adapter.ts +88 -88
- package/src/executor/error-handler.ts +250 -250
- package/src/executor/index.ts +22 -22
- package/src/executor/tool-executor.ts +148 -148
- package/src/hooks/config-watcher.ts +174 -174
- package/src/hooks/index.ts +23 -23
- package/src/hooks/mcp-hooks.ts +227 -227
- package/src/index.ts +106 -106
- package/src/logging/index.ts +15 -15
- package/src/logging/mcp-transport.ts +134 -134
- package/src/registry/index.ts +13 -13
- package/src/registry/mcp-tool-registry.ts +298 -298
- package/src/resources/skills/guides.ts +1136 -1136
- package/src/resources/skills/index.ts +12 -12
- package/src/resources/skills/loader.ts +218 -218
- package/src/resources/skills/mandu-composition/SKILL.md +91 -91
- package/src/resources/skills/mandu-composition/metadata.json +13 -13
- package/src/resources/skills/mandu-composition/rules/_sections.md +26 -26
- package/src/resources/skills/mandu-composition/rules/_template.md +77 -77
- package/src/resources/skills/mandu-composition/rules/comp-arch-avoid-boolean-props.md +146 -146
- package/src/resources/skills/mandu-composition/rules/comp-arch-compound-components.md +164 -164
- package/src/resources/skills/mandu-composition/rules/comp-island-event.md +161 -161
- package/src/resources/skills/mandu-composition/rules/comp-island-slot-split.md +167 -167
- package/src/resources/skills/mandu-composition/rules/comp-pattern-children.md +149 -149
- package/src/resources/skills/mandu-composition/rules/comp-state-context-interface.md +148 -148
- package/src/resources/skills/mandu-composition/rules/comp-state-lift-state.md +150 -150
- package/src/resources/skills/mandu-deployment/SKILL.md +92 -92
- package/src/resources/skills/mandu-deployment/_sections.md +41 -41
- package/src/resources/skills/mandu-deployment/_template.md +38 -38
- package/src/resources/skills/mandu-deployment/metadata.json +13 -13
- package/src/resources/skills/mandu-deployment/rules/deploy-build-bun.md +109 -109
- package/src/resources/skills/mandu-deployment/rules/deploy-build-output.md +115 -115
- package/src/resources/skills/mandu-deployment/rules/deploy-cicd-github.md +219 -219
- package/src/resources/skills/mandu-deployment/rules/deploy-docker-bun.md +150 -150
- package/src/resources/skills/mandu-deployment/rules/deploy-docker-compose.md +223 -223
- package/src/resources/skills/mandu-deployment/rules/deploy-platform-fly.md +152 -152
- package/src/resources/skills/mandu-deployment/rules/deploy-platform-render.md +179 -179
- package/src/resources/skills/mandu-deployment/rules/deploy-platform-supabase.md +323 -323
- package/src/resources/skills/mandu-deployment/rules/deploy-platform-vercel.md +140 -140
- package/src/resources/skills/mandu-fs-routes/SKILL.md +82 -82
- package/src/resources/skills/mandu-fs-routes/metadata.json +12 -12
- package/src/resources/skills/mandu-fs-routes/rules/_sections.md +36 -36
- package/src/resources/skills/mandu-fs-routes/rules/_template.md +69 -69
- package/src/resources/skills/mandu-fs-routes/rules/routes-api-methods.md +65 -65
- package/src/resources/skills/mandu-fs-routes/rules/routes-dynamic-param.md +93 -93
- package/src/resources/skills/mandu-fs-routes/rules/routes-naming-page.md +55 -55
- package/src/resources/skills/mandu-guard/SKILL.md +129 -129
- package/src/resources/skills/mandu-guard/metadata.json +12 -12
- package/src/resources/skills/mandu-guard/rules/_sections.md +36 -36
- package/src/resources/skills/mandu-guard/rules/_template.md +82 -82
- package/src/resources/skills/mandu-guard/rules/guard-config-rules.md +100 -100
- package/src/resources/skills/mandu-guard/rules/guard-layer-direction.md +76 -76
- package/src/resources/skills/mandu-guard/rules/guard-preset-mandu.md +81 -81
- package/src/resources/skills/mandu-guard/rules/guard-validate-import.md +80 -80
- package/src/resources/skills/mandu-hydration/SKILL.md +91 -91
- package/src/resources/skills/mandu-hydration/metadata.json +12 -12
- package/src/resources/skills/mandu-hydration/rules/_sections.md +31 -31
- package/src/resources/skills/mandu-hydration/rules/_template.md +72 -72
- package/src/resources/skills/mandu-hydration/rules/hydration-data-event.md +109 -109
- package/src/resources/skills/mandu-hydration/rules/hydration-directive-use-client.md +55 -55
- package/src/resources/skills/mandu-hydration/rules/hydration-island-setup.md +113 -113
- package/src/resources/skills/mandu-hydration/rules/hydration-priority-visible.md +68 -68
- package/src/resources/skills/mandu-performance/SKILL.md +85 -85
- package/src/resources/skills/mandu-performance/metadata.json +14 -14
- package/src/resources/skills/mandu-performance/rules/_sections.md +31 -31
- package/src/resources/skills/mandu-performance/rules/_template.md +64 -64
- package/src/resources/skills/mandu-performance/rules/perf-async-defer-await.md +103 -103
- package/src/resources/skills/mandu-performance/rules/perf-async-parallel.md +95 -95
- package/src/resources/skills/mandu-performance/rules/perf-bun-file.md +124 -124
- package/src/resources/skills/mandu-performance/rules/perf-bun-serve.md +125 -125
- package/src/resources/skills/mandu-performance/rules/perf-bundle-imports.md +80 -80
- package/src/resources/skills/mandu-performance/rules/perf-bundle-island-lazy.md +145 -145
- package/src/resources/skills/mandu-performance/rules/perf-cache-react.md +98 -98
- package/src/resources/skills/mandu-performance/rules/perf-render-transitions.md +154 -154
- package/src/resources/skills/mandu-security/SKILL.md +87 -87
- package/src/resources/skills/mandu-security/metadata.json +13 -13
- package/src/resources/skills/mandu-security/rules/_sections.md +31 -31
- package/src/resources/skills/mandu-security/rules/_template.md +74 -74
- package/src/resources/skills/mandu-security/rules/sec-auth-guard.md +127 -127
- package/src/resources/skills/mandu-security/rules/sec-env-management.md +133 -133
- package/src/resources/skills/mandu-security/rules/sec-input-validate.md +148 -148
- package/src/resources/skills/mandu-security/rules/sec-protect-csrf.md +146 -146
- package/src/resources/skills/mandu-security/rules/sec-protect-headers.md +138 -138
- package/src/resources/skills/mandu-slot/SKILL.md +85 -85
- package/src/resources/skills/mandu-slot/metadata.json +12 -12
- package/src/resources/skills/mandu-slot/rules/_sections.md +36 -36
- package/src/resources/skills/mandu-slot/rules/_template.md +63 -63
- package/src/resources/skills/mandu-slot/rules/slot-basic-structure.md +38 -38
- package/src/resources/skills/mandu-slot/rules/slot-ctx-response.md +56 -56
- package/src/resources/skills/mandu-slot/rules/slot-guard-auth.md +59 -59
- package/src/resources/skills/mandu-slot/rules/slot-http-methods.md +64 -64
- package/src/resources/skills/mandu-styling/SKILL.md +154 -154
- package/src/resources/skills/mandu-styling/_sections.md +43 -43
- package/src/resources/skills/mandu-styling/_template.md +32 -32
- package/src/resources/skills/mandu-styling/metadata.json +15 -15
- package/src/resources/skills/mandu-styling/rules/style-component-compound.md +235 -235
- package/src/resources/skills/mandu-styling/rules/style-component-slots.md +255 -255
- package/src/resources/skills/mandu-styling/rules/style-component-tokens.md +205 -205
- package/src/resources/skills/mandu-styling/rules/style-island-animations.md +272 -272
- package/src/resources/skills/mandu-styling/rules/style-island-scoping.md +167 -167
- package/src/resources/skills/mandu-styling/rules/style-island-variants.md +221 -221
- package/src/resources/skills/mandu-styling/rules/style-perf-critical.md +209 -209
- package/src/resources/skills/mandu-styling/rules/style-perf-purge.md +192 -192
- package/src/resources/skills/mandu-styling/rules/style-setup-modules.md +162 -162
- package/src/resources/skills/mandu-styling/rules/style-setup-panda.md +164 -164
- package/src/resources/skills/mandu-styling/rules/style-setup-tailwind.md +170 -170
- package/src/resources/skills/mandu-styling/rules/style-tailwind-v4-gotchas.md +179 -179
- package/src/resources/skills/mandu-styling/rules/style-theme-darkmode.md +229 -229
- package/src/resources/skills/mandu-testing/SKILL.md +99 -99
- package/src/resources/skills/mandu-testing/metadata.json +13 -13
- package/src/resources/skills/mandu-testing/rules/_sections.md +26 -26
- package/src/resources/skills/mandu-testing/rules/_template.md +65 -65
- package/src/resources/skills/mandu-testing/rules/test-component-island.md +195 -195
- package/src/resources/skills/mandu-testing/rules/test-e2e-playwright.md +196 -196
- package/src/resources/skills/mandu-testing/rules/test-mock-fetch.md +219 -219
- package/src/resources/skills/mandu-testing/rules/test-slot-unit.md +192 -192
- package/src/resources/skills/mandu-ui/SKILL.md +117 -117
- package/src/resources/skills/mandu-ui/_sections.md +23 -23
- package/src/resources/skills/mandu-ui/_template.md +32 -32
- package/src/resources/skills/mandu-ui/metadata.json +13 -13
- package/src/resources/skills/mandu-ui/rules/ui-accessibility-aria.md +232 -232
- package/src/resources/skills/mandu-ui/rules/ui-accessibility-focus.md +238 -238
- package/src/resources/skills/mandu-ui/rules/ui-composition-patterns.md +259 -259
- package/src/resources/skills/mandu-ui/rules/ui-island-integration.md +258 -258
- package/src/resources/skills/mandu-ui/rules/ui-radix-patterns.md +213 -213
- package/src/resources/skills/mandu-ui/rules/ui-shadcn-setup.md +209 -209
- package/src/resources/skills/recipes.ts +932 -932
- package/src/tools/generate.ts +7 -4
- package/src/tools/guard.ts +17 -4
- package/src/tools/hydration.ts +10 -10
- package/src/tools/project.ts +334 -334
- package/src/tools/runtime.ts +497 -497
- package/src/tools/seo.ts +417 -417
- package/src/tools/spec.ts +80 -159
- package/src/utils/project.ts +22 -12
- 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)
|