以管理员身份登录至 Adobe Sign
新增功能
快速入门
管理
- Admin Console 概述
- 用户管理
- 帐户/组设置
- 设置概述
- 全局设置
- 帐户级别和 ID
- 全新的收件人体验
- 自签名工作流
- 批量发送
- Web 表单
- 自定义发送工作流程
- Power Automate 工作流程
- 库文档
- 收集包含协议的表单数据
- 有限文件可见性
- 附加已签名协议的 PDF 副本
- 在电子邮件中包含链接
- 在电子邮件中包含图像
- 附加至电子邮件的文件将命名为
- 将审核报告附加到文档
- 将多个文档合并为一个
- 下载单个文档
- 上传签名文档
- 我的账户中的用户委托
- 允许外部收件人委派
- 授权签名
- 授权发送
- 授权添加电子密封
- 设置默认时区
- 设置默认日期格式
- 位于多个组的用户 (UMG)
- 组管理员权限
- 替换接收者
- 审核报告
- 事务页脚
- 在产品消息发送和指南中
- 可访问的 PDF
- 新版“编辑”体验
- 医疗保健客户
- 帐户设置
- 添加标志
- 自定义公司主机名/URL
- 添加公司名称
- 发布协议 URL 重定向
- 签名首选项
- 格式精美的签名
- 允许收件人签名的方式
- 签名者可以更改其姓名
- 允许接收者使用其保存的签名
- 自定义使用条款和消费者信息披露条款
- 在表单字段中导航收件人
- 重启协议工作流
- 拒绝签名
- 允许图章工作流
- 要求签名者提供其职务或公司
- 允许签名者打印并置入书面签名
- 进行电子签名时显示消息
- 需要签名者使用移动设备创建其签名
- 请求签名者的 IP 地址
- 从参与者图章中排除公司名称和职务
- 数字签名
- 电子签章
- 数字身份
- 报告设置
- 新版报告体验
- 经典报告设置
- 安全设置
- 发送设置
- 消息模板
- 生物识别设置
- 工作流程集成
- 公证设置
- 付款集成
- 签名者消息发送
- SAML 设置
- SAML 配置
- 安装 Microsoft Active Directory 联合身份验证服务
- 安装 Okta
- 安装 OneLogin
- 安装 Oracle Identity Federation
- SAML 配置
- 数据管理
- 时间戳设置
- 外部归档
- 账户语言
- 电子邮件设置
- 从 echosign.com 迁移到 adobesign.com
- 为收件人配置选项
- 监管要求指导
- 批量下载协议
- 申请您的域
- “举报滥用”链接
发送、签署和管理协议
- 收件人选项
- 发送协议
- 在文档中创作字段
- 应用程序内创作环境
- 使用文本标记创建表单
- 使用 Acrobat (AcroForms) 创建表单
- 字段
- 创作常见问题
- 签署协议
- 管理协议
- 审核报告
- 报告和数据导出
高级协议功能和工作流程
- Web 表单
- 可重复使用的模板(库模板)
- 转让 Web 表单和库模板的所有权
- Power Automate 工作流程
- Power Automate 集成和包含的权限概述
- 启用 Power Automate 集成
- “管理”页面上的上下文操作
- 跟踪 Power Automate 使用情况
- 创建新的工作流(示例)
- 用于工作流的触发器
- 从 Acrobat Sign 外部导入工作流
- 管理工作流
- 编辑工作流
- 共享工作流
- 禁用或启用工作流
- 删除工作流
- 实用模板
- 仅限管理员
- 协议存档
- Web 表单协议存档
- 将已完成的 Web 表单文档保存到 SharePoint 库
- 将已完成的 Web 表单文档保存到 OneDrive for Business
- 将已完成的文档保存到 Google Drive
- 将已完成的 Web 表单文档保存到 Box
- 协议数据提取
- 协议通知
- 发送包含协议内容和已签名协议的自定义电子邮件通知
- 在 Teams 渠道中获取 Adobe Acrobat Sign 通知
- 在 Slack 中获取 Adobe Acrobat Sign 通知
- 在 Webex 中获取 Adobe Acrobat Sign 通知
- 协议生成
- 通过 Power Apps 表单和 Word 模板生成文档,并发送以供签名
- 从 OneDrive 中的 Word 模板生成协议并获取签名
- 为所选 Excel 行生成协议,发送以供审阅和签名
- 自定义发送工作流程
- 共享用户和协议
与其他产品集成
- Acrobat Sign 集成概述
- Acrobat Sign for Salesforce
- Acrobat Sign for Microsoft
- 其他集成
- 合作伙伴管理的集成
- 如何获取集成密钥
Acrobat Sign 开发人员
- REST API
- Webhook
支持和故障排除
API 访问权限专为企业和开发人员级帐户保留。
核心文档的链接
REST API 6 有用链接:
- 注册开发人员帐户:https://acrobat.adobe.com/cn/zh-Hans/sign/developer-form.html
- 应用程序内方法:https://secure.adobesign.com/public/docs/restapi/v6
- 示例:https://opensource.adobe.com/acrobat-sign/developer_guide/index.html#!adobedocs/adobe-sign/master/samples.md
- Webhook:https://opensource.adobe.com/acrobat-sign/acrobat_sign_events/index.html
2021 年 5 月已停止支持旧版 SOAP API。
所有使用 SOAP API 的客户应尽快迁移到 REST API。
登录后,导航至帐户 > Acrobat Sign API > API 信息 > Rest API 和文档
。
一般概念
您无法通过在 Web UI 上查看页面来创作文档,也无法通过 API 使用 transientDocumentId 来拖放或分配签名人角色。
transientDocuments 调用会返回 transientDocumentID,有效期为 7 天。 您只能将其用于后续的 API 调用。它存储在 API 服务器上并分配了临时文档 ID。上传文件,然后在后续 API 调用中引用其 ID。
您无法使用 REST API 直接上传协议中的文档。
根据 REST 要求,首先应创建一个临时文档,然后在协议、小组件或库方法中将此 ID 用作文件源。
临时文档是上传到 Adobe 服务器的 Raw 文件,例如 PDF、doc、docx 等。因此,这是一种将基础文档传输到 API 服务器和将临时文档传输到 Web 上便捷方式。
是的,您可以通过 v6 中的工作流程使用 API 调用 POST /agreements 来发布协议。在 API 调用中传递 workflowId 参数。
您可以使用 GET /workflows 调用获取工作流程的 workflowId。
-
-
导航至帐户 > Adobe Sign API > API 请求日志
-
以管理员身份登录至 Adobe Sign 帐户
-
导航至:帐户 > Adobe Sign API > API 信息
-
单击 REST API 示例链接。
注意:要下载 JavaScript SDK,请参阅 https://github.com/adobe-sign/AdobeSignJsSdk。
从 v6 开始,sendTroughWeb 选项不再可用。取而代之的是 state。它是指协议所处的状态。只能在 POST 调用中提供 state 字段。如果在 PUT /agreements/{ID} 调用中提供此字段,它绝不会在 GET /agreements/{ID} 中返回并且会被忽略。可从 GET /agreements/ID 获取协议的最终状态。
state(string) = ['AUTHORING' or 'DRAFT' or 'IN_PROCESS'].
AUTHORING 允许用户创作协议文档,然后将其发送出去。此处的创作操作是指在协议文档中创建、编辑或放置表单字段及其配置(被分配人、条件、数据类型等)。在以“Authoring”状态发布文档后,此文档会显示在 Adobe Sign“管理”选项卡的“草稿”部分中。
DRAFT 是最终预期资源的临时或原始阶段,可在创建最终资源的步骤中进行更新,但不会显示在 Adobe Sign“管理”选项卡的“草稿”部分中。使用“Draft”状态时,无需提供参与者集信息,稍后可在调用 PUT/agreements/agreementId 以完成草稿时分配此信息。此步骤可以重复多次,直到您拥有创建协议所需的所有数据。
IN_PROCESS 将协议状态更改为“已发出进行签名”,并且会显示在 Adobe Sign“管理”选项卡的“已发出进行签名”部分中。
sendThroughWeb 允许您以交互方式发送协议。通过 v5 POST /agreements 请求内“选项”字段中的各种参数,用户能够配置这个交互式视图(“发送”页面)。所有这些页面配置参数(例如 fileUploadOptions)都将移到 POST agreements/ID/views API 中。
因此,实际上,您可以通过 POST /agreements API 创建一个“AUTHORING”状态的协议以实现 sendThroughWeb。然后,要在所需的配置中请求下一个页面的 URL,请调用 POST agreements/ID/views API。
请执行以下步骤:
1. 转到 REST API V6 文档并选择 POST/agreements 方法。
2. 使用以下请求代码:
{ "fileInfos": [ { "transientDocumentId": "***************************" } ], "name": "test", "participantSetsInfo": [ { "memberInfos": [ { "email": "abc@gmail.com" } ], "order": 1, "role": "SIGNER" } ], "signatureType": "ESIGN", "state": "AUTHORING" }
3. 现在,使用带有以下请求代码的方法 post /agreements/{agreementId}/views:
{ "name": "AUTHORING" } |
响应代码会提供创作字段的 URL。
可以通过以下方式定义回调 URL:
- 根据需要使用以下参数定义回调 URL:
"callbackInfo": "",
- 请联系 Adobe Sign 支持团队,以设置完整帐户的默认回调 URL。
SOAP UI (SmartBear) 会收到与进行 API 调用时出现的错误类似的 SSL 连接错误。如果您使用低于 TLS1.2 的过时 SSL 或 TLS 协议,则通常会出现此错误
ERROR: Exception in request: javax.net.ssl.SSLException: Received fatal alert: protocol_version
ERROR: An error occurred [Received fatal alert: protocol_version], see error log for details
-
在 Bin 文件夹下的 VMOPTIONS 文件中添加 (-Dsoapui.https.protocols=SSLv3,TLSv1.2)。
-
转到 C:\Program Files\SmartBear\SoapUI-5.2.1\bin(具体取决于 SOAP UI 的安装位置。它可能位于 C:\Program Files (x86) 下)
-
在 VMOPTIONS 文件中,启用完全读取/写入文件权限。
-
右键单击 VMOPTIONS 文件 >“属性”>“安全”选项卡,然后选择用户 > 单击“编辑”。(“用户访问控制”图标显示在“编辑”按钮上)> 选中所有复选框并单击“确定”。
-
对管理员、系统,以及所有应用程序包重复相同的操作。
-
使用“记事本”打开文件。
-
在底部添加此协议“-Dsoapui.https.protocols=SSLv3,TLSv1.2”并保存更改。
-
关闭 SOAP UI 并重新启动。在进行 API 调用时它将正常运行,而不会出现 SSL 错误。(请执行测试 ping 调用以进行检查)。
以下是在 Adobe Sign 应用程序中创建客户端 ID 和客户端密码的步骤:
-
登录到 Adobe Sign 帐户。
-
导航至帐户 > Adobe Sign API > API 应用程序。
-
要创建应用程序,请单击 + 图标。
-
输入“名称”和“显示名称”。
-
在“域”下,选择“客户”,然后单击“保存”。
-
单击以突出显示应用程序。
-
单击“对应用程序配置 OAuth”。
-
输入重定向 URI。
-
要启用所需范围,请选中相应的复选框并单击“保存”。
-
以帐户管理员身份登录至 Adobe Sign
-
导航至:帐户 > Adobe Sign API > API 信息
-
单击集成密钥链接
注意:如果未显示“集成密钥”链接,请与您的成功经理联系,让他们启用您的帐户。
-
- 使用直观值命名密钥
- 选择应用程序函数所需的各种范围
- 在完全配置密钥之后,单击保存
-
保存后,可在以下位置找到该密钥:帐户 > 个人首选项 > 访问令牌
将列出密钥的名称以及所有已启用的范围。
单击一次密钥说明,可显示操作链接:
- 集成密钥 - 此链接提供文本密钥
- 撤消 - 此操作将会永久撤消并删除访问令牌
-
登录到 Adobe Sign 帐户。
-
导航至“帐户”>“Adobe Sign API”>“API 应用程序”。
-
单击 + 图标以创建应用程序。
-
单击“对应用程序配置 OAuth”。
-
使用以下链接生成授权代码。客户端 ID、重定向 URI 以及范围必须与在应用程序中选择的以下 URL 中对应的值相同(避免在以下 URL 中出现空格,像“NA1”这样的分区应根据您的 Adobe Sign 帐户所属关系填充):
https://secure.na1.echosign.com/public/oauth?redirect_uri=https://www.google.co.in&response_type=code&client_id=CBJCHBCAABAAo9FZgq31_5BVG_kcIXEe6gNtn-R-gdNe&scope=user_login:self+agreement_send:account -
如果调用成功,请从地址栏中选取授权代码。
-
从 https://www.getpostman.com/apps 链接下载并安装 Postman。
-
下载并安装后,单击“新建”以创建 POST。
-
根据您的 Adobe Sign 帐户所属关系,输入 https://secure.na1.echosign.com/oauth/token 链接。
-
在“标头”下的“内容类型”中输入 application/x-www-form-urlencoded。
-
确保在“正文”下选择 x-www-form-urlencoded,并输入以下参数及其相应值(源自在 Adobe Sign 帐户中创建的应用程序),然后单击“发送”。
-
如果所有信息都正确,则会在响应中返回访问令牌和刷新令牌:
运行 OAuth 进程时,请确保遵循以下几点:
1. 指定正确的客户端 ID 和重定向 URI。
2. 授权 URL 中提供的范围应与 Adobe Sign 应用程序中提供的范围完全匹配。
3. 根据要配置的帐户,使用正确的分区(na1、na2、au1、eu1、jp1)。
4. 移除授权 URL 中提供的任何空格(如果有)。
5. 检查授权 URL 的语法:
https://secure.na1.echosign.com/public/oauth?redirect_uri=https://secure.na1.echosign.com/public/oauthDemo&
response_type=code&client_id=9MEJXY4Y4R7L2T&scope=agreement_send
访问令牌的有效期仅为 3600 秒(1 小时),之后这些令牌将过期。
API 请求持有者可以使用刷新令牌,以便根据需要生成新的访问令牌。
REST API V6 及更高版本支持 Webhook。
如果 Webhook 接收器在 72 小时内无响应,则将禁用 Webhook 且不会发送通知。
如果 Webhook 的目标 URL 因任何原因而停止运转,Adobe Sign 会将 JSON 排入队列,然后在 72 小时内循序渐进地重试推送。
未传送的事件将会保留在重试队列中,并且在接下来的 72 小时内,将会尽可能按照发生顺序来发送通知。
重试发送通知的策略是:将两次尝试之间的时间增加一倍,从 1 分钟的间隔开始,增加到每 12 小时一次,进而在 72 小时内重试 15 次。
要直接从 Adobe Sign UI 创建 Webhook,请首先通过 Azure AD 函数应用使用以下步骤创建 Webhook URL:
-
通过 Microsoft 帐户 https://portal.azure.com/ 登录。
-
在 AzureAD 帐户下,注册“Function App”。
-
转到 AzureAD 并转到“Function App”> 单击 + 图标以展开“函数”。
-
选择“Webhook + API”并选择“Javascript”作为语言,然后单击“创建函数”。
-
将 Index.js 文件替换为以下代码片段:
module.exports = function (context, req) { var clientId = req.headers['x-adobesign-clientid']; // Validate that the incoming ClientID is genuine if (clientId === '************************************') { context.res = { // status: 200, /* Defaults to 200 */ // any 2XX response is acceptable body: { 'xAdobeSignClientId' : clientId, }, headers : { 'Content-Type' : 'application/json' } }; } else { context.res = { status: 400, body: "Opps!! Illegitimate Call identified" }; } context.done(); };
-
单击右侧角落的“测试”按钮,并提供以下标头:
X-AdobeSign-ClientId as ***********************
-
单击“保存并运行”。
-
收到包含以下标头的“200 正常”响应后,单击“获取函数 URL”
-
复制 URL 并转到 Adobe Sign UI >“Webhook”,单击 + 图标以创建。
-
输入以下信息:
- 名称:建议使用其他管理员可轻松理解的直观名称。
- 范围:Webhook 捕捉的网络范围。“帐户”和“组”在界面中可用。
此 API 支持“帐户”、“组”、“用户”和“资源”范围。 - 每个 Webhook 只能定义一个范围
- URL:Adobe Sign 将 JSON 负载推送到的目标 URL。
- 事件:导致 Adobe Sign 构建 JSON 并将其推送到 URL 的触发器。
每个事件会生成与触发器事件相关的不同负载
在一个 Webhook 中可以包含多个事件。 - 通知参数:“通知参数”会标识事件 JSON 负载的各个部分,让您能够仅选择“事件”中重要的部分。
-
完全定义 Webhook 后单击“保存”,然后新的 Webhook 会立即开始响应触发器事件。
协议资源是指可通过其创建协议的资源,例如库文档、小组件以及协议本身。
要搜索协议资源事件,请首先向使用相关搜索参数创建 agreementAssetEvents 的 API 发出请求。
“响应”是结果的第一页,其中还包含搜索 ID 参数和下一页光标。您可以使用它来获取更多页面结果(如果使用 API 可以得到的话),API 会根据 search Id 检索 agreementAssetEvents。
-
打开适用于版本 5 的 REST API 文档。
-
转到 post/search/agreementAssetEvents 并使用相关范围生成访问令牌。
-
在请求代码中,根据要求定义开始日期和结束日期:
{ "endDate": "2018-05-22T22:33:33", "startDate": "2017-12-22T22:33:33" }
-
单击“立即试用”。它将会获取协议资源 ID,也可用作协议 ID。
用户/帐户管理
- 登录到 Adobe Sign。
- 导航至“帐户”>“Adobe Sign API”>“REST API 文档”。
- 选择“版本 5”。
- 在 post /users 方法下,使用
UserCreationInfo 方法
下提到的请求代码:{
"email": "email@email.com",
"firstName": "AA",
"lastName": "AB",
"password":"12******rte"
}
使用 Admin Console (Adobe One) 管理用户权利的 Adobe Sign 帐户,无法使用 Adobe Sign API 创建用户或管理现有用户。
Adobe One Admin Console 使用与 Adobe Sign API 不同的 API。有关更多信息,请参阅以下文章:
- https://helpx.adobe.com/cn/enterprise/help/users.html
- https://www.adobe.io/apis/cloudplatform/umapi-new.html
获取组 ID:
-
转到 https://secure.na1.echosign.com/public/docs/restapi/v5。
-
在“资源和操作”下,单击“组”。
-
单击“GET /groups”。
-
单击“oAuth Access-token”按钮。
-
生成访问令牌。
-
单击“立即试用”按钮。
您会收到如下响应,其中包含组名称和组 ID:
{ "groupInfoList": [ { "groupId": "3AAABLblqZhB4o9EnlvmGB_m8CrG5O6XClTBO7vmojOOexu5r3G95LtEV2Sp7BuhNvQYSvWB7PmmwVPXnhPIiYSuHV98Cerkp", "groupName": "Default Group" }, { "groupId": "3AAABLblqZhC3dPT6za5h7r1-BOEWivCe_OcAVONhcsKa57SL9_iCwGr5v_JED1No5jE20Pcjv0mYH2J-LoY1AcmqS69vRkO7", "groupName": "test" }, ] }
删除组:
-
单击“DELETE /groups/{groupId}”。
-
要生成访问令牌,请单击“oAuth Access-token”按钮。
-
在 groupId 框中,添加您要删除的在上一次调用响应中收到的 groupId。
-
单击“立即试用”。
删除组后,您会收到以下响应:“无内容”
无法删除已分配了用户的组。实际上,只能删除空白组。如果组中有用户,您会收到如下响应。
"code": "GROUP_NOT_EMPTY", "message": "The group cannot be deleted because it is not empty." } |
启动/发送协议
生成临时文档
-
单击 transientDocuments 并展开 POST/transientDocuments 方法
-
单击 OAuth Access-token 按钮
-
- 启用交易的范围
- 单击授权
-
如果收到质询,请单击允许访问
-
您将返回到“API 方法”页面。现在将填充授权值。
- 在文件名字段中输入文件名
- 单击选择文件按钮并上传协议文档
- 单击“立即试用!”按纽
-
将生成响应。
transientDocumentID 可在响应正文中找到:
使用“临时”文档生成协议
-
单击协议并展开 POST /agreements 方法
-
- 单击 OAuth Access-token 按钮
- 启用 OAuth 范围
- 单击授权
- 如果收到质询,请单击允许访问
-
您将返回到“API 方法”页面。现在将填充授权值。
- 将下面的脚本复制到文本编辑器中(此脚本只是一个最低配置的示例;您的生产代码将会有所不同)
- 将 trasientDocumentId 值插入到代码中指示的位置
{ "fileInfos": [ {"transientDocumentId":"PASTE YOUR TRANSIENTDOCUMENTID HERE"} ], "name": "test doc", "participantSetsInfo": [ { "memberInfos": [ { "email": "noreply@echosign.com" } ], "order": 1, "role": "SIGNER" } ], "signatureType": "ESIGN", "state": "DRAFT" }
- 复制您的自定义脚本并将其粘贴到 AgreementInfo 字段中
- 单击“立即试用!”按纽
-
将生成响应。
agreementID 可在响应正文中找到:
以下是在 FileInfo 参数中添加文件的操作步骤:
-
使用临时 ID:
转到 POST/transientDocuments,并从本地系统上传要使用的文档。
使用在 POST/agreements 方法中“文件信息”部分下生成的临时 ID:"fileInfos": [ { "transientDocumentId": "" } ],
-
使用库文档 ID:
转到“功能板”。单击“将文档添加到库”并保存模板。
在“REST API 文档”下,单击“GET/libraryDocuments”并检索要创建的模板的库 ID。
在“POST/Agreements”下,提供库文档 ID:"libraryDocumentId": "", "libraryDocumentName": "",
-
使用公开可用的 URL:
提供要在 FileInfo 参数下使用的可公开访问的 URL:
{ "documentURL": { "mimeType": "", "name": "", "url": "" },
-
选择“协议”>“POST/agreements”选项。
-
选择“Oauth Access-token”选项,并提供所需的范围。
-
添加访问令牌后,您可以使用以下请求代码:
{ "documentCreationInfo": { "recipientSetInfos": [ { "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{"email": "testemail@email.com"}] }, { "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{"email": "testemail@email.com"}] } ], "signatureFlow": "SEQUENTIAL", "name": "husband wife", "signatureType": "ESIGN", "fileInfos": [ { "transientDocumentId": "(SAMPLE VALUE)3AAABLblqZhAJ9H6e23kZAfBUbItPvIhHTEyA6eZhziEp4KSntYcULpo43OEXwuWiWa-IM1r1EExYW0044CjCkliP4WFL5yKBUDq5DYSmSxVlFypcD0at8kK-BX-Mu3T9c_3GUqgDg0ArX0MmzWT72GLR_0M4Jq--mtuqGzq-VK1s-WGR6GcbedVY7XWAf3b3h-SpE08Hc-iF3zO7jQzi9newXSl-iW2JJsb_55tggkyxkXAkj74C1WD6KkJzgblK0JU-seh6QPDd0Fv6_mfQe2EPQA31nXj50aXwD_xlUBq7mg5FeaBnZ5bzgoqIWGHkbyeD2taaFdw*"} ] } }
在 POST /agreements 调用中,对于 signatureflow 参数,您可以传递 SENDER_SIGNS_FIRST 或 SENDER_SIGNS_LAST 值,以便分别将发件人添加为第一位或最后一位签名者。
以下是 JSON 格式的调用示例:
{
"documentCreationInfo": {
"fileInfos": [
{ "transientDocumentId":"3AAABLblqZ-yourIDGoesHere"
}
],
"name": "Test",
"recipientSetInfos": [
{
"recipientSetMemberInfos": [
{
"email": "test@email.com"
}
],
"recipientSetRole": "SIGNER"
}
],
"signatureType": "ESIGN",
"signatureFlow": "SENDER_SIGNS_FIRST"
}
}
“以指定人员的名义发送”选项仅在启用“高级共享”的 REST API V6 中可用。
如果共享中未提供“发送”权限或者未启用高级共享,则会收到如下响应:
{"code":"PERMISSION_DENIED","message":"User provided in x-on-behalf-of-user header does not have required permission to perform this operation."}
|
对于“以指定人员的名义发送”功能,请启用帐户的“高级帐户共享”,以便用户在共享其帐户时可以向其他用户授予发送权限。有关“高级共享”的信息,请参阅启用高级帐户共享。
启用“用户共享”功能后,请执行以下步骤“以指定人员的名义发送”:
生成临时文档:
-
在“transientDocuments”下,单击“POST /transientDocuments”。
-
要生成授权令牌,请单击“OAUTH ACCESS-TOKEN”按钮。
-
在 x-on-behalf-of-user 中,采用以下格式提供您要其名义发送的用户电子邮件:email:test@email.com
-
要选择文件,请单击选择文件,然后单击立即试用。
您会收到包含 transientDocumentId 的如下响应:
{"transientDocumentId":"3AAABLblqZhB9Mjo0mrIu_pSgrf5VsMaKM68_Vmn80cimaqiUAD2OxrPp2e5H8GvjfiOxj4d5B8bCPkUfvaozW3KLisp_wseGVOL8A7oNZni1DWyFi4uNoxLQu4nUO44Wh63GQv9_HEJMePust0Pk94vJ_rbS96R7ic-vl7jbOkN0b4EB5-JMqlC-Fl_Vpyz8I1EQUrM5I4nB9ztMov4ad00yiOtDw0tB-Y2t5JdzM07P-mpJmwYEl8Fq2IeDuWjcR2tV7qY7TNGX2CNyh9jt0aMyduHeYa0GABr69z8Hm76eKdtaM_1E1ggWj205fSrNcwJsnpSO278*"}
使用“临时”文档生成协议:
-
在协议下,单击“POST /agreements”。
-
要生成授权令牌,请单击 OAUTH ACCESS-TOKEN 按钮。
-
在 x-on-behalf-of-user 中,提供在创建临时文档时使用的用户的电子邮件。
-
在“AgreementInfo”中,添加以下代码,然后单击“立即试用”。
{ "fileInfos": [ { "transientDocumentId":"3AAABLblqZhB9Mjo0mrIu_pSgrf5VsMaKM68_Vmn80cimaqiUAD2OxrPp2e5H8GvjfiOxj4d5B8bCPkUfvaozW3KLisp_wseGVOL8A7oNZni1DWyFi4uNoxLQu4nUO44Wh63GQv9_HEJMePust0Pk94vJ_rbS96R7ic-vl7jbOkN0b4EB5-JMqlC-Fl_Vpyz8I1EQUrM5I4nB9ztMov4ad00yiOtDw0tB-Y2t5JdzM07P-mpJmwYEl8Fq2IeDuWjcR2tV7qY7TNGX2CNyh9jt0aMyduHeYa0GABr69z8Hm76eKdtaM_1E1ggWj205fSrNcwJsnpSO278*" } ], "name": "Test", "participantSetsInfo": [ { "memberInfos": [ { "email": "signer@email.com" } ], "order": 1, "role": "SIGNER" } ], "signatureType": "ESIGN", "state": "IN_PROCESS" }
您会收到包含 agreementId 的如下响应:
{ "id": "CBJCHBCAABAAUlen3l_fzlj1Kbn_wGZAhYcIgN0J7Qtq" }
-
登录到 Adobe Sign。
-
导航至“帐户”>“Adobe Sign API”>“API 信息”,然后单击“REST API 方法文档”。
-
单击“POST/transientDocuments”,然后上传文件并创建临时文档 ID。
-
复制临时文档 ID,并在 POST /agreements 方法中使用该 ID。在框中提到以下 JSON 请求:
{ "documentCreationInfo": { "mergeFieldInfo": null, "recipientSetInfos": [{ "signingOrder": null, "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "securityOptions": null, "email": "test1@gmail.com" }], "privateMessage": "Hello 1", "securityOptions": null }, { "signingOrder": null, "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "securityOptions": null, "email": "test2@gmail.com" }], "privateMessage": "Hello 2", "securityOptions": null } ], "signatureType": "ESIGN", "callbackInfo": null, "message": "Please review and sign this document.", "locale": "en_US", "vaultingInfo": null, "securityOptions": null, "reminderFrequency": null, "ccs": null, "postSignOptions": null, "signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "daysUntilSigningDeadline": null, "formFieldLayerTemplates": [], "name": "Adobe Sign Agreement", "formFields": null, "fileInfos": [{ "libraryDocumentName": null, "transientDocumentId": "XXXXXXXXXXXX", "documentURL": null, "libraryDocumentId": null }] } }
-
要执行 JSON 请求,请单击“立即试用”按钮。
正确的 JSON 会返回包含协议 ID 的响应。
以下是可以在代码中传递的参数,用于设置打开密码:
{ "documentCreationInfo": [{ "signatureType": "ESIGN", "recipientSetInfos": [{ "recipientSetMemberInfos": [{ "email": "abc@xyz.com" }],
"recipientSetRole": "SIGNER" }], "signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "fileInfos": [ { "libraryDocumentId": "3AAABLblqZhBsm_vH7TVzU3hRdbtWuvzfTKDvBzaKZTiehjO2eGTk5Rlu02K-0BYn8HBJVFTWOmT_BQlrofPBlrCdjiJ_JI-V" } ], "name": "Open password to view document", "securityOptions": { "openPassword": "1234", "protectOpen": true } }] }
|
要使用 API 状态为“AUTHORING”的创建协议,请执行以下步骤:
转到“Post /agreements”,并创建具有所需范围的访问令牌。
请按如下方式使用请求代码:
{ "fileInfos": [ { "transientDocumentId": "*********************" } ], "name": "A1", "participantSetsInfo": [ { "memberInfos": [ { "email": "abc@xyz.com" } ], "order": 1, "role": "SIGNER" } ], "signatureType": "ESIGN", "state": "AUTHORING" }
|
-
转到 REST API V6 文档并选择 POST/agreements 方法。
-
使用以下请求代码:
{ "fileInfos": [ { "transientDocumentId": "***************************" } ], "name": "test", "participantSetsInfo": [ { "memberInfos": [ { "email": "abc@gmail.com" } ], "order": 1, "role": "SIGNER" } ], "signatureType": "ESIGN", "state": "AUTHORING" }
-
使用 put /agreements/{agreementId}/formFields 方法,以下列请求作为示例:
{ "fields": [ { "locations": [ { "height": 36, "left": 75, "pageNumber": "1", "top": 200, "width": 150 } ], "contentType": "SIGNATURE_BLOCK", "name": "sigBlock1", "inputType": "SIGNATURE", "recipientIndex":1 } ]}
在完成请求后,它会将协议发送给提到的收件人。
-
登录到 Adobe Sign。
-
导航至“帐户”>“Adobe Sign API”>“API 信息”,然后单击“REST API 方法文档”。
-
单击“POST/transientDocuments”,然后上传文件并创建临时文档 ID。
-
复制临时文档 ID,并在 POST /agreements 方法中使用该 ID。在框中提到以下 JSON 请求:
{ "documentCreationInfo": { "recipientSetInfos": [{ "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "email": "test1@gmail.com" }], "privateMessage": "Hello 1" }, { "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "email": "test2@gmail.com" }], "privateMessage": "Hello 2" } ], "signatureType": "ESIGN", "message": "Please review and sign this document.", "signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "name": "Demo1", "fileInfos": [{ "transientDocumentId": "XXXXXXXXXX" }], "formFields": [{ "hidden": "1", "defaultValue": "test1@gmail.com", "name": "Signer Email (Applicant-1)", "inputType": "TEXT_FIELD", "readOnly": true, "locations": { "pageNumber": 1, "top": 100, "left": 100, "width": 100, "height": 30 }, "contentType": "SIGNER_EMAIL" }, { "name": "Signature (Applicant-2)", "inputType": "SIGNATURE", "locations": { "pageNumber": 1, "top": 520, "left": 162, "width": 280, "height": 30 }, "contentType": "SIGNATURE", "required": 1, "recipientIndex": 1 }, { "name": "Signature (Applicant-3)", "inputType": "SIGNATURE", "locations": { "pageNumber": 2, "top": 312, "left": 154, "width": 280, "height": 30 }, "contentType": "SIGNATURE", "required": 1, "recipientIndex": 1 }, { "defaultValue": "017/09/2018", "displayFormatType": "DATE", "name": "Signature Date (Applicant-4)", "format": "DATE_DD_MM_YYYY", "inputType": "TEXT_FIELD", "readOnly": true, "locations": { "pageNumber": 2, "top": 260, "left": 90, "width": 80, "height": 30 }, "contentType": "DATA", "required": 1, "recipientIndex": 1 }, { "name": "Signature (Applicant-5)", "inputType": "SIGNATURE", "locations": { "pageNumber": 3, "top": 199, "left": 179, "width": 276, "height": 30 }, "contentType ": "SIGNATURE", "required": 1, "recipientIndex": 1 }, { "contentType": "SIGNATURE_DATE", "defaultValue": "06/07/2018", "displayFormatType": "DATE", "name": "Signature Date (Applicant-6)", "format": "DATE_DD_MM_YYYY", "inputType": "TEXT_FIELD", "readOnly": true, "locations": { "pageNumber": 3, "top": 188, "left": 488, "width": 76, "height": 25 }, "required": 1, "recipientIndex": 1 }, { "name": "Signature (Applicant-7)", "inputType": "SIGNATURE", "locations": { "pageNumber": 3, "top": 370, "left": 37, "width": 210, "height": 26 }, "contentType ": "SIGNATURE", "required": 1, "recipientIndex": 2 }, { "contentType ": "SIGNATURE_DATE", "defaultValue": "01/02/2018", "name": "Signature Date (Applicant-8)", "locations": { "pageNumber": 3, "top": 370, "left": 300, "width": 76, "height": 26 }, "required": 1, "recipientIndex": 2 } ] } }
-
要执行 JSON 请求,请单击“立即试用”按钮。
正确的 JSON 会返回包含协议 ID 的响应。
-
登录到 Adobe Sign。
-
导航至“帐户”>“Adobe Sign API”>“API 信息”,然后单击“REST API 方法文档”。
-
单击“POST/transientDocuments”,然后上传文件并创建临时文档 ID。
-
复制临时文档 ID,并在 POST /agreements 方法中使用该 ID。在框中提到以下 JSON 请求:
{ "options": { "noChrome": true, "authoringRequested": true }, "documentCreationInfo": { "recipientSetInfos": [{ "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "email": "test1@gmail.com" }], "privateMessage": "Hello 1" }, { "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "email": "test2@gmail.com" }], "privateMessage": "Hello 44" } ], "signatureType": "ESIGN", "message": "Please review and sign this document.", "locale": "en_US", "signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "formFieldLayerTemplates": [], "name": "Adobe Sign Agreement", "formFields": null, "fileInfos": [{ "libraryDocumentName": null, "transientDocumentId": "XXXXXXXXXXXX" }] } }
-
要执行 JSON 请求,请单击“立即试用”按钮。
正确的 JSON 会返回包含协议 ID 的响应。
-
要在“创作模式”下打开协议,请复制 URL 并将其粘贴到浏览器的地址栏中。
-
将表单字段拖放到所需位置。
-
要发送协议以请求签名,请单击“发送”。
使用 POST /agreements 创建协议。发送协议以请求签名,并在响应客户端时返回 agreementID。以下是使用手机身份验证方法发送协议的 JSON 格式。
{ "documentCreationInfo": { "mergeFieldInfo": null, "recipientSetInfos": [{ "signingOrder": null, "recipientSetRole": "SIGNER", "recipientSetMemberInfos": [{ "securityOptions": null, "email": "Signer@email.com" }],
"privateMessage": null, "securityOptions": [{ "authenticationMethod": "PHONE", "phoneInfos": [{ "phone": "1111111111", "countryCode": "+1" }] }] }],
"signatureType": "ESIGN", "callbackInfo": null, "message": "Please review and sign this document.", "locale": "en_US", "vaultingInfo": null, "securityOptions": null, "reminderFrequency": null, "ccs": null, "postSignOptions": null, "signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "daysUntilSigningDeadline": null, "formFieldLayerTemplates": [], "name": "Adobe Sign Agreement-Phone authentication testing", "formFields": null, "fileInfos": [{ "libraryDocumentName": null, "transientDocumentId": "3AAABLYourTransactionID", "documentURL": null, "libraryDocumentId": null }] },
"options": { "autoLoginUser": true, "authoringRequested": false, "noChrome": true, "sendThroughWeb": null, "sendThroughWebOptions": null, "locale": "en_US" } }
|
如何使用已为特定表单字段 (mergefield) 预填值的 API 来发送协议?
此调用的前提条件是首先完成“临时上传”步骤并获取此处要使用的“transientDocumentId”(使用:secure.na1.echosign.com/public/docs/restapi/v5#! /transientDocuments/createTransientDocument)。
- 此调用包含“mergeFieldInfo”部分,其中已提供特定表单字段的默认值。
- 这将在 API 调用中预填来自其他系统的数据。
- 协议中的这些字段要么可编辑,要么只读。
前提条件:
- 临时文档 ID
- 字段名称及相应的值
请求调用示例:
请求: POST /api/rest/v5/agreements HTTP/1.1 主机:api.na1.echosign.com(或者,您可以指定分区名称,该名称可使用 getbaseURis 调用找到:https://secure.na1.echosign.com/public/docs/restapi/v5#! /base_uris/getBaseUris 访问令牌:2AAABLblqZhA_D1mluNKQP7py5vXtt-1UHl9NR25e_C3LnKTUH14IblbrXODbXGRozyr7ChBkJNM* x-user-email:sender@yourdomain.com 内容类型:application/json 缓存控制:no-cache
{ "documentCreationInfo": { "signatureType": "ESIGN", "recipientSetInfos": [ { "recipientSetMemberInfos": [ { "email": “signerEmail@domain.com" } ], "recipientSetRole": "SIGNER" } ],
"signatureFlow": "SENDER_SIGNATURE_NOT_REQUIRED", "message": "Please Sign this from us!", "fileInfos": [ { "transientDocumentId": "3AAABLblqZhD1uP3ZnkJximC0JV1S677PR5xmybSJ-SJn6OtEy2tVqFyMN4xUAbhKTSkLw2Zb6HEF4zAGsrUd2ycoB8fFHQJhrci0O6267VztmIL4nCicSqvAjO7HckATHAsovVmuYwI9_FDDgHg0ogyti62L13HQFZIQRe9iyQMvvzbmksM7ODNK_HEepEKRCeJTtis9FOlz6uRCcIMNlbX_2GU8utWT" } ], "name": "MSA Edited”, "mergeFieldInfo": [ { "fieldName": "AccountName", "defaultValue": "Sam's Garage" }, { "fieldName": "AccountNumber", "defaultValue": "8756999" }, { "fieldName": "Zip", "defaultValue": "94501" }, { "fieldName": "City", "defaultValue": "CityVille" }, { "fieldName": "State", "defaultValue": "CA" }, { "fieldName": "Street", "defaultValue": "123 Some Road" }, { "fieldName": "Title1", "defaultValue": "COO" }, { "fieldName": "Description", "defaultValue": "Some new description here" } ] }
}
对此调用的响应是“agreementId”,您需要将它存储在系统中以便进行后续调用(signingUrl、status、formData 等)
响应: { "agreementId": "3AAABLblqZhCf_7xDcrOgKFwAabp1S-OFfvUdHf2wJsSMwlB95_x_WdUeab67jOkJi1IJzWuSJ0zdNNKugS1blZB4LT5vNVyJ" }
|
运行 post /megaSigns/{megaSignId}/views 方法时,显示错误信息:“请求的视图不适用于当前状态下的资源”。
如果在以下请求代码中提供的名称参数值无效,则会显示该错误:
{
"name": " "
}
例如,如果 MegaSign 协议已经处于“IN_PROCESS”状态,则提供“AUTHORING”值将会引发上述错误。确保提供的值符合当前的协议状态。
运行 put /megaSigns/{megaSignId}/state 方法时,显示错误信息:“没有提供 MegaSign 取消信息的值”。
当请求代码缺少参数时,会导致该错误:
"megaSignCancellationInfo": {
"comment": "",
"notifyOthers": false
}
请单击“填写模型架构”并提供完整的请求代码来运行 API 调用,而不是使用“最小架构”。
要更改 MegaSign 协议的状态,请使用 put /megaSigns/{megaSignId}/state 方法并执行以下步骤:
- 转到 REST API V6 文档并选择
put /megaSigns/{megaSignId}/state 方法。 - 提供授权值,以及 If-Match 和 megasignID。
- 要检索 megasignID,请使用 get /megaSigns
- 要检索 If-Match,请使用 get /megaSigns/{megaSignId},并在标头下找到“Etag”
- {
"state": "CANCELED",
"megaSignCancellationInfo": {
"comment": "cancel",
"notifyOthers": false
}
}
为成功注册 Webhook,Webhook URL 会通过 2XX 响应代码响应此验证请求,而且,它还可以通过以下两种方式之一发回相同的客户端 ID 值:
- 在响应标头 X-AdobeSign-ClientId 中。它是在请求中传递的同一标头,并且在响应中发回。
- 在 JSON 响应正文中,使用 X-AdobeSign-ClientId 的密钥及其值,该值与请求中发送的客户端 ID 相同。
Adobe Sign 会收到包含 X-AdobeSign-ClientId 的 2xx 响应。用户可以检查在 Webhook 中配置的响应是否正确。
Webhook URL 将不会按照预期行为进行响应。对于 Adobe Sign 发送的每个 Post 通知,URL 均通过 2XX 状态代码进行响应,并在响应标头中对请求标头 (X-AdobeSign-ClientId) 中发回的客户端 ID 做出回应。
有关完整信息,请参阅以下链接:
https://www.adobe.io/apis/documentcloud/sign/docs.html#!adobedocs/adobe-sign/master/webhooks/webhook_events.md
当 URL 未能遵守此协议时,Adobe Sign 会认为此 URL 未确认响应请求,也未尝试根据可靠策略重新计划。
如果 Webhook 无法响应,并且超过了最长重试时间或最大重试间隔,则将禁用 Webhook。
管理/获取关于协议的信息
要更改已经发送以供签名的文档,请使用 PUT /agreements/{agreementId} 方法更新现有协议。在以下请求代码中提供临时 ID 和协议 ID:
{ "documentUpdateInfo": { "fileInfos": [ { "agreementDocumentId": "", "transientDocumentId": "" } ] } }
|
以下是使用 Put /agreements/{agreementId}/state 将状态从“AUTHORING”更新为“IN_PROCESS”的操作说明:
-
获取使用 POST/Agreement 方法检索的协议 ID。
-
使用 Get /agreements/{agreementId} 来检索最新的 ETag。
-
转到 Put /agreements/{agreementId}/state 并提供以下信息: "state": "IN_PROCESS"
否。
当前 REST API 中没有用于上传已签名副本的方法。
发件人必须从管理页面上传已签名的副本。
DELETE /agreements/ID 用于允许在“管理”页面中隐藏协议。
Adobe 提供了
PUT /agreements/ID/me/visibility 这个新 API,用于控制协议的可见性(在 GET /agreements 调用中)。除了 DELETE /agreements/ID 提供的功能外,新的可见性端点还允许用户恢复“隐藏”操作,也就是说,让协议再次可见。
您还可以按照以下详细步骤操作:
- 转到 get /agreements 方法并检索协议 ID。
- 单击 put /agreements/{agreementId}/me/visibility 并提供以下请求示例:
{
"visibility": "HIDE"
}
协议 ID 仅在 get /libraryDocuments 中隐藏,但仍会显示在“管理”选项卡 UI 下。
默认情况下不启用 API 保留功能。
要启用 DELETE/agreements 操作,请与您的成功经理联系,并请求为帐户启用 API 保留功能。
有关如何为帐户启用保留功能的更多信息,请参阅 Adobe Sign - 文档保留。
-
以管理员身份登录 Adobe Sign 并导航至:https://secure.adobesign.com/public/docs/restapi/v6
-
- 单击协议并展开 GET /agreements 方法
- 单击“OAUTH ACCESS-TOKEN”按钮
- 启用 agreement_read:self 范围
- 单击授权按钮
- 如果收到质询,请单击允许访问
- 单击立即试用!按纽
-
将生成响应。
agreementID 可在响应正文中找到:
-
DELETE /agreements/{agreementId}/documents:删除与协议相关的所有文档。协议本身在“管理”页面中仍然可见。
- 选择要运行的 DELETE/agreements 操作。
- 单击“OAUTH ACCESS-TOKEN”按钮,创建范围为 arement_retention 的访问令牌。
- 提供要删除的协议的 agreementId。
- 删除协议后,响应正文中“无内容”。
如果未启用 DELETE/agreements 操作,则将会收到以下响应:
"code": "DYNAMIC_DOCUMENT_EXPIRATION_NOT_ENABLED",
"message": "The operation requires some account settings to be enabled.Please contact the Adobe Sign team to enable the settings."
如何通过 Adobe Sign REST API 下载已签名文档以及审核报告和支持文档,而不是使用以下方法通过单独调用来下载审核报告。
-
单击“GET /agreements/{agreementId}/combinedDocument”。
-
单击“oAuth Access-token”按钮。
-
接受授权后,将会自动生成访问令牌。
-
提供 agreementId。
-
在 attachSupportingDocuments 下,从下拉列表中选择 true。
-
在 attachAuditReport 下,从下拉菜单中选择 true。
-
单击立即试用! 按纽.
它将会下载合并的 PDF,其中包含已签名文档、支持文档和审核报告。
要下载批量文档,只能使用文档导出工具,而且使用 API,只能逐个下载文档。以下是相应的 API 方法:
https://secure.na1.adobesign.com/public/docs/restapi/v5#! /agreements/getCombinedDocument
库模板与 Web 表单
-
以管理员身份登录 Adobe Sign 并导航至:https://secure.na1.adobesign.com/public/docs/restapi/v6
-
- 单击 libraryDocuments 并展开 GET/libraryDocuments 方法
- 单击“OAUTH ACCESS-TOKEN”按钮
- 启用 library_read:self 范围
- 单击授权按钮
- 如果收到质询,请单击允许访问
- 单击立即试用!按纽
-
将生成响应。
libraryDocumentId 可在响应正文中找到:
Adobe 提供了 PUT/libraryDocuments/ID/me/visibility 这个新 API,用于控制协议的可见性(在 GET /agreements 调用中)。除了 DELETE /agreements/ID 提供的功能外,新的可见性端点还允许用户恢复“隐藏”操作,也就是说,让协议再次可见。
您可以按照以下详细步骤操作:
- 转到 get /libraryDocuments 方法并检索协议 ID。
- 单击 put /libraryDocuments/{libraryDocumentId}/me/visibility 并提供以下请求示例:
{
"visibility": "HIDE"
}
库 ID 仅在 get /libraryDocuments 中隐藏,但仍会显示在“管理”选项卡 UI 下。
- 向支持团队提交请求,以为删除库启用范围。
- API 将删除库文档。但是,使用此库文档创建的协议不会受到任何影响。
生成 libraryDocumentID
-
转到 https://secure.echosign.com/public/docs/restapi/v5。
-
单击 libraryDocuments。
-
单击 oAuth Access-token 按钮。
授权访问 - 自己、组或帐户的令牌。
-
选择 libraryTemplateType - 文档或 Form_field_layer。
-
单击立即试用。
对于所有模板,您将收到如下响应。(复制要删除的库模板的 libraryDocumentId。)
{ "libraryDocumentList": [ { "name": "testing fields", "modifiedDate": "2017-08-04T01:06:05-07:00", "scope": "PERSONAL", "libraryDocumentId": "3AAABLblqZhAK53Dvzq88Q1Ov0TEvMAySDPpIVjF1PWgUpy0H1uYggt4iwGiRSZYlWfl9ms_AcmgZ_uZMPPN2hNT9izwaspHc", "libraryTemplateTypes": [ "DOCUMENT" ] },
删除库模板
-
从响应正文复制 libraryDocumentID。
-
转到“删除 libraryDocuments”。
-
单击“oAuth Access-token”按钮。授权访问 - 自己、组或帐户的令牌。
-
将 libraryDocumentId 粘贴到“值”字段中。
-
单击立即试用。
模板已删除。您会收到以下错误代码:204
只能更新处于 Draft 状态的 Web 表单。
-
使用 post /widgets 创建小组件。
-
从 get/widgets 获取 widgetId。
-
使用 GET /widgets/{widgetId} 方法创建后,从响应标头中获取 Etag。
-
在 put /widgets/{widgetId} 下,使用源自 GET /widgets/{widgetId} 的 Etag。在“If-Match”参数下,输入 widgetId 和 widgetInfo。
{ "fileInfos": [ { "transientDocumentId": "******" } ], "name": "Widht_Name", "status": "DRAFT", "widgetParticipantSetInfo": { "memberInfos": [ { "email": "" } ], "role": "SIGNER" } }
-
用例示例
-
对正确的 x-api-user 进行 get/agreements 调用。
-
在响应正文中,找到要查找其签名 URL 的发送以供签名的协议,并记录协议 ID
-
使用从 get/agreements 调用收到的协议 ID 进行 get/agreements/{agreementId}/signingUrls 调用。
结果
输出将会返回签名者的电子邮件地址以及电子签名 URL。