PicoBot/.agents/skills/lark-im/references/lark-im-flag-create.md
ooodc a7883dbed9 refactor(todo): 重构待办事项管理逻辑及更新状态规则
- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段
- 强制每个任务都必须有唯一 id,且由用户负责生成
- 修改合并模式逻辑,merge=true 下保留未提及的旧任务
- 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress)
- 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled
- 优化状态转换校验,允许特定状态间合法切换
- 简化任务变更消息,移除详细的新增/更新/移除统计
- 更新文档和示例,明确 id 必须由用户生成和使用
- 修复和补充测试,增强状态转换和合并模式验证
- 调整任务时间戳生成逻辑,统一使用当前时间及索引
- 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
2026-06-13 09:22:33 +08:00

2.6 KiB

im +flag-create

Prerequisite: Read ../lark-shared/SKILL.md for 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 determine item_type:
    • Topic-style chat (chat_mode=topic) → item_type=thread
    • Regular chat (chat_mode=group) → item_type=msg_thread

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 feed is used without explicit --item-type so 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:

  1. Use +messages-search to find the message by content, then extract message_id from the result
  2. Do NOT use +flag-list to 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'