1 //******************************************************************
3 // Copyright 2015 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 RESOURCECONTAINERBUNDLEAPI_H_
22 #define RESOURCECONTAINERBUNDLEAPI_H_
28 #include "RCSBundleInfo.h"
29 #include "Configuration.h"
30 #include "NotificationReceiver.h"
31 #include "BundleResource.h"
33 using namespace OIC::Service;
39 class ResourceContainerBundleAPI: public NotificationReceiver
44 * Constructor for ResourceContainerBundleAPI
46 ResourceContainerBundleAPI();
49 * Virtual destructor for ResourceContainerBundleAPI
51 virtual ~ResourceContainerBundleAPI();
54 * Register bundle resource in the container
55 * and register resource server for bundle resource
57 * @param resource - bundle resource to register
61 virtual void registerResource(BundleResource *resource) = 0;
64 * Unregister bundle resource from the container
65 * and unregister resource server
67 * @param resource - bundle resource to unregister
71 virtual void unregisterResource(BundleResource *resource) = 0;
74 * Get Configuration data of certain bundle
76 * @param [in] bundleId - bundle id to get configuration data
78 * @param [out] configOutput - returned configuration data
82 virtual void getBundleConfiguration(const std::string &bundleId, configInfo *configOutput) = 0;
85 * Get the list of Configuration data of resources that certain bundle has
87 * @param [in] bundleId - bundle id to get configuration data
89 * @param [out] configOutput - returned resource configuration data vector
93 virtual void getResourceConfiguration(const std::string &bundleId,
94 std::vector< resourceInfo > *configOutput) = 0;
97 * API for getting an instance of ResourceContainerBundleAPI
99 * @return ResourceContainerBundleAPI * - return the object pointer of ResourceContainerBundleAPI
101 static ResourceContainerBundleAPI *getInstance();