
1. qcloud has a great revolution, the protocol has been changed to implement data template, so the old TencentCloud_SDK developed by us will not work fine now(mqtt still works, but data template will not works fine for recently created product/devices). 2. I merge the official qlcoud sdk(include both the iot-hub and iot-explorer sdk) into the componet/conectivity to support new protocol of data template 3. iot-hub sdk, supply the fundamental iot protocol(like mqtt coap, etc.) iot-explorer sdk, supply the high level service like data template based on mqtt 4. To know how it works, see qcloud_iot_explorer_sdk_data_template、qcloud_iot_hub_sdk_mqtt example(keil project in board\TencentOS_tiny_EVB_MX_Plus\KEIL\qcloud_iot_explorer_sdk_data_template and board\TencentOS_tiny_EVB_MX_Plus\KEIL\qcloud_iot_hub_sdk_mqtt)
192 lines
5.8 KiB
C
192 lines
5.8 KiB
C
/*
|
|
* Tencent is pleased to support the open source community by making IoT Hub available.
|
|
* Copyright (C) 2016 THL A29 Limited, a Tencent company. All rights reserved.
|
|
|
|
* Licensed under the MIT License (the "License"); you may not use this file except in
|
|
* compliance with the License. You may obtain a copy of the License at
|
|
* http://opensource.org/licenses/MIT
|
|
|
|
* Unless required by applicable law or agreed to in writing, software distributed under the License is
|
|
* distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
* either express or implied. See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <stdbool.h>
|
|
#include <string.h>
|
|
|
|
#include "qcloud_iot_export.h"
|
|
#include "qcloud_iot_import.h"
|
|
|
|
#ifdef AUTH_MODE_CERT
|
|
static char sg_cert_file[PATH_MAX + 1]; // full path of device cert file
|
|
static char sg_key_file[PATH_MAX + 1]; // full path of device key file
|
|
#endif
|
|
|
|
static DeviceInfo sg_devInfo;
|
|
|
|
|
|
void response_message_callback(void* coap_message, void* userContext)
|
|
{
|
|
int ret_code = IOT_COAP_GetMessageCode(coap_message);
|
|
switch (ret_code) {
|
|
case COAP_EVENT_RECEIVE_ACK:
|
|
Log_i("message received ACK, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
case COAP_EVENT_RECEIVE_RESPCONTENT:
|
|
{
|
|
char* payload = NULL;
|
|
int payload_len = 0;
|
|
int ret = -1;
|
|
ret = IOT_COAP_GetMessagePayload(coap_message, &payload, &payload_len);
|
|
if (ret == QCLOUD_RET_SUCCESS) {
|
|
Log_i("message received response, content: %s", payload);
|
|
}
|
|
else {
|
|
Log_e("message received response, content error.");
|
|
}
|
|
}
|
|
|
|
break;
|
|
case COAP_EVENT_UNAUTHORIZED:
|
|
Log_i("coap client auth token expired or invalid, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
case COAP_EVENT_FORBIDDEN:
|
|
Log_i("coap URI is invalid for this device, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
case COAP_EVENT_INTERNAL_SERVER_ERROR:
|
|
Log_i("coap server internal error, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
case COAP_EVENT_ACK_TIMEOUT:
|
|
Log_i("message receive ACK timeout, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
case COAP_EVENT_SEPRESP_TIMEOUT:
|
|
Log_i("message received ACK but receive response timeout, msgid: %d", IOT_COAP_GetMessageId(coap_message));
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
void event_handler(void *pcontext, CoAPEventMessage *message)
|
|
{
|
|
switch (message->event_type) {
|
|
case COAP_EVENT_RECEIVE_ACK:
|
|
Log_i("message received ACK, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
case COAP_EVENT_RECEIVE_RESPCONTENT:
|
|
Log_i("message received response, content: %s", IOT_COAP_GetMessageId(message->message));
|
|
break;
|
|
case COAP_EVENT_UNAUTHORIZED:
|
|
Log_i("coap client auth token expired or invalid, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
case COAP_EVENT_FORBIDDEN:
|
|
Log_i("coap URI is invalid for this device, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
case COAP_EVENT_INTERNAL_SERVER_ERROR:
|
|
Log_i("coap server internal error, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
case COAP_EVENT_ACK_TIMEOUT:
|
|
Log_i("message receive ACK timeout, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
case COAP_EVENT_SEPRESP_TIMEOUT:
|
|
Log_i("message received ACK but receive response timeout, msgid: %d", (unsigned)(uintptr_t)message->message);
|
|
break;
|
|
default:
|
|
Log_e("unrecogonized event type: %d", message->event_type);
|
|
break;
|
|
}
|
|
}
|
|
|
|
static int _setup_connect_init_params(CoAPInitParams* initParams)
|
|
{
|
|
int ret;
|
|
|
|
ret = HAL_GetDevInfo((void *)&sg_devInfo);
|
|
if(QCLOUD_RET_SUCCESS != ret){
|
|
return ret;
|
|
}
|
|
|
|
initParams->device_name = sg_devInfo.device_name;
|
|
initParams->product_id = sg_devInfo.product_id;
|
|
|
|
#ifdef AUTH_MODE_CERT
|
|
char certs_dir[PATH_MAX + 1] = "certs";
|
|
char current_path[PATH_MAX + 1];
|
|
char *cwd = getcwd(current_path, sizeof(current_path));
|
|
if (cwd == NULL)
|
|
{
|
|
Log_e("getcwd return NULL");
|
|
return QCLOUD_ERR_FAILURE;
|
|
}
|
|
sprintf(sg_cert_file, "%s/%s/%s", current_path, certs_dir, sg_devInfo.dev_cert_file_name);
|
|
sprintf(sg_key_file, "%s/%s/%s", current_path, certs_dir, sg_devInfo.dev_key_file_name);
|
|
|
|
initParams->cert_file = sg_cert_file;
|
|
initParams->key_file = sg_key_file;
|
|
#else
|
|
initParams->device_secret = sg_devInfo.device_secret;
|
|
#endif
|
|
|
|
initParams->command_timeout = QCLOUD_IOT_MQTT_COMMAND_TIMEOUT;
|
|
initParams->event_handle.h_fp = event_handler;
|
|
initParams->max_retry_count = 3;
|
|
|
|
|
|
return QCLOUD_RET_SUCCESS;
|
|
}
|
|
|
|
|
|
int coap_basic_thread(void)
|
|
{
|
|
int rc = QCLOUD_RET_SUCCESS;
|
|
|
|
IOT_Log_Set_Level(eLOG_DEBUG);
|
|
|
|
CoAPInitParams init_params = DEFAULT_COAPINIT_PARAMS;
|
|
rc = _setup_connect_init_params(&init_params);
|
|
if (rc != QCLOUD_RET_SUCCESS) {
|
|
Log_e("init params err,rc=%d", rc);
|
|
return rc;
|
|
}
|
|
|
|
void *coap_client = IOT_COAP_Construct(&init_params);
|
|
if (coap_client == NULL) {
|
|
Log_e("COAP Client construct failed.");
|
|
return QCLOUD_ERR_FAILURE;
|
|
}
|
|
|
|
do {
|
|
SendMsgParams send_params = DEFAULT_SENDMSG_PARAMS;
|
|
send_params.pay_load = "{\"name\":\"hello world\"}";
|
|
send_params.pay_load_len = strlen("{\"name\":\"hello world\"}");
|
|
send_params.resp_callback = response_message_callback;
|
|
|
|
char topicName[128] = "";
|
|
sprintf(topicName, "%s/%s/data", sg_devInfo.product_id, sg_devInfo.device_name);
|
|
Log_i("topic name is %s", topicName);
|
|
|
|
rc = IOT_COAP_SendMessage(coap_client, topicName, &send_params);
|
|
if (rc < 0) {
|
|
Log_e("client publish topic failed :%d.", rc);
|
|
}
|
|
else {
|
|
Log_d("client topic has been sent, msg_id: %d", rc);
|
|
}
|
|
|
|
rc = IOT_COAP_Yield(coap_client, 200);
|
|
|
|
if (rc != QCLOUD_RET_SUCCESS){
|
|
Log_e("exit with error: %d", rc);
|
|
break;
|
|
}
|
|
} while (1);
|
|
|
|
IOT_COAP_Destroy(&coap_client);
|
|
|
|
return QCLOUD_RET_SUCCESS;
|
|
}
|