Todoist 任务管理器:代理任务可见性
通过将内部推理和进度日志直接同步到 Todoist,最大化长时间运行的代理工作流的透明度。
痛点
当代理运行复杂的多步骤任务(如构建全栈应用或进行深度研究)时,用户往往会失去对代理当前正在做什么、哪些步骤已经完成以及代理可能被什么卡住的追踪。手动检查聊天记录对于后台任务来说很繁琐。
功能介绍
此用例使用 todoist-task-manager 技能来:
- 可视化状态:在特定部分创建任务,如
🟡 进行中或🟠 等待中。 - 外部化推理:将代理的内部"计划"发布到任务描述中。
- 流式日志:将子步骤完成作为评论实时添加到任务中。
- 自动协调:心跳脚本检查停滞的任务并通知用户。
所需技能
您不需要预构建的技能。只需提示您的 OpenClaw 代理创建以下设置指南中描述的 bash 脚本。由于 OpenClaw 可以管理自己的文件系统并执行 shell 命令,它会在您请求时"为您构建"技能。
详细设置指南
1. 配置 Todoist
创建一个项目(例如 "OpenClaw Workspace")并获取其 ID。为不同状态创建部分:
🟡 进行中🟠 等待中🟢 已完成
2. 实现:"代理构建"的技能
您可以请求 OpenClaw 为您创建这些脚本,而不是安装技能。每个脚本处理与 Todoist API 通信的不同部分。
scripts/todoist_api.sh(核心包装器):
bash
#!/bin/bash
# 用法:./todoist_api.sh <endpoint> <method> [data_json]
ENDPOINT=$1
METHOD=$2
DATA=$3
TOKEN="YOUR_TODOIST_API_TOKEN"
if [ -z "$DATA" ]; then
curl -s -X "$METHOD" "https://api.todoist.com/rest/v2/$ENDPOINT" \
-H "Authorization: Bearer $TOKEN"
else
curl -s -X "$METHOD" "https://api.todoist.com/rest/v2/$ENDPOINT" \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d "$DATA"
fiscripts/sync_task.sh(任务和状态管理):
bash
#!/bin/bash
# 用法:./sync_task.sh <task_content> <status> [task_id] [description] [labels_json_array]
CONTENT=$1
STATUS=$2
TASK_ID=$3
DESCRIPTION=$4
LABELS=$5
PROJECT_ID="YOUR_PROJECT_ID"
case $STATUS in
"In Progress") SECTION_ID="SECTION_ID_PROGRESS" ;;
"Waiting") SECTION_ID="SECTION_ID_WAITING" ;;
"Done") SECTION_ID="SECTION_ID_DONE" ;;
*) SECTION_ID="" ;;
esac
PAYLOAD="{\"content\": \"$CONTENT\""
[ -n "$SECTION_ID" ] && PAYLOAD="$PAYLOAD, \"section_id\": \"$SECTION_ID\""
[ -n "$PROJECT_ID" ] && [ -z "$TASK_ID" ] && PAYLOAD="$PAYLOAD, \"project_id\": \"$PROJECT_ID\""
if [ -n "$DESCRIPTION" ]; then
ESC_DESC=$(echo "$DESCRIPTION" | sed ':a;N;$!ba;s/\n/\\n/g' | sed 's/"/\\"/g')
PAYLOAD="$PAYLOAD, \"description\": \"$ESC_DESC\""
fi
[ -n "$LABELS" ] && PAYLOAD="$PAYLOAD, \"labels\": $LABELS"
PAYLOAD="$PAYLOAD}"
if [ -n "$TASK_ID" ]; then
./scripts/todoist_api.sh "tasks/$TASK_ID" POST "$PAYLOAD"
else
./scripts/todoist_api.sh "tasks" POST "$PAYLOAD"
fiscripts/add_comment.sh(进度日志):
bash
#!/bin/bash
# 用法:./add_comment.sh <task_id> <comment_text>
TASK_ID=$1
TEXT=$2
ESC_TEXT=$(echo "$TEXT" | sed ':a;N;$!ba;s/\n/\\n/g' | sed 's/"/\\"/g')
PAYLOAD="{\"task_id\": \"$TASK_ID\", \"content\": \"$ESC_TEXT\"}"
./scripts/todoist_api.sh "comments" POST "$PAYLOAD"3. 使用提示
您可以将此提示提供给您的代理来设置和使用可见性系统:
我想让您为您自己的运行构建一个基于 Todoist 的任务可见性系统。
首先,在 'scripts/' 文件夹中创建三个 bash 脚本:
1. todoist_api.sh(Todoist REST API 的 curl 包装器)
2. sync_task.sh(用于创建或更新具有特定 section_id 的任务,分别对应进行中、等待中和已完成)
3. add_comment.sh(用于将进度日志发布为评论)
使用以下变量进行设置:
- Token:[您的 Todoist API 令牌]
- Project ID:[您的项目 ID]
- Section IDs:[进行中 ID、等待中 ID、已完成 ID]
创建后,对于我给您的每个复杂任务:
1. 在"进行中"中创建任务,在描述中包含您的完整计划。
2. 对于每个子步骤完成,调用 add_comment.sh 记录您做了什么。
3. 完成后将任务移动到"已完成"。