电子签名服务和云平台整合管理合同

1、概要

电子签名技术现在越来越普及,很多公司已应用电子合同。主要是因为纸张既不易保存,也不易查找,已不再作为管理合同的唯一方式。
kintone作为非常易于扩展的paas平台,自然也是可以非常简单的接入任何电子签名系统。
今天我们就以电子牵平台作为范例给大家介绍如何接入外部电子签名系统。

2、关于电子牵

电子牵是国内知名互联网企业字节跳动子公司巨量引擎下推出的电子签名服务。累计已有20w+中小企业和个人使用。

同时他们提供了完整的api,通过它,我们就能在kintone上完成一整套电子合同签名流程。

电子牵api文档:Docs

3、功能简要

以往用户常常使用kintone来做电子合同的管理,但是这些合同依然需要再手动打印成纸质合同,然后和对方进行签署并保存。
现在通过和电子牵的对接,这些电子合同将直接附带上电子签名,然后生成法律效应,完全可以抛弃纸质合同,直接用kintone来管理它们。

4、流程说明

  • 签署双方需要完成在电子牵上的认证及绑定信息

  • 通过kintone的合同管理来发起包括合同上传,撤销,发起签署,归档等操作

  • 将这些有效数据同步到电子牵平台

  • 发起短信及邮件通知到签署双方

  • 签署双方在电子牵的页面完成签署操作

  • 签署成功后,电子牵平台会自动发起回调到kintone平台,更新合同的所有签署信息

对于合同管理者来说:所有操作都只需在kintone完成,无需打开电子牵页面。

而对于需要签署的外部用户或者企业来说:所有的认证及签署都能在电子牵端完成。无需拥有或登录kintone平台。这样既保证了kintone系统的安全,又让用户无担忧的完成签署过程 。

电子牵时序图:

电子签名服务和云平台整合管理合同_第1张图片

下面我们就来结合kintone和电子牵来开发一个demo程序(本示例程序使用nodejs作为服务端语言开发)

请提前准备

  • 电子牵token:appCode,appSecret等用来调用电子牵的api

  • 邮件服务器:用来发送邮件通知

  • 短信接口:用来发送短信通知 

5、开发

因为这里涉及到了很多接口,包括文件上传等,同时上传到电子牵都需要添加签名,如果在客户端处理,会暴露签名密钥等安全问题,同时还有很多复杂的逻辑处理及回调处理。所以,认证和合同管理这两个应用我们都不是直接在kintone上调用电子牵的服务器,而是再架设了一个服务端中间件来处理这些操作。

服务端中间件的功能:

  • 提供kintone请求的接口:处理来自kintone的请求,并转发到电子牵平台。

  • 提供电子牵的回调接口:处理来自电子牵平台的回调请求(认证成功,签署成功等)。

  • 向用户发起签署的短信及邮件通知。

1)认证

通过电子牵的时序图我们知道,我们首先要对签署双方进行验证,并且绑定。

这边做了一个简单的kintone端到电子牵端的认证应用,来完成这电子牵平台的认证。

电子签名服务和云平台整合管理合同_第2张图片 

我们通过中间服务器,将kintone发起的认证请求转发到电子牵的“申请个人认证链接”接口,成功后就会返回适用于该用户的认证地址,同时会将这个认证链接通过短信及邮件发送给用户。

接下来只要用户完成认证后,就能实现和电子牵的绑定。中间服务器的认证回调接口会去kintone更新这条记录的认证状态。

注意:

电子牵的用户签署页面暂时只支持手机验证,因为需要用到人脸识别,上传身份信息等,建议在邮件中加入二维码链接,来方便用户使用。

服务端的代码片段示例:开发者网站代码查看

 2)合同管理

电子签名服务和云平台整合管理合同_第3张图片

3)kintone端的自定义开发

功能:

  • 用户在kintone上发起合同上传,合同撤销,发起签署,合同归档等请求到中间服务器

  • 通过当前状态字段,禁用非当前状态能执行的功能,防止误操作

 电子签名服务和云平台整合管理合同_第4张图片

4)服务端中间件的开发

实现上传,撤销,签署,归档等所有电子牵接口

上传:

  • 上传分为文件上传模版上传

  • 文件上传是直接上传待签名的完整合同,而模版上传是将模版合同和合同数据一起传送给电子牵。

  • 这边使用的是文件上传,大家可以根据自己的实际需求来判断使用哪种方式来进行合同的上传。

签署:

  • 签署文件需要定义签名坐标或者关键字,这样用户拿到的签署页面会在默认的坐标或者关键字位置添加签名。
    在自动签署中是必须定义好的。而手动签署的话,用户可以根据参数选择是否调整签名位置。

  • 如果是企业自身,可以实现自动签署功能,来简化签署步骤。

  • 签署接口发起后,向签署双方发起短信邮件通知。

撤销:

  • 如果双方都没有进行签署操作,此时可以发起撤销操作,来中断此次合同的签署。

  • 撤销后kintone上的合同对应电子牵平台的transcode将重置。

  • 撤销后,可以重新上传合同文件,并且更新新的transcode。

归档:

  • 只有所有签署方都完成签署后,才能发起归档操作。

  • 归档后的合同,合同将生效,同时无法继续添加签署方,无法对合同做任何修改。

签署功能的代码片段:开发者网站代码查看

 

因为篇幅的关系,这边不对代码做太多的演示,具体我们将代码开源,有兴趣的可以在github上查看:

kintone-samples/sample-electronic-contract-CN (github.com)

应用方面的演示可以联系我们的产品部门,可以提供完整的演示环境。

注意事项

直接使用此处提供的程序范例的情况,才望子不予以保证程序的正常运行。

才望子不提供对程序范例的技术支持。

 

你可能感兴趣的:(PaaS平台,云服务,kintone,电子合同,电子签名,前端,javascript)