Obsidian Conversation Backup
Automatically backs up Clawdbot conversations to Obsidian with beautiful chat-style formatting. Prevents data loss from /new resets with hourly incremental snapshots.
Features
- •Incremental backups: Hourly snapshots of new messages only (no duplication)
- •Chat formatting: Obsidian callouts with emojis, timestamps, proper multi-paragraph support
- •Hourly breakdowns: Organize conversations by clock hour for easy reference
- •Zero token cost: Pure shell scripting, no LLM calls
- •Smart filtering: Skips empty messages and system notifications
Quick Setup
Installation
# Extract the skill (if downloaded as .skill file) unzip obsidian-conversation-backup.skill cd obsidian-conversation-backup # Run installer (interactive) chmod +x install.sh ./install.sh
The installer will ask for:
- •Obsidian vault path
- •Session directory location
- •Tracking files location
Or manual setup:
- •Copy
config.exampletoconfig - •Edit
configwith your paths - •Make scripts executable:
chmod +x scripts/*.sh
Enable Automatic Backups
Add to crontab for hourly backups:
crontab -e # Add this line (runs every hour at :00) 0 * * * * /path/to/obsidian-conversation-backup/scripts/monitor_and_save.sh
Customize Chat Appearance (Optional)
Edit scripts/format_message_v2.jq to change:
- •User emoji (default: 🐉)
- •Assistant emoji (default: 🦞)
- •Callout types (default:
[!quote]for user,[!check]for assistant)
Usage
Automatic Incremental Backups
Once configured in cron, the system runs automatically:
Every hour:
- •Checks for new messages (≥10 lines)
- •Creates incremental snapshot if found
- •Saves to:
YYYY-MM-DD-HHmm-incremental.md - •Skips if no new conversation
Example output:
2026-01-20-1500-incremental.md (messages from last save to now) 2026-01-20-1600-incremental.md (new messages since 15:00) 2026-01-20-1700-incremental.md (new messages since 16:00)
Protection: Max conversation loss = 1 hour
On-Demand Full Snapshot
Save complete conversation anytime:
scripts/save_full_snapshot.sh [topic-name]
Examples:
scripts/save_full_snapshot.sh important-decisions scripts/save_full_snapshot.sh bug-fix-discussion scripts/save_full_snapshot.sh # uses "full-conversation" as default
Hourly Breakdown (Organization)
Create organized breakdown by clock hour:
scripts/create_hourly_snapshots.sh YYYY-MM-DD
Example:
scripts/create_hourly_snapshots.sh 2026-01-20
Output:
2026-01-20-1500-hourly.md (15:00-15:59 messages) 2026-01-20-1600-hourly.md (16:00-16:59 messages) 2026-01-20-1700-hourly.md (17:00-17:59 messages)
Use case: End-of-day organization for easy reference
Chat Format
Messages appear as colored Obsidian callouts:
User messages (blue [!quote] callout):
> [!quote] 🐉 User · 15:30 > This is my message
Assistant messages (green [!check] callout):
> [!check] 🦞 Zoidbot · 15:31 > This is the response
Features:
- •Timestamps (HH:MM format)
- •Multi-paragraph support (uses
<br><br>for paragraph breaks) - •Proper line wrapping (all lines prefixed with
>) - •Empty messages filtered out
- •System notifications excluded
Token Monitoring
The monitor_and_save.sh script also tracks token usage:
Warnings via Telegram:
- •800k tokens (80%): "Consider /new soon"
- •900k tokens (90%): "Run /new NOW"
Implementation:
# Sends warning only when crossing threshold (one-time) # No repeated warnings # Resets when back under 800k
File Structure
scripts/ ├── monitor_and_save.sh # Hourly incremental backup + token monitoring ├── save_full_snapshot.sh # On-demand full conversation save ├── create_hourly_snapshots.sh # Organize by clock hour └── format_message_v2.jq # Chat formatting logic
Configuration
Tracking Files
The system uses hidden files to track state:
/root/clawd/.last_save_line_count # For token monitoring /root/clawd/.last_snapshot_timestamp # For incremental saves /root/clawd/.token_warning_sent # For warning deduplication
Note: Do not delete these files or incremental backups may duplicate content
Session File Location
Default: /root/.clawdbot/agents/main/sessions/*.jsonl
If your session files are elsewhere, update the SESSION_FILE path in each script.
Troubleshooting
No snapshots being created
- •Check cron is running:
crontab -l - •Verify script has execute permission:
chmod +x scripts/*.sh - •Check logs: Run manually to see errors
Messages breaking out of callouts
- •Ensure
format_message_v2.jqhas thegsub("\n\n"; "<br><br>")line - •Check that all lines have
>prefix - •Verify jq is installed:
jq --version
Duplicated content in snapshots
- •Delete tracking files and let system reset:
bash
rm /root/clawd/.last_snapshot_timestamp
Empty callout boxes appearing
- •Update
format_message_v2.jqto filter empty messages - •Check for the
if ($text_content | length) > 0condition
Requirements
- •jq: JSON parsing (
apt-get install jq) - •cron: For automatic backups
- •Obsidian vault: Target directory for markdown files
Advanced Customization
Change Backup Frequency
Edit crontab:
# Every 2 hours 0 */2 * * * /path/to/monitor_and_save.sh # Every 30 minutes */30 * * * * /path/to/monitor_and_save.sh # Specific times only (9am, 12pm, 6pm, 9pm) 0 9,12,18,21 * * * /path/to/monitor_and_save.sh
Change Minimum Message Threshold
Edit monitor_and_save.sh:
# Change from 10 to 5 messages minimum if [[ $new_lines -lt 5 ]]; then
Add More Callout Styles
Obsidian callout types:
- •
[!quote]- Blue - •
[!check]- Green - •
[!note]- Cyan - •
[!tip]- Purple - •
[!warning]- Orange - •
[!danger]- Red
Customize Telegram Notifications
Edit monitor_and_save.sh to change warning text or add custom notifications.
Best Practices
- •Run hourly breakdown at end of day - Use as organizational tool, not backup
- •Keep incremental backups running - This is your safety net
- •Test scripts after setup - Run manually first to verify output
- •Backup tracking files - Include
.last_snapshot_timestampin vault backups - •Use descriptive topic names - For full snapshots, use meaningful names
Example Workflow
Daily routine:
- •Automatic incremental backups run hourly (no action needed)
- •At end of day:
scripts/create_hourly_snapshots.sh 2026-01-20 - •Review organized hourly files in Obsidian
- •Delete old incrementals if desired (hourly breakdown covers them)
Before /new reset:
- •Optional:
scripts/save_full_snapshot.sh before-reset - •Run
/newsafely - conversation is backed up - •Continue chatting - incrementals resume automatically
Integration with Clawdbot
This skill works with:
- •HEARTBEAT.md: Automatic token monitoring
- •MEMORY.md: Conversation archival system
- •Telegram integration: Warning notifications
- •Any Obsidian vault: Works with existing vaults
Credits
Created by the Clawdbot community for reliable conversation backup and beautiful Obsidian formatting.