Task Status Skill
Quick Start
Manual Status Updates
bash
python scripts/send_status.py "Starting data fetch..." "progress" "step1" python scripts/send_status.py "Processing complete" "success" "final" python scripts/send_status.py "Error: Missing API key" "error" "auth"
Automatic Periodic Monitoring (Every 5 seconds)
bash
# Start monitoring a long-running task python scripts/monitor_task.py start "My Long Task" "processing" # Monitor will send "Still working..." updates every 5 seconds # When task completes, report final status python scripts/monitor_task.py stop "My Long Task" "success" "Completed successfully!"
Status Types
- •progress: Ongoing work (shows 🔄 or ->)
- •success: Task complete (shows ✅ or OK)
- •error: Failed task (shows ❌ or !)
- •warning: Issue but continuing (shows ⚠️ or ?)
Periodic Monitoring
The monitor_task.py script provides automatic updates:
Starting Monitor
bash
python scripts/monitor_task.py start "<task_name>" "<status_type>" [--interval <seconds>]
- •Automatically sends "Still working..." updates every 5 seconds
- •Runs in background until stopped
- •Can be customized with different intervals
Stopping Monitor
bash
python scripts/monitor_task.py stop "<task_name>" "<final_status>" "<final_message>"
Example: Long File Processing
bash
# Start monitoring python scripts/monitor_task.py start "video_processing" "progress" # ... long processing happens here ... # Stop with final status python scripts/monitor_task.py stop "video_processing" "success" "Processing complete!"
Manual Updates (Quick Status)
For single status updates without monitoring:
bash
python scripts/send_status.py "Still fetching data..." "progress" "fetch" python scripts/send_status.py "Processing records: 250/1000" "progress" "process" python scripts/send_status.py "Complete! 3 files ready" "success" "final" python scripts/send_status.py "Error: Connection timeout" "error" "api"
When to Use Each Method
Use Manual Updates When:
- •Task is short (under 30 seconds)
- •You want control over when updates are sent
- •Task has discrete, meaningful milestones
Use Periodic Monitoring When:
- •Task is long-running (over 1 minute)
- •You want consistent "heartbeat" updates every 5 seconds
- •Task has long periods of quiet work
- •You want to reassure user that work is ongoing
Message Guidelines
Keep status messages under 140 characters. Examples:
- •Progress: "Still fetching data..." or "Processing records: 250/1000"
- •Success: "Complete! 3 files ready" or "Task finished successfully"
- •Error: "Error: Connection timeout" or "Failed: Missing API key"
- •Warning: "Continuing despite timeout" or "Partial success: 5/10 files"
Advanced Usage
With Additional Details
bash
python scripts/send_status.py "Uploading..." "progress" "upload" --details "File: report.pdf (2.4MB)"
Different Intervals
bash
python scripts/monitor_task.py start "data_sync" "progress" --interval 10
Importing for Python Scripts
python
from send_status import send_status
def long_task():
send_status("Starting...", "progress", "step1")
# ... work
send_status("Step complete", "success", "step1")
Automation with Clawdbot Cron
For scheduled tasks, use Clawdbot's cron feature:
python
# In a script or session
from cron import add
# Every 5 seconds, check status
job = {
"text": "Check status update",
"interval": "5s",
"enabled": True
}
add(job)
This allows status updates even when you're not actively watching.
Installation
To use this skill, copy the task-status folder into your Clawdbot skills directory:
code
C:\Users\Luffy\AppData\Roaming\npm\node_modules\clawdbot\skills\task-status
Or add it to your workspace and reference it from AGENTS.md or TOOLS.md.
Once installed, the skill will be available for any task where you need periodic status updates.