跳到主要内容

通过多文件创建合同组签署流程

1. 接口描述

接口请求域名: essbasic.tencentcloudapi.com 。

接口(ChannelCreateFlowGroupByFiles)用于使用 PDF 文件创建合同组签署流程。

  • 该接口允许通过选择多个模板一次性创建多个合同,这些合同被组织在一个合同组中。
  • 每个签署方将收到一个签署链接,通过这个链接可以访问并签署合同组中的所有合同。
  • 合同组中的合同必须作为一个整体进行签署,不能将合同组拆分成单独的合同进行逐一签署。

2. 适用场景

该接口适用于需要一次性完成多份合同签署的情况,多份合同一般具有关联性,用户以目录的形式查看合同。

3. 发起方要求和签署方实名要求

  • 发起方要求:作为合同发起方的第三方子企业A的员工必须进行实名认证。
  • 签署方要求:签署方可以是多种身份(如第三方子企业的员工、个人、SaaS平台企业员工),其中企业和员工可以不进行实名认证。

可以作为发起方和签署方的角色列表

场景编号可作为发起方类型可作为签署方的类型
场景一第三方子企业A员工第三方子企业A员工
场景二第三方子企业A员工第三方子企业B员工
场景三第三方子企业A员工个人/自然人
场景四第三方子企业A员工SaaS平台企业员工

4. 签署方参数差异

  • 根据签署方的不同类型(第三方子企业的员工、个人、SaaS平台企业员工),传递的参数也不同。具体参数的结构和要求可以参考开发者中心提供的 FlowApproverInfo 结构体说明。

5. 合同额度的扣减与返还

  • 扣减时机:合同一旦发起,相关的合同额度就会被扣减,合同组下面的每个合同都要扣减一个合同额度。
  • 返还条件:只有在合同被撤销且没有任何签署方签署过,或者只有自动签署的情况下,合同额度才会被返还。
  • 不返还的情况:如果合同已过期、被拒签、签署完成或已解除,合同额度将不会被返还。

6. 静默(自动)签署的限制

  • 在使用静默(自动)签署功能时,合同签署方不能有填写控件。此接口静默签(企业自动签)能力为白名单功能,使用前请联系对接的客户经理沟通。

7.合同组暂不支持抄送功能

默认接口请求频率限制:20次/秒。

推荐使用 API Explorer
点击调试
API Explorer 提供了在线调用、签名验证、SDK 代码生成和快速检索接口等能力。您可查看每次调用的请求内容和返回结果以及自动生成 SDK 调用示例。

2. 输入参数

以下请求参数列表仅列出了接口请求参数和部分公共参数,完整公共参数列表见 公共请求参数

参数名称必选类型描述
ActionString公共参数,本接口取值:ChannelCreateFlowGroupByFiles。
VersionString公共参数,本接口取值:2021-05-26。
RegionString公共参数,此参数为可选参数。
FlowFileInfos.NArray of FlowFileInfo合同组中每个合同签署流程的信息,合同组中最少包含2个合同,不能超过50个合同。
FlowGroupNameString合同组的名称(可自定义此名称),长度不能超过200,只能由中文、字母、数字和下划线组成。
示例值:"2023年采购合同们"
AgentAgent合同的发起企业和发起人信息,点击查看合同发起企业和人展示的位置

此接口下面信息必填。

  • 渠道应用标识: Agent.AppId
  • 第三方平台子客企业标识: Agent.ProxyOrganizationOpenId(合同的发起企业)
  • 第三方平台子客企业中的员工标识: Agent.ProxyOperator.OpenId (合同的发起人)



合同的发起企业和发起人必需已经完成实名,并加入企业
ApproverVerifyTypeString合同组中签署人校验和认证的方式:
  • VerifyCheck:人脸识别(默认)
  • MobileCheck:手机号验证

