Webhook 
功能介绍 
草料将【动态数据】以JSON格式推送到指定接口URL,将数据传输到另一个系统,实现消息提醒和业务对接。 这个地址需要 允许公网访问。你的服务器需在5s内返回200状态值作为应答;应答异常最多重试5次(15s/1m/4m/16m/1h)
当前只支持表单数据推送,包含新提交表单数据、修改表单数据、表单审核结果、标记处理进度推送
应用场景 
1. 连接第三方应用,实现群消息推送,表格数据汇总 
通过腾讯轻联(腾讯云推出的"应用连接器"),将草料二维码和其他应用/服务进行连接。 实现如:数据群消息推送、数据二次分析、对接CRM系统、智能AI等功能。以此打破数据孤岛,让数据发挥价值。了解详情
2. 对接自有系统 
将扫码收集数据等功能在草料平台实现,再通过API与企业系统的流程进行对接,企业即可在保留原有系统的前提下,以极低的成本应用草料功能。

操作流程 
可以在表单设置页面选择数据API,添加推送地址,
也可以在数据API功能页面添加推送地址后选择表单推送。
1. 表单设置页 
表单设置页中,选择【数据API】,填写名称和推送的地址,点保存完成设置。 *注意:该设置为表单全局设置,关联此表单的所有码上生效。


2. 数据API功能页 
进入后台 【数据管理】-【数据API】 - 【开通webhook】 填写推送数据和选择需要推送的表单。已开通过的情况下,点击配置,添加更多推送。 *注意:在使用腾讯轻联时,因为在腾讯轻联中无法选择表单,所以这里只能选择一个表单或者直接在表单中设置


