bun-package-manager
Bun package manager commands (install, add, remove, update), workspaces, lockfiles, npm/yarn/pnpm migration. Use for dependency management with Bun.
git clone --depth 1 https://github.com/secondsky/claude-skills /tmp/bun-package-manager && cp -r /tmp/bun-package-manager/plugins/bun/skills/bun-package-manager ~/.claude/skills/bun-package-managerSKILL.md
# Bun Package Manager
Bun's package manager is a dramatically faster replacement for npm, yarn, and pnpm. Up to **25x faster** than npm install.
## Quick Start
```bash
# Install all dependencies
bun install
# Add packages
bun add react react-dom
bun add -D typescript @types/react
# Remove packages
bun remove lodash
# Update packages
bun update
# Run package binaries
bunx create-next-app
```
## Core Commands
| Command | Description |
|---------|-------------|
| `bun install` | Install all dependencies |
| `bun add <pkg>` | Add dependency |
| `bun add -D <pkg>` | Add dev dependency |
| `bun add -O <pkg>` | Add optional dependency |
| `bun add --peer <pkg>` | Add peer dependency |
| `bun remove <pkg>` | Remove dependency |
| `bun update [pkg]` | Update dependencies |
| `bunx <pkg>` | Run package binary |
| `bun pm cache rm` | Clear cache |
## Installation Flags
```bash
# Production mode (no devDependencies)
bun install --production
# Frozen lockfile (CI/CD)
bun install --frozen-lockfile
bun ci # shorthand
# Dry run
bun install --dry-run
# Verbose/Silent
bun install --verbose
bun install --silent
# Force reinstall
bun install --force
# Global packages
bun install -g cowsay
```
## Lockfile
Bun uses `bun.lock` (text-based since v1.2):
```bash
# Generate text lockfile
bun install --save-text-lockfile
# Upgrade from binary bun.lockb
bun install --save-text-lockfile --frozen-lockfile --lockfile-only
rm bun.lockb
```
## Workspaces (Monorepos)
```json
{
"name": "my-monorepo",
"workspaces": ["packages/*", "apps/*"]
}
```
Run commands across workspaces:
```bash
# Run in matching packages
bun run --filter 'pkg-*' build
# Run in all workspaces
bun run --filter '*' test
# Install for specific packages
bun install --filter 'pkg-a'
```
## Lifecycle Scripts
Bun does **not** run lifecycle scripts from dependencies by default (security). Whitelist trusted packages:
```json
{
"trustedDependencies": ["my-trusted-package"]
}
```
```bash
# Skip all lifecycle scripts
bun install --ignore-scripts
# Concurrent scripts
bun install --concurrent-scripts 5
```
## Overrides & Resolutions
Force specific versions for nested dependencies:
```json
{
"overrides": {
"lodash": "4.17.21"
}
}
```
Yarn-style resolutions also supported:
```json
{
"resolutions": {
"lodash": "4.17.21"
}
}
```
## Non-npm Dependencies
```json
{
"dependencies": {
"dayjs": "git+https://github.com/iamkun/dayjs.git",
"lodash": "git+ssh://github.com/lodash/lodash.git#4.17.21",
"zod": "github:colinhacks/zod",
"react": "https://registry.npmjs.org/react/-/react-18.2.0.tgz",
"bun-types": "npm:@types/bun"
}
}
```
## Installation Strategies
### Hoisted (default for single packages)
Traditional flat node_modules:
```bash
bun install --linker hoisted
```
### Isolated (default for workspaces)
pnpm-like strict isolation:
```bash
bun install --linker isolated
```
Isolated prevents "phantom dependencies" - packages can only access declared dependencies.
## CI/CD
```yaml
# GitHub Actions
- uses: oven-sh/setup-bun@v2
- run: bun ci # frozen lockfile
```
## Platform-Specific
```bash
# Install for different platform
bun install --cpu=x64 --os=linux
```
## Secure Installation
When installing packages, follow supply chain security best practices:
- **Block post-install scripts** — Bun disables them by default; allow specific packages via `trustedDependencies` in `package.json`
- **Cooldown period** — Configure `minimumReleaseAge` in `bunfig.toml` to wait 7 days for new versions
- **Audit before installing** — Run `socket package score npm <pkg>` or use `socket npm install <pkg>` to check packages before they reach your project
Load the `dependency-upgrade` skill for full security configuration including Socket CLI integration, cooldown setup, lockfile validation, and CI enforcement.
## Common Errors
| Error | Cause | Fix |
|-------|-------|-----|
| `Cannot find module` | Missing dependency | Run `bun install` |
| `Lockfile mismatch` | package.json changed | Run `bun install` |
| `Peer dependency` | Missing peer | `bun add` the peer |
| `Lifecycle script failed` | Untrusted package | Add to `trustedDependencies` |
## Migration from Other Package Managers
### From pnpm
Bun automatically migrates `pnpm-lock.yaml`:
```bash
bun install # Auto-converts to bun.lock
```
Workspace config moves to package.json:
```json
{
"workspaces": {
"packages": ["apps/*", "packages/*"],
"catalog": {
"react": "^18.0.0"
}
}
}
```
### From npm/Yarn
Simply run `bun install` - Bun reads `package-lock.json` and `yarn.lock`.
## When to Load References
Load `references/cli-commands.md` when:
- Need complete CLI flag reference
- Working with advanced options
Load `references/workspaces.md` when:
- Setting up monorepos
- Configuring workspace filters
Load `references/migration.md` when:
- Migrating from npm/yarn/pnpm
- Converting lockfilesRole-based access control (RBAC) with permissions and policies. Use for admin dashboards, enterprise access, multi-tenant apps, fine-grained authorization, or encountering permission hierarchies, role inheritance, policy conflicts.
100+ animated React components (Aceternity UI) for Next.js with Tailwind. Use for hero sections, parallax, 3D effects, or encountering animation, shadcn CLI integration errors.
shadcn/ui AI chat components for conversational interfaces. Use for streaming chat, tool/function displays, reasoning visualization, or encountering Next.js App Router setup, Tailwind v4 integration, AI SDK v5 migration errors.
Vercel AI SDK v5 for backend AI (text generation, structured output, tools, agents). Multi-provider. Use for server-side AI or encountering AI_APICallError, AI_NoObjectGeneratedError, streaming failures.
Vercel AI SDK v5 React hooks (useChat, useCompletion, useObject) for AI chat interfaces. Use for React/Next.js AI apps or encountering parse stream errors, no response, streaming issues.
Secure API authentication with JWT, OAuth 2.0, API keys. Use for authentication systems, third-party integrations, service-to-service communication, or encountering token management, security headers, auth flow errors.
Creates comprehensive API changelogs documenting breaking changes, deprecations, and migration strategies for API consumers. Use when managing API versions, communicating breaking changes, or creating upgrade guides.
Verifies API contracts between services using consumer-driven contracts, schema validation, and tools like Pact. Use when testing microservices communication, preventing breaking changes, or validating OpenAPI specifications.