注意:
1. MobileCheck 方式,未实名的个人/自然人签署方无需进行人脸识别实名认证即可查看合同(但签署合同时仍然需要人脸实名),企业签署方需经过人脸认证。
2. 合同组的校验和认证的方式会优先使用,会覆盖合同组中单个合同和合同签署方认证方式的限制配置。
示例值:VerifyCheck
FlowGroupOptionsFlowGroupOptions合同组的签署配置项信息,例如在合同组签署过程中,是否需要对每个子合同进行独立的意愿确认。

3. 输出参数

参数名称类型描述
FlowGroupIdString合同组ID,为32位字符串。
建议开发者妥善保存此合同组ID,以便于顺利进行后续操作。
示例值:yDwFmUUckpstqfvzUE1h3jo1f3cqjkGm
FlowIdsArray of String合同组中每个合同流程ID,每个ID均为32位字符串。

注:
此数组的顺序和入参中的FlowGroupInfos顺序一致
示例值:["yDRSRUUgygj6rqi6UuO4zjEBDACwAjgT","yDRS4UUgygqdcjjdUuO4zjEC0osCOsHS"]
ApproversArray of FlowGroupApprovers合同组签署方信息。
RequestIdString唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。

4. 示例

示例1 创建三个合同组成的合同组

  1. 入参中FlowFileInfos有三个元素, 表示三个合同组成此合同组
  2. 每个合同都是B2C合同

输入示例

POST / HTTP/1.1
Host: essbasic.tencentcloudapi.com
Content-Type: application/json
X-TC-Action: ChannelCreateFlowGroupByFiles
<公共请求参数>

{
"Agent": {
"ProxyOperator": {
"OpenId": "kevin"
},
"ProxyOrganizationOpenId": "zk_online_org",
"AppId": "394fc83e7a1cc97ba27c3342f425c836"
},
"FlowGroupName": "采购合同",
"FlowFileInfos": [
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "番茄的采购合同",
"Deadline": 0,
"FlowDescription": "2023年番茄的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"OrganizationName": "王五示例企业",
"OrganizationOpenId": "zk_online_org",
"OpenId": "zk",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5ZCI5ZCM5Lus5ZCI5ZCM5Lus",
"Unordered": true,
"NeedSignReview": false
},
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "黄瓜的采购合同",
"Deadline": 0,
"FlowDescription": "2023年黄瓜的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"OrganizationName": "李四示例企业",
"OrganizationOpenId": "zk_online_org",
"OpenId": "zk",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5paw55qE5a2Q5ZCI5ZCMMg==",
"Unordered": true,
"NeedSignReview": false
},
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "马铃薯的采购合同",
"Deadline": 0,
"FlowDescription": "2023年马铃薯的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"OrganizationName": "张三示例企业",
"OrganizationOpenId": "zk_online_org",
"OpenId": "zk",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5paw55qE5a2Q5ZCI5ZCMMw==",
"Unordered": true,
"NeedSignReview": false
}
]
}

输出示例

{
"Response": {
"FlowGroupId": "yDwiSUUg0e3wmkUyoVjXzyZbNlhaVk85",
"FlowIds": [
"yDwiSUUg0e3wm2UyoVjXz1xWSYus0Jtc",
"yDwiSUUg0e3wmrUyoVjXzSP9OEVRSAlk",
"yDwiSUUg0e3wmhUyoVjXzByicWYPOymz"
],
"RequestId": "s1698139089675399175"
}
}

示例2 创建三个合同组成的合同组,指定每个子合同第一方为动态签署方

  1. 入参中FlowFileInfos有三个元素, 表示三个合同组成此合同组
  2. 每个合同都是B2C合同 3.三份子合同均指定一方为动态签署方(即不指定具体签署人,FillType=1),可在发起后再进行补充。

输入示例

POST / HTTP/1.1
Host: essbasic.tencentcloudapi.com
Content-Type: application/json
X-TC-Action: ChannelCreateFlowGroupByFiles
<公共请求参数>

