RFC (Request for Comments) specification writing with objective technical analysis. Use when creating technical specifications, design documents, or architecture proposals that require structured evaluation of options and trade-offs.
Resources
1Install
npx skillscat add jpoutrin/product-forge/rfc-specification Install via the SkillsCat registry.
RFC Specification Writing Skill
This skill automatically activates when writing technical specifications, design documents, or architecture proposals that require structured evaluation and stakeholder review.
When This Skill Activates
- Creating a new technical RFC or design document
- Proposing architectural changes or new systems
- Evaluating technical options objectively
- Documenting technical decisions with rationale
- Writing system design specifications
Core Principles
Objective Technical Analysis
RFCs must maintain strict neutrality when evaluating options:
Evidence-Based Evaluation
- Support claims with data, benchmarks, or documented experience
- Avoid subjective language ("better", "best", "obvious choice")
- Present measurable criteria for comparison
Balanced Trade-off Analysis
- Every option has advantages AND disadvantages
- Document both explicitly for each alternative
- Avoid dismissing options without clear justification
Separation of Facts and Opinions
- Clearly label assumptions vs verified facts
- Cite sources for technical claims
- Distinguish between team preferences and technical constraints
Stakeholder Neutrality
- Present options without advocating for a predetermined choice
- Let evaluation criteria drive the recommendation
- Document dissenting opinions fairly
RFC Document Structure
Required Sections
Header Metadata
--- rfc_id: RFC-XXXX title: [Descriptive Title] status: DRAFT | REVIEW | APPROVED | IN_PROGRESS | COMPLETED | SUPERSEDED author: [Name] reviewers: [List of reviewers with status] created: YYYY-MM-DD last_updated: YYYY-MM-DD decision_date: YYYY-MM-DD (when approved) ---Overview (1-2 paragraphs)
- What this RFC proposes
- Why it matters now
- Expected outcome
Background & Context
- Current state of the system
- Historical context if relevant
- Glossary of terms
- Links to related RFCs or documentation
Problem Statement
- Specific problem being addressed
- Evidence of the problem (metrics, incidents, user feedback)
- Impact of not solving (cost, risk, opportunity loss)
Goals & Non-Goals
- Explicit scope boundaries
- What success looks like
- What this RFC deliberately does NOT address
Evaluation Criteria
- Measurable criteria for comparing options
- Weight or priority of each criterion
- Minimum thresholds where applicable
Options Analysis
For each option (minimum 2):### Option N: [Name] **Description**: [What this option entails] **Advantages**: - [Pro 1] - [Pro 2] **Disadvantages**: - [Con 1] - [Con 2] **Evaluation Against Criteria**: | Criterion | Score/Rating | Notes | |-----------|--------------|-------| | ... | ... | ... | **Effort Estimate**: [Complexity and resources required] **Risk Assessment**: [Potential risks and mitigations]Recommendation
- Recommended option with justification
- How it scores against criteria
- Acknowledged trade-offs being accepted
Technical Design (for approved RFCs)
- Architecture diagrams
- API specifications
- Data models
- Security considerations
Implementation Plan
- Phases and milestones
- Dependencies
- Rollback strategy
Open Questions
- Unresolved technical questions
- Areas needing further investigation
- Pending stakeholder input
Decision Record
- Final decision made
- Date and approvers
- Key discussion points
- Conditions or constraints on approval
RFC Lifecycle
DRAFT → REVIEW → APPROVED → IN_PROGRESS → COMPLETED
↓
SUPERSEDED (if replaced by newer RFC)Status Definitions
| Status | Description |
|---|---|
| DRAFT | Initial writing, not ready for review |
| REVIEW | Open for stakeholder feedback |
| APPROVED | Decision made, ready for implementation |
| IN_PROGRESS | Implementation underway |
| COMPLETED | Implementation finished |
| SUPERSEDED | Replaced by newer RFC (link to new RFC) |
Evaluation Criteria Framework
Use these standard criteria categories (adapt as needed):
Technical Criteria
- Performance: Latency, throughput, resource usage
- Scalability: Horizontal/vertical scaling, bottlenecks
- Reliability: Fault tolerance, recovery, availability
- Security: Attack surface, data protection, compliance
- Maintainability: Code complexity, debugging, updates
Operational Criteria
- Operability: Monitoring, alerting, incident response
- Deployment: CI/CD integration, rollback capability
- Documentation: Learning curve, knowledge transfer
Business Criteria
- Time to Implement: Development effort, dependencies
- Cost: Infrastructure, licensing, maintenance
- Risk: Technical risk, organizational risk
Neutral Language Guidelines
Avoid
- "Obviously the best choice"
- "Everyone agrees that..."
- "This is clearly superior"
- "The only sensible option"
- Dismissing alternatives as "not worth considering"
Use Instead
- "Based on criteria X, Option A scores higher because..."
- "Option B requires consideration of trade-off Y"
- "The data suggests that..."
- "Stakeholder input indicates a preference for..."
- "Given constraints A and B, Option C is recommended"
Quality Checklist
Before marking RFC as REVIEW:
- All required sections are complete
- At least 2 alternatives are analyzed
- Evaluation criteria are explicit and measurable
- Trade-offs are documented for each option
- Language is objective and evidence-based
- Technical diagrams are included where helpful
- Open questions are clearly listed
- Implementation plan is realistic
Integration with CTO Architect Workflow
When the CTO Architect agent creates technical specifications:
- Use this skill for any significant technical decision
- Follow the template in
references/rfc-template.md - Ensure neutral evaluation of all options
- Link to related PRDs when applicable
- Request review from appropriate technical stakeholders
File Naming Convention
- RFC documents:
RFC-XXXX-<short-description>.md - Example:
RFC-0042-api-gateway-selection.md
Directory Structure
rfcs/
├── draft/ # Work in progress
├── review/ # Under stakeholder review
├── approved/ # Approved, awaiting or in implementation
├── completed/ # Implementation finished
└── archive/ # Superseded or abandoned
└── YYYY/References
- Template:
./references/rfc-template.md - Evaluation Matrix:
./references/evaluation-matrix.md