- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
4.2 KiB
4.2 KiB
im +feed-shortcut-create
Prerequisite: Read
../lark-shared/SKILL.mdfor 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_idmust be anoc_xxxopen_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_xxxfirst withim +chat-searchorim +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 botfor 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.