{
"Agent": {
"ProxyOperator": {
"OpenId": "kevin"
},
"ProxyOrganizationOpenId": "zk_online_org",
"AppId": "394fc83e7a1cc97ba27c3342f425c836"
},
"FlowGroupName": "采购合同",
"FlowFileInfos": [
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "番茄的采购合同",
"Deadline": 0,
"FlowDescription": "2023年番茄的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"ApproverOption": {
"FillType": 1
},
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5ZCI5ZCM5Lus5ZCI5ZCM5Lus",
"Unordered": true,
"NeedSignReview": false
},
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "黄瓜的采购合同",
"Deadline": 0,
"FlowDescription": "2023年黄瓜的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"ApproverOption": {
"FillType": 1
},
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5paw55qE5a2Q5ZCI5ZCMMg==",
"Unordered": true,
"NeedSignReview": false
},
{
"FileIds": [
"yDR1nUU06b46rUy0fKyKocxqVM6QwE88"
],
"FlowName": "马铃薯的采购合同",
"Deadline": 0,
"FlowDescription": "2023年马铃薯的采购50吨合同",
"FlowType": "采购合同",
"FlowApprovers": [
{
"ApproverType": "ENTERPRISESERVER",
"ApproverOption": {
"FillType": 1
},
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SEAL",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 100,
"ComponentHeight": 100,
"ComponentValue": "yDR1kUU0zproxUy0fKyKg4XBzdcXcTBg"
}
]
},
{
"Name": "典子谦",
"ApproverType": "PERSON",
"Mobile": "13200000000",
"SignComponents": [
{
"ComponentWidth": 100,
"FileIndex": 0,
"ComponentType": "SIGN_SIGNATURE",
"ComponentPage": 1,
"ComponentRequired": true,
"ComponentPosX": 100,
"ComponentPosY": 200,
"ComponentHeight": 100
}
]
}
],
"CustomerData": "5paw55qE5a2Q5ZCI5ZCMMw==",
"Unordered": true,
"NeedSignReview": false
}
]
}

输出示例

{
"Response": {
"Approvers": [
{
"Approvers": [
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu2fUuyXGHSxNMdtKoFQ",
"SignId": "yDCVHUUckpwbqu2xUuyXGHS1pifZeuEM"
},
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu24UuyXGHSwSOzFjmPR",
"SignId": "yDCVHUUckpwbqu2bUuyXGHSyMBsyo35X"
}
],
"FlowId": "yDCVHUUckpwbqu2eUuyXGHSubvJWEDif"
},
{
"Approvers": [
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu2mUuyXGHSx4AVZuJkj",
"SignId": "yDCVHUUckpwbqu29UuyXGHSS9mARSyFZ"
},
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu27UuyXGHSR81vG2CR9",
"SignId": "yDCVHUUckpwbqu2uUuyXGHS8JfqC4sho"
}
],
"FlowId": "yDCVHUUckpwbqu2zUuyXGHSBho2CDwGz"
},
{
"Approvers": [
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu28UuyXGHS1CLfd5m1g",
"SignId": "yDCVHUUckpwbqu22UuyXGHS8gj9IYCTL"
},
{
"ApproverRoleName": "",
"RecipientId": "yDCVHUUckpwbqu2rUuyXGHSw7ZeJH7Dk",
"SignId": "yDCVHUUckpwbqu25UuyXGHSu11RucwZR"
}
],
"FlowId": "yDCVHUUckpwbqu2qUuyXGHSvEB4yY7su"
}
],
"FlowGroupId": "yDCVHUUckpwbquhgUuyXGHSxM3rGJCM3",
"FlowIds": [
"yDCVHUUckpwbqu2eUuyXGHSubvJWEDif",
"yDCVHUUckpwbqu2zUuyXGHSBho2CDwGz",
"yDCVHUUckpwbqu2qUuyXGHSvEB4yY7su"
],
"RequestId": "s1711351873868654231"
}
}

