approvals
feishu.agent.toolkit.approvals
¶
审批工具工厂:列出审批定义、读取审批定义表单、创建审批实例(需审批)。详见 feishu.agent.toolkit。
list_approval_definitions
¶
list_approval_definitions(*, description: str, name: str = 'list_approval_definitions', locale: str = 'zh-CN', as_user: bool = True, auth_scopes: Sequence[str] = ()) -> Tool
读类工厂:列出当前身份可发起的审批定义,返回一个 feishu.agent.tools.Tool。
飞书按调用身份过滤可发起的审批定义,因此默认以请求用户身份(as_user=True)读取。
每项摘要通常包含 approval_code 与 approval_name,供后续 get_approval_definition
与 create_approval_instance 使用。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'list_approval_definitions'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否以请求用户身份读取。默认为 |
True
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
get_approval_definition
¶
get_approval_definition(*, description: str, name: str = 'get_approval_definition', locale: str = 'zh-CN', as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
读类工厂:按 approval_code 读取单个审批定义的表单结构,返回一个 feishu.agent.tools.Tool。
返回经 feishu.approval.approval_definition_schema 归一化后的紧凑表单 schema(含 fields
控件列表),供模型据此构造 create_approval_instance 的 form。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'get_approval_definition'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否以请求用户身份读取。默认为 |
False
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
create_approval_instance
¶
create_approval_instance(*, description: str, name: str = 'create_approval_instance', locale: str = 'zh-CN', requires_approval: bool = True, as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
写类工厂:基于 approval_code 与模型构造的 form 创建审批实例,返回一个需审批的 feishu.agent.tools.Tool。
requires_approval=True 时,feishu.agent.loop.Agent 先挂起并发审批卡片;用户批准后处理函数才执行写入。
申请人身份**强制**为当前轮的请求用户(feishu.agent.context.ToolContext.requesting_user),模型无法
覆盖,以防越权代他人提交。form 接受 widget_id -> value 映射、完整控件载荷列表或已序列化的 JSON 串,
由 feishu.approval.approval_instance 归一化为 Feishu 审批实例载荷。
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
| Python | |
|---|---|
191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 | |
cancel_approval_instance
¶
cancel_approval_instance(*, description: str, name: str = 'cancel_approval_instance', locale: str = 'zh-CN', requires_approval: bool = True, as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
写类工厂:撤回一个审批实例,返回一个需审批的 feishu.agent.tools.Tool。
requires_approval=True 时,feishu.agent.loop.Agent 先挂起并发审批卡片;用户批准后处理函数才执行写入,
调用 client.approval.instances.cancel(approval_code, instance_code, user_id)。撤回人身份**强制**为当前轮的
请求用户(feishu.agent.context.ToolContext.requesting_user),模型无法覆盖——instance_code 标识的审批
实例必须由该用户本人发起,以防越权代他人撤回。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'cancel_approval_instance'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否需用户二次确认。默认为 |
True
|
|
bool
|
是否以请求用户身份写入。默认为 |
False
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
get_approval_status
¶
get_approval_status(*, description: str, name: str = 'get_approval_status', locale: str = 'zh-CN', as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
读类工厂:按 instance_code 读取单个审批实例详情,返回一个 feishu.agent.tools.Tool。
调用 client.approval.instances.get(instance_id),返回的实例含 approval_code、approval_name、
status、form、task_list、comment_list、timeline 等字段,供模型据此向用户概述审批进展,并从
task_list 中识别可供同意 / 拒绝的 task_id。instance_code 与飞书的 instance_id 同义,二者均可。
最小权限(zero-trust):实例读取走租户令牌,可按 id 取到**任意**实例(含收款账户等表单数据),故此处
强制校验「请求用户必须是该实例的参与者」(发起人,或 task_list/timeline 中的审批人 / 处理人,见
feishu.approval.approval_instance_participant_ids);否则返回 BLOCKED——防止被越权操控的智能体凭
实例 id 拉取他人审批与银行账户信息。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'get_approval_status'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否以请求用户身份读取。默认为 |
False
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
approve_approval_task
¶
approve_approval_task(*, description: str, name: str = 'approve_approval_task', locale: str = 'zh-CN', requires_approval: bool = True, as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
写类工厂:同意一个审批任务,返回一个需审批的 feishu.agent.tools.Tool。
requires_approval=True 时,feishu.agent.loop.Agent 先挂起并发审批卡片;用户批准后处理函数才执行写入,
调用 client.approval.tasks.approve(task)。审批人身份**强制**为当前轮的请求用户
(feishu.agent.context.ToolContext.requesting_user),模型无法覆盖——task_id 标识的待办必须属于该用户本人,
以防越权代他人审批。comment 为可选审批意见。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'approve_approval_task'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否需用户二次确认。默认为 |
True
|
|
bool
|
是否以请求用户身份写入。默认为 |
False
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
| Python | |
|---|---|
482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 | |
reject_approval_task
¶
reject_approval_task(*, description: str, name: str = 'reject_approval_task', locale: str = 'zh-CN', requires_approval: bool = True, as_user: bool = False, auth_scopes: Sequence[str] = ()) -> Tool
写类工厂:拒绝一个审批任务,返回一个需审批的 feishu.agent.tools.Tool。
requires_approval=True 时,feishu.agent.loop.Agent 先挂起并发审批卡片;用户批准后处理函数才执行写入,
调用 client.approval.tasks.reject(task)。审批人身份**强制**为当前轮的请求用户
(feishu.agent.context.ToolContext.requesting_user),模型无法覆盖——task_id 标识的待办必须属于该用户本人,
以防越权代他人审批。comment 为可选审批意见。
参数:
| 名称 | 类型 | 描述 | 默认 |
|---|---|---|---|
|
str
|
工具描述(产品本地化文案)。 |
必需 |
|
str
|
工具名。默认为 |
'reject_approval_task'
|
|
str
|
本地化标识。默认为 |
'zh-CN'
|
|
bool
|
是否需用户二次确认。默认为 |
True
|
|
bool
|
是否以请求用户身份写入。默认为 |
False
|
|
Sequence[str]
|
缺少授权时申请的飞书权限范围。 |
()
|
返回:
| 类型 | 描述 |
|---|---|
Tool
|
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
| Python | |
|---|---|
562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 | |
list_my_pending_approvals
¶
list_my_pending_approvals(*, description: str, name: str = 'list_my_pending_approvals', locale: str = 'zh-CN', as_user: bool = True, auth_scopes: Sequence[str] = ()) -> Tool
读类工厂:列出「请求用户本人」的待办审批任务,返回一个 feishu.agent.tools.Tool。
最小权限(zero-trust):仅查询发起请求的用户本人的待办(topic="1"),用户身份取自
feishu.agent.context.ToolContext.requesting_user,模型无法指向他人。每个任务含 instance_code
与 task_id,可配合 feishu.agent.toolkit.approvals.approve_approval_task /
feishu.agent.toolkit.approvals.reject_approval_task 处理。
示例:
| Python Console Session | |
|---|---|
源代码位于: feishu/agent/toolkit/approvals.py
list_my_payment_accounts
¶
list_my_payment_accounts(*, description: str, name: str = 'list_my_payment_accounts', locale: str = 'zh-CN') -> Tool
读类工厂:列出请求用户**本人**的收款账户(脱敏标签 + 不可逆句柄),返回一个 feishu.agent.tools.Tool。
飞书无枚举用户绑定收款账户的接口,故从用户本人历史审批实例中恢复(按其 open_id 过滤,绝不触及他人,详见
feishu.agent.payment_accounts.PaymentAccountResolver)。只返回 account_id(句柄)与 label(脱敏,
如「杭州银行 ****8383 (张三)」),**绝不**返回完整卡号。供模型为审批表单的 account 控件挑选账户:恰好一个
直接用、多个问用户选哪个、一个都没有则请用户先在飞书添加;选定后把 {widget_id: account_id} 传入
feishu.agent.toolkit.approvals.create_approval_instance 的 accounts 参数。
示例:
| Python Console Session | |
|---|---|