From 28a03e3dfc0c10519f59bf04846db264e523f1e4 Mon Sep 17 00:00:00 2001 From: Daniel Adam Date: Tue, 27 Jun 2023 10:34:00 +0200 Subject: [PATCH] api/cloud: fix coverity issues 319236, 319242: Unchecked return value --- api/cloud/oc_cloud_resource.c | 33 ++++--- python/oc_python.c | 163 +++++++++++++++++----------------- 2 files changed, 102 insertions(+), 94 deletions(-) diff --git a/api/cloud/oc_cloud_resource.c b/api/cloud/oc_cloud_resource.c index 49fb89ed11..44a362b056 100644 --- a/api/cloud/oc_cloud_resource.c +++ b/api/cloud/oc_cloud_resource.c @@ -117,27 +117,34 @@ cloud_update_from_request(oc_cloud_context_t *ctx, const oc_request_t *request) cloud_conf_update_t data; memset(&data, 0, sizeof(data)); - char *access_token; + char *access_token = NULL; bool has_at = oc_rep_get_string(request->request_payload, OC_RSRVD_ACCESSTOKEN, &access_token, &data.access_token_len); - data.access_token = access_token; + if (has_at) { + data.access_token = access_token; + } - char *auth_provider; - oc_rep_get_string(request->request_payload, OC_RSRVD_AUTHPROVIDER, - &auth_provider, &data.auth_provider_len); - data.auth_provider = auth_provider; + char *auth_provider = NULL; + if (oc_rep_get_string(request->request_payload, OC_RSRVD_AUTHPROVIDER, + &auth_provider, &data.auth_provider_len)) { + data.auth_provider = auth_provider; + } - char *ci_server; + char *ci_server = NULL; bool has_cis = oc_rep_get_string(request->request_payload, OC_RSRVD_CISERVER, &ci_server, &data.ci_server_len); - data.ci_server = ci_server; + if (has_cis) { + data.ci_server = ci_server; + } // OCF 2.0 spec version added sid property. - char *sid; + char *sid = NULL; bool has_sid = oc_rep_get_string(request->request_payload, OC_RSRVD_SERVERID, &sid, &data.sid_len); - data.sid = sid; + if (has_sid) { + data.sid = sid; + } if (has_cis && (data.ci_server_len == 0 || (has_at && has_sid))) { cloud_update_by_resource(ctx, &data); @@ -173,9 +180,9 @@ post_cloud(oc_request_t *request, oc_interface_mask_t interface, // char *cis; size_t cis_len = 0; - oc_rep_get_string(request->request_payload, OC_RSRVD_CISERVER, &cis, - &cis_len); - if (cis_len == 0) { + if (oc_rep_get_string(request->request_payload, OC_RSRVD_CISERVER, &cis, + &cis_len) && + cis_len == 0) { request_invalid_in_state = false; } } diff --git a/python/oc_python.c b/python/oc_python.c index f1405c0836..764e1344ae 100644 --- a/python/oc_python.c +++ b/python/oc_python.c @@ -1888,95 +1888,96 @@ resource_discovery(const char *anchor, const char *uri, oc_string_array_t types, (void)bm; (void)types; (void)endpoint; - char strtypes[200] = " "; - char strinterfaces[200] = " "; + + if (uri == NULL) { + OC_PRINTF("[C]\nERROR DISCOVERING RESOURCES\n"); + cb_result = false; + return OC_STOP_DISCOVERY; + } + char json[1024] = ""; + strcat(json, "{\"uri\" : \""); + strcat(json, uri); + strcat(json, "\","); - if (uri) { - strcat(json, "{\"uri\" : \""); - strcat(json, uri); - strcat(json, "\","); - - strcat(json, "\"types\": ["); - int array_size = (int)oc_string_array_get_allocated_size(types); - for (int i = 0; i < array_size; i++) { - const char *t = oc_string_array_get_item(types, i); - strcat(strtypes, "\""); - strcat(strtypes, t); - strcat(strtypes, "\""); - if (i < array_size - 1) { - strcat(strtypes, ","); - } + char strtypes[200] = " "; + strcat(json, "\"types\": ["); + int array_size = (int)oc_string_array_get_allocated_size(types); + for (int i = 0; i < array_size; i++) { + const char *t = oc_string_array_get_item(types, i); + strcat(strtypes, "\""); + strcat(strtypes, t); + strcat(strtypes, "\""); + if (i < array_size - 1) { + strcat(strtypes, ","); } - strcat(json, strtypes); - strcat(json, "],"); + } + strcat(json, strtypes); + strcat(json, "],"); - strcat(json, "\"if\": ["); - bool comma = false; + strcat(json, "\"if\": ["); + bool comma = false; - // OC_PRINTF (" %d", if) - if ((iface_mask & OC_IF_BASELINE) == OC_IF_BASELINE) { - strcat(strinterfaces, "\"oic.r.baseline\""); - comma = true; - } - if ((iface_mask & OC_IF_RW) == OC_IF_RW) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.rw\""); - comma = true; - } - if ((iface_mask & OC_IF_R) == OC_IF_R) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.r\""); - comma = true; - } - if ((iface_mask & OC_IF_S) == OC_IF_S) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.s\""); - comma = true; - } - if ((iface_mask & OC_IF_A) == OC_IF_A) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.a\""); - comma = true; - } - if ((iface_mask & OC_IF_CREATE) == OC_IF_CREATE) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.create\""); - comma = true; - } - if ((iface_mask & OC_IF_LL) == OC_IF_LL) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.ll\""); - comma = true; - } - if ((iface_mask & OC_IF_B) == OC_IF_B) { - if (comma) - strcat(strinterfaces, ","); - strcat(strinterfaces, "\"oic.r.b\""); - } - strcat(json, strinterfaces); - strcat(json, "]"); - strcat(json, "}"); - - // OC_PRINTF("[C]anchor %s, uri : %s\n", anchor, uri); - inform_resource_python(anchor, uri, strtypes, json); - if (!more) { - OC_PRINTF("[C]----End of discovery response---\n"); - cb_result = true; - return OC_STOP_DISCOVERY; + char strinterfaces[200] = " "; + // OC_PRINTF (" %d", if) + if ((iface_mask & OC_IF_BASELINE) == OC_IF_BASELINE) { + strcat(strinterfaces, "\"oic.r.baseline\""); + comma = true; + } + if ((iface_mask & OC_IF_RW) == OC_IF_RW) { + if (comma) { + strcat(strinterfaces, ","); } - return OC_CONTINUE_DISCOVERY; - } else { - OC_PRINTF("[C]\nERROR DISCOVERING RESOURCES\n"); - cb_result = false; + strcat(strinterfaces, "\"oic.r.rw\""); + comma = true; + } + if ((iface_mask & OC_IF_R) == OC_IF_R) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.r\""); + comma = true; + } + if ((iface_mask & OC_IF_S) == OC_IF_S) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.s\""); + comma = true; + } + if ((iface_mask & OC_IF_A) == OC_IF_A) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.a\""); + comma = true; + } + if ((iface_mask & OC_IF_CREATE) == OC_IF_CREATE) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.create\""); + comma = true; + } + if ((iface_mask & OC_IF_LL) == OC_IF_LL) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.ll\""); + comma = true; + } + if ((iface_mask & OC_IF_B) == OC_IF_B) { + if (comma) + strcat(strinterfaces, ","); + strcat(strinterfaces, "\"oic.r.b\""); + } + strcat(json, strinterfaces); + strcat(json, "]"); + strcat(json, "}"); + + // OC_PRINTF("[C]anchor %s, uri : %s\n", anchor, uri); + inform_resource_python(anchor, uri, strtypes, json); + if (!more) { + OC_PRINTF("[C]----End of discovery response---\n"); + cb_result = true; return OC_STOP_DISCOVERY; } + return OC_CONTINUE_DISCOVERY; } void