2 // Open Service Platform
3 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
5 // Licensed under the Apache License, Version 2.0 (the License);
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
9 // http://www.apache.org/licenses/LICENSE-2.0
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
19 * @file FIo_RegistryImpl.h
20 * @brief This is the header file for the %_RegistryImpl class.
22 * This header file contains the declarations of the %_RegistryImpl class.
25 #ifndef _FIO_INTERNAL_REGISTRY_IMPL_H_
26 #define _FIO_INTERNAL_REGISTRY_IMPL_H_
28 #include <FOspConfig.h>
29 #include <FBaseObject.h>
30 #include <FIoFileLock.h>
33 namespace Tizen {namespace Base
45 namespace Tizen { namespace Io
51 // @enum %Registry value Type
54 REG_VALUE_TYPE_INT = 1, // Integer type
55 REG_VALUE_TYPE_REAL, // Real type
56 REG_VALUE_TYPE_STRING, // String type
57 REG_VALUE_TYPE_BINARY, // Binary type
58 REG_VALUE_TYPE_UUID, // UUID type
59 REG_VALUE_TYPE_UUIDSET, // UUIDSET type
63 class _OSP_EXPORT_ _RegistryImpl
64 : public Tizen::Base::Object
70 virtual ~_RegistryImpl(void);
72 result Construct(const Tizen::Base::String& regPath, long openMode, const Tizen::Base::ByteBuffer* pKey = null);
74 result Construct(const Tizen::Base::String& regPath, const char* pOpenMode, const Tizen::Base::ByteBuffer* pSecretKey);
76 static result Remove(const Tizen::Base::String& regPath);
78 result AddSection(const Tizen::Base::String& SectionName);
80 result RemoveSection(const Tizen::Base::String& SectionName);
82 result GetSectionListN(Tizen::Base::Collection::IList** pRetList);
84 result GetEntryListN(const Tizen::Base::String& sectionName, Tizen::Base::Collection::HashMap** pRetList);
87 * Gets all entries in the specified section of the registry.
90 * @return A map of entries @n
91 * If this method fails, @c null value is returned. @n
92 * When there are no entries at all, the method returns an empty map instance.
93 * Use the GetCount() method to check the number of element in the map.
94 * @param sectionName The section name
95 * @exception E_SUCCESS The method was successful.
96 * @exception E_INVALID_STATE This instance has not been constructed yet.
97 * @exception E_SECTION_NOT_FOUND The specified @c sectionName was not found within the registry.
98 * @exception E_OUT_OF_MEMORY The memory was insufficient.
99 * @exception E_IO The system error has occurred.
100 * @remarks Do not forget to delete not only the returned IMap instance, but also its
101 * contents by invoking IMap::RemoveAll(). @n
102 * The specific error code can be accessed using the GetLastResult() method.
104 Tizen::Base::Collection::IMap* GetAllEntriesN(const Tizen::Base::String& sectionName) const;
106 Tizen::Base::Collection::IList* GetAllEntryNamesN(const Tizen::Base::String& sectionName) const;
108 result GetEntryList(const Tizen::Base::String& sectionName, Tizen::Base::Collection::HashMap& retMap);
110 result GetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, float& entryValue);
112 result GetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, double& entryValue);
114 result GetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, Tizen::Base::String& entryValue);
116 result AddValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, float entryValue);
118 result AddValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, double entryValue);
120 result AddValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, const Tizen::Base::String& entryValue);
122 result SetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, float entryValue);
124 result SetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, double entryValue);
126 result SetValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName, const Tizen::Base::String& entryValue);
128 result RemoveValue(const Tizen::Base::String& sectionName, const Tizen::Base::String& entryName);
132 int GetSectionIndex(const Tizen::Base::String& sectionName);
134 Tizen::Base::String GetSectionName(int sectionIndex);
136 int GetEntryIndex(int sectionIndex, const Tizen::Base::String& entryName);
138 Tizen::Base::String GetEntryName(int sectionIndex, int entryIndex);
140 void Removekey(const Tizen::Base::String& sectionName, const Tizen::Base::String& keyName);
142 int GetAllSectionCount(void);
144 int GetAllEntryCount(int sectionIndex);
146 void RemoveEntry(int sectionIndex, int entryIndex);
148 void GetEntryValue(int sectionIndex, int entryIndex, _RegValueType type, void* pValue, int* pSize);
150 void ModifyEntryValue(int sectionIndex, int entryIndex, _RegValueType type, const void* pValue, int size);
152 FileLock* LockN(FileLockType lockType);
154 FileLock* TryToLockN(FileLockType lockType);
156 static result ConvertToSecureRegistry(const Tizen::Base::String& plainRegPath, const Tizen::Base::String& secureRegPath, const Tizen::Base::ByteBuffer* key = null);
158 static _RegistryImpl* GetInstance(Registry& registry);
160 static const _RegistryImpl* GetInstance(const Registry& registry);
163 _RegistryImpl(const _RegistryImpl& source);
165 _RegistryImpl& operator =(const _RegistryImpl& source);
167 void* GetSectionByIndex(int sectionIndex);
169 static bool ConvertRegistryOpenMode(long legacyMode, char* pOpenMode);
171 static result CheckOpenMode(const Tizen::Base::String& openMode);
173 _RegistryCore* __pRegistryCore;
181 #endif // _FIO_INTERNAL_REGISTRY_IMPL_H_