PicoBot/skills/lark-im/references/lark-im-feed-shortcut-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

4.2 KiB

im +feed-shortcut-create

Prerequisite: Read ../lark-shared/SKILL.md for authentication, global parameters, and security rules.

This skill maps to shortcut: lark-cli im +feed-shortcut-create. Underlying API: POST /open-apis/im/v2/feed_shortcuts.

What it does

Adds one or more chats to the current user's feed shortcuts — equivalent to right-clicking a chat in the Feishu client and pinning it to the feed sidebar.

  • Only CHAT-type shortcuts are exposed by the OpenAPI gateway right now (feed_card_id must be an oc_xxx open_chat_id).
  • Batch up to 10 chat IDs per call; pass more by issuing multiple calls.
  • Currently only supports user identity (--as user); bot identity is not allowed by the server.
  • If you only know a group name, resolve its oc_xxx first with im +chat-search or im +chat-list.

Commands

# Add a single chat as a feed shortcut (defaults to head/top insertion)
lark-cli im +feed-shortcut-create --as user --chat-id oc_xxx

# Add multiple chats; comma-separated or repeated flag both work
lark-cli im +feed-shortcut-create --as user --chat-id oc_a,oc_b,oc_c
lark-cli im +feed-shortcut-create --as user --chat-id oc_a --chat-id oc_b

# Append at the bottom of the shortcut list instead of the top
lark-cli im +feed-shortcut-create --as user --chat-id oc_xxx --tail

# Preview the request without sending
lark-cli im +feed-shortcut-create --as user --chat-id oc_xxx --dry-run

Parameters

Parameter Default Description
--chat-id <oc_xxx> required open_chat_id to add as a feed shortcut; repeatable or comma-separated; max 10 per call
--head true (implied) Insert at the top of the shortcut list; mutually exclusive with --tail
--tail false Append at the bottom of the shortcut list
--as user required Server only accepts user_access_token for this API

Response

The response is a batch ledger. A full success exits 0 with ok:true. Any non-empty failed_shortcuts is a partial failure: the process exits non-zero (currently exit 1), stdout carries ok:false, and the full ledger remains machine-readable:

Field Meaning
total Number of requested shortcuts
success_count Number of requested shortcuts not reported in failed_shortcuts
failure_count Number of requested shortcuts reported as failed; failed_shortcuts preserves the raw server failure list
succeeded_shortcuts Requested shortcut entries that succeeded
failed_shortcuts Per-item failures returned by the server, enriched with reason_label

The shortcut adds a reason_label field next to each numeric reason:

reason reason_label Meaning
1 no_permission User has no permission on the feed card
2 invalid_item feed_card_id is invalid or type doesn't match
3 has_pending_delete The chat is being deleted
4 type_not_support Type is not whitelisted (only CHAT is open now)
5 internal_error Server internal error

Example:

{
  "ok": false,
  "data": {
    "total": 2,
    "success_count": 1,
    "failure_count": 1,
    "succeeded_shortcuts": [
      { "feed_card_id": "oc_good", "type": 1 }
    ],
    "failed_shortcuts": [
      {
        "shortcut": { "feed_card_id": "oc_bad", "type": 1 },
        "reason": 2,
        "reason_label": "invalid_item"
      }
    ]
  }
}

Permissions

  • Required scope: im:feed.shortcut:write
  • Only available with user identity (--as user). The CLI will reject --as bot for this shortcut.

Note

  • The shortcut list is per user: the call adds shortcuts for the currently authenticated user only.
  • Adding the same chat twice is idempotent at the user level (re-adding an existing shortcut is a no-op rather than an error).
  • Scripts should check the process exit code, top-level ok, and ledger counts. Partial failures intentionally keep machine-readable success and failure details on stdout.
  • To inspect the current shortcut list, use +feed-shortcut-list. To remove a shortcut, use +feed-shortcut-remove.