--- id: wiki-2026-0508-오픈소스-컴포넌트-open-source-components title: 오픈소스 컴포넌트 (Open Source Components) category: 10_Wiki/Topics status: verified canonical_id: self aliases: [OSS Components, 오픈소스 라이브러리, Third-party Components] duplicate_of: none source_trust_level: A confidence_score: 0.9 verification_status: applied tags: [oss, components, supply-chain, security, frontend] raw_sources: [] last_reinforced: 2026-05-10 github_commit: pending tech_stack: language: TypeScript framework: React/Node --- # 오픈소스 컴포넌트 (Open Source Components) ## 매 한 줄 > **"매 application 의 70-90% 매 OSS dependency 의 의 — 매 transitive supply chain 의 risk 의 surface 의."**. 매 modern 의 frontend stack 의 React/Vue + UI library (shadcn/ui, Radix, MUI) + utility (date-fns, zod) + build tool 의 의 의 의 의. 매 2026 의 의 SBOM (Software Bill of Materials) + provenance attestation (SLSA Level 3+) 의 의 의 production 의 의 의. ## 매 핵심 ### 매 OSS 의 layer - **UI primitive**: Radix UI, Headless UI — accessibility-first, unstyled. - **UI library**: shadcn/ui (copy-paste), MUI, Mantine, Chakra — styled out of box. - **Utility**: date-fns, zod (schema), clsx, lodash-es. - **State**: Zustand, TanStack Query, Jotai, Redux Toolkit. - **Build**: Vite, Turbopack, esbuild, swc. ### 매 supply chain risk - **Typosquatting**: `react-domm` vs `react-dom` — npm install 의 의 malicious code 의 inject 의. - **Dependency confusion**: 의 internal package name 의 public registry 의 의 의 hijack. - **Compromised maintainer**: event-stream (2018), ua-parser-js (2021), xz-utils (2024) — legit package 의 의 backdoor 의 inject 의 case. - **Transitive depth**: 매 single `npm install next` 의 의 600+ transitive dep 의 의 의. ### 매 응용 1. SBOM 생성 (CycloneDX / SPDX) — 매 release 의 attach. 2. License compliance — GPL contamination 의 의 commercial product 의 의 risk. 3. Vulnerability scanning — Dependabot, Snyk, Socket.dev (behavior-based). ## 💻 패턴 ### shadcn/ui 의 install (copy-paste model) ```bash # 매 npm package 의 의 — source code 의 의 project 의 copy pnpm dlx shadcn@latest init pnpm dlx shadcn@latest add button dialog form # → src/components/ui/button.tsx 의 의 의 의 — 의 own. ``` ### Radix primitive composition ```tsx import * as Dialog from '@radix-ui/react-dialog'; export function ConfirmDialog({ children, onConfirm }: Props) { return ( {children} Confirm Cancel ); } ``` ### Zod schema validation ```ts import { z } from 'zod'; const UserSchema = z.object({ email: z.string().email(), age: z.number().int().min(13).max(120), role: z.enum(['admin', 'user', 'guest']), }); type User = z.infer; // API boundary 의 의 export async function createUser(input: unknown): Promise { const parsed = UserSchema.parse(input); // throws on invalid return db.user.create({ data: parsed }); } ``` ### SBOM 생성 (CycloneDX) ```bash # 매 npm project 의 의 SBOM 의 의 npx @cyclonedx/cyclonedx-npm --output-file sbom.json # 매 Docker image 의 의 SBOM syft packages docker:myapp:latest -o cyclonedx-json > sbom.json # 매 SLSA provenance 의 의 GitHub Action 의 의 의 # .github/workflows/release.yml 의 slsa-framework/slsa-github-generator 의 의 ``` ### Socket.dev install-time check ```bash # 매 install 의 의 behavior-based scan npx @socketsecurity/cli npm install # → install scripts, network access, file system 의 access 의 의 detect. ``` ### License audit ```bash npx license-checker --production --summary # → MIT: 245, ISC: 30, Apache-2.0: 15, GPL-3.0: 1 ⚠️ ``` ### Renovate config ```json { "extends": ["config:recommended"], "vulnerabilityAlerts": { "enabled": true, "labels": ["security"] }, "packageRules": [ { "matchUpdateTypes": ["patch"], "automerge": true }, { "matchPackagePatterns": ["^@types/"], "automerge": true } ] } ``` ## 매 결정 기준 | 상황 | Approach | |---|---| | Design system 구축 | shadcn/ui (copy-paste, full control) | | Enterprise app, accessibility 의 critical | Radix + Tailwind 의 own design | | Rapid prototype | MUI / Mantine (styled OOTB) | | Schema validation | zod (TS-native) | | Date math | date-fns / Temporal API (의 native) | | Supply chain audit | Socket.dev + Renovate + SBOM | **기본값**: shadcn/ui + Radix + zod + Renovate + CycloneDX SBOM. ## 🔗 Graph - 부모: [[Frontend_Architecture]] · [[Software_Supply_Chain_Security]] - 변형: [[Headless_UI]] · [[Component_Library]] - 응용: [[Design_System]] · [[Dependency_Management]] - Adjacent: [[SBOM]] · [[SLSA]] · [[Dependabot]] ## 🤖 LLM 활용 **언제**: package selection (의 maintained / popular / license-clean), boilerplate (zod schema, Radix composition). **언제 X**: novel security audit (LLM 의 zero-day pattern 의 의 — 의 Snyk/Socket 의 의), license compliance ruling (legal review 의 의). ## ❌ 안티패턴 - **Untyped JS dependency**: 매 `@types/*` 의 의 missing — runtime 의 의 의 의. - **Wildcard version (`^` 의 의 의 `*`)**: 매 reproducible build 의 의 — pnpm lock 의 의 의 의. - **Vendoring 의 abuse**: 매 transitive 의 의 update path 의 의 — fork 만 의 의 의. - **License blindness**: AGPL 의 의 closed-source SaaS 의 의 license violation. - **No SBOM**: incident response 의 의 의 의 affected version 의 의 의 의 의. ## 🧪 검증 / 중복 - Verified (npm registry, CycloneDX spec, SLSA framework, OWASP Dependency-Check). - 신뢰도 A. ## 🕓 Changelog | 날짜 | 변경 | |---|---| | 2026-05-08 | Phase 1 | | 2026-05-10 | Manual cleanup — OSS components + supply chain security 의 의 |