/usr/include/sipxtapi/os/OsConfigDb.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 | //
// Copyright (C) 2006-2012 SIPez LLC. All rights reserved.
//
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _OsConfigDb_h_
#define _OsConfigDb_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "os/OsDefs.h"
#include "os/OsRWMutex.h"
#include "utl/UtlContainable.h"
#include "utl/UtlSortedList.h"
#include "utl/UtlString.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class OsConfigEncryption;
class UtlSList;
/**
* Class for holding a name/value pair.
*/
class DbEntry : public UtlContainable
{
public:
DbEntry(const UtlString &key);
DbEntry(const UtlString &key, const UtlString &value);
~DbEntry();
virtual UtlContainableType getContainableType() const;
static const UtlContainableType TYPE;
virtual unsigned int hash() const;
int compareTo(const UtlContainable *b) const;
UtlString key;
UtlString value;
};
/**
* Configuration database containing key/value pairs with ability to
* read and write to disk.
*/
class OsConfigDb
{
friend class OsConfigDbTest;
public:
OsConfigDb();
virtual ~OsConfigDb();
virtual OsStatus loadFromFile(FILE* fp);
/**
* Load the configuration database from a file
*/
virtual OsStatus loadFromFile(const char *filename);
/**
* Load the configuation database from a string buffer(Buffer
* CANNOT be encrypted) with the following format:
*
* s : s\n
* s :
* s\n...
*/
virtual OsStatus loadFromBuffer(const char *buf);
/**
* Store the config database to a file
*/
virtual OsStatus storeToFile(const char *filename);
/**
* Attempts to update existing file without loosing comments or parameter order
*/
virtual OsStatus updateFile(const char* filename) const;
/**
* Remove the key/value pair associated with rKey.
*
* return OS_SUCCESS if the key was found in the database,
* return OS_NOT_FOUND otherwise
*/
OsStatus remove(const UtlString& rKey);
/**
* Remove all the key/value pairs starting with the designated prefix
*
* return OS_SUCCESS if one key or more keys were found in the database,
* return OS_NOT_FOUND otherwise
*/
OsStatus removeByPrefix(const UtlString& rPrefix) ;
/**
* Insert the key/value pair into the config database If the
* database already contains an entry for this key, then set the
* value for the existing entry to rNewValue.
*/
void set(const UtlString& rKey, const UtlString& rNewValue);
/**
* Insert the key/value pair into the config database If the
* database already contains an entry for this key, then set the
* value for the existing entry to iNewValue.
*/
void set(const UtlString& rKey, const int iNewValue) ;
/**
* Sets rValue to the value in the database associated with rKey.
* If rKey is found in the database, returns OS_SUCCESS. Otherwise,
* returns OS_NOT_FOUND and sets rValue to the empty string.
*/
virtual OsStatus get(const UtlString& rKey, UtlString& rValue) const;
/**
* Sets rValue to the value in the database associated with rKey.
* If rKey is found in the database, returns OS_SUCCESS. Otherwise,
* returns OS_NOT_FOUND and sets rValue to -1.
*/
virtual OsStatus get(const UtlString& rKey, int& rValue) const;
/**
* Filename, URI, or what helps identify the contents of this config
*/
virtual const char *getIdentityLabel() const;
/**
* Filename, URI, or what helps identify the contents of this config
*/
virtual void setIdentityLabel(const char *idLabel);
/**
* Current encryption support. NULL when there's no encryption
* support, !NULL then there's a possiblity that actual contents of
* config will be encrypted or decrypted from/to io source.
*/
OsConfigEncryption *getEncryption() const;
/**
* Set the default encryption support for all OsConfig instances
*/
static void setStaticEncryption(OsConfigEncryption *encryption);
/**
* Get the encryption support for call instances
*/
static OsConfigEncryption *getStaticEncryption();
/**
* force capitalization of all keys, most profiles want this off
* even keys are typcialy stored as capitalized
*/
void setCapitalizeName(UtlBoolean capitalize);
/**
* Store all contents into a buffer, call calculateBufferSize to
* get safe size. Call strlen to get actual size
*/
void storeToBuffer(char *buff) const;
/**
* Return gauronteed to be large enough, (unless values are
* changed) when storing into a buffer
*/
int calculateBufferSize() const;
/**
* Return TRUE if the database is empty, otherwise FALSE
*/
virtual UtlBoolean isEmpty(void) const;
/**
* Return the number of entries in the config database
*/
virtual int numEntries(void) const;
/**
* Get a hash of name value pairs with the given key prefix
*/
virtual OsStatus getSubHash(const UtlString& rHashSubKey, /**< the prefix for keys to name value pairs
* which are copied into the given rSubDb. The key in the
* sub-OsConfigDb have the prefix removed.
*/
OsConfigDb& rSubDb) const;
/**
* Relative to <i>rKey</i>, return the key and value associated
* with next (lexicographically ordered) key/value pair stored in
* the database. If rKey is the empty string, key and value
* associated with the first entry in the database will be
* returned.
*
* @return OS_SUCCESS if there is a "next" entry;
* @return OS_NOT_FOUND if rKey is not found in the database and is not the
* empty string
* @return OS_NO_MORE_DATA if there is no "next" entry.
*/
virtual OsStatus getNext(const UtlString& rKey,
UtlString& rNextKey, UtlString& rNextValue) const;
/**
* Stores a list of strings to the configuration datadase using the
* designated prefix as the base for the list items. The prefix is used
* to build unique configuration keys. For example, if you use specify
* a prefix of "MYLIST" and supply a list containing ("item 1", "item 2",
* and "item 3"), you will end up with the following:
*
* MYLIST.COUNT : 3
* MYLIST.1 : item 1
* MYLIST.2 : item 2
* MYLIST.3 : item 3
*
* Warning: All items with a key of "[rPrefix]." are removed as a side effect.
*
* @param rPrefix Configuration name prefix
* @param rList List of UtlString values.
*/
virtual void addList(const UtlString& rPrefix,
UtlSList& rList) ;
/**
* Loads a list of strings from the configuration datadase using the
* designated prefix as the base for the list items. The number of
* list items is returned.
*
* @param rPrefix Configuration name prefix
* @param rList List of UtlString values.
*
* @see addList
*/
virtual int loadList(const UtlString& rPrefix,
UtlSList& rList) const;
/**
* Helper method to obtain a port value from the configuration database.
* Results are as follows:
* <pre>
* PORT_DEFAULT : Let a port be selected automatically.
* Represented as "DEFAULT".
* PORT_NONE : Disabled (either specified as such, the key
* was not found, or the value was blank)
* Represented as "NONE".
* other : The port number that was specified
* Represented as a decimal integer.
* </pre>
*
* @param szKey Key file to lookup.
*/
int getPort(const char* szKey) const;
/**
* Delete all entries from the configuration database
*/
void clear() ;
/**
* Remove newlines and carriage returns from string
*/
static void removeNewlineReturns(UtlString& stringData);
protected:
/** reader/writer lock for synchronization */
mutable OsRWMutex mRWMutex;
/** sorted storage of key/values */
UtlSortedList mDb;
/** ID, used to distiguish which files should be encrypted */
UtlString mIdentityLabel;
/**
* Force capitalization on all keys. Most profile do not want this
* on even though most of their keys are already captilized
*/
UtlBoolean mCapitalizeName;
OsStatus loadFromEncryptedFile(const char *filename);
OsStatus loadFromUnencryptedFile(FILE* fp);
OsStatus loadFromEncryptedBuffer(char *buf, int bufLen);
OsStatus loadFromUnencryptedBuffer(const char *buf);
OsStatus storeToEncryptedFile(const char *filename);
OsStatus storeBufferToFile(const char *filename, const char *buff, unsigned long buffLen);
void dump();
virtual OsStatus storeToFile(FILE* fp);
/**
* Parse "key : value" and returns TRUE if parameter found
* Returns false if line is blank or a comment (begins with #).
*/
static UtlBoolean parseLine(const char* line, UtlBoolean capitalizeName, const char* fileLabelForError,
UtlString& name, UtlString& value);
/**
* Method for inserting a key/value pair into the dictionary
* The write lock for the database should be taken before calling this
* method. If the database already contains an entry for this key, then
* set the value for the existing entry to rNewValue.
*/
void insertEntry(const UtlString& rKey, const UtlString& rNewValue);
/**
* Copy constructor (not implemented for this class)
*/
OsConfigDb(const OsConfigDb& rOsConfigDb);
/**
* Assignment operator (not implemented for this class)
*/
OsConfigDb& operator=(const OsConfigDb& rhs);
/**
* Utility func to remove all chars = c from given string
*/
static void removeChars(UtlString *s, char c);
};
/* ============================ INLINE METHODS ============================ */
#endif // _OsConfigDb_h_
|