9.9 KiB
## 任务相关
#### 校验任务参数
* 方法说明
校验输入参数中的 task_id 和 task_label 字段对应的数据是否在数据库中存在。
```python
async def check_task_param(param: str) -> bool
-
输入参数
其参数
param是 JSON 字符串,结构如下:
{
# 任务类型 id
"task_id": "12345",
# 任务名称
"task_label": "Ps2Ws"
}
-
输出参数
-
True,对应的任务数据在数据库中存在。
-
False,对应的任务数据在数据库中不存在,或task_id和task_label同时为空。
-
异常
本方法不抛出异常。
异步创建并运行一个任务
-
方法说明
本方法是非阻塞方法,将在脚本中创建一个线程,来执行天风任务的实例。
async def create_wind_task(param: str) -> str
-
输入参数
其参数
param是 JSON 字符串,结构如下:
{
# 任务类型 id
"task_id": "12345",
# 任务名称
"task_label": "Ps2Ws",
# 指定创建的任务实例的id
"task_record_id": "04d11f4f-d17c-4a41-9cf7-67de468035f9",
# 在天风任务中定义的参数
"input_params": "{\"fromSite\":\"PS-01\"}"
}
注意:task_id 和 task_label 两者必选其一。如果同时存在,将首选使用 task_id 字段。
注意,input_params 字段,是个 JSON 字符串。需要在脚本里将任务参数序列化为 JSON。
-
输出参数
JSON字符串
{
"code": 200, # 200表示成功 -1表示失败
"msg": "" # 提示信息
}
-
异常
本方法不抛出异常。
根据任务实例 ID 查询任务实例
-
方法说明
根据任务实例 ID 查询任务数据。
async def get_task_record_by_id(task_record_id: str) -> str
-
输入参数
task_record_id,str 类型,是任务实例的唯一 ID。
-
输出参数
-
如存在指定 ID 的任务实例,返回 JSON 格式的字符串。
{ # 任务实例id "id": "123", # 天风任务id "def_id": "6743", # 天风任务名 "def_label": "agvMove", # 任务实例状态(1000:运行中,1001:终止,1002:暂停,1003:结束,1004:异常结束,1005:重启异常,1006:异常中断) "status": 1000, # 任务创建时间 "created_on": "2022-02-12 11:23:12.0", # 任务结束时间 "ended_on": "2022-02-12 11:26:12.0", # 任务状态描述 "state_description": "物料搬运中", # 外部订单号 "out_order_no": "D6567812", # 机器人Id "agv_id": "" } -
如果不存在指定 ID 的任务实例,返回 "null"。
-
异常
本方法抛出异常。
根据外部单号查询任务实例列表
-
方法说明
根据外部单号查询任务实例列表。
async def get_task_record_by_agv_id(agv_id: str) -> str
-
输入参数
agv_id,str 类型,是机器人 ID。
-
输出参数(JSON 格式的字符串):
是 JSON 数组,包含查询到的任务实例数据。
[{
# 任务实例id
"id": "123",
# 天风任务id
"def_id": "6743",
# 天风任务名
"def_label": "agvMove",
# 任务实例状态(1000:运行中,1001:终止,1002:暂停,1003:结束,1004:异常结束, 1005:重启异常, 1006:异常中断)
"status": 1000,
# 任务创建时间
"created_on": "2022-02-12 11:23:12",
# 结束原因
"ended_reason": "运行结束",
# 任务结束时间
"ended_on": "2022-02-12 11:26:12",
# 任务状态描述
"state_description": "物料搬运中",
# 外部订单号
"out_order_no": "D6567812"
}]
如果不存在对应机器人的任务实例数据,返回 "[]"。
-
异常
本方法抛出异常。
任务封口
-
方法说明
将VWED任务系统中指定ID的任务封口。
async def mark_complete(task_id: str, auto_get_token: bool = True) -> Dict[str, Any]
-
输入参数
task_id,str 类型,VWED任务系统任务ID。 auto_get_token,bool 类型,是否自动获取登录token,默认True。
-
输出参数
返回字典类型,包含封口结果信息。
{
"success": True/False, # 封口是否成功
"message": "...", # 提示信息
"data": {...} # 封口结果数据(成功时)
}
-
异常
本方法不抛出异常。
校验任务实例ID是否存在
-
方法说明
校验任务实例id是否存在。
async def is_task_record_id_exist(task_record_id: str) -> bool
-
输入参数
task_record_id,str 类型,任务实例id。
-
输出参数
-
True,存在。
-
False,不存在。
-
异常
本方法会抛出异常。
校验任务名称是否存在
-
方法说明
校验任务名称是否存在。
async def is_task_label_exist(task_name: str) -> bool
-
输入参数
task_name,str 类型,任务名称。
-
输出参数
-
True,存在。
-
False,不存在。
-
异常
本方法会抛出异常。
根据查询条件获取任务实例
-
方法说明
根据参数的条件查询任务实例。
async def query_task_record(param: str) -> str
-
输入参数
其参数
param是 JSON 字符串,结构如下:
{
# 任务类型 id
"task_id": "",
# 任务实例 id
"task_record_id": "",
# 任务实例状态(1000:运行中,1001:终止,1002:暂停,1003:结束,1004:异常结束,1005:重启异常,1006:异常中断)
"status": "",
# 执行任务的机器人 id
"agv_id": "",
# 开始时间,需满足'yyyy-MM-dd HH:mm:ss'格式。如果该值非空,则返回创建日期大于该时间的任务实例
"start_date": "",
# 结束时间,需满足'yyyy-MM-dd HH:mm:ss'格式。如果该值非空,则返回创建日期小于该时间的任务实例
"end_date": ""
}
-
输出参数
是 JSON 数组,包含查询到的任务实例数据。
[{
# 任务实例id
"id": "123",
# 天风任务id
"def_id": "6743",
# 天风任务名
"def_label": "agvMove",
# 任务实例状态(1000:运行中,1001:终止,1002:暂停,1003:结束,1004:异常结束,1005:重启异常,1006:异常中断)
"status": 1000,
# 任务创建时间
"created_on": "2022-02-12 11:23:12",
# 结束原因
"ended_reason": "运行结束",
# 任务结束时间
"ended_on": "2022-02-12 11:26:12",
# 任务状态描述
"state_description": "物料搬运中",
# 外部订单号
"out_order_no": "D6567812"
}]
如果不存在满足条件的任务实例数据,返回 "[]"。
-
异常
本方法抛出异常。
接收并持久化第三方系统任务请求
- 方法说明
def save_task_log(log_param: str) -> None
-
输入参数
其参数
param是 JSON 字符串,结构如下:
{
# 任务类型 id
"task_id": "402883a27cda555f017cda6f55ad01b6",
# 任务实例 id
"task_record_id": "04d11f4f-d17c-4a41-9cf7-67de468035f9",
# 任务块 id
"block_id": 2,
# 日志信息
"message": "[RootBp]任务开始运行:task_id=402883a27cda555f017cda6f55ad01b6",
# 日志级别:1,正常运行;2,正常停止;3,异常中断。
"level": 1
}
-
输出参数
无
-
异常
本方法不抛出异常。
创建并运行一个任务
-
方法说明
本方法是阻塞方法,可以在脚本中创建一个天风任务的实例,并在任务执行结束后返回。
async def sync_create_wind_task(task_param: str) -> str
-
输入参数
其参数
param是 JSON 字符串,结构如下:
{
# 任务类型 id
"task_id": "12345",
# 任务名称
"task_label": "Ps2Ws",
# 指定创建的任务实例的id
"task_record_id": "04d11f4f-d17c-4a41-9cf7-67de468035f9",
# 在天风任务中定义的参数
"input_params": "{\"fromSite\":\"PS-01\"}"
}
注意,task_id 和 task_label 两者必选其一。如果同时存在,将首选使用 task_id 字段。
注意,input_params 字段,是个 JSON 字符串。需要在脚本里将任务参数序列化为 JSON。
-
输出参数
-
"9013",任务正常结束。
-
"9014",任务异常结束。
-
异常
本方法不抛出异常。
终止任务
-
方法说明
本方法是非阻塞方法,可用于终止多个正在运行的天风任务实例。
async def terminate_tasks(param: str) -> None
-
输入参数
其参数
param是 JSON 字符串,结构如下:
[
{
# 指定创建的任务实例的id
"task_record_id": "04d11f4f-d17c-4a41-9cf7-67de468035f9"
},
{
# 指定创建的任务实例的id
"task_record_id": "04d11f4f-d17c-4a41-9cf7-67de468035fe"
}
]
-
输出参数
无
-
异常
本方法会抛出异常。
查询子任务的任务id列表
-
方法说明
本方法是非阻塞方法,可根据父任务的id查询所有子任务的id。
async def get_children_task_record_id(record_id: str) -> str
-
输入参数
record_id,父任务的record_id。
-
输出参数
包含子任务id的 JSON 字符串,转换成 JSON 对象之后的示例数据如下所示:
[
"child-58d549a4-6d4c-4e01-a327-269e3d4c1863",
"child-sdsdfvsd-qrwe-4e02-a327-269eqwcfs863"
]
如果不存在满足条件的子任务,返回 "[]"。
-
异常
本方法会抛出异常。
设置任务优先级
-
方法说明
本方法是非阻塞方法,可根据设置任务的优先级。设置前会先验证任务记录ID是否存在。
async def set_task_priority(task_record_id: str, priority: int) -> None
-
输入参数
task_record_id,任务的实例id。
priority, 任务的优先级
-
输出参数
无
-
异常
本方法会抛出异常。当任务记录ID不存在时,会抛出包含详细错误信息的异常。