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"
44 // PL_TAG is made as generic predefined tag because of build problems in arduino for using logging
45 #define PL_TAG "PayloadLog"
48 #define OIC_LOG_PAYLOAD(level, payload) OCPayloadLog((level),(payload))
49 #define UUID_SIZE (16)
50 const char *convertTriggerEnumToString(OCPresenceTrigger trigger);
51 OCPresenceTrigger convertTriggerStringToEnum(const char * triggerStr);
53 #if defined(RD_CLIENT) || defined(RD_SERVER)
54 INLINE_API void OCTagsLog(const LogLevel level, const OCTagsPayload *tags)
58 if (tags->n.deviceName)
60 OIC_LOG_V(level, PL_TAG, " Device Name : %s ", tags->n.deviceName);
64 OIC_LOG_V(level, PL_TAG, " Device ID : %s ", tags->di.id);
66 OIC_LOG_V(level, PL_TAG, " lt : %" PRIu64 ,tags->ttl);
74 INLINE_API void OCLinksLog(const LogLevel level, const OCLinksPayload *links)
85 OIC_LOG_V(level, PL_TAG, " href: %s ",links->href);
87 OIC_LOG(level, PL_TAG, " RT: ");
88 OCStringLL *rt = links->rt;
93 OIC_LOG_V(level, PL_TAG, " %s", rt->value);
97 OIC_LOG(level, PL_TAG, " IF: ");
98 OCStringLL *itf = links->itf;
103 OIC_LOG_V(level, PL_TAG, " %s", itf->value);
107 OIC_LOG(level, PL_TAG, " MT: ");
108 OCStringLL *mt = links->type;
113 OIC_LOG_V(level, PL_TAG, " %s", mt->value);
119 OIC_LOG_V(level, PL_TAG, " %s", links->type->value);
121 OIC_LOG_V(level, PL_TAG, " INS: %d", links->ins);
122 OIC_LOG_V(level, PL_TAG, " TTL: %" PRIu64 , links->ttl);
123 OIC_LOG_V(level, PL_TAG, " P: %d", links->p);
126 OIC_LOG_V(level, PL_TAG, " REL: %s", links->rel);
130 OIC_LOG_V(level, PL_TAG, " TITLE: %s", links->title);
134 OIC_LOG_V(level, PL_TAG, " URI: %s", links->anchor);
140 INLINE_API void OCPayloadLogRep(LogLevel level, OCRepPayload* payload)
142 OIC_LOG(level, (PL_TAG), "Payload Type: Representation");
143 OCRepPayload* rep = payload;
147 OIC_LOG_V(level, PL_TAG, "\tResource #%d", i);
150 OIC_LOG_V(level, PL_TAG, "\tURI:%s", rep->uri);
153 OCStringLL* strll = rep->types;
156 OIC_LOG(level, PL_TAG, "\tResource Types:");
159 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
164 strll = rep->interfaces;
167 OIC_LOG(level, PL_TAG, "\tInterfaces:");
170 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
175 // TODO Finish Logging: Values
176 OCRepPayloadValue* val = rep->values;
177 OIC_LOG(level, PL_TAG, "\tValues:");
182 case OCREP_PROP_NULL:
183 OIC_LOG_V(level, PL_TAG, "\t\t%s: NULL", val->name);
186 OIC_LOG_V(level, PL_TAG, "\t\t%s(int):%zd", val->name, val->i);
188 case OCREP_PROP_DOUBLE:
189 OIC_LOG_V(level, PL_TAG, "\t\t%s(double):%f", val->name, val->d);
191 case OCREP_PROP_BOOL:
192 OIC_LOG_V(level, PL_TAG, "\t\t%s(bool):%s", val->name, val->b ? "true" : "false");
194 case OCREP_PROP_STRING:
195 OIC_LOG_V(level, PL_TAG, "\t\t%s(string):%s", val->name, val->str);
197 case OCREP_PROP_BYTE_STRING:
198 OIC_LOG_V(level, PL_TAG, "\t\t%s(binary):", val->name);
199 OIC_LOG_BUFFER(level, PL_TAG, val->ocByteStr.bytes, val->ocByteStr.len);
201 case OCREP_PROP_OBJECT:
202 OIC_LOG_V(level, PL_TAG, "\t\t%s(OCRep):%s", val->name, val->obj->uri);
203 OCPayloadLogRep(level, val->obj);
205 case OCREP_PROP_ARRAY:
206 switch(val->arr.type)
209 OIC_LOG_V(level, PL_TAG, "\t\t%s(int array):%zu x %zu x %zu",
211 val->arr.dimensions[0], val->arr.dimensions[1],
212 val->arr.dimensions[2]);
214 case OCREP_PROP_DOUBLE:
215 OIC_LOG_V(level, PL_TAG, "\t\t%s(double array):%zu x %zu x %zu",
217 val->arr.dimensions[0], val->arr.dimensions[1],
218 val->arr.dimensions[2]);
220 case OCREP_PROP_BOOL:
221 OIC_LOG_V(level, PL_TAG, "\t\t%s(bool array):%zu x %zu x %zu",
223 val->arr.dimensions[0], val->arr.dimensions[1],
224 val->arr.dimensions[2]);
226 case OCREP_PROP_STRING:
227 OIC_LOG_V(level, PL_TAG, "\t\t%s(string array):%zu x %zu x %zu",
229 val->arr.dimensions[0], val->arr.dimensions[1],
230 val->arr.dimensions[2]);
232 case OCREP_PROP_BYTE_STRING:
233 OIC_LOG_V(level, PL_TAG, "\t\t%s(byte array):%zu x %zu x %zu",
235 val->arr.dimensions[0], val->arr.dimensions[1],
236 val->arr.dimensions[2]);
238 case OCREP_PROP_OBJECT:
240 OIC_LOG_V(level, PL_TAG, "\t\t%s(OCRep array):%zu x %zu x %zu",
242 val->arr.dimensions[0], val->arr.dimensions[1],
243 val->arr.dimensions[2]);
246 if (val->arr.dimensions[0] > 0)
248 for (i = 0 ; i < val->arr.dimensions[0] ; i++)
250 OCPayloadLogRep(level, val->arr.objArray[i]);
256 OIC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown/unsupported array type!",
262 OIC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown type!", val->name);
274 INLINE_API void OCPayloadLogDiscovery(LogLevel level, OCDiscoveryPayload* payload)
276 OIC_LOG(level, PL_TAG, "Payload Type: Discovery");
278 while(payload && payload->resources)
280 OIC_LOG_V(level, PL_TAG, "\tSID: %s", payload->sid);
281 if (payload->baseURI)
283 OIC_LOG_V(level, PL_TAG, "\tBase URI:%s", payload->baseURI);
287 OIC_LOG_V(level, PL_TAG, "\tNAME: %s", payload->name);
291 OIC_LOG_V(level, PL_TAG, "\tURI: %s", payload->uri);
295 for (OCStringLL *strll = payload->type; strll; strll = strll->next)
297 OIC_LOG_V(level, PL_TAG, "\tResource Type: %s", strll->value);
300 OIC_LOG(level, PL_TAG, "\tInterface:");
301 for (OCStringLL *itf = payload->iface; itf; itf = itf->next)
303 OIC_LOG_V(level, PL_TAG, "\t\t%s", itf->value);
306 OCResourcePayload* res = payload->resources;
311 OIC_LOG_V(level, PL_TAG, "\tResource #%d", i);
312 OIC_LOG_V(level, PL_TAG, "\tURI:%s", res->uri);
313 OIC_LOG(level, PL_TAG, "\tResource Types:");
314 OCStringLL* strll = res->types;
317 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
320 OIC_LOG(level, PL_TAG, "\tInterfaces:");
321 strll = res->interfaces;
324 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
328 OIC_LOG_V(level, PL_TAG, "\tBitmap: %u", res->bitmap);
329 OIC_LOG_V(level, PL_TAG, "\tSecure?: %s", res->secure ? "true" : "false");
330 OIC_LOG_V(level, PL_TAG, "\tPort: %u", res->port);
331 OIC_LOG(level, PL_TAG, "");
335 payload = payload->next;
339 INLINE_API void OCPayloadLogDevice(LogLevel level, OCDevicePayload* payload)
341 OIC_LOG(level, PL_TAG, "Payload Type: Device");
342 OIC_LOG_V(level, PL_TAG, "\tSID:%s", payload->sid);
343 OIC_LOG_V(level, PL_TAG, "\tDevice Name:%s", payload->deviceName);
344 OIC_LOG_V(level, PL_TAG, "\tSpec Version:%s", payload->specVersion);
345 if (payload->dataModelVersions)
347 OIC_LOG(level, PL_TAG, "\tData Model Version:");
348 for (OCStringLL *strll = payload->dataModelVersions; strll; strll = strll->next)
350 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
355 OIC_LOG(level, PL_TAG, "\tResource Type:");
356 for (OCStringLL *strll = payload->types; strll; strll = strll->next)
358 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
361 if (payload->interfaces)
363 OIC_LOG(level, PL_TAG, "\tInterface:");
364 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
366 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
371 INLINE_API void OCPayloadLogPlatform(LogLevel level, OCPlatformPayload* payload)
373 OIC_LOG(level, PL_TAG, "Payload Type: Platform");
374 OIC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
375 OIC_LOG_V(level, PL_TAG, "\tPlatform ID:%s", payload->info.platformID);
376 OIC_LOG_V(level, PL_TAG, "\tMfg Name:%s", payload->info.manufacturerName);
377 OIC_LOG_V(level, PL_TAG, "\tMfg URL:%s", payload->info.manufacturerUrl);
378 OIC_LOG_V(level, PL_TAG, "\tModel Number:%s", payload->info.modelNumber);
379 OIC_LOG_V(level, PL_TAG, "\tDate of Mfg:%s", payload->info.dateOfManufacture);
380 OIC_LOG_V(level, PL_TAG, "\tPlatform Version:%s", payload->info.platformVersion);
381 OIC_LOG_V(level, PL_TAG, "\tOS Version:%s", payload->info.operatingSystemVersion);
382 OIC_LOG_V(level, PL_TAG, "\tHardware Version:%s", payload->info.hardwareVersion);
383 OIC_LOG_V(level, PL_TAG, "\tFirmware Version:%s", payload->info.firmwareVersion);
384 OIC_LOG_V(level, PL_TAG, "\tSupport URL:%s", payload->info.supportUrl);
385 OIC_LOG_V(level, PL_TAG, "\tSystem Time:%s", payload->info.systemTime);
389 OIC_LOG(level, PL_TAG, "\tResource Types:");
390 for (OCStringLL *strll = payload->rt; strll; strll = strll->next)
392 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
395 if (payload->interfaces)
397 OIC_LOG(level, PL_TAG, "\tResource Interfaces:");
398 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
400 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
405 INLINE_API void OCPayloadLogPresence(LogLevel level, OCPresencePayload* payload)
407 OIC_LOG(level, PL_TAG, "Payload Type: Presence");
408 OIC_LOG_V(level, PL_TAG, "\tSequence Number:%u", payload->sequenceNumber);
409 OIC_LOG_V(level, PL_TAG, "\tMax Age:%d", payload->maxAge);
410 OIC_LOG_V(level, PL_TAG, "\tTrigger:%s", convertTriggerEnumToString(payload->trigger));
411 OIC_LOG_V(level, PL_TAG, "\tResource Type:%s", payload->resourceType);
414 INLINE_API void OCPayloadLogSecurity(LogLevel level, OCSecurityPayload* payload)
416 size_t payloadSize = payload->payloadSize;
417 OIC_LOG(level, PL_TAG, "Payload Type: Security");
421 // Add a zero-character string terminator.
422 char *securityData = (char *)OICMalloc(payloadSize + 1);
426 memcpy(securityData, payload->securityData, payloadSize);
427 assert(securityData[payloadSize - 1] != '\0');
428 securityData[payloadSize] = '\0';
429 OIC_LOG_V(level, PL_TAG, "\tSecurity Data: %s", securityData);
430 OICFree(securityData);
435 #if defined(RD_CLIENT) || defined(RD_SERVER)
436 INLINE_API void OCRDPayloadLog(const LogLevel level, const OCRDPayload *payload)
443 if (payload->rdDiscovery)
445 OIC_LOG(level, PL_TAG, "RD Discovery");
446 OIC_LOG_V(level, PL_TAG, " Device Name : %s", payload->rdDiscovery->n.deviceName);
447 OIC_LOG_V(level, PL_TAG, " Device Identity : %s", payload->rdDiscovery->di.id);
448 OIC_LOG_V(level, PL_TAG, " Bias: %d", payload->rdDiscovery->sel);
450 if (payload->rdPublish)
452 OIC_LOG(level, PL_TAG, "RD Publish");
453 OCResourceCollectionPayload *rdPublish = payload->rdPublish;
454 OCTagsLog(level, rdPublish->tags);
455 OCLinksLog(level, rdPublish->setLinks);
459 INLINE_API void OCPayloadLog(LogLevel level, OCPayload* payload)
463 OIC_LOG(level, PL_TAG, "NULL Payload");
466 switch(payload->type)
468 case PAYLOAD_TYPE_REPRESENTATION:
469 OCPayloadLogRep(level, (OCRepPayload*)payload);
471 case PAYLOAD_TYPE_DISCOVERY:
472 OCPayloadLogDiscovery(level, (OCDiscoveryPayload*)payload);
474 case PAYLOAD_TYPE_DEVICE:
475 OCPayloadLogDevice(level, (OCDevicePayload*)payload);
477 case PAYLOAD_TYPE_PLATFORM:
478 OCPayloadLogPlatform(level, (OCPlatformPayload*)payload);
480 case PAYLOAD_TYPE_PRESENCE:
481 OCPayloadLogPresence(level, (OCPresencePayload*)payload);
483 case PAYLOAD_TYPE_SECURITY:
484 OCPayloadLogSecurity(level, (OCSecurityPayload*)payload);
486 #if defined(RD_CLIENT) || defined(RD_SERVER)
487 case PAYLOAD_TYPE_RD:
488 OCRDPayloadLog(level, (OCRDPayload*)payload);
492 OIC_LOG_V(level, PL_TAG, "Unknown Payload Type: %d", payload->type);
497 #define OIC_LOG_PAYLOAD(level, payload)