tractatus/docs/research/phase-5-integration-roadmap.md
TheFlow 2298d36bed fix(submissions): restructure Economist package and fix article display
- Create Economist SubmissionTracking package correctly:
  * mainArticle = full blog post content
  * coverLetter = 216-word SIR— letter
  * Links to blog post via blogPostId
- Archive 'Letter to The Economist' from blog posts (it's the cover letter)
- Fix date display on article cards (use published_at)
- Target publication already displaying via blue badge

Database changes:
- Make blogPostId optional in SubmissionTracking model
- Economist package ID: 68fa85ae49d4900e7f2ecd83
- Le Monde package ID: 68fa2abd2e6acd5691932150

Next: Enhanced modal with tabs, validation, export

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-24 08:47:42 +13:00

450 lines
12 KiB
Markdown

# Phase 5 PoC - Integration Roadmap
**Date**: 2025-10-10
**Status**: Production deployment successful
**Progress**: 2/6 services integrated (33%)
---
## Current State (Week 3 Complete)
### ✅ Services Integrated with MemoryProxy
**BoundaryEnforcer** (🟢 OPERATIONAL)
- MemoryProxy initialized: ✅
- Rules loaded: 3/3 (inst_016, inst_017, inst_018)
- Audit trail: Active
- Tests: 48/48 passing
- Performance: +2ms overhead (~5%)
**BlogCuration** (🟢 OPERATIONAL)
- MemoryProxy initialized: ✅
- Rules loaded: 3/3 (inst_016, inst_017, inst_018)
- Audit trail: Active
- Tests: 26/26 passing
- Performance: +2ms overhead (~5%)
### ⏳ Services Pending Integration
**InstructionPersistenceClassifier** (🟡 PENDING)
- Current: Uses `.claude/instruction-history.json` directly
- Integration: HIGH PRIORITY
- Estimated effort: 2-3 hours
- Benefits: Persistent rule storage, audit trail for classifications
**CrossReferenceValidator** (🟡 PENDING)
- Current: Uses `.claude/instruction-history.json` directly
- Integration: HIGH PRIORITY
- Estimated effort: 2-3 hours
- Benefits: Rule querying via MemoryProxy, audit trail for validations
**MetacognitiveVerifier** (🟡 PENDING)
- Current: Independent service
- Integration: MEDIUM PRIORITY
- Estimated effort: 1-2 hours
- Benefits: Audit trail for verification decisions
**ContextPressureMonitor** (🟡 PENDING)
- Current: Uses `.claude/session-state.json`
- Integration: LOW PRIORITY
- Estimated effort: 1-2 hours
- Benefits: Session state persistence in .memory/
---
## Integration Plan
### Session 1: Core Service Integration (HIGH PRIORITY)
**Duration**: 2-3 hours
**Services**: InstructionPersistenceClassifier, CrossReferenceValidator
#### InstructionPersistenceClassifier Integration
**Current Implementation**:
```javascript
// Reads from .claude/instruction-history.json
const data = await fs.readFile(INSTRUCTION_HISTORY_PATH, 'utf8');
const parsed = JSON.parse(data);
return parsed.instructions;
```
**Target Implementation**:
```javascript
// Use MemoryProxy
async initialize() {
await this.memoryProxy.initialize();
// Load all rules for classification reference
}
async classify(instruction) {
// Classify instruction
const result = { quadrant, persistence, ... };
// Audit classification decision
await this.memoryProxy.auditDecision({
sessionId: context.sessionId,
action: 'instruction_classification',
metadata: {
instruction_id: instruction.id,
quadrant: result.quadrant,
persistence: result.persistence
}
});
return result;
}
```
**Benefits**:
- Rules accessible via MemoryProxy
- Audit trail for all classifications
- Cache management
- Backward compatible
**Testing**:
- Update existing tests (verify no breaking changes)
- Add integration test (classification + audit)
- Verify 100% backward compatibility
---
#### CrossReferenceValidator Integration
**Current Implementation**:
```javascript
// Reads from .claude/instruction-history.json
async checkConflicts(action, context) {
const instructions = await this._loadInstructions();
// Check for conflicts
}
```
**Target Implementation**:
```javascript
async initialize() {
await this.memoryProxy.initialize();
}
async checkConflicts(action, context) {
// Load relevant rules by quadrant or persistence
const strategicRules = await this.memoryProxy.getRulesByQuadrant('STRATEGIC');
const highPersistenceRules = await this.memoryProxy.getRulesByPersistence('HIGH');
// Check conflicts
const conflicts = this._findConflicts(action, [...strategicRules, ...highPersistenceRules]);
// Audit validation decision
await this.memoryProxy.auditDecision({
sessionId: context.sessionId,
action: 'conflict_validation',
rulesChecked: conflicts.map(c => c.ruleId),
violations: conflicts,
allowed: conflicts.length === 0
});
return conflicts;
}
```
**Benefits**:
- Query rules by quadrant/persistence
- Audit trail for validation decisions
- Better performance (cache + filtering)
**Testing**:
- Update existing tests
- Add integration test
- Verify conflict detection still works
---
### Session 2: Monitoring & Verification (MEDIUM PRIORITY)
**Duration**: 2 hours
**Services**: MetacognitiveVerifier, ContextPressureMonitor (optional)
#### MetacognitiveVerifier Integration
**Current Implementation**:
```javascript
// Independent verification service
async verify(operation, context) {
// Verify alignment, coherence, completeness, etc.
return verificationResult;
}
```
**Target Implementation**:
```javascript
async initialize() {
await this.memoryProxy.initialize();
}
async verify(operation, context) {
const result = {
alignment: this._checkAlignment(operation),
coherence: this._checkCoherence(operation),
completeness: this._checkCompleteness(operation),
// ...
};
// Audit verification decision
await this.memoryProxy.auditDecision({
sessionId: context.sessionId,
action: 'metacognitive_verification',
metadata: {
operation_type: operation.type,
confidence_score: result.confidenceScore,
issues_found: result.issues.length,
verification_passed: result.passed
}
});
return result;
}
```
**Benefits**:
- Audit trail for verification decisions
- Track verification patterns over time
- Identify common verification failures
---
### Session 3: Advanced Features (OPTIONAL)
**Duration**: 3-4 hours
**Focus**: Context editing experiments, analytics
#### Context Editing Experiments
**Goal**: Test Anthropic Memory Tool API for context pruning
**Experiments**:
1. **50+ Turn Conversation**:
- Store rules at start
- Have 50+ turn conversation
- Measure token usage
- Prune context (keep rules)
- Verify rules still accessible
2. **Token Savings Measurement**:
- Baseline: No context editing
- With editing: Prune stale content
- Calculate token savings
- Validate rule retention
3. **Context Editing Strategy**:
- When to prune (every N turns?)
- What to keep (rules, recent context)
- What to discard (old conversation)
**Expected Findings**:
- Token savings: 20-40% in long conversations
- Rules persist: 100% (stored in memory)
- Performance: <100ms for context edit
---
#### Audit Analytics Dashboard (Optional)
**Goal**: Analyze audit trail for governance insights
**Features**:
1. **Violation Trends**:
- Most violated rules
- Violation frequency over time
- By service, by session
2. **Enforcement Patterns**:
- Most blocked domains
- Human intervention frequency
- Decision latency tracking
3. **Service Health**:
- Rule loading success rate
- Audit write failures
- Cache hit/miss ratio
**Implementation**:
```bash
# Simple CLI analytics
node scripts/analyze-audit-trail.js --date 2025-10-10
# Output:
# Total decisions: 1,234
# Violations: 45 (3.6%)
# Most violated: inst_017 (15 times)
# Services: BoundaryEnforcer (87%), BlogCuration (13%)
```
---
## Production Deployment Checklist
### Prerequisites
- [x] MemoryProxy service tested (25/25 tests)
- [x] Migration script validated (18/18 rules)
- [x] Backward compatibility verified (99/99 tests)
- [x] Audit trail functional (JSONL format)
### Deployment Steps
**1. Initialize Services**:
```javascript
// In application startup
const BoundaryEnforcer = require('./services/BoundaryEnforcer.service');
const BlogCuration = require('./services/BlogCuration.service');
async function initializeServices() {
await BoundaryEnforcer.initialize();
await BlogCuration.initialize();
// Add more services as integrated...
}
```
**2. Verify Initialization**:
```bash
# Run deployment test
node scripts/test-production-deployment.js
# Expected output:
# ✅ MemoryProxy initialized
# ✅ BoundaryEnforcer: 3/3 rules loaded
# ✅ BlogCuration: 3/3 rules loaded
# ✅ Audit trail active
```
**3. Monitor Audit Trail**:
```bash
# Watch audit logs
tail -f .memory/audit/decisions-$(date +%Y-%m-%d).jsonl | jq
# Check audit log size (daily rotation)
ls -lh .memory/audit/
```
**4. Validate Service Behavior**:
- BoundaryEnforcer: Test enforcement decisions
- BlogCuration: Test content validation
- Check audit entries created
---
## Success Metrics
### Integration Coverage
- **Current**: 2/6 services (33%)
- **Session 1 Target**: 4/6 services (67%)
- **Session 2 Target**: 5-6/6 services (83-100%)
### Test Coverage
- **Current**: 99/99 tests (100%)
- **Target**: Maintain 100% as services added
### Performance
- **Current**: +2ms per service (~5% overhead)
- **Target**: <10ms total overhead across all services
### Audit Coverage
- **Current**: 2 services generating audit logs
- **Target**: All services audit critical decisions
---
## Risk Assessment
| Risk | Probability | Impact | Mitigation |
|------|------------|--------|------------|
| **Integration breaking changes** | LOW | HIGH | 100% backward compat required |
| **Performance degradation** | LOW | MEDIUM | Benchmark after each integration |
| **Audit log growth** | MEDIUM | LOW | Daily rotation + monitoring |
| **MemoryProxy single point of failure** | LOW | HIGH | Graceful degradation implemented |
| **Context editing API issues** | MEDIUM | LOW | Optional feature, can defer |
---
## Timeline
### Week 3 (Complete) ✅
- MemoryProxy service
- BoundaryEnforcer integration
- BlogCuration integration
- Migration script
- Production deployment
### Week 4 (Session 1) - Estimated 2-3 hours
- InstructionPersistenceClassifier integration
- CrossReferenceValidator integration
- Update tests
- Verify backward compatibility
### Week 5 (Session 2) - Estimated 2 hours
- MetacognitiveVerifier integration
- Optional: ContextPressureMonitor
- Audit analytics (basic)
### Week 6 (Optional) - Estimated 3-4 hours
- Context editing experiments
- Advanced analytics
- Performance optimization
- Documentation updates
---
## Next Steps
### Immediate (Before Next Session)
1. Production deployment successful
2. Monitor audit logs for insights
3. 📝 Document integration patterns
4. 📝 Update CLAUDE.md with MemoryProxy usage
### Session 1 Preparation
1. Read InstructionPersistenceClassifier implementation
2. Read CrossReferenceValidator implementation
3. Plan integration approach (similar to BoundaryEnforcer)
4. Prepare test scenarios
### Session 2 Preparation
1. Review MetacognitiveVerifier
2. Identify audit logging opportunities
3. Plan analytics dashboard (if time)
---
## Resources
### Documentation
- **Week 1 Summary**: `docs/research/phase-5-week-1-summary.md`
- **Week 2 Summary**: `docs/research/phase-5-week-2-summary.md`
- **Week 3 Summary**: `docs/research/phase-5-week-3-summary.md`
- **Integration Roadmap**: `docs/research/phase-5-integration-roadmap.md` (this file)
### Code References
- **MemoryProxy**: `src/services/MemoryProxy.service.js`
- **BoundaryEnforcer**: `src/services/BoundaryEnforcer.service.js` (reference implementation)
- **BlogCuration**: `src/services/BlogCuration.service.js` (reference implementation)
- **Migration Script**: `scripts/migrate-to-memory-proxy.js`
### Test Files
- **MemoryProxy Tests**: `tests/unit/MemoryProxy.service.test.js` (25 tests)
- **BoundaryEnforcer Tests**: `tests/unit/BoundaryEnforcer.test.js` (48 tests)
- **BlogCuration Tests**: `tests/unit/BlogCuration.service.test.js` (26 tests)
- **Integration Test**: `tests/poc/memory-tool/week3-boundary-enforcer-integration.js`
---
**Status**: 📊 Framework 33% integrated (2/6 services)
**Next Milestone**: 67% integration (4/6 services) - Session 1
**Final Target**: 100% integration (6/6 services) - Session 2
**Recommendation**: Proceed with Session 1 (InstructionPersistenceClassifier + CrossReferenceValidator) when ready
---
**Document Status**: Complete
**Last Updated**: 2025-10-10
**Author**: Claude Code + John Stroh
**Contact**: research@agenticgovernance.digital