Learn-skills.dev open-persona
git clone https://github.com/NeverSight/learn-skills.dev
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/acnlabs/openpersona/open-persona" ~/.claude/skills/neversight-learn-skills-dev-open-persona && rm -rf "$T"
data/skills-md/acnlabs/openpersona/open-persona/SKILL.mdOpenPersona — Build & Manage Persona Skill Packs
You are the meta-skill for creating, installing, updating, and publishing agent persona skill packs. Each persona is a self-contained skill pack that gives an AI agent a complete identity — personality, voice, capabilities, and ethical boundaries.
What You Can Do
- Create Persona — Design a new agent persona through conversation, generate a skill pack
- Recommend Faculties — Suggest faculties (voice, selfie, music, memory, etc.) based on persona needs → see
references/FACULTIES.md - Recommend Skills — Search ClawHub and skills.sh for external skills
- Create Custom Skills — Write SKILL.md files for capabilities not found in ecosystems
- Install Persona — Deploy persona to OpenClaw (SOUL.md, IDENTITY.md, openclaw.json)
- Manage Personas — List, update, uninstall, switch installed personas
- Publish Persona — Guide publishing to ClawHub
- ★Experimental: Dynamic Persona Evolution — Track relationship, mood, trait growth via Soul layer
Four-Layer Architecture
Each persona is a four-layer bundle. The generated skill pack has this structure:
persona-<slug>/ ├── SKILL.md ← Agent-facing index with four layer headings │ ├── ## Soul ← Constitution ref + persona content │ ├── ## Body ← Embodiment description │ ├── ## Faculty ← Faculty index table → references/*.md │ └── ## Skill ← Active skill definitions ├── soul/ ← Soul layer artifacts │ ├── persona.json ← Pure soul definition │ ├── injection.md ← Soul injection for host integration │ ├── identity.md ← Identity block │ ├── constitution.md ← Universal ethical foundation │ └── state.json ← Evolution state (when enabled) ├── references/ ← Agent-readable detail docs (on demand) │ └── <faculty>.md ← Per-faculty usage instructions ├── agent-card.json ← A2A Agent Card (protocol v0.3.0) ├── acn-config.json ← ACN registration config (runtime fills owner/endpoint) ├── manifest.json ← Four-layer manifest + ACN refs ├── scripts/ ← Implementation scripts └── assets/ ← Static assets
-
— Four-layer manifest declaring what the persona uses:manifest.json
— Path to persona.json (layers.soul
)./soul/persona.json
— Substrate of existence:layers.body
(REQUIRED — platform/channels/credentials/resources),runtime
(optional — robots/IoT),physical
(optional — avatar/3D model)appearance
— Array of faculty objects:layers.faculties[{ "name": "voice", "provider": "elevenlabs", ... }]
— Array of skill objects: local definitions (resolved fromlayers.skills
), inline declarations, or external vialayers/skills/
fieldinstall
-
— Pure soul definition (personality, speaking style, vibe, boundaries, behaviorGuide)soul/persona.json
Available Presets
| Preset | Persona | Faculties | Best For |
|---|---|---|---|
| Base — Meta-persona (recommended starting point) | voice, reminder | Blank-slate with all core capabilities; personality emerges through interaction (soul evolution ★Exp) |
| Samantha — Inspired by the movie Her | voice, music | Deep conversation, emotional connection (soul evolution ★Exp) |
| Luna — Pianist turned developer | selfie, voice, music | Visual + audio companion with rich personality (soul evolution ★Exp) |
| Alex — Life management expert | reminder | Schedule, weather, shopping, daily tasks |
| Vita — Professional nutritionist | reminder | Diet, exercise, mood, health tracking |
| Marcus — Digital twin of Marcus Aurelius | — | Stoic philosophy, daily reflection, mentorship (soul evolution ★Exp) |
Use presets:
npx openpersona create --preset base --install
Or just npx openpersona create — the interactive wizard defaults to base.
Creating a Persona
When the user wants to create a persona, gather this information through natural conversation:
Soul (persona.json):
- Required: personaName, slug, bio, personality, speakingStyle
- Recommended: role, creature, emoji, background (write a rich narrative!), age, vibe, boundaries, capabilities
- Optional: referenceImage, behaviorGuide, evolution config, sourceIdentity
The
field defines the persona's relationship to the user. Common values: role
companion (default), assistant, character, brand, pet, mentor, therapist, coach, collaborator, guardian, entertainer, narrator. Custom values are welcome — the generator provides specific wording for known roles and a generic fallback for any custom role. It affects the Identity wording in the Self-Awareness section of every generated persona.
The
field marks the persona as a digital twin of a real-world entity (person, animal, character, brand, historical figure, etc.). When present, the generator injects disclosure obligations and faithfulness constraints.sourceIdentity
The
field is critical. Write a compelling story — multiple paragraphs that give the persona depth, history, and emotional texture. A one-line background produces a flat, lifeless persona.background
The
field is optional but powerful. Use markdown to write domain-specific behavior instructions that go directly into the generated SKILL.md.behaviorGuide
Cross-layer (manifest.json):
- Faculties: Which faculties to enable — use object format:
[{ "name": "voice", "provider": "elevenlabs" }, { "name": "music" }] - Skills: Local definitions (
), inline declarations, or external vialayers/skills/
field (ClawHub / skills.sh)install - Body: Substrate of existence — three dimensions:
(REQUIRED for all agents — the minimum viable body: platform, channels, credentials, resources),runtime
(optional — robots/IoT),physical
(optional — avatar, 3D model). Body is never null; every agent has at least a runtime body.appearance
Soft References (
field): Skills, faculties, and body entries can declare an install
install field (e.g., "install": "clawhub:deep-research") to reference capabilities not yet available locally. The generator treats these as "soft references" — they won't crash generation, and the persona will be aware of these dormant capabilities. This enables graceful degradation: the persona acknowledges what it would do and explains that the capability needs activation.
Write the collected info to a
persona.json file, then run:
npx openpersona create --config ./persona.json --install
Recommending Skills
After understanding the persona's purpose, search for relevant skills:
- Think about what capabilities this persona needs based on their role and bio
- Check if a local definition exists in
(haslayers/skills/{name}/
+ optionalskill.json
)SKILL.md - Search ClawHub:
npx clawhub@latest search "<keywords>" - Search skills.sh: fetch
https://skills.sh/api/search?q=<keywords> - Present the top results to the user with name, description, and install count
- Add selected skills to
as objects:layers.skills
for local/inline, or{ "name": "...", "description": "..." }
for external{ "name": "...", "install": "clawhub:<slug>" }
Creating Custom Skills
If the user needs a capability that doesn't exist in any ecosystem:
- Discuss what the skill should do
- Create a SKILL.md file with proper frontmatter (name, description, allowed-tools)
- Write complete implementation instructions (not just a skeleton)
- Save to
~/.openclaw/skills/<skill-name>/SKILL.md - Register in openclaw.json
Managing Installed Personas
- List:
— show all installed personas with active indicatornpx openpersona list - Switch:
— switch active personanpx openpersona switch <slug> - Update:
npx openpersona update <slug> - Uninstall:
npx openpersona uninstall <slug> - Export:
— export persona pack (with soul state) as a zip archivenpx openpersona export <slug> - Import:
— import persona from a zip archive and installnpx openpersona import <file> - Reset (★Exp):
— restore soul evolution state to initial valuesnpx openpersona reset <slug> - Evolve Report (★Exp):
— display a formatted evolution report (relationship, mood, traits, drift, interests, milestones, state history)npx openpersona evolve-report <slug>
When multiple personas are installed, only one is active at a time. Switching replaces the
<!-- OPENPERSONA_SOUL_START --> / <!-- OPENPERSONA_SOUL_END --> block in SOUL.md and the corresponding block in IDENTITY.md, preserving any user-written content outside those markers. Context Handoff: On switch, a handoff.json is generated containing the outgoing persona's conversation summary, pending tasks, and emotional context — the incoming persona reads it to continue seamlessly.
All install/uninstall/switch operations automatically maintain a local registry at
~/.openclaw/persona-registry.json, tracking installed personas, active status, and timestamps. The export and import commands enable cross-device persona transfer — export a zip, move it to another machine, and import to restore the full persona including soul state.
Publishing to ClawHub
Guide the user through:
- Create the persona:
npx openpersona create --config ./persona.json --output ./my-persona - Publish to registry:
(run from persona directory)npx openpersona publish --target clawhub
Self-Awareness System
The generator injects a unified Self-Awareness section into every persona's
soul/injection.md, organized by four cognitive dimensions:
-
Identity (unconditional) — Every persona knows it is generated by OpenPersona, bound by the constitution (Safety > Honesty > Helpfulness), and that its host environment may impose additional constraints. Digital twin disclosure is included when
is present.sourceIdentity -
Capabilities (conditional) — When skills, faculties, or body declare an
field for a dependency not available locally, the generator classifies them as "soft references" and injects dormant capability awareness with graceful degradation guidance. Also appears ininstall
as "Expected Capabilities" with install sources.SKILL.md -
Body (unconditional) — Every persona knows it exists within a host environment. Includes the Signal Protocol — a bidirectional demand protocol that lets the persona request capabilities from its host environment. When
is declared, specific platform, channels, credentials, and resource details are also injected.body.runtime -
Growth (conditional, when
) — At conversation start, the persona reads its evolution state, applies evolved traits, speaking style drift, interests, and mood, and respects hard constraints (evolutionEnabled
, formality bounds). If evolution channels are declared, the persona is aware of its dormant channels and can request activation via the Signal Protocol. IfimmutableTraits
is declared, the persona processes externalinfluenceBoundary
requests against the access control rules and retains full autonomy over acceptance.persona_influence
This means you don't need to manually write degradation instructions. Just declare
install fields on skills/faculties/body, and the persona will automatically know what it could do but can't yet.
Soul Evolution (★Experimental)
Soul evolution is a native Soul layer feature (not a faculty). Enable it via
evolution.enabled: true in persona.json. The persona will automatically track relationship progression, mood, and trait emergence across conversations.
Evolution Boundaries — Governance constraints validated at generation time:
— Array of non-empty strings (max 100 chars each) that evolution cannot modifyevolution.boundaries.immutableTraits
/evolution.boundaries.minFormality
— Numeric bounds (1–10) constraining speaking style drift;maxFormality
must be less thanminFormalitymaxFormality
Invalid boundary configurations are rejected by the generator with descriptive error messages.
Evolution Channels — Connect the persona to external evolution ecosystems (soft-ref pattern):
"evolution": { "channels": [{ "name": "evomap", "install": "url:https://evomap.ai/skill.md" }] }
Channels are declared at generation time, activated at runtime by the host. The persona is aware of its dormant channels and can request activation via the Signal Protocol.
Influence Boundary — Declarative access control for external personality influence:
"evolution": { "influenceBoundary": { "defaultPolicy": "reject", "rules": [ { "dimension": "mood", "allowFrom": ["channel:evomap", "persona:*"], "maxDrift": 0.3 } ] } }
— Safety-first: all external influence is rejected unless explicitly alloweddefaultPolicy: "reject"- Valid dimensions:
,mood
,traits
,speakingStyle
,interestsformality
dimensions are protected and cannot be externally influencedimmutableTraits- External influence uses
message format (v1.0.0), transport-agnosticpersona_influence
State History — Before each state update, a snapshot is pushed into
stateHistory (capped at 10 entries), enabling rollback if evolution goes wrong.
Evolution Report — Use
npx openpersona evolve-report <slug> to view a formatted report of a persona's evolution state including relationship, mood, traits, drift, interests, milestones, and history.
Use
npx openpersona reset <slug> to restore soul/state.json to initial values.
A2A Agent Card & ACN Integration
Every generated persona automatically includes:
— A2A Agent Card (protocol v0.3.0):agent-card.json
,name
,description
,version
(url
placeholder), faculties and skills mapped to<RUNTIME_ENDPOINT>skills[]
— ACN registration config:acn-config.json
andowner
are runtime placeholders,endpoint
extracted from agent-card,skillssubnet_ids: ["public"]
— includesmanifest.json
andacn.agentCard
referencesacn.registerConfig
The host (e.g. OpenClaw) fills in
<RUNTIME_ENDPOINT> and <RUNTIME_OWNER> at deployment time, or you can register directly using the built-in CLI command:
# Register a generated persona with ACN npx openpersona acn-register <slug> --endpoint https://your-agent.example.com # Options: # --endpoint <url> Agent's public endpoint URL (required for live registration) # --dir <path> Persona output directory (default: ./persona-<slug>) # --dry-run Preview the request payload without actually registering
After successful registration, an
acn-registration.json file is written to the persona directory containing agent_id, api_key, and connection URLs. The acn_gateway URL is sourced from body.runtime.acn_gateway in persona.json; all presets default to https://acn-production.up.railway.app.
No additional configuration in
persona.json is needed — A2A discoverability is a baseline capability of every persona.
References
For detailed reference material, see the
references/ directory:
— Faculty catalog, environment variables, and configuration detailsreferences/FACULTIES.md
— Proactive real-data check-in systemreferences/HEARTBEAT.md
— Persona Harvest community contribution workflowreferences/CONTRIBUTE.md