Install
openclaw skills install fadada-document-sign法大大电子签完整签署技能。覆盖合同发起、已有流程查询、撤回、下载等全生命周期操作。当用户说"发合同"、"查合同"、"查流程"、"查任务"、"撤回合同"、"撤销签署"、"下载合同"、"下载已签合同"等时触发。
openclaw skills install fadada-document-sign基于法大大 FASC API 5.0,提供一键式合同发起签署能力,将合同文件发送给签署方进行电子签署。
fadada-document-sign 提供合同签署的完整生命周期能力:
| 属于本 skill | 不属于本 skill |
|---|---|
| 发起新的合同签署流程 | 起草/生成合同正文或 PDF |
| 将文件发给签署方签署 | 审查合同条款、识别风险 |
| 上传合同后发起签署 | 审批通过/驳回 |
| 查询签署模板列表和详情 | 作废已完成合同 |
| 查询已有签署流程 | - |
| 撤回未完成签署任务 | - |
| 下载已签署合同 | - |
进入条件:用户说"发合同"且当前会话有上传文件
进入条件:用户说"用模板发起"、"查一下模板"等
进入条件:用户说"查合同"、"查流程"、"查任务"等
进入条件:用户说"撤回合同"、"撤销任务"等
进入条件:用户说"下载合同"、"保存合同"等
适用场景: 用户上传合同文件,说"发合同给对方签" 执行流程:
scripts/upload_file.py 将合同文件上传到法大大平台
scripts/initiate_sign.py 发起签署
关键要点:
适用场景: 用户说"查一下有哪些模板",然后选择一个发起 执行流程:
scripts/list_templates.py 查询签署模板
scripts/get_template_detail.py
scripts/initiate_sign.py 发起签署
--template-id 参数关键要点:
| 脚本路径 | 用途 | 关键参数 |
|---|---|---|
scripts/upload_file.py | 上传合同文件到法大大平台 | --file-path: 文件路径, --file-name: 文件名 |
scripts/initiate_sign.py | 调用法大大API发起签署 | --task-name: 任务名称, --file-ids: 文件ID列表, --signers: 签署方JSON |
scripts/list_templates.py | 查询签署模板列表 | --template-name: 模板名称(可选) |
scripts/get_template_detail.py | 查询模板详情 | --template-id: 模板ID |
scripts/list_sign_tasks.py | 查询已有签署流程列表 | --status: 状态筛选, --keyword: 关键词, --page: 页码 |
scripts/query_sign_status.py | 查询签署任务详情/状态 | --task-id: 任务ID |
scripts/cancel_sign_task.py | 撤回签署任务 | --task-id: 任务ID, --reason: 撤回原因 |
scripts/download_signed_contract.py | 下载已签署合同 | --task-id: 任务ID, --save-path: 保存路径 |
scripts/utils.py | 公共工具函数 | - |
# ==================== 发起签署 ====================
# 上传文件
python scripts/upload_file.py --file-path "/path/to/contract.pdf" --file-name "合同.pdf"
# 发起签署
python scripts/initiate_sign.py \
--task-name "劳动合同签署" \
--file-ids '["file_id_from_upload"]' \
--signers '[{"name":"张三","phone":"13800138000","actorType":"person"}]'
# 基于模板发起
python scripts/initiate_sign.py \
--task-name "劳动合同签署" \
--template-id "template_id" \
--signers '[{"name":"张三","phone":"13800138000","actorType":"person","participantId":"xxx"}]'
# ==================== 查询已有流程 ====================
# 查询所有签署任务
python scripts/list_sign_tasks.py
# 按状态筛选(signing=签署中, finished=已完成, cancelled=已撤销)
python scripts/list_sign_tasks.py --status signing
# 关键词搜索
python scripts/list_sign_tasks.py --keyword "劳动合同"
# 分页查询
python scripts/list_sign_tasks.py --page 1 --page-size 20
# 查询单个任务详情
python scripts/query_sign_status.py --task-id "task_id_here"
# ==================== 撤回任务 ====================
# 撤回签署任务
python scripts/cancel_sign_task.py --task-id "task_id_here"
# 撤回并填写原因
python scripts/cancel_sign_task.py --task-id "task_id_here" --reason "合同内容有误"
# ==================== 下载合同 ====================
# 获取下载链接
python scripts/download_signed_contract.py --task-id "task_id_here"
# 下载并保存到本地
python scripts/download_signed_contract.py \
--task-id "task_id_here" \
--save-path "./signed_contract.pdf"
--signers 参数为 JSON 数组,每个元素表示一个签署方。
| 字段 | 必填 | 说明 |
|---|---|---|
name | 是 | 个人姓名 |
phone | 条件 | 手机号,phone 和 email 至少传一个 |
email | 条件 | 邮箱,phone 和 email 至少传一个 |
actorType | 是 | 固定传 person |
示例:
[
{
"name": "张三",
"phone": "13800138000",
"actorType": "person"
}
]
| 字段 | 必填 | 说明 |
|---|---|---|
name | 是 | 企业全称 |
contactName | 是 | 经办人姓名 |
phone | 条件 | 经办人手机号,phone 和 email 至少传一个 |
email | 条件 | 经办人邮箱,phone 和 email 至少传一个 |
actorType | 是 | 固定传 corp |
openCorpId | 否 | 企业ID(已授权企业) |
企业示例:
[
{
"name": "杭州未来科技有限公司",
"contactName": "李经理",
"phone": "13800138000",
"actorType": "corp"
}
]
python scripts/initiate_sign.py \
--task-name "采购合同签署" \
--file-ids '["file_id"]' \
--signers '[{"name":"杭州未来科技有限公司","contactName":"李经理","phone":"13800138000","actorType":"corp"},{"name":"王五","phone":"13900139000","actorType":"person"}]'
| 场景 | 处理方式 |
|---|---|
| 文件格式不支持 | 提示用户仅支持 PDF 格式,请上传 PDF 文件 |
| 上传失败 | 展示错误信息,建议重新上传 |
| 签署方信息不完整 | 停在信息填写步骤,等待用户补全 |
| 发起签署失败 | 展示错误原因,提供重试选项 |
| 未配置凭证 | 提示配置法大大 API 凭证 |
| 任务状态不可撤回 | 提示当前任务状态不支持撤回(如已完成/已作废) |
| 任务状态不可下载 | 提示当前任务状态不支持下载(如签署中/未完成) |
| 任务不存在 | 提示任务ID无效或无权访问 |
| 下载失败 | 展示错误信息,建议检查网络后重试 |
| 步骤 | 内容 | 详细说明 |
|---|---|---|
| 1 | 个人注册&认证 | 企业管理员完成个人实名认证 |
| 2 | 企业创建&认证 | 创建企业并完成企业实名认证 |
| 3 | 创建应用并启用 | 创建应用并提交审核启用 |
| 4 | 获取凭证 | 获取 AppID、AppSecret、openCorpId |
| 5 | 配置正式环境 | 替换为正式环境信息 |
详细操作指引:https://dev.fadada.com/api-guide/YYNLQW2Z2W/9QMQ2MU4FGK3AOXA
获取步骤:
| 步骤 | 操作 |
|---|---|
| 1 | 进入 企业设置 → 集成管理 → 应用集成,选择已启用的应用 |
| 2 | 点击 AppSecret 的【查看】按钮 |
| 3 | 获取短信验证码并填写验证 |
| 4 | 验证通过后,点击【复制图标】复制 AppID 和 AppSecret |
| 环境变量 | 说明 | 来源 |
|---|---|---|
| FADADA_APP_ID | 应用ID(AppID) | 应用详情页 |
| FADADA_APP_SECRET | 应用密钥(AppSecret) | 应用详情页(需验证) |
| FADADA_OPEN_CORP_ID | 企业ID(openCorpId) | 应用详情页 / 自动获取 |
| FADADA_ENV | 环境 (production/uat) | 默认 production |
⚠️ 注意:openCorpId 可不配置,系统会自动通过
/app/get-openId-list接口获取应用归属企业的 openCorpId
设置 FADADA_ENV 环境变量:
production - 正式环境(默认)uat - UAT测试环境重要特性:如果未配置 FADADA_OPEN_CORP_ID,系统会自动通过 /app/get-openId-list 接口获取应用归属企业的 openCorpId。
配置优先级:
open_corp_id 参数FADADA_OPEN_CORP_ID适用场景:
使用 HMAC-SHA256 签名算法进行接口认证:
| 接口 | 地址 | 说明 | 状态 |
|---|---|---|---|
| 获取服务访问凭证 | /service/get-access-token | 获取访问令牌 | ✅ 可用 |
| 上传本地文件 | /file/get-upload-url | 获取上传URL | ✅ 可用 |
| 文件处理 | /file/process | 转换为PDF | ✅ 可用 |
| 创建签署任务 | /sign-task/create | 发起签署 | ✅ 可用 |
| 添加签署参与方 | /sign-task/actor/add | 添加签署方 | ✅ 可用 |
| 获取签署链接 | /sign-task/actor/get-url | 获取签署URL | ✅ 可用 |
| 查询签署任务详情 | /sign-task/app/get-detail | 查询单个任务状态 | ✅ 可用 |
| 查询签署模板列表 | /sign-template/get-list | 模板列表 | ✅ 可用 |
| 查询签署模板详情 | /sign-template/get-detail | 模板详情 | ✅ 可用 |
| 查询签署任务列表 | /sign-task/owner/get-list | 批量查询任务 | ✅ 可用 |
| 撤回签署任务 | /sign-task/cancel | 撤回任务 | ✅ 可用 |
| 获取合同下载链接 | /sign-task/owner/get-download-url | 下载合同 | ✅ 可用 |
| 查询授权用户列表 | /app/get-openId-list | 获取归属企业openCorpId | ✅ 可用 |
以下接口已验证可用:
/sign-task/owner/get-list)/sign-task/cancel)/sign-task/owner/get-download-url)如遇 404 错误,请确认账户是否具备相应权限。
| 状态 | 说明 |
|---|---|
| draft | 草稿 |
| waiting | 待提交 |
| signing | 签署中 |
| finished | 已完成 |
| cancelled | 已撤销 |
| abolished | 已作废 |
| expired | 已过期 |
| 返回码 | 说明 |
|---|---|
| 100000 | 请求成功 |
| 100001 | 系统错误 |
| 100002 | 访问凭证失效 |
| 200001 | 参数错误 |
| 200002 | 签名验证失败 |
| 300001 | 业务处理失败 |
| 400001 | 权限不足 |