static void prv_instance_dump(lwm2m_object_t * objectP, uint16_t id) { int numData; lwm2m_tlv_t * dataArray; int size; uint8_t * buffer; int i; uint16_t res; numData = 0; res = objectP->readFunc(id, &numData, &dataArray, objectP); if (res != COAP_205_CONTENT) { printf("Error "); print_status(stdout, res); printf("\r\n"); return; } dump_tlv(stdout, numData, dataArray, 0); size = lwm2m_tlv_serialize(numData, dataArray, &buffer); printf("char objectTlv[%d] = {", size); for (i = 0 ; i < size ; i++) { printf("0x%02X, ", buffer[i]); } printf("\b\b};\r\n"); lwm2m_tlv_free(numData, dataArray); lwm2m_free(buffer); }
int main(int argc, char *argv[]) { lwm2m_tlv_t * tlvP; int size; int length; char * buffer; char buffer1[] = {0x03, 0x0A, 0xC1, 0x01, 0x14, 0x03, 0x0B, 0xC1, 0x01, 0x15, 0x03, 0x0C, 0xC1, 0x01, 0x16}; char buffer2[] = {0xC8, 0x00, 0x14, 0x4F, 0x70, 0x65, 0x6E, 0x20, 0x4D, 0x6F, 0x62, 0x69, 0x6C, 0x65, 0x20, 0x41, 0x6C, 0x6C, 0x69, 0x61, 0x6E, 0x63, 0x65, 0xC8, 0x01, 0x16, 0x4C, 0x69, 0x67, 0x68, 0x74, 0x77 , 0x65, 0x69, 0x67, 0x68, 0x74, 0x20, 0x4D, 0x32, 0x4D, 0x20, 0x43, 0x6C, 0x69, 0x65, 0x6E, 0x74 , 0xC8, 0x02, 0x09, 0x33, 0x34, 0x35, 0x30, 0x30, 0x30, 0x31, 0x32, 0x33, 0xC3, 0x03, 0x31, 0x2E , 0x30, 0x86, 0x06, 0x41, 0x00, 0x01, 0x41, 0x01, 0x05, 0x88, 0x07, 0x08, 0x42, 0x00, 0x0E, 0xD8 , 0x42, 0x01, 0x13, 0x88, 0x87, 0x08, 0x41, 0x00, 0x7D, 0x42, 0x01, 0x03, 0x84, 0xC1, 0x09, 0x64 , 0xC1, 0x0A, 0x0F, 0x83, 0x0B, 0x41, 0x00, 0x00, 0xC4, 0x0D, 0x51, 0x82, 0x42, 0x8F, 0xC6, 0x0E, 0x2B, 0x30, 0x32, 0x3A, 0x30, 0x30, 0xC1, 0x0F, 0x55}; printf("Buffer 1:\n"); decode(buffer1, sizeof(buffer1), 0); printf("\n\nBuffer 1 using lwm2m_tlv_t:\n"); size = lwm2m_tlv_parse(buffer1, sizeof(buffer1), &tlvP); dump_tlv(size, tlvP, 0); length = lwm2m_tlv_serialize(size, tlvP, &buffer); if (length != sizeof(buffer1)) { printf("\n\nSerialize Buffer 1 failed: %d bytes instead of %d\n", length, sizeof(buffer1)); } else if (memcmp(buffer, buffer1, length) != 0) { printf("\n\nSerialize Buffer 1 failed:\n"); prv_output_buffer(buffer, length); printf("\ninstead of:\n"); prv_output_buffer(buffer1, length); } else { printf("\n\nSerialize Buffer 1 OK\n"); } lwm2m_tlv_free(size, tlvP); printf("\n\n============\n\nBuffer 2: \r\r\n"); decode(buffer2, sizeof(buffer2), 0); printf("\n\nBuffer 2 using lwm2m_tlv_t: \r\r\n"); size = lwm2m_tlv_parse(buffer2, sizeof(buffer2), &tlvP); dump_tlv(size, tlvP, 0); length = lwm2m_tlv_serialize(size, tlvP, &buffer); if (length != sizeof(buffer2)) { printf("\n\nSerialize Buffer 2 failed: %d bytes instead of %d\n", length, sizeof(buffer2)); } else if (memcmp(buffer, buffer2, length) != 0) { printf("\n\nSerialize Buffer 2 failed:\n"); prv_output_buffer(buffer, length); printf("\ninstead of:\n"); prv_output_buffer(buffer2, length); } else { printf("\n\nSerialize Buffer 2 OK\n\n"); } lwm2m_tlv_free(size, tlvP); }
coap_status_t object_read(lwm2m_context_t * contextP, lwm2m_uri_t * uriP, char ** bufferP, int * lengthP) { coap_status_t result; lwm2m_object_t * targetP; lwm2m_tlv_t * tlvP = NULL; int size = 0; targetP = prv_find_object(contextP, uriP->objectId); if (NULL == targetP) return NOT_FOUND_4_04; if (NULL == targetP->readFunc) return METHOD_NOT_ALLOWED_4_05; if (targetP->instanceList == NULL) { // CDCC: Do not need to check the object instance for object which do not need register. // this is a single instance object if (targetP->needRegister && LWM2M_URI_IS_SET_INSTANCE(uriP) && (uriP->instanceId != 0)) { return COAP_404_NOT_FOUND; } } else { if (LWM2M_URI_IS_SET_INSTANCE(uriP)) { if (NULL == lwm2m_list_find(targetP->instanceList, uriP->instanceId)) { return COAP_404_NOT_FOUND; } } else { // multiple object instances read lwm2m_list_t * instanceP; int i; size = 0; for (instanceP = targetP->instanceList; instanceP != NULL ; instanceP = instanceP->next) { size++; } tlvP = lwm2m_tlv_new(size); if (tlvP == NULL) return COAP_500_INTERNAL_SERVER_ERROR; result = COAP_205_CONTENT; instanceP = targetP->instanceList; i = 0; while (instanceP != NULL && result == COAP_205_CONTENT) { result = targetP->readFunc(instanceP->id, (int*)&(tlvP[i].length), (lwm2m_tlv_t **)&(tlvP[i].value), targetP); tlvP[i].type = LWM2M_TYPE_OBJECT_INSTANCE; tlvP[i].id = instanceP->id; i++; instanceP = instanceP->next; } if (result == COAP_205_CONTENT) { *lengthP = lwm2m_tlv_serialize(size, tlvP, bufferP); if (*lengthP == 0) result = COAP_500_INTERNAL_SERVER_ERROR; } lwm2m_tlv_free(size, tlvP); return result; } } // single instance read if (LWM2M_URI_IS_SET_RESOURCE(uriP)) { size = 1; tlvP = lwm2m_tlv_new(size); if (tlvP == NULL) return COAP_500_INTERNAL_SERVER_ERROR; tlvP->type = LWM2M_TYPE_RESSOURCE; tlvP->flags = LWM2M_TLV_FLAG_TEXT_FORMAT; tlvP->id = uriP->resourceId; } result = targetP->readFunc(uriP->instanceId, &size, &tlvP, targetP); if (result == COAP_205_CONTENT) { if (size == 1 && tlvP->type == LWM2M_TYPE_RESSOURCE && (tlvP->flags && LWM2M_TLV_FLAG_TEXT_FORMAT) != 0 ) { *bufferP = (char *)malloc(tlvP->length); if (*bufferP == NULL) { result = COAP_500_INTERNAL_SERVER_ERROR; } else { memcpy(*bufferP, tlvP->value, tlvP->length); *lengthP = tlvP->length; } } else { *lengthP = lwm2m_tlv_serialize(size, tlvP, bufferP); if (*lengthP == 0) result = COAP_500_INTERNAL_SERVER_ERROR; } } lwm2m_tlv_free(size, tlvP); return result; }