EnOS 报表工具 API 概述¶
EnOS报表工具是助力企业或组织实现零代码制作报表和管理日常报表任务的一站式、轻量级工具。报表工具提供简单的报表设计和管理体验,降低报表交付成本,提高报表管理效率。
通过报表工具API,应用开发人员可以进行报表模板的新建、更新、查询和删除操作,同时支持查询报表模板参数,并能够以多种格式生成报表,以满足跨领域、跨场景、跨部门的业务需求。关于报表工具 API 的完整接口列表及功能说明,参见 API 列表。
前提条件¶
确保已获取服务账号,且服务账号拥有调用该 API 的权限。更多信息,参见 获取 API 调用权限。
API 列表 
¶
你可以通过以下表格了解可以调用报表工具服务 API 执行哪些操作,每项操作对应的 URL,以及是否适用于 EnOS Cloud 和 EnOS Edge。
| 操作名称 | 描述 | URL | 适用于 EnOS Cloud | 适用于 EnOS Edge | 
|---|---|---|---|---|
| 新建报表模板 | /report-design-service/v1.0/report-file/create | √ | × | |
| 更新报表模板 | /report-design-service/v1.0/report-file/update | √ | × | |
| 查询单个报表模板 | /report-design-service/v1.0/report-file/query | √ | × | |
| 查询一系列报表模板 | /report-design-service/v1.0/report-file/list/query | √ | × | |
| 删除报表模板 | /report-design-service/v1.0/report-file/delete | √ | × | |
| 查询报表模板参数 | /report-design-service/v1.0/report-file/arguments/query | √ | × | |
| 生成报表 | /report-runtime-service/v1.0/report?action=create | √ | × | 
API 请求¶
报表工具 API 请求包含请求 URI 和请求消息头两部分。
请求 URI¶
METHOD https://{api-gateway}/{service-name}/{version}/{endpoint-url}?{action=<action>&{ }}
其中:
- METHOD:请求方法。例如:- GET或- POST。
- api-gateway:API 服务的网关地址。例如:- app-portal-xxx.enos-iot.com。可通过登入 EnOS 应用门户 > 开发者控制台,点击右上角的 帮助 > 环境信息 里 API 网关 中获取。
- service-name:API 服务名称。例如:- report-design-service或- report-runtime-service。
- version:API 版本。目前支持- v1.0。
- endpoint-url:资源和对资源的操作。例如:- report-file或- preview。
- action=<action>&:查询参数,如果有多个参数,使用- &作为分隔符。例如:- action=query&orgId=yourOrgId。
请求消息头(Header)¶
REST API 规范和 HTTP 规范所需的任何其他字段,绑定在请求消息头中。
常用的请求消息头为 Content-Type,代表数据提交方式,一般情况下它的值可设为 application / json; charset = UTF-8;若执行文件上传或其他表单提交,值设为 multipart / form-data; charset = UTF-8。
请求参数 (Body)¶
每个 API 接口中请求消息体的参数有所不同。以下表格介绍用来指定报表模板的请求参数。
| 名称 | 数据类型 | 描述 | 
|---|---|---|
| reportKey | String | 报表模板的自定义 ID,由用户指定。 | 
| reportId | String | 各版本报表模板的唯一 ID,新建或更新报表模板时由接口返回。该参数值随报表模板的变更而更新。 | 
| originalId | String | 报表模板的初始 ID,新建报表模板时由接口返回。该参数值不随模板的更新而改变。 | 
备注
在一个请求中同时使用以上参数时,系统按照如下优先级来查询: originalId (最高) > reportId > reportKey (最低)。
请求示例¶
#requestURL:
POST https://{api-gateway}/report-design-service/v1.0/report-file/update?orgId=yourOrgId
#requestbody:
{
    "fileUrl": "https://your.file.server.domain/yourTemplate.rpt",
    "originalId": "ddaa91a6723c9d111758c1cf52b14d8f",
    "reportKey": "yourReportKey",
    "type": "cus"
}
API 返回结果¶
API 返回 JSON 结构体,格式如下:
{
    "data": {data},
    "success": {true/false}
}
返回参数¶
对返回参数的详细说明如下:
| 名称 | 数据类型 | 描述 | 
|---|---|---|
| msg | String | 对状态码的解释和说明。成功为  | 
| code | Integer | API 请求状态码, | 
| data | Array 或 Object | API 响应返回结果集,数据类型包括:基本数据类型、复杂类型或数组。 | 
| success | String | 报表工具 API 返回  | 
返回码 
对所有返回码的详细说明如下:
| Code | Message | 描述 | 
|---|---|---|
| 0 | Success | 请求成功。 | 
| 93001 | Request parameters are non-compliance. Illegal parameters are { } | 请求中包含非法参数。 | 
| 93002 | Request body is non-compliance. Illegal request body is { } | 请求中包含非法消息体。 | 
| 93008 | Error occurred when downloading files from the remote storage. File path is { } | 无法从 blob 或 S3 中下载文件。 | 
| 93009 | Error occurred when parsing report arguments. | 无法解析参数。 | 
| 93010 | No available report or no permission to query reports. Report file IDs are :/query operation error.condition:{ } | 查询报表失败。 | 
| 93012 | Error occurred when generating reports. Download URL is { }, type is { }, category is { } | 生成报表失败。 | 
| 93013 | Found more than one rptdesign files in zip folder. Files are { } | ZIP 文件中包含多个 rptdesign 文件。 | 
| 93014 | No rptdesign found: neither a single file nor a zip file is uploaded. | 无法找到合法的 rptdesign 文件。 | 
| 93015 | zip file is broken | ZIP 文件已损坏。 | 
| 93016 | rptdesign file is not compliance: the mime type must be XML while the current mime type is { } | 检测到非法的 rptdesign 文件。 | 
| 93017 | Error occurred when processing report parameters, msg : { }/rptdesign file contains sensitive string | 生成报表过程中检测到不正确的报表参数。 | 
| 93018 | Render report exception, report file name : { } , render type : {}, locale { } | 生成报表过程中渲染报表失败。 | 
| 93028 | Report key is in use: report Key { } , type { } , category { } | 报表模板 ID 已存在。 | 
| 93029 | No available records found from database, query criteria are { } , we expected at least { } | 当前条件下无查询结果。 | 
| 93070 | Error occurred when uploading files to remote storage. File path is { } | 无法将文件上传至 blob 或 S3。 | 
| 93071 | Error occurred when uploading files, type : { } , category : { } , file name : { } | 上传文件失败。 | 
| 93072 | Failed to initialize report context | 报表初始化失败。 | 
| 93074 | Could not find the authority rptdesign, condition { }, orgId{ } | 无法找到符合条件的 rptdesign 文件。 | 
返回示例¶
返回成功示例。
{
    "msg": "OK",
    "code": 0,
    "data": {
        "reportId": "002443f7b9a513b834b187999c6d8855",
        "originalId": "ddaa91a6723c9d111758c1cf52b14d8f",
        "reportKey":"yourReportKey"
    }
}
返回失败示例。
{
    "msg": "Operation template error. operation type is UPDATE",
    "code": 93033,
    "success": false
}