Skip to content

[BE] Persona Marketplace - PersonaManager (#16)#51

Merged
SaharBarak merged 1 commit into
mainfrom
feat/persona-manager-16-clean
Feb 6, 2026
Merged

[BE] Persona Marketplace - PersonaManager (#16)#51
SaharBarak merged 1 commit into
mainfrom
feat/persona-manager-16-clean

Conversation

@SaharBarak
Copy link
Copy Markdown
Owner

Summary

Implements the PersonaManager infrastructure for the Persona Marketplace epic.

🧹 Clean PR - Replaces #45 which had mixed commits

Changes

  • src/lib/personas/types.ts: Defines CustomPersona interface extending AgentPersona
  • src/lib/personas/PersonaManager.ts: Full CRUD operations for custom personas
  • src/lib/personas/index.ts: Module exports
  • src/lib/personas/__tests__/PersonaManager.test.ts: 79 comprehensive tests

Features

  • CRUD operations for custom personas
  • Persistence in ~/.forge/personas/
  • Validation with errors and warnings
  • Filtering by industry, tags, author, favorites
  • Import/export JSON
  • Persona sets for grouping
  • Session integration via applyToSession()

Tests

✅ 79 tests passing

Related

Closes #16
Part of Epic: Persona Marketplace (#3)
Replaces #45

Add PersonaManager for custom persona CRUD operations:

- Define CustomPersona interface extending AgentPersona
- Create PersonaManager class with full CRUD operations
- Load/save personas from ~/.forge/personas/
- Comprehensive validation logic with errors and warnings
- Support persona sets for grouping
- Session integration with applyToSession()
- Import/export functionality
- Favorites and usage tracking
- Filter and sort capabilities
- 79 comprehensive tests covering all functionality

Part of Epic: Persona Marketplace (#3)
Closes #16
@SaharBarak
Copy link
Copy Markdown
Owner Author

BE Review ✅

Clean recreation of #45 - reviewed code is identical.

PersonaManager.ts (967 lines):

  • CRUD operations with file persistence
  • Validation with comprehensive rules
  • Filtering, sorting, import/export
  • Persona sets support
  • Event emitter pattern

79 tests - solid coverage

LGTM. Ready to merge.

@SaharBarak SaharBarak merged commit 45c1752 into main Feb 6, 2026
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[BE] Persona Marketplace - PersonaManager

1 participant