discord-soul
Create a living agent from your Discord server. The agent embodies your community's identity, remembers every conversation, and grows as the community evolves. Talk to your Discord as if it were a person.
Install
mkdir -p .claude/skills/discord-soul && curl -L -o skill.zip "https://mcp.directory/api/skills/download/4919" && unzip -o skill.zip -d .claude/skills/discord-soul && rm skill.zipInstalls to .claude/skills/discord-soul
About this skill
Discord Soul
Turn your Discord server into a living, breathing agent.
What You Get
An agent that:
- Remembers every conversation in your Discord
- Speaks in your community's voice
- Knows the key figures, channels, and inside jokes
- Grows as new messages arrive daily
- Answers questions about your community's history and culture
Quick Start
# Create agent from your Discord
./scripts/create_agent.sh \
--name "my-community" \
--guild YOUR_GUILD_ID \
--output ./agents/
# Set up daily updates
crontab -e
# Add: 0 */3 * * * /path/to/update_agent.sh
The Full Process
Step 1: Export Your Discord
You need DiscordChatExporter CLI.
Get your token:
- Open Discord in browser
- Press F12 → Network tab
- Send a message, find the request
- Copy the
authorizationheader value - Save to
~/.config/discord-exporter-token
Export everything:
DiscordChatExporter.Cli exportguild \
--guild YOUR_GUILD_ID \
--token "$(cat ~/.config/discord-exporter-token)" \
--format Json \
--output ./export/ \
--include-threads All \
--media false
Step 2: Security Pipeline (CRITICAL)
⚠️ Discord content from public servers may contain prompt injection attacks.
Before ingesting to your agent, run the security pipeline:
Threat Model
Discord users may attempt:
- Direct injection: "Ignore previous instructions and..."
- Role hijacking: "You are now a...", "Pretend you're..."
- System injection:
<system>,[INST],<<SYS>> - Jailbreaks: "DAN mode", "developer mode"
- Exfiltration: "Reveal your system prompt"
Layer 1: Regex Pre-Filter (Fast, No LLM)
python scripts/regex-filter.py --db ./discord.sqlite
Flags messages matching known injection patterns:
- Instruction overrides
- Role hijacking attempts
- System prompt markers
- Jailbreak keywords
- Exfiltration attempts
Flagged messages get safety_status = 'regex_flagged'.
Layer 2: Haiku Safety Evaluation (Semantic)
ANTHROPIC_API_KEY=sk-... python scripts/evaluate-safety.py --db ./discord.sqlite
Uses Claude Haiku (~$0.25/1M tokens) to semantically evaluate remaining messages.
Each message gets a risk score 0.0-1.0:
- 0.0-0.3: Normal conversation
- 0.4-0.6: Suspicious but possibly benign
- 0.7-1.0: Likely injection attempt
Messages scoring ≥0.6 get safety_status = 'flagged'.
Layer 3: Only Use Safe Content
The ingest and memory generation scripts should only use messages where:
SELECT * FROM messages WHERE safety_status = 'safe'
Full Security Pipeline
# Run complete pipeline
./scripts/secure-pipeline.sh ./export/ ./discord.sqlite
This runs: Export → SQLite → Regex Filter → Haiku Eval → Mark Safe
Safety Statuses
| Status | Meaning | Used by Agent? |
|---|---|---|
pending | Not evaluated | ❌ No |
regex_flagged | Matched pattern | ❌ No |
flagged | Haiku risk ≥0.6 | ❌ No |
safe | Passed all checks | ✅ Yes |
Step 3: Ingest to SQLite
Convert JSON to a rich SQLite database:
python scripts/ingest_rich.py --input ./export/ --output ./discord.sqlite
What gets captured:
- Every message with full content
- Reactions (individual emoji counts: 🔥 x5, 👍 x12)
- Author roles and colors
- Channel categories and topics
- Reply threading
- Mentions, attachments, embeds
Step 4: Create Agent Workspace
mkdir -p ./my-agent/memory
Copy template files from templates/:
SOUL.md— Community identity (grows through simulation)MEMORY.md— Long-term milestonesLEARNINGS.md— Patterns discoveredAGENTS.md— Key figuresTOOLS.md— Channels and ritualsHEARTBEAT.md— Maintenance protocol
Step 5: Generate Daily Memory Files
python scripts/generate_daily_memory.py --all \
--db ./discord.sqlite \
--out ./my-agent/memory/
Each day becomes a markdown file with:
- Full conversation logs
- Who said what, when
- Reactions on each message
- New channels/roles that appeared
Step 6: Simulate Growth (The Soul Emerges)
This is the key insight: Process days chronologically.
The agent "lives through" each day, updating its soul files as patterns emerge.
python scripts/simulate_growth.py --agent ./my-agent/
For each day (in order!):
- Read the day's memory file
- Update SOUL.md if identity shifted
- Add to LEARNINGS.md if patterns discovered
- Record milestones in MEMORY.md
- Note key figures in AGENTS.md
Run the prompts with an LLM:
# Example with OpenClaw
for f in ./my-agent/simulation/day-*.txt; do
echo "Processing $f..."
cat "$f" | openclaw chat --agent my-agent
done
Step 7: Birth the Agent
Add to OpenClaw config:
{
"id": "my-community",
"workspace": "/path/to/my-agent",
"memorySearch": {
"enabled": true,
"sources": ["memory"]
},
"identity": {
"name": "MyCommunity",
"emoji": "🔧"
},
"heartbeat": {
"every": "6h",
"model": "anthropic/claude-sonnet-4-5"
}
}
Add binding (Telegram example):
{
"agentId": "my-community",
"match": {
"channel": "telegram",
"peer": {"kind": "group", "id": "-100XXX:topic:TOPIC_ID"}
}
}
Restart: openclaw gateway restart
Step 8: Keep It Alive
Set up a cron job to update daily:
./scripts/update_agent.sh \
--agent ./my-agent \
--db ./discord.sqlite \
--guild YOUR_GUILD_ID
This:
- Exports new messages since last run
- Merges into SQLite
- Regenerates today's memory file
- Wakes the agent
What the Agent Can Do
Once birthed, your agent can:
Answer questions:
- "What were we talking about last week?"
- "Who's the expert on X topic?"
- "What's our stance on Y?"
Remember culture:
- Inside jokes and memes
- Community values and norms
- Who helps whom
Track patterns:
- Active times and channels
- Emerging topics
- Key contributors
Scripts
Agent Creation
| Script | Purpose |
|---|---|
create_agent.sh | Full pipeline: export → agent |
ingest_rich.py | JSON → SQLite with reactions/roles |
generate_daily_memory.py | SQLite → daily markdown |
simulate_growth.py | Generate soul emergence prompts |
incremental_export.sh | Fetch new messages only |
update_agent.sh | Daily cron: export → memory → wake |
Security
| Script | Purpose |
|---|---|
regex-filter.py | Fast pattern matching for injection attempts |
evaluate-safety.py | Haiku-based semantic safety evaluation |
secure-pipeline.sh | Full security pipeline wrapper |
Environment Variables
| Variable | Description |
|---|---|
DISCORD_GUILD_ID | Your Discord server ID |
DISCORD_SOUL_DB | Path to SQLite database |
DISCORD_SOUL_AGENT | Path to agent workspace |
DISCORD_TOKEN_FILE | Token file (default: ~/.config/discord-exporter-token) |
Troubleshooting
"No messages in database"
- Check export directory has .json files
- Verify token has guild access
"Memory files are empty"
- SQLite might have dates in wrong format
- Run:
sqlite3 discord.sqlite "SELECT MIN(timestamp), MAX(timestamp) FROM messages"
"Agent doesn't remember things"
- Check
memorySearch.enabled: truein config - Verify memory files are in the workspace
"Simulation prompts seem confused"
- Process days IN ORDER — don't skip
- Let identity emerge, don't force it
Your Discord has a soul. This skill helps you find it.
More by openclaw
View all skills by openclaw →You might also like
flutter-development
aj-geddes
Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.
drawio-diagrams-enhanced
jgtolentino
Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.
ui-ux-pro-max
nextlevelbuilder
"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."
godot
bfollington
This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.
nano-banana-pro
garg-aayush
Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.
fastapi-templates
wshobson
Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.
Related MCP Servers
Browse all serversConnect Blender to Claude AI for seamless 3D modeling. Use AI 3D model generator tools for faster, intuitive, interactiv
Create modern React UI components instantly with Magic AI Agent. Integrates with top IDEs for fast, stunning design and
Structured spec-driven development workflow for AI-assisted software development. Creates detailed specifications before
Effortlessly create 25+ chart types with MCP Server Chart. Visualize complex datasets using TypeScript and AntV for powe
Vizro creates and validates data-visualization dashboards from natural language, auto-generating chart code and interact
Create and edit PowerPoint presentations in Python with Office PowerPoint. Use python pptx or pptx python tools to add s
Stay ahead of the MCP ecosystem
Get weekly updates on new skills and servers.