- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
2.6 KiB
2.6 KiB
im +flag-create
Prerequisite: Read
../lark-shared/SKILL.mdfor authentication, global parameters, and security rules.
This skill maps to shortcut: lark-cli im +flag-create. Underlying API: POST /open-apis/im/v1/flags.
Default Behavior
- Message-layer flag (default):
item_type=default, flag_type=message - Feed-layer flag: Use
--flag-type feed— automatically detects chat type to determineitem_type:- Topic-style chat (
chat_mode=topic) →item_type=thread - Regular chat (
chat_mode=group) →item_type=msg_thread
- Topic-style chat (
Commands
# Flag a message (default: message-layer)
lark-cli im +flag-create --as user --message-id om_xxx
# Create feed-layer flag (auto-detects chat type)
lark-cli im +flag-create --as user --message-id om_xxx --flag-type feed
# Explicit item-type override (rarely needed)
lark-cli im +flag-create --as user --message-id om_xxx --item-type thread --flag-type feed
# Preview request (dry-run, doesn't send)
lark-cli im +flag-create --as user --message-id om_xxx --dry-run
Parameters
| Parameter | Required | Description |
|---|---|---|
--message-id <om_xxx> |
Required | Message ID |
--flag-type <name> |
No | message (default) or feed |
--item-type <name> |
No | Override auto-detection: default|thread|msg_thread (rarely needed) |
--as user |
Required | Currently only supports user identity |
Valid Combinations
The server only accepts these (item_type, flag_type) pairs:
(default, message)— regular message flag(thread, feed)— feed flag in topic-style chat(msg_thread, feed)— feed flag in regular chat
Permissions
- Required scopes:
im:feed.flag:write,im:message.group_msg:get_as_user,im:message.p2p_msg:get_as_user,im:chat:read - The message/chat read scopes are used when
--flag-type feedis used without explicit--item-typeso the CLI can auto-detect chat type. - If missing, CLI will prompt with
lark-cli auth login --scope "..."
Note
- Do not call +flag-list for verification: If the create API returns success, the flag is created. Calling +flag-list to verify is expensive (requires full pagination) and unnecessary.
Finding Message ID Efficiently
If you have message content but not the message ID:
- Use
+messages-searchto find the message by content, then extractmessage_idfrom the result - Do NOT use
+flag-listto find the message — it requires full pagination and is very inefficient
# Search by message content to find message_id
lark-cli im +messages-search --as user --query "message content here" -q '.data.items[0].message_id'