5. 错误码

以下仅列出了接口业务逻辑相关的错误码,其他错误码详见 公共错误码

错误码描述
FailedOperation操作失败。
FailedOperation.AgeNotAchieveNormalLegal签署人未达到合法年龄。
InternalError内部错误。
InternalError.Db数据库错误。
InternalError.DbConnection数据库连接出错。
InternalError.Decryption解密错误。
InternalError.Encryption加密错误。
InternalError.GenerateId生成唯一ID错误。
InternalError.System系统错误。
InternalError.ThirdParty第三方错误。
InvalidParameter参数错误。
InvalidParameter.Application应用号不存在。
InvalidParameter.ApproverType参数错误,不合法的签署人类型,请修改后重试。
InvalidParameter.ApproverVerifyTypeApproverVerifyType参数值非法
InvalidParameter.BizApproverAlreadyExists重复添加签署人。
InvalidParameter.CardType证件类型错误。
InvalidParameter.CustomShowMap参数错误,无效的自定义页卡模板,仅支持{合同名称}{发起方姓名}{发起方企业}{签署方N姓名}{签署方N企业},请修改后重试。
InvalidParameter.CustomerData参数错误,UserData长度非法,请修改后重试。
InvalidParameter.DataNotFound数据不存在。
InvalidParameter.FlowApproverInfos参数错误,不合法的备选签署人数量,请检查后重试。
InvalidParameter.FlowApprovers参数错误,参与者数量不能为空且不能超过数量限制,请修改后重试。
InvalidParameter.FlowCallbackUrl参数错误,不合法的签署流程回调链接,请修改后重试。
InvalidParameter.FlowDeadLine参数错误,不合法的签署流程截止日期,请修改后重试。
InvalidParameter.FlowDescription参数错误,不合法的签署流程描述,请修改后重试。
InvalidParameter.FlowFileIds参数错误,目前仅支持单个文件发起,请修改后重试。
InvalidParameter.FlowName参数错误,不合法的签署流程名称,请修改后重试。
InvalidParameter.FlowType参数错误,不合法的FlowType,请修改后重试。
InvalidParameter.Name姓名不符合要求。
InvalidParameter.NonsupportMobile不支持的手机号。
InvalidParameter.OrganizationName企业名称不合法。
InvalidParameter.ParamError参数错误。
InvalidParameter.SignComponentType参数错误,不合法的签署控件类型,请修改后重试。
InvalidParameter.Unordered参数错误,不合法的签署顺序,请检查后重试。
InvalidParameter.UnsupportedComponentType参数错误,不支持的控件类型,请检查后重试。
InvalidParameterValue参数取值错误。
LimitExceeded超过配额限制。
MissingParameter缺少参数错误。
MissingParameter.MissComponentName缺少控件名称参数,请检查后重试。
OperationDenied操作被拒绝。
OperationDenied.ByFilesServerSignForbid文件发起静默签未开通白名单。
OperationDenied.ErrNoResourceAccess无资源访问权限。
OperationDenied.InvalidApproverAge签署人未达到合法年龄。
OperationDenied.NoApproverMobileCheckPermission企业暂未开通手机号验证身份的服务,请在企业中心开通再使用
OperationDenied.NoIdentityVerify未通过个人实名。
OperationDenied.NoQuota流程配额不足。
OperationDenied.OverseaAbilityNotOpen当前企业员工没有开通境外签署能力。
ResourceNotFound资源不存在。
ResourceNotFound.Application应用号不存在。
ResourceNotFound.Resource资源不存在。
ResourceNotFound.Seal印章不存在,请检查后重试。
UnauthorizedOperation.NoPermissionFeature请升级到对应版本后即可使用该接口。
更多开发者交流反馈
购买咨询
联系销售
预约咨询
购买热线
售后反馈