src/include/common/client/DMTClientConfig.h

00001 /*
00002  * Funambol is a mobile platform developed by Funambol, Inc. 
00003  * Copyright (C) 2003 - 2007 Funambol, Inc.
00004  * 
00005  * This program is free software; you can redistribute it and/or modify it under
00006  * the terms of the GNU Affero General Public License version 3 as published by
00007  * the Free Software Foundation with the addition of the following permission 
00008  * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
00009  * WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE 
00010  * WARRANTY OF NON INFRINGEMENT  OF THIRD PARTY RIGHTS.
00011  * 
00012  * This program is distributed in the hope that it will be useful, but WITHOUT
00013  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
00014  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
00015  * details.
00016  * 
00017  * You should have received a copy of the GNU Affero General Public License 
00018  * along with this program; if not, see http://www.gnu.org/licenses or write to
00019  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
00020  * MA 02110-1301 USA.
00021  * 
00022  * You can contact Funambol, Inc. headquarters at 643 Bair Island Road, Suite 
00023  * 305, Redwood City, CA 94063, USA, or at email address info@funambol.com.
00024  * 
00025  * The interactive user interfaces in modified source and object code versions
00026  * of this program must display Appropriate Legal Notices, as required under
00027  * Section 5 of the GNU Affero General Public License version 3.
00028  * 
00029  * In accordance with Section 7(b) of the GNU Affero General Public License
00030  * version 3, these Appropriate Legal Notices must retain the display of the
00031  * "Powered by Funambol" logo. If the display of the logo is not reasonably 
00032  * feasible for technical reasons, the Appropriate Legal Notices must display
00033  * the words "Powered by Funambol".
00034  */
00035 #ifndef INCL_DM_CONFIG
00036 #define INCL_DM_CONFIG
00037 
00041 #include "base/fscapi.h"
00042 #include "http/constants.h"
00043 #include "spdm/constants.h"
00044 #include "spds/SyncManagerConfig.h"
00045 #include "spds/AccessConfig.h"
00046 #include "spds/DeviceConfig.h"
00047 #include "spds/SyncSourceConfig.h"
00048 #include "spdm/ManagementNode.h"
00049 #include "base/globalsdef.h"
00050 
00051 BEGIN_NAMESPACE
00052 
00053 class DMTree;
00054 
00062 class DMTClientConfig : public SyncManagerConfig {
00063 
00064     protected:
00065 
00066         char*  rootContext;
00067 
00068         DMTree* dmt;
00069         ManagementNode* syncMLNode;
00070         ManagementNode* sourcesNode;
00071 
00072         void initialize();
00073         DMTClientConfig();
00074 
00075         /* top level functions */
00076         virtual bool readAccessConfig(ManagementNode& n);
00077         virtual void saveAccessConfig(ManagementNode& n);
00078         virtual bool readDeviceConfig(ManagementNode& n);
00079         virtual void saveDeviceConfig(ManagementNode& n);
00080         virtual bool readSourceConfig(int i, ManagementNode& n);
00081         virtual void saveSourceConfig(int i, ManagementNode& n);
00082 
00095         virtual bool readAuthConfig(ManagementNode& syncMLNode,
00096                                     ManagementNode& authNode);
00103         virtual void saveAuthConfig(ManagementNode& syncMLNode,
00104                                     ManagementNode& authNode);
00105 
00113         virtual bool readConnConfig(ManagementNode& syncMLNode,
00114                                     ManagementNode& connNode);
00122         virtual void saveConnConfig(ManagementNode& syncMLNode,
00123                                     ManagementNode& connNode);
00124 
00132         virtual bool readExtAccessConfig(ManagementNode& syncMLNode,
00133                                          ManagementNode& extNode);
00141         virtual void saveExtAccessConfig(ManagementNode& syncMLNode,
00142                                          ManagementNode& extNode);
00143 
00150         virtual bool readDevInfoConfig(ManagementNode& syncMLNode,
00151                                        ManagementNode& devInfoNode);
00158         virtual void saveDevInfoConfig(ManagementNode& syncMLNode,
00159                                        ManagementNode& devInfoNode);
00160 
00168         virtual bool readDevDetailConfig(ManagementNode& syncMLNode,
00169                                          ManagementNode& devDetailNode);
00177         virtual void saveDevDetailConfig(ManagementNode& syncMLNode,
00178                                          ManagementNode& devDetailNode);
00179 
00187         virtual bool readExtDevConfig(ManagementNode& syncMLNode,
00188                                       ManagementNode& extNode);
00196         virtual void saveExtDevConfig(ManagementNode& syncMLNode,
00197                                       ManagementNode& extNode);
00198 
00207         virtual bool readSourceVars(int i,
00208                                     ManagementNode& sourcesNode,
00209                                     ManagementNode& sourceNode);
00210 
00219         virtual void saveSourceVars(int i,
00220                                     ManagementNode& sourcesNode,
00221                                     ManagementNode& sourceNode);
00222 
00232         virtual bool readSourceConfig(int i,
00233                                       ManagementNode& sourcesNode,
00234                                       ManagementNode& sourceNode);
00235 
00245         virtual void saveSourceConfig(int i,
00246                                       ManagementNode& sourcesNode,
00247                                       ManagementNode& sourceNode);
00248 
00249     public:
00250 
00251         DMTClientConfig(const char*  root);
00252 
00253         ~DMTClientConfig();
00254 
00255         SyncSourceConfig* getSyncSourceConfig(const char* name, bool refresh = false);
00256         SyncSourceConfig* getSyncSourceConfig(unsigned int i,   bool refresh = false);
00257 
00258         virtual bool read();
00259         virtual bool save();
00260 
00267         virtual bool open();
00268 
00276         virtual ManagementNode* getSyncMLNode();
00277 
00281         virtual int getNumSources();
00282 
00289         virtual ManagementNode* getSyncSourceNode(int index);
00290 
00294         virtual ManagementNode* getSyncSourceNode(const char* name);
00295 
00301         virtual void close();
00302 };
00303 
00304 
00305 END_NAMESPACE
00306 
00309 #endif

Generated on Fri Jul 25 15:04:15 2008 for Funambol C++ Client Library by  doxygen 1.5.1