Merge branch 'master' into resource-container
[platform/upstream/iotivity.git] / resource / csdk / stack / include / payload_logging.h
1 //******************************************************************
2 //
3 // Copyright 2015 Intel Mobile Communications GmbH All Rights Reserved.
4 //
5 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
6 //
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
10 //
11 //      http://www.apache.org/licenses/LICENSE-2.0
12 //
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.
18 //
19 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
20
21 #ifndef PAYLOAD_LOGGING_H_
22 #define PAYLOAD_LOGGING_H_
23
24 #include "logger.h"
25 #ifdef __TIZEN__
26 #include <dlog.h>
27 #endif
28
29 #define __STDC_FORMAT_MACROS
30 #define __STDC_LIMIT_MACROS
31 #include <inttypes.h>
32 #include "rdpayload.h"
33
34 #ifdef __cplusplus
35 extern "C"
36 {
37 #endif
38
39 // PL_TAG is made as generic predefined tag because of build problems in arduino for using logging
40 #define PL_TAG "PayloadLog"
41
42 #ifdef TB_LOG
43     #define OC_LOG_PAYLOAD(level, payload) OCPayloadLog((level),(payload))
44     #define UUID_SIZE (16)
45     #define UUID_LENGTH (37)
46 const char *convertTriggerEnumToString(OCPresenceTrigger trigger);
47 OCPresenceTrigger convertTriggerStringToEnum(const char * triggerStr);
48
49 static inline void OCPayloadLogRep(LogLevel level, OCRepPayload* payload)
50 {
51     OC_LOG(level, (PL_TAG), "Payload Type: Representation");
52     OCRepPayload* rep = payload;
53     int i = 1;
54     while(rep)
55     {
56         OC_LOG_V(level, PL_TAG, "\tResource #%d", i);
57         OC_LOG_V(level, PL_TAG, "\tURI:%s", rep->uri);
58         OC_LOG(level, PL_TAG, "\tResource Types:");
59         OCStringLL* strll =  rep->types;
60         while(strll)
61         {
62             OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
63             strll = strll->next;
64         }
65         OC_LOG(level, PL_TAG, "\tInterfaces:");
66         strll =  rep->interfaces;
67         while(strll)
68         {
69             OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
70             strll = strll->next;
71         }
72
73         // TODO Finish Logging: Values
74         OCRepPayloadValue* val = rep->values;
75
76         OC_LOG(level, PL_TAG, "\tValues:");
77
78         while(val)
79         {
80             switch(val->type)
81             {
82                 case OCREP_PROP_NULL:
83                     OC_LOG_V(level, PL_TAG, "\t\t%s: NULL", val->name);
84                     break;
85                 case OCREP_PROP_INT:
86                     OC_LOG_V(level, PL_TAG, "\t\t%s(int):%zd", val->name, val->i);
87                     break;
88                 case OCREP_PROP_DOUBLE:
89                     OC_LOG_V(level, PL_TAG, "\t\t%s(double):%f", val->name, val->d);
90                     break;
91                 case OCREP_PROP_BOOL:
92                     OC_LOG_V(level, PL_TAG, "\t\t%s(bool):%s", val->name, val->b ? "true" : "false");
93                     break;
94                 case OCREP_PROP_STRING:
95                     OC_LOG_V(level, PL_TAG, "\t\t%s(string):%s", val->name, val->str);
96                     break;
97                 case OCREP_PROP_BYTE_STRING:
98                     OC_LOG_V(level, PL_TAG, "\t\t%s(binary):", val->name);
99                     OC_LOG_BUFFER(level, PL_TAG, val->ocByteStr.bytes, val->ocByteStr.len);
100                     break;
101                 case OCREP_PROP_OBJECT:
102                     // Note: Only prints the URI (if available), to print further, you'll
103                     // need to dig into the object better!
104                     OC_LOG_V(level, PL_TAG, "\t\t%s(OCRep):%s", val->name, val->obj->uri);
105                     break;
106                 case OCREP_PROP_ARRAY:
107                     switch(val->arr.type)
108                     {
109                         case OCREP_PROP_INT:
110                             OC_LOG_V(level, PL_TAG, "\t\t%s(int array):%zu x %zu x %zu",
111                                     val->name,
112                                     val->arr.dimensions[0], val->arr.dimensions[1],
113                                     val->arr.dimensions[2]);
114                             break;
115                         case OCREP_PROP_DOUBLE:
116                             OC_LOG_V(level, PL_TAG, "\t\t%s(double array):%zu x %zu x %zu",
117                                     val->name,
118                                     val->arr.dimensions[0], val->arr.dimensions[1],
119                                     val->arr.dimensions[2]);
120                             break;
121                         case OCREP_PROP_BOOL:
122                             OC_LOG_V(level, PL_TAG, "\t\t%s(bool array):%zu x %zu x %zu",
123                                     val->name,
124                                     val->arr.dimensions[0], val->arr.dimensions[1],
125                                     val->arr.dimensions[2]);
126                             break;
127                         case OCREP_PROP_STRING:
128                             OC_LOG_V(level, PL_TAG, "\t\t%s(string array):%zu x %zu x %zu",
129                                     val->name,
130                                     val->arr.dimensions[0], val->arr.dimensions[1],
131                                     val->arr.dimensions[2]);
132                             break;
133                         case OCREP_PROP_BYTE_STRING:
134                             OC_LOG_V(level, PL_TAG, "\t\t%s(byte array):%lld x %lld x %lld",
135                                     val->name,
136                                     val->arr.dimensions[0], val->arr.dimensions[1],
137                                     val->arr.dimensions[2]);
138                             break;
139                         case OCREP_PROP_OBJECT:
140                             OC_LOG_V(level, PL_TAG, "\t\t%s(OCRep array):%zu x %zu x %zu",
141                                     val->name,
142                                     val->arr.dimensions[0], val->arr.dimensions[1],
143                                     val->arr.dimensions[2]);
144                             break;
145                         default:
146                             OC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown/unsupported array type!",
147                                     val->name);
148                             break;
149                     }
150                     break;
151                 default:
152                     OC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown type!", val->name);
153                     break;
154             }
155             val = val -> next;
156         }
157
158         ++i;
159         rep = rep->next;
160     }
161
162 }
163
164 static inline void OCPayloadLogDiscovery(LogLevel level, OCDiscoveryPayload* payload)
165 {
166     OC_LOG(level, PL_TAG, "Payload Type: Discovery");
167     int i = 1;
168
169     if(!payload->resources)
170     {
171         OC_LOG(level, PL_TAG, "\tNO Resources");
172         return;
173     }
174
175     OCResourcePayload* res = payload->resources;
176
177     while(res)
178     {
179         OC_LOG_V(level, PL_TAG, "\tResource #%d", i);
180         OC_LOG_V(level, PL_TAG, "\tURI:%s", res->uri);
181         OC_LOG(level, PL_TAG, "\tSID:");
182         OC_LOG_BUFFER(level, PL_TAG, res->sid, UUID_SIZE);
183         OC_LOG(level, PL_TAG, "\tResource Types:");
184         OCStringLL* strll =  res->types;
185         while(strll)
186         {
187             OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
188             strll = strll->next;
189         }
190         OC_LOG(level, PL_TAG, "\tInterfaces:");
191         strll =  res->interfaces;
192         while(strll)
193         {
194             OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
195             strll = strll->next;
196         }
197
198         OC_LOG_V(level, PL_TAG, "\tBitmap: %u", res->bitmap);
199         OC_LOG_V(level, PL_TAG, "\tSecure?: %s", res->secure ? "true" : "false");
200         OC_LOG_V(level, PL_TAG, "\tPort: %u", res->port);
201         OC_LOG(level, PL_TAG, "");
202         res = res->next;
203         ++i;
204     }
205 }
206
207 static inline void OCPayloadLogDevice(LogLevel level, OCDevicePayload* payload)
208 {
209     OC_LOG(level, PL_TAG, "Payload Type: Device");
210     OC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
211     OC_LOG(level, PL_TAG, "\tSID:");
212     OC_LOG_BUFFER(level, PL_TAG, payload->sid, UUID_SIZE);
213     OC_LOG_V(level, PL_TAG, "\tDevice Name:%s", payload->deviceName);
214     OC_LOG_V(level, PL_TAG, "\tSpec Version%s", payload->specVersion);
215     OC_LOG_V(level, PL_TAG, "\tData Model Version:%s", payload->dataModelVersion);
216 }
217
218 static inline void OCPayloadLogPlatform(LogLevel level, OCPlatformPayload* payload)
219 {
220     OC_LOG(level, PL_TAG, "Payload Type: Platform");
221     OC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
222     OC_LOG_V(level, PL_TAG, "\tPlatform ID:%s", payload->info.platformID);
223     OC_LOG_V(level, PL_TAG, "\tMfg Name:%s", payload->info.manufacturerName);
224     OC_LOG_V(level, PL_TAG, "\tMfg URL:%s", payload->info.manufacturerUrl);
225     OC_LOG_V(level, PL_TAG, "\tModel Number:%s", payload->info.modelNumber);
226     OC_LOG_V(level, PL_TAG, "\tDate of Mfg:%s", payload->info.dateOfManufacture);
227     OC_LOG_V(level, PL_TAG, "\tPlatform Version:%s", payload->info.platformVersion);
228     OC_LOG_V(level, PL_TAG, "\tOS Version:%s", payload->info.operatingSystemVersion);
229     OC_LOG_V(level, PL_TAG, "\tHardware Version:%s", payload->info.hardwareVersion);
230     OC_LOG_V(level, PL_TAG, "\tFirmware Version:%s", payload->info.firmwareVersion);
231     OC_LOG_V(level, PL_TAG, "\tSupport URL:%s", payload->info.supportUrl);
232     OC_LOG_V(level, PL_TAG, "\tSystem Time:%s", payload->info.systemTime);
233 }
234
235 static inline void OCPayloadLogPresence(LogLevel level, OCPresencePayload* payload)
236 {
237     OC_LOG(level, PL_TAG, "Payload Type: Presence");
238     OC_LOG_V(level, PL_TAG, "\tSequence Number:%u", payload->sequenceNumber);
239     OC_LOG_V(level, PL_TAG, "\tMax Age:%d", payload->maxAge);
240     OC_LOG_V(level, PL_TAG, "\tTrigger:%s", convertTriggerEnumToString(payload->trigger));
241     OC_LOG_V(level, PL_TAG, "\tResource Type:%s", payload->resourceType);
242 }
243
244 static inline void OCPayloadLogSecurity(LogLevel level, OCSecurityPayload* payload)
245 {
246     OC_LOG(level, PL_TAG, "Payload Type: Security");
247     OC_LOG_V(level, PL_TAG, "\tSecurity Data: %s", payload->securityData);
248 }
249
250 static inline void OCRDPayloadLog(const LogLevel level, const OCRDPayload *payload)
251 {
252     if (!payload)
253     {
254         return;
255     }
256
257     if (payload->rdDiscovery)
258     {
259         OC_LOG(level, PL_TAG, "RD Discovery");
260         OC_LOG_V(level, PL_TAG, "  Device Name : %s", payload->rdDiscovery->n.deviceName);
261         OC_LOG_V(level, PL_TAG, "  Device Identity : %s", payload->rdDiscovery->di.id);
262         OC_LOG_V(level, PL_TAG, "  Bias: %d", payload->rdDiscovery->sel);
263     }
264     if (payload->rdPublish)
265     {
266         OC_LOG(level, PL_TAG, "RD Publish");
267         OCResourceCollectionPayload *rdPublish = payload->rdPublish;
268         OCTagsLog(level, rdPublish->tags);
269         OCLinksLog(level, rdPublish->setLinks);
270     }
271 }
272
273 static inline void OCPayloadLog(LogLevel level, OCPayload* payload)
274 {
275     if(!payload)
276     {
277         OC_LOG(level, PL_TAG, "NULL Payload");
278         return;
279     }
280     switch(payload->type)
281     {
282         case PAYLOAD_TYPE_REPRESENTATION:
283             OCPayloadLogRep(level, (OCRepPayload*)payload);
284             break;
285         case PAYLOAD_TYPE_DISCOVERY:
286             OCPayloadLogDiscovery(level, (OCDiscoveryPayload*)payload);
287             break;
288         case PAYLOAD_TYPE_DEVICE:
289             OCPayloadLogDevice(level, (OCDevicePayload*)payload);
290             break;
291         case PAYLOAD_TYPE_PLATFORM:
292             OCPayloadLogPlatform(level, (OCPlatformPayload*)payload);
293             break;
294         case PAYLOAD_TYPE_PRESENCE:
295             OCPayloadLogPresence(level, (OCPresencePayload*)payload);
296             break;
297         case PAYLOAD_TYPE_SECURITY:
298             OCPayloadLogSecurity(level, (OCSecurityPayload*)payload);
299             break;
300         case PAYLOAD_TYPE_RD:
301             OCRDPayloadLog(level, (OCRDPayload*)payload);
302             break;
303         default:
304             OC_LOG_V(level, PL_TAG, "Unknown Payload Type: %d", payload->type);
305             break;
306     }
307 }
308 #else
309     #define OC_LOG_PAYLOAD(level, payload)
310 #endif
311
312 #ifdef __cplusplus
313 }
314 #endif
315
316 #endif