plan-feature
Plan feature implementation with technical specifications for Solana projects
mkdir -p ~/.claude/commands && curl -fsSL https://raw.githubusercontent.com/solanabr/solana-ai-kit/HEAD/.claude/commands/plan-feature.md -o ~/.claude/commands/plan-feature.mdplan-feature.md
Create a detailed implementation plan for a Solana blockchain feature.
## Feature Description
$ARGUMENTS
## Planning Framework
### 1. Feature Analysis
Break down the feature into:
**User Stories**
- As a [user type], I want to [action] so that [benefit]
**Technical Requirements**
- On-chain components (programs, accounts)
- Off-chain components (clients, indexers)
- Integration points
**Dependencies**
- External programs (Token, Metaplex, etc.)
- SDKs and libraries
- Infrastructure (RPC, indexer)
**Edge Cases**
- Error conditions
- Boundary values
- Concurrent access
**Success Criteria**
- Functional requirements met
- Security requirements met
- Performance targets met
### 2. Architecture Design
**On-Chain Architecture**
```
┌─────────────────────────────────────────────────┐
│ Your Program │
├─────────────────────────────────────────────────┤
│ Instructions │ Accounts │ Events │
│ - initialize │ - UserAccount │ - Init │
│ - action │ - StateAccount │ - Action│
│ - close │ - VaultPDA │ - Close │
└─────────────────────────────────────────────────┘
│ │
▼ ▼
┌─────────────────┐ ┌─────────────────┐
│ Token Program │ │ System Program │
└─────────────────┘ └─────────────────┘
```
**Client Architecture**
```
┌──────────────┐ ┌──────────────┐ ┌──────────────┐
│ Frontend │────▶│ SDK/Client │────▶│ RPC │
│ (React/ │ │ (@solana/ │ │ (Helius/ │
│ Unity) │ │ kit) │ │ Triton) │
└──────────────┘ └──────────────┘ └──────────────┘
```
**Data Flow**
```
User Action → Frontend → Transaction Build → Sign → Send → Confirm → Update UI
```
### 3. Account Design
For each account type:
```markdown
### [AccountName]
**Purpose:** [What this account stores]
**Seeds (if PDA):** `["prefix", key1, key2]`
**Size:** [Calculate exact bytes]
| Field | Type | Size | Description |
|-------|------|------|-------------|
| discriminator | [u8; 8] | 8 | Anchor discriminator |
| field1 | Pubkey | 32 | Description |
| field2 | u64 | 8 | Description |
| **Total** | | **X** | + rent exempt |
**Rent:** ~X.XXX SOL
**Lifecycle:**
1. Created by: [instruction]
2. Modified by: [instructions]
3. Closed by: [instruction]
```
### 4. Instruction Design
For each instruction:
```markdown
### `instruction_name`
**Purpose:** [What it does]
**Accounts:**
| Name | Type | Description |
|------|------|-------------|
| user | Signer, Mut | Pays for transaction |
| state | Mut | State to modify |
| system_program | Program | For account creation |
**Arguments:**
| Name | Type | Validation |
|------|------|------------|
| amount | u64 | > 0, <= balance |
**Logic:**
1. Validate inputs
2. Check permissions
3. Perform action
4. Emit event
**Errors:**
| Error | When |
|-------|------|
| InvalidAmount | amount == 0 |
| Unauthorized | signer != authority |
**CU Estimate:** ~X,XXX CU
```
### 5. Implementation Phases
```markdown
## Phase 1: Foundation (Day 1)
### What will be implemented:
- [ ] Project setup and dependencies
- [ ] Account structures
- [ ] Basic instruction scaffolding
### Files to create:
- `programs/my-program/src/lib.rs` - Program entry
- `programs/my-program/src/state/mod.rs` - Account definitions
- `programs/my-program/src/instructions/mod.rs` - Instruction handlers
### What to review:
- Account sizes calculated correctly
- PDA seeds are unique and deterministic
- Dependencies are correct versions
---
## Phase 2: Core Logic (Day 2-3)
### What will be implemented:
- [ ] Initialize instruction
- [ ] Main feature instruction(s)
- [ ] Event emission
### Files to create/modify:
- `programs/my-program/src/instructions/initialize.rs`
- `programs/my-program/src/instructions/action.rs`
- `programs/my-program/src/events.rs`
### What to review:
- All validations in place
- Error handling complete
- Events contain necessary data
---
## Phase 3: Testing (Day 3-4)
### What will be implemented:
- [ ] Unit tests for each instruction
- [ ] Integration tests for flows
- [ ] Edge case testing
### Files to create:
- `tests/my-program.ts` - TypeScript tests
- `programs/my-program/tests/` - Rust tests (if using)
### What to review:
- All success paths tested
- All error conditions tested
- Concurrent access scenarios
---
## Phase 4: Client Integration (Day 4-5)
### What will be implemented:
- [ ] TypeScript SDK functions
- [ ] React hooks (if web)
- [ ] Unity integration (if game)
### Files to create:
- `sdk/src/instructions.ts` - Instruction builders
- `sdk/src/accounts.ts` - Account fetching
- `app/hooks/useProgram.ts` - React hooks
### What to review:
- Error handling in client
- Loading states
- Transaction confirmation UX
---
## Phase 5: Polish & Deploy (Day 5-6)
### What will be implemented:
- [ ] Documentation
- [ ] Devnet deployment
- [ ] Final testing on devnet
### Files to create:
- `README.md` - Project documentation
- `docs/API.md` - API reference
### What to review:
- Documentation complete
- Devnet tests pass
- Ready for audit (if needed)
```
### 6. Risk Assessment
```markdown
## Risks and Mitigations
### Technical Risks
| Risk | Likelihood | Impact | Mitigation |
|------|------------|--------|------------|
| CU limits exceeded | Medium | High | Profile early, optimize |
| Account size too small | Low | High | Calculate carefully, add buffer |
| Reentrancy vulnerability | Low | Critical | Use checks-effects-interactions |
### Integration Risks
| Risk | Likelihood | Impact | Mitigation |
|------|------------|--------|------------|
| External program changes | Low | Medium | Pin versions, monitor |
| RPC rate limits | Medium | Medium | Use dedicated RPC |
### Timeline Risks
| Risk | Likelihood | Impact | Mitigation |
|------|------------|--------|------------|
| Underestimated complexity | High | Medium | Add buffer time |
| Testing reveals issues | Medium |Anchor framework specialist for rapid Solana program development. Use for building programs with Anchor macros, IDL generation, account validation, and standardized patterns. Prioritizes developer experience while maintaining security.\\n\\nUse when: Building new programs quickly, team projects needing standardization, projects requiring IDL for client generation, or when developer experience is prioritized over maximum CU optimization.
DeFi integration specialist for composing with Solana protocols including Jupiter, Drift, Kamino, Raydium, Orca, Meteora, Marginfi, and Sanctum. Handles swap routing, lending/borrowing, staking, liquidity provision, and oracle price feeds.\n\nUse when: Integrating DeFi protocols, building swap interfaces, implementing lending/borrowing, setting up yield strategies, working with Pyth/Switchboard oracles, or composing multi-protocol transactions.
CI/CD, infrastructure, and deployment specialist for Solana projects. Handles GitHub Actions, Docker, monitoring, RPC management, and Cloudflare Workers edge deployment.\n\nUse when: Setting up CI/CD pipelines, containerizing Solana validators or programs, configuring monitoring and alerting, managing RPC infrastructure, deploying edge workers, or automating build and deploy workflows.
Senior Solana game architect for game system design, Unity/C# architecture, on-chain game state, player progression, NFT integration, and PlaySolana ecosystem. Use for high-level game design decisions, architecture reviews, and planning complex game systems.\n\nUse when: Designing new Solana games from scratch, planning game state on-chain, Unity project architecture, integrating with PlaySolana/PSG1, or deciding between implementation approaches.
React Native and Expo specialist for building Solana mobile dApps. Handles mobile wallet adapter integration, transaction signing UX, deep linking, and mobile-specific performance optimization.\n\nUse when: Building React Native or Expo mobile apps with Solana integration, implementing mobile wallet adapter flows, setting up deep links for transaction signing, or optimizing mobile dApp performance.
CU optimization specialist using Pinocchio framework. Use for performance-critical programs requiring 80-95% CU reduction vs Anchor. Specializes in zero-copy access, manual validation, and minimal binary size.\\n\\nUse when: CU limits are being hit, transaction costs are significant at scale, binary size must be minimized, or maximum throughput is required.
Rust backend specialist for building async services that interact with Solana blockchain. Builds APIs, indexing services, and off-chain processing using Axum, Tokio, and modern async patterns.\n\nUse when: Building REST/WebSocket APIs for Solana dApps, implementing transaction indexers, creating webhook services, or any Rust backend that interacts with Solana.
Senior Solana program architect for system design, account structures, PDA schemes, token economics, and cross-program composability. Use for high-level design decisions, architecture reviews, and planning complex multi-program systems.\n\nUse when: Designing new programs from scratch, planning account structures, optimizing PDA schemes, reviewing architecture for security, or deciding between implementation approaches.