推送数据类型 
当前仅支持表单记录的数据推送。但当二维码是批量子码时,除表单记录字段外,还会将模板名称和可变内容一起推送过去。还不支持仅推送子码可变内容
- 普通活码:推送表单记录
- 批量子码:推送表单记录+批量模板名称+子码可变内容
推送事件类型 
现在支持以下几种事件。
- 新提交表单数据
- 修改表单数据
- 表单审核结果推送
- 标记进度状态更新
推送格式说明 
推送方式 
POST
Content-Type: application/json格式 
草料的所有事件请求均遵循以下格式:
{
    "time": "2022-06-30 17:06:39",
    "event": "事件标识",
    "data": {}
}各字段解释如下: 
| 字段名 | 含义 | 类型 | 
|---|---|---|
| time | 事件的发生时间,采用+8区YYYY-mm-dd HH:ii:ss表示 | string | 
| event | 事件,事件枚举见事件类型章节 | string | 
| data | 数据,不同的事件拥有不同的格式,以具体事件的文档为准。 | object | 
事件类型标识 
| 事件 | 标识 | 
|---|---|
| 有新的表单数据提交 | FORM_DATA_SUBMIT | 
| 表单数据被编辑 | FORM_DATA_EDITED | 
| 表单数据被审核 | FORM_DATA_REVIEW | 
有新的表单数据提交 
表单事件暂时不会推送音频、视频、文件类型的数据
示例数据:
{
  "time": "2022-06-30 17:06:39",
  "event": "FORM_DATA_SUBMIT",
  "data": {
    "ref_data": {
      "created_at": "2022-06-30 17:06:39",
      "serial_number": "L1000001",
      "form": {
        "number": "D20",
        "name": "会议签到"
      },
      "submitter": {
        "name": "填写人A",
        "phone_number": "18888881111"
      },
      "review": {
        "state": "待审核",
        "time": "2022-06-30 17:06:39"
      },
      "process": {
        "state": "未处理",
        "time": "2022-06-30 17:06:39"
      },
      "fields": {
        "姓名": "草料",
        "手机": "18888648888",
        "微信名": "CHEN",
        "身份证号": "330200000000000000",
        "工号": "FBI100",
        "单选项": "是",
        "多选项": [
          "选项1",
          "选项3"
        ],
        "检查项": {
          "项目1": "是",
          "项目2": "否",
          "项目3": "无需填写",
          "项目4": ""
        }
      },
      "ref_qrcode": {
        "name": "测试二维码",
        "type": "CHILD",
        "code": "qAbCxZ",
        "template": {
          "name": "测试模板"
        },
        "fields": {
          "文本1填充位": "A",
          "文本2填充位": "B"
        },
        "state": {
          "状态组1": "异常",
          "状态组2": "正常"
        }
      }
    }
  }
}字段说明 
| 字段 | 描述 | 类型 | 
|---|---|---|
| time | 事件发生时间 | string | 
| event | 事件标识 | string | 
| data | 事件详情数据 | object | 
| data.ref_data | 事件中表单详情数据 | object | 
| data.ref_data.created_at | 填表时间 | string | 
| data.ref_data.serial_number | 记录编号 | string | 
| data.ref_data.web_url | 记录地址 | string | 
| data.ref_data.form | 表单信息 | object | 
| data.ref_data.form.number | 表单编号 | string | 
| data.ref_data.form.name | 表单名称 | string | 
| data.ref_data.submitter | 表单填写人信息 | object | 
| data.ref_data.submitter.name | 表单填写人名称 | string | 
| data.ref_data.submitter.phone_number | 表单填写人手机号 | string | 
| data.ref_data.review | 审核信息(仅开启审核功能存在) | object | 
| data.ref_data.review.state | 审核状态 审核中/审核通过/审核不通过 | string | 
| data.ref_data.review.time | 审核时间 | string | 
| data.ref_data.process | 闭环信息(仅开启闭环功能时存在) | object | 
| data.ref_data.process.state | 闭环处理状态 | string | 
| data.ref_data.process.time | 闭环处理时间 | string | 
| data.ref_data.fields | 表单字段(组件)信息 | map<string, any> | 
| data.ref_qrcode | 二维码信息 | object | 
| data.ref_qrcode.name | 二维码名称 | string | 
| data.ref_qrcode.type | 二维码类型 CHILD(子码)/NORMAL(普通活码) | string | 
| data.ref_qrcode.code | 码唯一标识 | string | 
| data.ref_qrcode.web_url | 码链接 | string | 
| data.ref_qrcode.template | 码模板信息(仅子码存在) | string | 
| data.ref_qrcode.template.name | 码模板名称 | string | 
| data.ref_qrcode.fields | 子码填充位信息(仅子码存在) | object | 
| data.ref_qrcode.state | 码状态信息 | map<string, string> | 
其中表单字段信息(data.ref_data.fields)和子码字段信息(data.ref_qrcode.fields)内均是key value形式的数据。key代表组件/填充位名称,value代表值。value的类型视该组件的类型决定。
表单数据被编辑 
事件标识为:FORM_DATA_EDITED 请求数据与 "有新的表单数据提交" 事件相同
表单数据被审核 
事件标识为:FORM_DATA_REVIEW 请求数据与 "有新的表单数据提交" 事件相同,可以通过data.ref_data.review.state字段获取审核结果
表单组件数据示例 
姓名、手机、微信名、身份证号、工号、车牌、性别、单行文本、多行文本、日期、时间、但选项、多级选择、编号
均以字符串格式推送。例如:
{
    "fields": {
        "姓名": "草料",
        "性别": "男",
        "多级选择": "浙江省/宁波市/海曙区"
    }
}检查项 
检查项是一个map<string, enum string>组成,例如:
{
    "fields": {
         "检查项A": "是",
         "检查项B": "否",
         "检查项C": "无需填写",
         "检查项D": "",
    }
}值的枚举如下 
| 值 | 含义 | 
|---|---|
| 是 | √ | 
| 否 | × | 
| 无需填写 | / | 
| 空字符串 | 
图片 
图片类型组件的值是一个对象,内容如下:
{
    "fields": {
         "图片": {
             "preview_url": "https://草料预览URL/",
              "urls": [
                "图片1下载链接",
                "图片2下载链接"
              ]
         }
    }
}常见问题 
1. webhook功能收费吗? 
草料的不同收费版本对应不同的每月推送动态数据条数:
- 免费版、基础版和高级版:1,000条/月;
- 旗舰版:20,000条/月;
- 行业专属版:推送条数不限。
具体查看草料版本推送说明
如果你对接了腾讯轻联,腾讯轻联有自己的收费规则,腾讯轻联的免费版:500个任务/月。具体查看腾讯轻联版本定价说明
2. 推送条数的计算方式 
每一次数据推送就算一条,有新表单记录、完成审核操作、变更闭环状态、还有修改表单记录。
3. 图片组件有两个地址,应该如何选择。 
每个图片组件我们提供了两个地址,xxx.urls和xxx.preview_urls两种。
- xxx.urls是图片地址,可以引用后直接显示图片(有多图时,不能直接显示),可用于群消息推送时,消息中直接显示图片,也可以用于AI识别;
- xxx.previews_urls是图片预览页地址,可以打开这个地址,浏览多个图片。应用时以超链接的方式进行展示,点击去浏览图片内容。
