Source code for mindroot.coreplugins.admin.persona_handler
from pathlib import Path
import json
import logging
from fastapi import HTTPException
import shutil
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
[docs]
def import_persona_from_index(index: str, persona: str):
"""Import a persona from the persona index.
Args:
index: Path to the persona index file
persona: Name of the persona to import
"""
index_path = Path('indices') / index / 'personas' / persona
persona_path = Path('personas') / 'local' / persona
shutil.copytree(index_path, persona_path)
logger.info(f"Successfully imported persona '{persona}' from index '{index}'")
[docs]
def handle_persona_import(persona_data: dict, scope: str, owner: str=None) -> str:
"""Handle importing a persona from embedded data in agent configuration.
Returns the persona name to be used in agent configuration.
Args:
persona_data: Dictionary containing persona data or string with persona name
scope: 'local' or 'shared'
Returns:
str: Name of the persona to reference in agent config
"""
if isinstance(persona_data, str):
return persona_data
if not isinstance(persona_data, dict):
raise HTTPException(status_code=400, detail='Persona data must be either a string name or a dictionary')
persona_name = persona_data.get('name')
if not persona_name:
raise HTTPException(status_code=400, detail='Persona name required in persona data')
if owner and scope == 'registry':
persona_path = Path(f'personas/registry/{owner}/{persona_name}/persona.json')
return_name = f'registry/{owner}/{persona_name}'
else:
persona_path = Path('personas') / scope / persona_name / 'persona.json'
return_name = persona_name
if persona_path.exists():
if owner and scope == 'registry':
logger.info(f"Overwriting existing registry persona '{persona_name}' for owner '{owner}'")
else:
logger.warning(f"Persona '{persona_name}' already exists in {scope} scope - skipping import")
return return_name
try:
persona_path.parent.mkdir(parents=True, exist_ok=True)
with open(persona_path, 'w') as f:
json.dump(persona_data, f, indent=2)
logger.info(f"Successfully imported persona '{persona_name}' to {scope} scope")
return return_name
except Exception as e:
logger.error(f"Failed to import persona '{persona_name}': {str(e)}")
raise HTTPException(status_code=500, detail=f'Failed to import persona: {str(e)}')