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
37 #include "oic_malloc.h"
38 #include "ocpayload.h"
46 // PL_TAG is made as generic predefined tag because of build problems in arduino for using logging
47 #define PL_TAG "PayloadLog"
50 #define OIC_LOG_PAYLOAD(level, payload) OCPayloadLog((level),(payload))
51 #define UUID_SIZE (16)
53 const char *convertTriggerEnumToString(OCPresenceTrigger trigger);
54 OCPresenceTrigger convertTriggerStringToEnum(const char * triggerStr);
56 INLINE_API void OCPayloadLogRep(LogLevel level, OCRepPayload* payload);
58 INLINE_API void OCPayloadLogRepValues(LogLevel level, OCRepPayloadValue* val)
65 OIC_LOG_V(level, PL_TAG, "\t\t%s: NULL", val->name);
68 OIC_LOG_V(level, PL_TAG, "\t\t%s(int):%zd", val->name, val->i);
70 case OCREP_PROP_DOUBLE:
71 OIC_LOG_V(level, PL_TAG, "\t\t%s(double):%f", val->name, val->d);
74 OIC_LOG_V(level, PL_TAG, "\t\t%s(bool):%s", val->name, val->b ? "true" : "false");
76 case OCREP_PROP_STRING:
77 OIC_LOG_V(level, PL_TAG, "\t\t%s(string):%s", val->name, val->str);
79 case OCREP_PROP_BYTE_STRING:
80 OIC_LOG_V(level, PL_TAG, "\t\t%s(binary):", val->name);
81 OIC_LOG_BUFFER(level, PL_TAG, val->ocByteStr.bytes, val->ocByteStr.len);
83 case OCREP_PROP_OBJECT:
84 // Note: Only prints the URI (if available), to print further, you'll
85 // need to dig into the object better!
86 OIC_LOG_V(level, PL_TAG, "\t\t%s(object):", val->name);
87 OCPayloadLogRep(level, val->obj);
89 case OCREP_PROP_ARRAY:
93 OIC_LOG_V(level, PL_TAG, "\t\t%s(int array):%zu x %zu x %zu: ",
95 val->arr.dimensions[0], val->arr.dimensions[1],
96 val->arr.dimensions[2]);
97 OIC_LOG(level, PL_TAG, "\t\t Values:");
98 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
100 OIC_LOG_V(level, PL_TAG, "\t\t\t %zd", val->arr.iArray[i]);
103 case OCREP_PROP_DOUBLE:
104 OIC_LOG_V(level, PL_TAG, "\t\t%s(double array):%zu x %zu x %zu: ",
106 val->arr.dimensions[0], val->arr.dimensions[1],
107 val->arr.dimensions[2]);
108 OIC_LOG(level, PL_TAG, "\t\t Values:");
109 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
111 OIC_LOG_V(level, PL_TAG, "\t\t\t %lf", val->arr.dArray[i]);
114 case OCREP_PROP_BOOL:
115 OIC_LOG_V(level, PL_TAG, "\t\t%s(bool array):%zu x %zu x %zu: ",
117 val->arr.dimensions[0], val->arr.dimensions[1],
118 val->arr.dimensions[2]);
119 OIC_LOG(level, PL_TAG, "\t\t Values:");
120 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
122 OIC_LOG_V(level, PL_TAG, "\t\t\t %d", val->arr.bArray[i]);
125 case OCREP_PROP_STRING:
126 OIC_LOG_V(level, PL_TAG, "\t\t%s(string array):%zu x %zu x %zu: ",
128 val->arr.dimensions[0], val->arr.dimensions[1],
129 val->arr.dimensions[2]);
130 OIC_LOG(level, PL_TAG, "\t\t Values:");
131 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
133 OIC_LOG_V(level, PL_TAG, "\t\t\t %s", val->arr.strArray[i]);
136 case OCREP_PROP_BYTE_STRING:
137 OIC_LOG_V(level, PL_TAG, "\t\t%s(byte array):%zu x %zu x %zu: ",
139 val->arr.dimensions[0], val->arr.dimensions[1],
140 val->arr.dimensions[2]);
141 OIC_LOG(level, PL_TAG, "\t\t Values:");
142 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
144 OIC_LOG_BUFFER(level, PL_TAG, val->arr.ocByteStrArray[i].bytes, val->arr.ocByteStrArray[i].len);
147 case OCREP_PROP_OBJECT:
148 OIC_LOG_V(level, PL_TAG, "\t\t%s(object array):%zu x %zu x %zu: ",
150 val->arr.dimensions[0], val->arr.dimensions[1],
151 val->arr.dimensions[2]);
152 OIC_LOG(level, PL_TAG, "\t\t Values:");
154 for (size_t i = 0; i < val->arr.dimensions[0]; i++)
156 OCPayloadLogRep(level, val->arr.objArray[i]);
159 case OCREP_PROP_ARRAY: //Seems as nested arrays doesn't not supported in API
161 OIC_LOG_V(ERROR, PL_TAG, "%s <-- Unknown/unsupported array type!",
167 OIC_LOG_V(ERROR, PL_TAG, "%s <-- Unknown type!", val->name);
174 INLINE_API void OCPayloadLogRep(LogLevel level, OCRepPayload* payload)
176 OIC_LOG(level, (PL_TAG), "Payload Type: Representation");
178 for (OCRepPayload* rep = payload; rep; rep = rep->next, ++i)
180 OIC_LOG_V(level, PL_TAG, "\tResource #%d", i);
183 OIC_LOG_V(level, PL_TAG, "\tURI:%s", rep->uri);
187 OIC_LOG(level, PL_TAG, "\tResource Types:");
188 for (OCStringLL* strll = rep->types; strll; strll = strll->next)
190 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
195 OIC_LOG(level, PL_TAG, "\tInterfaces:");
196 for (OCStringLL* strll = rep->interfaces; strll; strll = strll->next)
198 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
201 OIC_LOG(level, PL_TAG, "\tValues:");
202 OCPayloadLogRepValues(level, rep->values);
206 INLINE_API void OCPayloadLogDiscovery(LogLevel level, OCDiscoveryPayload* payload)
208 OIC_LOG(level, PL_TAG, "Payload Type: Discovery");
210 while(payload && payload->resources)
212 OIC_LOG_V(level, PL_TAG, "\tSID: %s", payload->sid);
213 if (payload->baseURI)
215 OIC_LOG_V(level, PL_TAG, "\tBase URI:%s", payload->baseURI);
219 OIC_LOG_V(level, PL_TAG, "\tNAME: %s", payload->name);
223 OIC_LOG_V(level, PL_TAG, "\tURI: %s", payload->uri);
227 for (OCStringLL *strll = payload->type; strll; strll = strll->next)
229 OIC_LOG_V(level, PL_TAG, "\tResource Type: %s", strll->value);
232 OIC_LOG(level, PL_TAG, "\tInterface:");
233 for (OCStringLL *itf = payload->iface; itf; itf = itf->next)
235 OIC_LOG_V(level, PL_TAG, "\t\t%s", itf->value);
238 OCResourcePayload* res = payload->resources;
243 OIC_LOG_V(level, PL_TAG, "\tResource #%d", i);
244 OIC_LOG_V(level, PL_TAG, "\tURI:%s", res->uri);
245 OIC_LOG(level, PL_TAG, "\tResource Types:");
246 OCStringLL* strll = res->types;
249 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
252 OIC_LOG(level, PL_TAG, "\tInterfaces:");
253 strll = res->interfaces;
256 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
260 OIC_LOG_V(level, PL_TAG, "\tBitmap: %u", res->bitmap);
261 OIC_LOG_V(level, PL_TAG, "\tSecure?: %s", res->secure ? "true" : "false");
262 OIC_LOG_V(level, PL_TAG, "\tPort: %u", res->port);
263 OIC_LOG(level, PL_TAG, "");
267 payload = payload->next;
271 INLINE_API void OCPayloadLogDevice(LogLevel level, OCDevicePayload* payload)
273 OIC_LOG(level, PL_TAG, "Payload Type: Device");
274 OIC_LOG_V(level, PL_TAG, "\tSID:%s", payload->sid);
275 OIC_LOG_V(level, PL_TAG, "\tDevice Name:%s", payload->deviceName);
276 OIC_LOG_V(level, PL_TAG, "\tSpec Version:%s", payload->specVersion);
277 if (payload->dataModelVersions)
279 OIC_LOG(level, PL_TAG, "\tData Model Version:");
280 for (OCStringLL *strll = payload->dataModelVersions; strll; strll = strll->next)
282 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
287 OIC_LOG(level, PL_TAG, "\tResource Type:");
288 for (OCStringLL *strll = payload->types; strll; strll = strll->next)
290 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
293 if (payload->interfaces)
295 OIC_LOG(level, PL_TAG, "\tInterface:");
296 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
298 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
303 INLINE_API void OCPayloadLogPlatform(LogLevel level, OCPlatformPayload* payload)
305 OIC_LOG(level, PL_TAG, "Payload Type: Platform");
306 OIC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
307 OIC_LOG_V(level, PL_TAG, "\tPlatform ID:%s", payload->info.platformID);
308 OIC_LOG_V(level, PL_TAG, "\tMfg Name:%s", payload->info.manufacturerName);
309 OIC_LOG_V(level, PL_TAG, "\tMfg URL:%s", payload->info.manufacturerUrl);
310 OIC_LOG_V(level, PL_TAG, "\tModel Number:%s", payload->info.modelNumber);
311 OIC_LOG_V(level, PL_TAG, "\tDate of Mfg:%s", payload->info.dateOfManufacture);
312 OIC_LOG_V(level, PL_TAG, "\tPlatform Version:%s", payload->info.platformVersion);
313 OIC_LOG_V(level, PL_TAG, "\tOS Version:%s", payload->info.operatingSystemVersion);
314 OIC_LOG_V(level, PL_TAG, "\tHardware Version:%s", payload->info.hardwareVersion);
315 OIC_LOG_V(level, PL_TAG, "\tFirmware Version:%s", payload->info.firmwareVersion);
316 OIC_LOG_V(level, PL_TAG, "\tSupport URL:%s", payload->info.supportUrl);
317 OIC_LOG_V(level, PL_TAG, "\tSystem Time:%s", payload->info.systemTime);
321 OIC_LOG(level, PL_TAG, "\tResource Types:");
322 for (OCStringLL *strll = payload->rt; strll; strll = strll->next)
324 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
327 if (payload->interfaces)
329 OIC_LOG(level, PL_TAG, "\tResource Interfaces:");
330 for (OCStringLL *strll = payload->interfaces; strll; strll = strll->next)
332 OIC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
337 INLINE_API void OCPayloadLogPresence(LogLevel level, OCPresencePayload* payload)
339 OIC_LOG(level, PL_TAG, "Payload Type: Presence");
340 OIC_LOG_V(level, PL_TAG, "\tSequence Number:%u", payload->sequenceNumber);
341 OIC_LOG_V(level, PL_TAG, "\tMax Age:%d", payload->maxAge);
342 OIC_LOG_V(level, PL_TAG, "\tTrigger:%s", convertTriggerEnumToString(payload->trigger));
343 OIC_LOG_V(level, PL_TAG, "\tResource Type:%s", payload->resourceType);
346 INLINE_API void OCPayloadLogSecurity(LogLevel level, OCSecurityPayload* payload)
348 size_t payloadSize = payload->payloadSize;
349 OIC_LOG(level, PL_TAG, "Payload Type: Security");
353 // Add a zero-character string terminator.
354 char *securityData = (char *)OICMalloc(payloadSize + 1);
358 memcpy(securityData, payload->securityData, payloadSize);
359 // assert(securityData[payloadSize - 1] != '\0');
360 securityData[payloadSize] = '\0';
361 OIC_LOG_V(level, PL_TAG, "\tSecurity Data: %s", securityData);
362 OICFree(securityData);
367 INLINE_API void OCPayloadLog(LogLevel level, OCPayload* payload)
371 OIC_LOG(level, PL_TAG, "NULL Payload");
374 switch(payload->type)
376 case PAYLOAD_TYPE_REPRESENTATION:
377 OCPayloadLogRep(level, (OCRepPayload*)payload);
379 case PAYLOAD_TYPE_DISCOVERY:
380 OCPayloadLogDiscovery(level, (OCDiscoveryPayload*)payload);
382 case PAYLOAD_TYPE_DEVICE:
383 OCPayloadLogDevice(level, (OCDevicePayload*)payload);
385 case PAYLOAD_TYPE_PLATFORM:
386 OCPayloadLogPlatform(level, (OCPlatformPayload*)payload);
388 case PAYLOAD_TYPE_PRESENCE:
389 OCPayloadLogPresence(level, (OCPresencePayload*)payload);
391 case PAYLOAD_TYPE_SECURITY:
392 OCPayloadLogSecurity(level, (OCSecurityPayload*)payload);
395 OIC_LOG_V(level, PL_TAG, "Unknown Payload Type: %d", payload->type);
400 #define OIC_LOG_PAYLOAD(level, payload)