1 //******************************************************************
3 // Copyright 2014 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 // Defining _POSIX_C_SOURCE macro with 200112L (or greater) as value
22 // causes header files to expose definitions
23 // corresponding to the POSIX.1-2001 base
24 // specification (excluding the XSI extension).
25 // For POSIX.1-2001 base specification,
26 // Refer http://pubs.opengroup.org/onlinepubs/009695399/
27 #define _POSIX_C_SOURCE 200112L
28 #include "ocresource.h"
30 #include "ocresourcehandler.h"
31 #include "ocobserve.h"
32 #include "occollection.h"
33 #include "oic_malloc.h"
34 #include "oic_string.h"
37 #include "ocpayload.h"
40 #include "cainterface.h"
44 #define TAG PCF("ocresource")
45 #define VERIFY_SUCCESS(op, successCode) { if (op != successCode) \
46 {OC_LOG_V(FATAL, TAG, "%s failed!!", #op); goto exit;} }
48 #define VERIFY_NON_NULL(arg, logLevel, retVal) { if (!(arg)) { OC_LOG((logLevel), \
49 TAG, PCF(#arg " is NULL")); return (retVal); } }
51 extern OCResource *headResource;
52 static OCPlatformInfo savedPlatformInfo = {};
53 static OCDeviceInfo savedDeviceInfo = {};
55 //-----------------------------------------------------------------------------
56 // Default resource entity handler function
57 //-----------------------------------------------------------------------------
58 OCEntityHandlerResult defaultResourceEHandler(OCEntityHandlerFlag flag,
59 OCEntityHandlerRequest * request, void* callbackParam)
61 //TODO ("Implement me!!!!");
62 // TODO: remove silence unused param warnings
66 return OC_EH_OK; // Making sure that the Default EH and the Vendor EH have matching signatures
69 /* This method will retrieve the port at which the secure resource is hosted */
70 static OCStackResult GetSecurePortInfo(CATransportAdapter_t connType, uint16_t *port)
72 CAEndpoint_t* info = NULL;
74 OCStackResult ret = OC_STACK_ERROR;
76 CAResult_t caResult = CAGetNetworkInformation(&info, &size);
77 if ((caResult == CA_STATUS_OK) && info && size)
81 if ((info[size].flags & CA_SECURE) && info[size].adapter == connType)
83 if (info[size].adapter == CA_ADAPTER_IP)
85 *port = info[size].port;
98 * Function will extract 0, 1 or 2 filters from query.
99 * More than 2 filters or unsupported filters will result in error.
100 * If both filters are of the same supported type, the 2nd one will be picked.
101 * Resource and device filters in the SAME query are NOT validated
102 * and resources will likely not clear filters.
104 static OCStackResult ExtractFiltersFromQuery(char *query, char **filterOne, char **filterTwo)
109 char *restOfQuery = NULL;
110 int numKeyValuePairsParsed = 0;
115 OC_LOG_V(INFO, TAG, PCF("Received query %s for param extraction"), query);
117 char *keyValuePair = strtok_r (query, OC_QUERY_SEPARATOR, &restOfQuery);
121 if (numKeyValuePairsParsed >= 2)
123 OC_LOG(ERROR, TAG, PCF("More than 2 queries params in URI."));
124 return OC_STACK_INVALID_QUERY;
127 key = strtok_r(keyValuePair, OC_KEY_VALUE_DELIMITER, &value);
131 return OC_STACK_INVALID_QUERY;
133 else if (strcmp (key, OC_RSRVD_INTERFACE) == 0)
135 *filterOne = value; // if
137 else if (strcmp (key, OC_RSRVD_RESOURCE_TYPE) == 0)
139 *filterTwo = value; // rt
143 OC_LOG_V(ERROR, TAG, "Unsupported query key: %s", key);
144 return OC_STACK_INVALID_QUERY;
146 ++numKeyValuePairsParsed;
148 keyValuePair = strtok_r(NULL, OC_QUERY_SEPARATOR, &restOfQuery);
151 OC_LOG_V(INFO, TAG, "Extracted params %s and %s.", *filterOne, *filterTwo);
155 static OCVirtualResources GetTypeOfVirtualURI(const char *uriInRequest)
157 if (strcmp(uriInRequest, OC_RSRVD_WELL_KNOWN_URI) == 0)
159 return OC_WELL_KNOWN_URI;
161 else if (strcmp(uriInRequest, OC_RSRVD_DEVICE_URI) == 0)
163 return OC_DEVICE_URI;
165 else if (strcmp(uriInRequest, OC_RSRVD_PLATFORM_URI) == 0)
167 return OC_PLATFORM_URI;
169 else if (strcmp(uriInRequest, OC_RSRVD_RESOURCE_TYPES_URI) == 0)
171 return OC_RESOURCE_TYPES_URI;
174 else if (strcmp(uriInRequest, OC_RSRVD_PRESENCE_URI) == 0)
178 #endif //WITH_PRESENCE
179 return OC_UNKNOWN_URI;
182 static OCStackResult getQueryParamsForFiltering (OCVirtualResources uri, char *query,
183 char **filterOne, char **filterTwo)
185 if(!filterOne || !filterTwo)
187 return OC_STACK_INVALID_PARAM;
194 if (uri == OC_PRESENCE)
196 //Nothing needs to be done, except for pass a OC_PRESENCE query through as OC_STACK_OK.
197 OC_LOG(INFO, TAG, PCF("OC_PRESENCE Request for virtual resource."));
202 OCStackResult result = OC_STACK_OK;
206 result = ExtractFiltersFromQuery(query, filterOne, filterTwo);
212 OCStackResult BuildVirtualResourceResponse(const OCResource *resourcePtr,
213 OCDiscoveryPayload* payload, CATransportAdapter_t adapter )
215 if (!resourcePtr || !payload)
217 return OC_STACK_INVALID_PARAM;
220 if (resourcePtr->resourceProperties & OC_SECURE)
222 if(GetSecurePortInfo (adapter, &port) != OC_STACK_OK)
228 OCDiscoveryPayloadAddResource(payload, resourcePtr, port);
233 uint8_t IsCollectionResource (OCResource *resource)
240 for (int i = 0; i < MAX_CONTAINED_RESOURCES; i++)
242 if (resource->rsrcResources[i])
250 OCResource *FindResourceByUri(const char* resourceUri)
257 OCResource * pointer = headResource;
260 if (strcmp(resourceUri, pointer->uri) == 0)
264 pointer = pointer->next;
266 OC_LOG(INFO, TAG, PCF("Resource not found"));
271 OCStackResult DetermineResourceHandling (const OCServerRequest *request,
272 ResourceHandling *handling,
273 OCResource **resource)
275 if(!request || !handling || !resource)
277 return OC_STACK_INVALID_PARAM;
280 OC_LOG(INFO, TAG, PCF("Entering DetermineResourceHandling"));
282 const OCDevAddr *devAddr = &request->devAddr;
284 // Check if virtual resource
285 if (GetTypeOfVirtualURI(request->resourceUrl) != OC_UNKNOWN_URI)
287 *handling = OC_RESOURCE_VIRTUAL;
288 *resource = headResource;
291 if (strlen((const char*)(request->resourceUrl)) == 0)
293 // Resource URL not specified
294 *handling = OC_RESOURCE_NOT_SPECIFIED;
295 return OC_STACK_NO_RESOURCE;
299 OCResource *resourcePtr = NULL;
300 resourcePtr = FindResourceByUri((const char*)request->resourceUrl);
301 *resource = resourcePtr;
304 if(defaultDeviceHandler)
306 *handling = OC_RESOURCE_DEFAULT_DEVICE_ENTITYHANDLER;
310 // Resource does not exist
311 // and default device handler does not exist
312 *handling = OC_RESOURCE_NOT_SPECIFIED;
313 return OC_STACK_NO_RESOURCE;
316 // secure resource will entertain only authorized requests
317 if ((resourcePtr->resourceProperties & OC_SECURE) && ((devAddr->flags & OC_FLAG_SECURE) == 0))
319 OC_LOG(ERROR, TAG, PCF("Un-authorized request. Ignoring"));
320 return OC_STACK_RESOURCE_ERROR;
323 if (IsCollectionResource (resourcePtr))
325 // Collection resource
326 if (resourcePtr->entityHandler != defaultResourceEHandler)
328 *handling = OC_RESOURCE_COLLECTION_WITH_ENTITYHANDLER;
333 *handling = OC_RESOURCE_COLLECTION_DEFAULT_ENTITYHANDLER;
339 // Resource not a collection
340 if (resourcePtr->entityHandler != defaultResourceEHandler)
342 *handling = OC_RESOURCE_NOT_COLLECTION_WITH_ENTITYHANDLER;
347 *handling = OC_RESOURCE_NOT_COLLECTION_DEFAULT_ENTITYHANDLER;
354 OCStackResult EntityHandlerCodeToOCStackCode(OCEntityHandlerResult ehResult)
356 OCStackResult result;
361 result = OC_STACK_OK;
364 result = OC_STACK_SLOW_RESOURCE;
367 result = OC_STACK_ERROR;
369 case OC_EH_FORBIDDEN:
370 result = OC_STACK_RESOURCE_ERROR;
372 case OC_EH_RESOURCE_CREATED:
373 result = OC_STACK_RESOURCE_CREATED;
375 case OC_EH_RESOURCE_DELETED:
376 result = OC_STACK_RESOURCE_DELETED;
378 case OC_EH_RESOURCE_NOT_FOUND:
379 result = OC_STACK_NO_RESOURCE;
382 result = OC_STACK_ERROR;
388 static bool resourceMatchesRTFilter(OCResource *resource, char *resourceTypeFilter)
395 // Null or empty is analogous to no filter.
396 if (resourceTypeFilter == NULL || *resourceTypeFilter == 0)
401 OCResourceType *resourceTypePtr = resource->rsrcType;
403 while (resourceTypePtr)
405 if (strcmp (resourceTypePtr->resourcetypename, resourceTypeFilter) == 0)
409 resourceTypePtr = resourceTypePtr->next;
412 OC_LOG_V(INFO, TAG, PCF("%s does not contain rt=%s."), resource->uri, resourceTypeFilter);
416 static bool resourceMatchesIFFilter(OCResource *resource, char *interfaceFilter)
423 // Null or empty is analogous to no filter.
424 if (interfaceFilter == NULL || *interfaceFilter == 0)
429 OCResourceInterface *interfacePtr = resource->rsrcInterface;
433 if (strcmp (interfacePtr->name, interfaceFilter) == 0)
437 interfacePtr = interfacePtr->next;
440 OC_LOG_V(INFO, TAG, PCF("%s does not contain if=%s."), resource->uri, interfaceFilter);
445 * If the filters are null, they will be assumed to NOT be present
446 * and the resource will not be matched against them.
447 * Function will return true if all non null AND non empty filters passed in find a match.
449 static bool includeThisResourceInResponse(OCResource *resource,
450 char *interfaceFilter,
451 char *resourceTypeFilter)
455 OC_LOG(ERROR, TAG, PCF("Invalid resource"));
459 if ( !(resource->resourceProperties & OC_ACTIVE) ||
460 !(resource->resourceProperties & OC_DISCOVERABLE))
462 OC_LOG_V(INFO, TAG, PCF("%s not ACTIVE or DISCOVERABLE"), resource->uri);
466 return resourceMatchesIFFilter(resource, interfaceFilter) &&
467 resourceMatchesRTFilter(resource, resourceTypeFilter);
471 OCStackResult SendNonPersistantDiscoveryResponse(OCServerRequest *request, OCResource *resource,
472 OCPayload *discoveryPayload)
474 OCEntityHandlerResponse response = {};
476 response.ehResult = OC_EH_OK;
477 response.payload = discoveryPayload;
478 response.persistentBufferFlag = 0;
479 response.requestHandle = (OCRequestHandle) request;
480 response.resourceHandle = (OCResourceHandle) resource;
482 return OCDoResponse(&response);
485 static OCStackResult HandleVirtualResource (OCServerRequest *request, OCResource* resource)
487 if (!request || !resource)
489 return OC_STACK_INVALID_PARAM;
492 OCStackResult discoveryResult = OC_STACK_ERROR;
493 OCPayload* payload = NULL;
494 char *filterOne = NULL;
495 char *filterTwo = NULL;
497 OC_LOG(INFO, TAG, PCF("Entering HandleVirtualResource"));
499 OCVirtualResources virtualUriInRequest = GetTypeOfVirtualURI (request->resourceUrl);
502 if (virtualUriInRequest == OC_WELL_KNOWN_URI)
504 discoveryResult = getQueryParamsForFiltering (virtualUriInRequest, request->query,
505 &filterOne, &filterTwo);
506 if (discoveryResult != OC_STACK_OK)
508 OC_LOG_V(ERROR, TAG, "Error (%d) validating query.\n", discoveryResult);
509 return discoveryResult;
511 payload = (OCPayload*)OCDiscoveryPayloadCreate();
515 return OC_STACK_NO_MEMORY;
519 for(;resource && discoveryResult == OC_STACK_OK; resource = resource->next)
521 if(includeThisResourceInResponse(resource, filterOne, filterTwo))
523 discoveryResult = BuildVirtualResourceResponse(resource,
524 (OCDiscoveryPayload*)payload,
525 (CATransportAdapter_t)request->devAddr.adapter);
529 else if (virtualUriInRequest == OC_DEVICE_URI)
531 payload = (OCPayload*)OCDevicePayloadCreate(OC_RSRVD_DEVICE_URI,
532 OCGetServerInstanceID(), savedDeviceInfo.deviceName,
533 OC_SPEC_VERSION, OC_DATA_MODEL_VERSION);
536 discoveryResult = OC_STACK_NO_MEMORY;
539 else if (virtualUriInRequest == OC_PLATFORM_URI)
541 OCPlatformPayload* payload = OCPlatformPayloadCreate(
542 OC_RSRVD_PLATFORM_URI,
546 discoveryResult = OC_STACK_NO_MEMORY;
553 if(resource->resourceProperties & OC_ACTIVE)
555 discoveryResult = SendPresenceNotification(resource->rsrcType,
556 OC_PRESENCE_TRIGGER_CHANGE);
561 // Presence uses observer notification api to respond via SendPresenceNotification.
562 if (virtualUriInRequest != OC_PRESENCE)
564 if(discoveryResult == OC_STACK_OK)
566 discoveryResult = SendNonPersistantDiscoveryResponse(request, resource,
568 OCPayloadDestroy(payload);
572 OC_LOG_V(ERROR, TAG, "Error (%d) building (%d) discovery response. "\
573 "Not responding to request.", discoveryResult, virtualUriInRequest);
577 return discoveryResult;
581 HandleDefaultDeviceEntityHandler (OCServerRequest *request)
585 return OC_STACK_INVALID_PARAM;
588 OCStackResult result = OC_STACK_OK;
589 OCEntityHandlerResult ehResult = OC_EH_ERROR;
590 OCEntityHandlerRequest ehRequest = {};
592 OC_LOG(INFO, TAG, PCF("Entering HandleResourceWithDefaultDeviceEntityHandler"));
593 result = FormOCEntityHandlerRequest(&ehRequest, (OCRequestHandle) request,
594 request->method, (OCResourceHandle) NULL, request->query,
595 request->payload, request->payloadSize,
596 request->numRcvdVendorSpecificHeaderOptions,
597 request->rcvdVendorSpecificHeaderOptions,
598 (OCObserveAction)request->observationOption, (OCObservationId)0);
599 VERIFY_SUCCESS(result, OC_STACK_OK);
601 // At this point we know for sure that defaultDeviceHandler exists
602 ehResult = defaultDeviceHandler(OC_REQUEST_FLAG, &ehRequest,
603 (char*) request->resourceUrl, defaultDeviceHandlerCallbackParameter);
604 if(ehResult == OC_EH_SLOW)
606 OC_LOG(INFO, TAG, PCF("This is a slow resource"));
607 request->slowFlag = 1;
609 else if(ehResult == OC_EH_ERROR)
611 FindAndDeleteServerRequest(request);
613 result = EntityHandlerCodeToOCStackCode(ehResult);
619 HandleResourceWithEntityHandler (OCServerRequest *request,
620 OCResource *resource,
621 uint8_t collectionResource)
623 if(!request || ! resource)
625 return OC_STACK_INVALID_PARAM;
628 OCStackResult result = OC_STACK_ERROR;
629 OCEntityHandlerResult ehResult = OC_EH_ERROR;
630 OCEntityHandlerFlag ehFlag = OC_REQUEST_FLAG;
631 ResourceObserver *resObs = NULL;
633 OCEntityHandlerRequest ehRequest = {};
635 OC_LOG(INFO, TAG, PCF("Entering HandleResourceWithEntityHandler"));
637 result = FormOCEntityHandlerRequest(&ehRequest, (OCRequestHandle) request,
638 request->method, (OCResourceHandle) resource, request->query,
639 request->payload, request->payloadSize, request->numRcvdVendorSpecificHeaderOptions,
640 request->rcvdVendorSpecificHeaderOptions,
641 (OCObserveAction)request->observationOption, 0);
642 VERIFY_SUCCESS(result, OC_STACK_OK);
644 if(ehRequest.obsInfo.action == OC_OBSERVE_NO_OPTION)
646 OC_LOG(INFO, TAG, PCF("No observation requested"));
647 ehFlag = OC_REQUEST_FLAG;
649 else if(ehRequest.obsInfo.action == OC_OBSERVE_REGISTER && !collectionResource)
651 OC_LOG(INFO, TAG, PCF("Observation registration requested"));
653 result = GenerateObserverId(&ehRequest.obsInfo.obsId);
654 VERIFY_SUCCESS(result, OC_STACK_OK);
656 result = AddObserver ((const char*)(request->resourceUrl),
657 (const char *)(request->query),
658 ehRequest.obsInfo.obsId, request->requestToken, request->tokenLength,
659 resource, request->qos,
662 if(result == OC_STACK_OK)
664 OC_LOG(INFO, TAG, PCF("Added observer successfully"));
665 request->observeResult = OC_STACK_OK;
666 ehFlag = (OCEntityHandlerFlag)(OC_REQUEST_FLAG | OC_OBSERVE_FLAG);
670 result = OC_STACK_OK;
672 // The error in observeResult for the request will be used when responding to this
673 // request by omitting the observation option/sequence number.
674 request->observeResult = OC_STACK_ERROR;
675 OC_LOG(ERROR, TAG, PCF("Observer Addition failed"));
676 ehFlag = OC_REQUEST_FLAG;
680 else if(ehRequest.obsInfo.action == OC_OBSERVE_DEREGISTER &&
683 OC_LOG(INFO, TAG, PCF("Deregistering observation requested"));
685 resObs = GetObserverUsingToken (request->requestToken, request->tokenLength);
689 // Stack does not contain this observation request
690 // Either token is incorrect or observation list is corrupted
691 result = OC_STACK_ERROR;
694 ehRequest.obsInfo.obsId = resObs->observeId;
695 ehFlag = (OCEntityHandlerFlag)(ehFlag | OC_OBSERVE_FLAG);
697 result = DeleteObserverUsingToken (request->requestToken, request->tokenLength);
699 if(result == OC_STACK_OK)
701 OC_LOG(INFO, TAG, PCF("Removed observer successfully"));
702 request->observeResult = OC_STACK_OK;
706 result = OC_STACK_OK;
707 request->observeResult = OC_STACK_ERROR;
708 OC_LOG(ERROR, TAG, PCF("Observer Removal failed"));
713 result = OC_STACK_ERROR;
717 ehResult = resource->entityHandler(ehFlag, &ehRequest, resource->entityHandlerCallbackParam);
718 if(ehResult == OC_EH_SLOW)
720 OC_LOG(INFO, TAG, PCF("This is a slow resource"));
721 request->slowFlag = 1;
723 else if(ehResult == OC_EH_ERROR)
725 FindAndDeleteServerRequest(request);
727 result = EntityHandlerCodeToOCStackCode(ehResult);
733 HandleCollectionResourceDefaultEntityHandler (OCServerRequest *request,
734 OCResource *resource)
736 if(!request || !resource)
738 return OC_STACK_INVALID_PARAM;
741 OCStackResult result = OC_STACK_ERROR;
742 OCEntityHandlerRequest ehRequest = {};
744 result = FormOCEntityHandlerRequest(&ehRequest, (OCRequestHandle) request,
745 request->method, (OCResourceHandle) resource, request->query,
746 request->payload, request->payloadSize, request->numRcvdVendorSpecificHeaderOptions,
747 request->rcvdVendorSpecificHeaderOptions,
748 (OCObserveAction)request->observationOption, (OCObservationId) 0);
749 if(result != OC_STACK_OK)
754 return (DefaultCollectionEntityHandler (OC_REQUEST_FLAG, &ehRequest));
758 ProcessRequest(ResourceHandling resHandling, OCResource *resource, OCServerRequest *request)
760 OCStackResult ret = OC_STACK_OK;
764 case OC_RESOURCE_VIRTUAL:
766 ret = HandleVirtualResource (request, resource);
769 case OC_RESOURCE_DEFAULT_DEVICE_ENTITYHANDLER:
771 ret = HandleDefaultDeviceEntityHandler(request);
774 case OC_RESOURCE_NOT_COLLECTION_DEFAULT_ENTITYHANDLER:
776 OC_LOG(INFO, TAG, PCF("OC_RESOURCE_NOT_COLLECTION_DEFAULT_ENTITYHANDLER"));
777 return OC_STACK_ERROR;
779 case OC_RESOURCE_NOT_COLLECTION_WITH_ENTITYHANDLER:
781 ret = HandleResourceWithEntityHandler (request, resource, 0);
784 case OC_RESOURCE_COLLECTION_WITH_ENTITYHANDLER:
786 ret = HandleResourceWithEntityHandler (request, resource, 1);
789 case OC_RESOURCE_COLLECTION_DEFAULT_ENTITYHANDLER:
791 ret = HandleCollectionResourceDefaultEntityHandler (request, resource);
794 case OC_RESOURCE_NOT_SPECIFIED:
796 ret = OC_STACK_NO_RESOURCE;
801 OC_LOG(INFO, TAG, PCF("Invalid Resource Determination"));
802 return OC_STACK_ERROR;
808 void DeletePlatformInfo()
810 OC_LOG(INFO, TAG, PCF("Deleting platform info."));
812 OICFree(savedPlatformInfo.platformID);
813 savedPlatformInfo.platformID = NULL;
815 OICFree(savedPlatformInfo.manufacturerName);
816 savedPlatformInfo.manufacturerName = NULL;
818 OICFree(savedPlatformInfo.manufacturerUrl);
819 savedPlatformInfo.manufacturerUrl = NULL;
821 OICFree(savedPlatformInfo.modelNumber);
822 savedPlatformInfo.modelNumber = NULL;
824 OICFree(savedPlatformInfo.dateOfManufacture);
825 savedPlatformInfo.dateOfManufacture = NULL;
827 OICFree(savedPlatformInfo.platformVersion);
828 savedPlatformInfo.platformVersion = NULL;
830 OICFree(savedPlatformInfo.operatingSystemVersion);
831 savedPlatformInfo.operatingSystemVersion = NULL;
833 OICFree(savedPlatformInfo.hardwareVersion);
834 savedPlatformInfo.hardwareVersion = NULL;
836 OICFree(savedPlatformInfo.firmwareVersion);
837 savedPlatformInfo.firmwareVersion = NULL;
839 OICFree(savedPlatformInfo.supportUrl);
840 savedPlatformInfo.supportUrl = NULL;
842 OICFree(savedPlatformInfo.systemTime);
843 savedPlatformInfo.systemTime = NULL;
846 static OCStackResult DeepCopyPlatFormInfo(OCPlatformInfo info)
848 savedPlatformInfo.platformID = OICStrdup(info.platformID);
849 savedPlatformInfo.manufacturerName = OICStrdup(info.manufacturerName);
850 savedPlatformInfo.manufacturerUrl = OICStrdup(info.manufacturerUrl);
851 savedPlatformInfo.modelNumber = OICStrdup(info.modelNumber);
852 savedPlatformInfo.dateOfManufacture = OICStrdup(info.dateOfManufacture);
853 savedPlatformInfo.platformVersion = OICStrdup(info.platformVersion);
854 savedPlatformInfo.operatingSystemVersion = OICStrdup(info.operatingSystemVersion);
855 savedPlatformInfo.hardwareVersion = OICStrdup(info.hardwareVersion);
856 savedPlatformInfo.firmwareVersion = OICStrdup(info.firmwareVersion);
857 savedPlatformInfo.supportUrl = OICStrdup(info.supportUrl);
858 savedPlatformInfo.systemTime = OICStrdup(info.systemTime);
860 if ((!savedPlatformInfo.platformID && info.platformID)||
861 (!savedPlatformInfo.manufacturerName && info.manufacturerName)||
862 (!savedPlatformInfo.manufacturerUrl && info.manufacturerUrl)||
863 (!savedPlatformInfo.modelNumber && info.modelNumber)||
864 (!savedPlatformInfo.dateOfManufacture && info.dateOfManufacture)||
865 (!savedPlatformInfo.platformVersion && info.platformVersion)||
866 (!savedPlatformInfo.operatingSystemVersion && info.operatingSystemVersion)||
867 (!savedPlatformInfo.hardwareVersion && info.hardwareVersion)||
868 (!savedPlatformInfo.firmwareVersion && info.firmwareVersion)||
869 (!savedPlatformInfo.supportUrl && info.supportUrl)||
870 (!savedPlatformInfo.systemTime && info.systemTime))
872 DeletePlatformInfo();
873 return OC_STACK_INVALID_PARAM;
880 OCStackResult SavePlatformInfo(OCPlatformInfo info)
882 DeletePlatformInfo();
884 OCStackResult res = DeepCopyPlatFormInfo(info);
886 if (res != OC_STACK_OK)
888 OC_LOG_V(ERROR, TAG, PCF("Failed to save platform info. errno(%d)"), res);
892 OC_LOG(ERROR, TAG, PCF("Platform info saved."));
898 void DeleteDeviceInfo()
900 OC_LOG(INFO, TAG, PCF("Deleting device info."));
902 OICFree(savedDeviceInfo.deviceName);
903 savedDeviceInfo.deviceName = NULL;
906 static OCStackResult DeepCopyDeviceInfo(OCDeviceInfo info)
908 savedDeviceInfo.deviceName = OICStrdup(info.deviceName);
910 if(!savedDeviceInfo.deviceName && info.deviceName)
913 return OC_STACK_NO_MEMORY;
919 OCStackResult SaveDeviceInfo(OCDeviceInfo info)
921 OCStackResult res = OC_STACK_OK;
925 res = DeepCopyDeviceInfo(info);
927 VERIFY_SUCCESS(res, OC_STACK_OK);
929 if(OCGetServerInstanceID() == NULL)
931 OC_LOG(INFO, TAG, PCF("Device ID generation failed"));
932 res = OC_STACK_ERROR;
936 OC_LOG(INFO, TAG, PCF("Device initialized successfully."));