移植说明

优质
小牛编辑
142浏览
2023-12-01

本文主要介绍拿到 OneNET 软件包后,需要做的移植工作。

OneNET 软件包已经将硬件平台相关的特性剥离出去,因此 OneNET 本身的移植工作非常少,如果不启用自动注册功能就不需要移植任何接口。

如果启用了自动注册,用户需要新建 onenet_port.c,并将文件添加至工程。onenet_port.c 主要是实现开启自动注册后,获取注册信息、获取设备信息和保存设备信息等功能。接口定义如下所示:

/* 检查是否已经注册 */
rt_bool_t onenet_port_is_registed(void);
/* 获取注册信息 */
rt_err_t onenet_port_get_register_info(char *dev_name, char *auth_info);
/* 保存设备信息 */
rt_err_t onenet_port_save_device_info(char *dev_id, char *api_key);
/* 获取设备信息 */
rt_err_t onenet_port_get_device_info(char *dev_id, char *api_key, char *auth_info);

获取注册信息

rt_err_t onenet_port_get_register_info(char *ds_name, char *auth_info);

开发者只需要在该接口内,实现注册信息的读取和拷贝即可。

onenet_port_get_register_info(char *dev_name, char *auth_info)
{
    /* 读取或生成设备名字和鉴权信息 */

    /* 将设备名字和鉴权信息分别拷贝到 dev_name 和 auth_info 中*/
}

保存设备信息

rt_err_t onenet_port_save_device_info(char *dev_id, char *api_key);

开发者只需要在该接口内,将注册返回的设备信息保存在设备里即可。

onenet_port_save_device_info(char *dev_id, char *api_key)
{
    /* 保存返回的 dev_id 和 api_key */

    /* 保存设备状态为已注册状态 */
}

检查是否已经注册

rt_bool_t onenet_port_is_registed(void);

开发者只需要在该接口内,返回本设备是否已经在 OneNET 平台注册即可。

onenet_port_is_registed(void)
{
    /* 读取并判断设备的注册状态 */

    /* 返回设备是否已经注册 */
}

获取设备信息

rt_err_t onenet_port_get_device_info(char *dev_id, char *api_key, char *auth_info);

开发者只需要在该接口内,读取并返回设备信息即可

onenet_port_get_device_info(char *dev_id, char *api_key, char *auth_info)
{
    /* 读取设备id,api_key和鉴权信息 */

    /* 将设备id,api_key和鉴权信息分别拷贝到 dev_id,api_key 和 auth_info 中*/
}