1 //******************************************************************
3 // Copyright 2016 Samsung Electronics 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 OC_RESOURCE_DIRECTORY_DATABASE_H_
22 #define OC_RESOURCE_DIRECTORY_DATABASE_H_
31 * Opens the RD publish database.
33 * @param path to the database file.
35 * @return ::OC_STACK_OK in case of success or else other value.
37 OCStackResult OCRDDatabaseInit(const char *path);
40 * Stores in database the published resource.
42 * @param payload is the the published resource payload.
43 * @param address provide information about endpoint connectivity details.
45 * @return ::OC_STACK_OK in case of success or else other value.
47 OCStackResult OCRDDatabaseStoreResources(const OCRepPayload *payload, const OCDevAddr *address);
50 * Search the RD database for queries.
52 * @param interfaceType is the interface type that is queried.
53 * @param resourceType is the resource type that is queried.
54 * @param discPayload is NULL if no resource found or else OCDiscoveryPayload with the details
57 * @return ::OC_STACK_OK in case of success or else other value.
59 OCStackResult OCRDDatabaseCheckResources(const char *interfaceType, const char *resourceType,
60 OCDiscoveryPayload *discPayload);
63 * Updates the RD resource
65 * @param deviceId of the device for which resources will be update.
67 * @return ::OC_STACK_OK in case of success or else other value.
69 OCStackResult OCRDDatabaseUpdateDevice(const char *deviceId);
72 * Delete the RD resource
74 * @param deviceId of the device for which resources will be deleted.
76 * @return ::OC_STACK_OK in case of success or else other value.
78 OCStackResult OCRDDatabaseDeleteDevice(const char *deviceId);
81 * Close the RD publish database.
83 * @return ::OC_STACK_OK in case of success or else other value.
85 OCStackResult OCRDDatabaseClose();