1 //******************************************************************
3 // Copyright 2015 Intel Mobile Communications GmbH All Rights Reserved.
5 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
7 // Licensed under the Apache License, Version 2.0 (the "License");
8 // you may not use this file except in compliance with the License.
9 // You may obtain a copy of the License at
11 // http://www.apache.org/licenses/LICENSE-2.0
13 // Unless required by applicable law or agreed to in writing, software
14 // distributed under the License is distributed on an "AS IS" BASIS,
15 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 // See the License for the specific language governing permissions and
17 // limitations under the License.
19 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
21 #ifndef PAYLOAD_LOGGING_H_
22 #define PAYLOAD_LOGGING_H_
29 #ifndef __STDC_FORMAT_MACROS
30 #define __STDC_FORMAT_MACROS
32 #ifndef __STDC_LIMIT_MACROS
33 #define __STDC_LIMIT_MACROS
36 #include "rdpayload.h"
37 #include "oic_malloc.h"
38 #include "ocpayload.h"
45 // PL_TAG is made as generic predefined tag because of build problems in arduino for using logging
46 #define PL_TAG "PayloadLog"
49 #define OIC_LOG_PAYLOAD(level, payload) OCPayloadLog((level),(payload))
50 #define UUID_SIZE (16)
51 const char *convertTriggerEnumToString(OCPresenceTrigger trigger);
52 OCPresenceTrigger convertTriggerStringToEnum(const char * triggerStr);
54 #if defined(RD_CLIENT) || defined(RD_SERVER)
55 INLINE_API void OCTagsLog(const LogLevel level, const OCTagsPayload *tags)
59 if (tags->n.deviceName)
61 OIC_LOG_V(level, PL_TAG, " Device Name : %s ", tags->n.deviceName);
65 OIC_LOG_V(level, PL_TAG, " Device ID : %s ", tags->di.id);
67 OIC_LOG_V(level, PL_TAG, " lt : %" PRIu64 ,tags->ttl);
75 INLINE_API void OCLinksLog(const LogLevel level, const OCLinksPayload *links)
86 OIC_LOG_V(level, PL_TAG, " href: %s ",links->href);
88 OIC_LOG(level, PL_TAG, " RT: ");
89 OCStringLL *rt = links->rt;
94 OIC_LOG_V(level, PL_TAG, " %s", rt->value);
98 OIC_LOG(level, PL_TAG, " IF: ");
99 OCStringLL *itf = links->itf;
104 OIC_LOG_V(level, PL_TAG, " %s", itf->value);
108 OIC_LOG(level, PL_TAG, " MT: ");
109 OCStringLL *mt = links->type;
114 OIC_LOG_V(level, PL_TAG, " %s", mt->value);
120 OIC_LOG_V(level, PL_TAG, " %s", links->type->value);
122 OIC_LOG_V(level, PL_TAG, " INS: %d", links->ins);
123 OIC_LOG_V(level, PL_TAG, " TTL: %" PRIu64 , links->ttl);
124 OIC_LOG_V(level, PL_TAG, " P: %d", links->p);
127 OIC_LOG_V(level, PL_TAG, " REL: %s", links->rel);
131 OIC_LOG_V(level, PL_TAG, " TITLE: %s", links->title);
135 OIC_LOG_V(level, PL_TAG, " URI: %s", links->anchor);
142 //forward declaration required because function below is recursive
143 INLINE_API void OCPayloadLogRep(LogLevel level, OCRepPayload* payload);
145 INLINE_API void OCPayloadLogRepValues(LogLevel level, OCRepPayloadValue* val)
151 case OCREP_PROP_NULL:
152 OIC_LOG_V(level, PL_TAG, "%s: NULL", val->name);
155 OIC_LOG_V(level, PL_TAG, "%s(int):%zd", val->name, val->i);
157 case OCREP_PROP_DOUBLE:
158 OIC_LOG_V(level, PL_TAG, "%s(double):%f", val->name, val->d);
160 case OCREP_PROP_BOOL:
161 OIC_LOG_V(level, PL_TAG, "%s(bool):%s", val->name, val->b ? "true" : "false");
163 case OCREP_PROP_STRING:
164 OIC_LOG_V(level, PL_TAG, "%s(string):%s", val->name, val->str);
166 case OCREP_PROP_BYTE_STRING:
167 OIC_LOG_V(level, PL_TAG, "%s(binary):", val->name);
168 OIC_LOG_BUFFER(level, PL_TAG, val->ocByteStr.bytes, val->ocByteStr.len);
170 case OCREP_PROP_OBJECT:
171 OIC_LOG_V(level, PL_TAG, "%s(OCRep):%s", val->name, val->obj->uri);
172 OCPayloadLogRep(level, val->obj);
174 case OCREP_PROP_ARRAY:
176 size_t len = calcDimTotal(val->arr.dimensions);
178 OIC_LOG_V(level, PL_TAG, "%s(array): length = %zu", val->name, len);
180 for (size_t i = 0; i < len; i++)
182 OIC_LOG_V(level, PL_TAG, "%s[%zu]:", val->name, i);
183 char *indent = (char *)"\t\t";
185 switch(val->arr.type)
188 OIC_LOG_V(level, PL_TAG, "%s%zd", indent, val->arr.iArray[i]);
190 case OCREP_PROP_DOUBLE:
191 OIC_LOG_V(level, PL_TAG, "%s%f", indent, val->arr.dArray[i]);
193 case OCREP_PROP_BOOL:
194 OIC_LOG_V(level, PL_TAG, "%s%s", indent, val->arr.bArray[i] ? "true" : "false");
196 case OCREP_PROP_STRING:
197 OIC_LOG_V(level, PL_TAG, "%s%s", indent, val->arr.strArray[i]);
199 case OCREP_PROP_BYTE_STRING:
201 OCByteString* data = &val->arr.ocByteStrArray[i];
202 OIC_LOG_V(level, PL_TAG, "%s binary string, it's len = %zu, bytes:", indent, data->len);
203 OIC_LOG_BUFFER(level, PL_TAG, data->bytes, data->len);
206 case OCREP_PROP_OBJECT:
207 OCPayloadLogRep(level, val->arr.objArray[i]);
209 case OCREP_PROP_ARRAY: //Seems as nested arrays doesn't not supported in API
211 OIC_LOG_V(ERROR, PL_TAG, "%s <-- Unknown/unsupported array type!",
219 OIC_LOG_V(ERROR, PL_TAG, "%s <-- Unknown type!", val->name);
226 INLINE_API void OCPayloadLogRep(LogLevel level, OCRepPayload* payload)
228 OCRepPayload* rep = payload;
232 OCStringLL* strll = rep->types;
237 strll = rep->interfaces;
243 // TODO Finish Logging: Values
244 OCRepPayloadValue* val = rep->values;
246 OCPayloadLogRepValues(level, val);
253 INLINE_API void OCPayloadLogDiscovery(LogLevel level, OCDiscoveryPayload* payload)
255 OIC_LOG(level, PL_TAG, "Payload Type: Discovery");
257 while(payload && payload->resources)
259 OIC_LOG_V(level, PL_TAG, "\tSID: %s", payload->sid);
260 if (payload->baseURI)
262 OIC_LOG_V(level, PL_TAG, "\tBase URI:%s", payload->baseURI);
266 OIC_LOG_V(level, PL_TAG, "\tNAME: %s", payload->name);
270 OIC_LOG_V(level, PL_TAG, "\tURI: %s", payload->uri);
274 for (OCStringLL *strll = payload->type; strll; strll = strll->next)
276 OIC_LOG_V(level, PL_TAG, "\tResource Type: %s", strll->value);
279 OIC_LOG(level, PL_TAG, "\tInterface:");
280 for (OCStringLL *itf = payload->iface; itf; itf = itf->next)
282 OIC_LOG_V(level, PL_TAG, "\t\t%s", itf->value);
285 OCResourcePayload* res = payload->resources;
290 OIC_LOG_V(level, PL_TAG, "\tResource #%d", i);
291 OIC_LOG_V(level, PL_TAG, "\tURI:%s", res->uri);
292 OIC_LOG(level, PL_TAG, "\tResource Types:");
293 OCStringLL* strll = res->types;
296 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
299 OIC_LOG(level, PL_TAG, "\tInterfaces:");
300 strll = res->interfaces;
303 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
307 OIC_LOG_V(level, PL_TAG, "\tBitmap: %u", res->bitmap);
308 OIC_LOG_V(level, PL_TAG, "\tSecure?: %s", res->secure ? "true" : "false");
309 OIC_LOG_V(level, PL_TAG, "\tPort: %u", res->port);
310 OIC_LOG(level, PL_TAG, "");
314 payload = payload->next;
318 INLINE_API void OCPayloadLogDevice(LogLevel level, OCDevicePayload* payload)
320 OIC_LOG(level, PL_TAG, "Payload Type: Device");
321 OIC_LOG_V(level, PL_TAG, "\tSID:%s", payload->sid);
322 OIC_LOG_V(level, PL_TAG, "\tDevice Name:%s", payload->deviceName);
323 OIC_LOG_V(level, PL_TAG, "\tSpec Version:%s", payload->specVersion);
324 if (payload->dataModelVersions)
326 OIC_LOG(level, PL_TAG, "\tData Model Version:");
327 for (OCStringLL *strll = payload->dataModelVersions; strll; strll = strll->next)
329 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
334 OIC_LOG(level, PL_TAG, "\tResource Type:");
335 for (OCStringLL *strll = payload->types; strll; strll = strll->next)
337 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
340 if (payload->interfaces)
342 OIC_LOG(level, PL_TAG, "\tInterface:");
343 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
345 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
350 INLINE_API void OCPayloadLogPlatform(LogLevel level, OCPlatformPayload* payload)
352 OIC_LOG(level, PL_TAG, "Payload Type: Platform");
353 OIC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
354 OIC_LOG_V(level, PL_TAG, "\tPlatform ID:%s", payload->info.platformID);
355 OIC_LOG_V(level, PL_TAG, "\tMfg Name:%s", payload->info.manufacturerName);
356 OIC_LOG_V(level, PL_TAG, "\tMfg URL:%s", payload->info.manufacturerUrl);
357 OIC_LOG_V(level, PL_TAG, "\tModel Number:%s", payload->info.modelNumber);
358 OIC_LOG_V(level, PL_TAG, "\tDate of Mfg:%s", payload->info.dateOfManufacture);
359 OIC_LOG_V(level, PL_TAG, "\tPlatform Version:%s", payload->info.platformVersion);
360 OIC_LOG_V(level, PL_TAG, "\tOS Version:%s", payload->info.operatingSystemVersion);
361 OIC_LOG_V(level, PL_TAG, "\tHardware Version:%s", payload->info.hardwareVersion);
362 OIC_LOG_V(level, PL_TAG, "\tFirmware Version:%s", payload->info.firmwareVersion);
363 OIC_LOG_V(level, PL_TAG, "\tSupport URL:%s", payload->info.supportUrl);
364 OIC_LOG_V(level, PL_TAG, "\tSystem Time:%s", payload->info.systemTime);
368 OIC_LOG(level, PL_TAG, "\tResource Types:");
369 for (OCStringLL *strll = payload->rt; strll; strll = strll->next)
371 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
374 if (payload->interfaces)
376 OIC_LOG(level, PL_TAG, "\tResource Interfaces:");
377 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
379 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
384 INLINE_API void OCPayloadLogPresence(LogLevel level, OCPresencePayload* payload)
386 OIC_LOG(level, PL_TAG, "Payload Type: Presence");
387 OIC_LOG_V(level, PL_TAG, "\tSequence Number:%u", payload->sequenceNumber);
388 OIC_LOG_V(level, PL_TAG, "\tMax Age:%d", payload->maxAge);
389 OIC_LOG_V(level, PL_TAG, "\tTrigger:%s", convertTriggerEnumToString(payload->trigger));
390 OIC_LOG_V(level, PL_TAG, "\tResource Type:%s", payload->resourceType);
393 INLINE_API void OCPayloadLogSecurity(LogLevel level, OCSecurityPayload* payload)
395 size_t payloadSize = payload->payloadSize;
396 OIC_LOG(level, PL_TAG, "Payload Type: Security");
400 // Add a zero-character string terminator.
401 char *securityData = (char *)OICMalloc(payloadSize + 1);
405 memcpy(securityData, payload->securityData, payloadSize);
406 assert(securityData[payloadSize - 1] != '\0');
407 securityData[payloadSize] = '\0';
408 OIC_LOG_V(level, PL_TAG, "\tSecurity Data: %s", securityData);
409 OICFree(securityData);
414 #if defined(RD_CLIENT) || defined(RD_SERVER)
415 INLINE_API void OCRDPayloadLog(const LogLevel level, const OCRDPayload *payload)
422 if (payload->rdDiscovery)
424 OIC_LOG(level, PL_TAG, "RD Discovery");
425 OIC_LOG_V(level, PL_TAG, " Device Name : %s", payload->rdDiscovery->n.deviceName);
426 OIC_LOG_V(level, PL_TAG, " Device Identity : %s", payload->rdDiscovery->di.id);
427 OIC_LOG_V(level, PL_TAG, " Bias: %d", payload->rdDiscovery->sel);
429 if (payload->rdPublish)
431 OIC_LOG(level, PL_TAG, "RD Publish");
432 OCResourceCollectionPayload *rdPublish = payload->rdPublish;
433 OCTagsLog(level, rdPublish->tags);
434 OCLinksLog(level, rdPublish->setLinks);
438 INLINE_API void OCPayloadLog(LogLevel level, OCPayload* payload)
442 OIC_LOG(level, PL_TAG, "NULL Payload");
445 switch(payload->type)
447 case PAYLOAD_TYPE_REPRESENTATION:
448 OCPayloadLogRep(level, (OCRepPayload*)payload);
450 case PAYLOAD_TYPE_DISCOVERY:
451 OCPayloadLogDiscovery(level, (OCDiscoveryPayload*)payload);
453 case PAYLOAD_TYPE_DEVICE:
454 OCPayloadLogDevice(level, (OCDevicePayload*)payload);
456 case PAYLOAD_TYPE_PLATFORM:
457 OCPayloadLogPlatform(level, (OCPlatformPayload*)payload);
459 case PAYLOAD_TYPE_PRESENCE:
460 OCPayloadLogPresence(level, (OCPresencePayload*)payload);
462 case PAYLOAD_TYPE_SECURITY:
463 OCPayloadLogSecurity(level, (OCSecurityPayload*)payload);
465 #if defined(RD_CLIENT) || defined(RD_SERVER)
466 case PAYLOAD_TYPE_RD:
467 OCRDPayloadLog(level, (OCRDPayload*)payload);
471 OIC_LOG_V(level, PL_TAG, "Unknown Payload Type: %d", payload->type);
476 #define OIC_LOG_PAYLOAD(level, payload)