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_
34 // PL_TAG is made as generic predefined tag because of build problems in arduino for using logging
35 #define PL_TAG "PayloadLog"
38 #define OC_LOG_PAYLOAD(level, payload) OCPayloadLog((level),(payload))
39 #define UUID_SIZE (16)
40 #define UUID_LENGTH (37)
41 const char *convertTriggerEnumToString(OCPresenceTrigger trigger);
42 OCPresenceTrigger convertTriggerStringToEnum(const char * triggerStr);
44 static inline void OCPayloadLogRep(LogLevel level, OCRepPayload* payload)
46 OC_LOG(level, (PL_TAG), "Payload Type: Representation");
47 OCRepPayload* rep = payload;
51 OC_LOG_V(level, PL_TAG, "\tResource #%d", i);
52 OC_LOG_V(level, PL_TAG, "\tURI:%s", rep->uri);
53 OC_LOG(level, PL_TAG, "\tResource Types:");
54 OCStringLL* strll = rep->types;
57 OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
60 OC_LOG(level, PL_TAG, "\tInterfaces:");
61 strll = rep->interfaces;
64 OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
68 // TODO Finish Logging: Values
69 OCRepPayloadValue* val = rep->values;
71 OC_LOG(level, PL_TAG, "\tValues:");
78 OC_LOG_V(level, PL_TAG, "\t\t%s: NULL", val->name);
81 OC_LOG_V(level, PL_TAG, "\t\t%s(int):%lld", val->name, val->i);
83 case OCREP_PROP_DOUBLE:
84 OC_LOG_V(level, PL_TAG, "\t\t%s(double):%f", val->name, val->d);
87 OC_LOG_V(level, PL_TAG, "\t\t%s(bool):%s", val->name, val->b ? "true" : "false");
89 case OCREP_PROP_STRING:
90 OC_LOG_V(level, PL_TAG, "\t\t%s(string):%s", val->name, val->str);
92 case OCREP_PROP_OBJECT:
93 // Note: Only prints the URI (if available), to print further, you'll
94 // need to dig into the object better!
95 OC_LOG_V(level, PL_TAG, "\t\t%s(OCRep):%s", val->name, val->obj->uri);
97 case OCREP_PROP_ARRAY:
101 OC_LOG_V(level, PL_TAG, "\t\t%s(int array):%lld x %lld x %lld",
103 val->arr.dimensions[0], val->arr.dimensions[1],
104 val->arr.dimensions[2]);
106 case OCREP_PROP_DOUBLE:
107 OC_LOG_V(level, PL_TAG, "\t\t%s(double array):%lld x %lld x %lld",
109 val->arr.dimensions[0], val->arr.dimensions[1],
110 val->arr.dimensions[2]);
112 case OCREP_PROP_BOOL:
113 OC_LOG_V(level, PL_TAG, "\t\t%s(bool array):%lld x %lld x %lld",
115 val->arr.dimensions[0], val->arr.dimensions[1],
116 val->arr.dimensions[2]);
118 case OCREP_PROP_STRING:
119 OC_LOG_V(level, PL_TAG, "\t\t%s(string array):%lld x %lld x %lld",
121 val->arr.dimensions[0], val->arr.dimensions[1],
122 val->arr.dimensions[2]);
124 case OCREP_PROP_OBJECT:
125 OC_LOG_V(level, PL_TAG, "\t\t%s(OCRep array):%lld x %lld x %lld",
127 val->arr.dimensions[0], val->arr.dimensions[1],
128 val->arr.dimensions[2]);
131 OC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown/unsupported array type!",
137 OC_LOG_V(ERROR, PL_TAG, "\t\t%s <-- Unknown type!", val->name);
149 static inline void OCPayloadLogDiscovery(LogLevel level, OCDiscoveryPayload* payload)
151 OC_LOG(level, PL_TAG, "Payload Type: Discovery");
154 if(!payload->resources)
156 OC_LOG(level, PL_TAG, "\tNO Resources");
160 OCResourcePayload* res = payload->resources;
164 OC_LOG_V(level, PL_TAG, "\tResource #%d", i);
165 OC_LOG_V(level, PL_TAG, "\tURI:%s", res->uri);
166 OC_LOG(level, PL_TAG, "\tSID:");
167 OC_LOG_BUFFER(level, PL_TAG, res->sid, UUID_SIZE);
168 OC_LOG(level, PL_TAG, "\tResource Types:");
169 OCStringLL* strll = res->types;
172 OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
175 OC_LOG(level, PL_TAG, "\tInterfaces:");
176 strll = res->interfaces;
179 OC_LOG_V(level, PL_TAG, "\t\t%s", strll->value);
183 OC_LOG_V(level, PL_TAG, "\tBitmap: %u", res->bitmap);
184 OC_LOG_V(level, PL_TAG, "\tSecure?: %s", res->secure ? "true" : "false");
185 OC_LOG_V(level, PL_TAG, "\tPort: %u", res->port);
186 OC_LOG(level, PL_TAG, "");
192 static inline void OCPayloadLogDevice(LogLevel level, OCDevicePayload* payload)
194 OC_LOG(level, PL_TAG, "Payload Type: Device");
195 OC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
196 OC_LOG(level, PL_TAG, "\tSID:");
197 OC_LOG_BUFFER(level, PL_TAG, payload->sid, UUID_SIZE);
198 OC_LOG_V(level, PL_TAG, "\tDevice Name:%s", payload->deviceName);
199 OC_LOG_V(level, PL_TAG, "\tSpec Version%s", payload->specVersion);
200 OC_LOG_V(level, PL_TAG, "\tData Model Version:%s", payload->dataModelVersion);
203 static inline void OCPayloadLogPlatform(LogLevel level, OCPlatformPayload* payload)
205 OC_LOG(level, PL_TAG, "Payload Type: Platform");
206 OC_LOG_V(level, PL_TAG, "\tURI:%s", payload->uri);
207 OC_LOG_V(level, PL_TAG, "\tPlatform ID:%s", payload->info.platformID);
208 OC_LOG_V(level, PL_TAG, "\tMfg Name:%s", payload->info.manufacturerName);
209 OC_LOG_V(level, PL_TAG, "\tMfg URL:%s", payload->info.manufacturerUrl);
210 OC_LOG_V(level, PL_TAG, "\tModel Number:%s", payload->info.modelNumber);
211 OC_LOG_V(level, PL_TAG, "\tDate of Mfg:%s", payload->info.dateOfManufacture);
212 OC_LOG_V(level, PL_TAG, "\tPlatform Version:%s", payload->info.platformVersion);
213 OC_LOG_V(level, PL_TAG, "\tOS Version:%s", payload->info.operatingSystemVersion);
214 OC_LOG_V(level, PL_TAG, "\tHardware Version:%s", payload->info.hardwareVersion);
215 OC_LOG_V(level, PL_TAG, "\tFirmware Version:%s", payload->info.firmwareVersion);
216 OC_LOG_V(level, PL_TAG, "\tSupport URL:%s", payload->info.supportUrl);
217 OC_LOG_V(level, PL_TAG, "\tSystem Time:%s", payload->info.systemTime);
220 static inline void OCPayloadLogPresence(LogLevel level, OCPresencePayload* payload)
222 OC_LOG(level, PL_TAG, "Payload Type: Presence");
223 OC_LOG_V(level, PL_TAG, "\tSequence Number:%u", payload->sequenceNumber);
224 OC_LOG_V(level, PL_TAG, "\tMax Age:%d", payload->maxAge);
225 OC_LOG_V(level, PL_TAG, "\tTrigger:%s", convertTriggerEnumToString(payload->trigger));
226 OC_LOG_V(level, PL_TAG, "\tResource Type:%s", payload->resourceType);
229 static inline void OCPayloadLogSecurity(LogLevel level, OCSecurityPayload* payload)
231 OC_LOG(level, PL_TAG, "Payload Type: Security");
232 OC_LOG_V(level, PL_TAG, "\tSecurity Data: %s", payload->securityData);
235 static inline void OCPayloadLog(LogLevel level, OCPayload* payload)
239 OC_LOG(level, PL_TAG, "NULL Payload");
242 switch(payload->type)
244 case PAYLOAD_TYPE_REPRESENTATION:
245 OCPayloadLogRep(level, (OCRepPayload*)payload);
247 case PAYLOAD_TYPE_DISCOVERY:
248 OCPayloadLogDiscovery(level, (OCDiscoveryPayload*)payload);
250 case PAYLOAD_TYPE_DEVICE:
251 OCPayloadLogDevice(level, (OCDevicePayload*)payload);
253 case PAYLOAD_TYPE_PLATFORM:
254 OCPayloadLogPlatform(level, (OCPlatformPayload*)payload);
256 case PAYLOAD_TYPE_PRESENCE:
257 OCPayloadLogPresence(level, (OCPresencePayload*)payload);
259 case PAYLOAD_TYPE_SECURITY:
260 OCPayloadLogSecurity(level, (OCSecurityPayload*)payload);
263 case PAYLOAD_TYPE_RD:
264 OCRDPayloadLog(level, PL_TAG, (OCRDPayload*)payload);
268 OC_LOG_V(level, PL_TAG, "Unknown Payload Type: %d", payload->type);
273 #define OC_LOG_PAYLOAD(level, payload)