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 00036 00037 #ifndef INCL_DATA_STORE 00038 #define INCL_DATA_STORE 00039 /** @cond DEV */ 00040 00041 #include "base/fscapi.h" 00042 #include "base/util/ArrayList.h" 00043 #include "syncml/core/SourceRef.h" 00044 #include "syncml/core/ContentTypeInfo.h" 00045 #include "syncml/core/DSMem.h" 00046 #include "syncml/core/SyncCap.h" 00047 #include "base/globalsdef.h" 00048 00049 BEGIN_NAMESPACE 00050 00051 00052 class DataStore : public ArrayElement { 00053 00054 // ------------------------------------------------------------ Private data 00055 private: 00056 SourceRef* sourceRef; 00057 char* displayName; 00058 long maxGUIDSize; 00059 ContentTypeInfo* rxPref; 00060 ArrayList* rx; // ContentTypeInfo[] 00061 ContentTypeInfo* txPref; 00062 ArrayList* tx; // ContentTypeInfo[] 00063 ArrayList* ctCaps; 00064 DSMem* dsMem; 00065 SyncCap* syncCap; 00066 00067 void initialize(); 00068 00069 // ---------------------------------------------------------- Public data 00070 public: 00071 00072 DataStore(); 00073 ~DataStore(); 00074 00075 /** 00076 * Creates a new DataStore object with the given input information 00077 * 00078 * @param sourceRef specifies the source address from the associated 00079 * command - NOT NULL 00080 * @param displayName the display name 00081 * @param maxGUIDSize the maximum GUID size. Set to -1 if the Maximum GUID 00082 * size is unknown or unspecified. Otherwise, this 00083 * parameter should be a positive number. 00084 * @param rxPref the relative information received to the content type 00085 * preferred - NOT NULL 00086 * @param rx an array of the relative info received to the content type 00087 * supported - NOT NULL 00088 * @param txPref the relative information trasmitted 00089 * to the content type preferred - NOT NULL 00090 * @param tx an array of the relative info trasmitted to the content type 00091 * supported - NOT NULL 00092 * @param dsMem the datastore memory info 00093 * @param syncCap the synchronization capabilities - NOT NULL 00094 * 00095 */ 00096 DataStore(SourceRef* sourceRef, 00097 char* displayName, 00098 long maxGUIDSize, 00099 ContentTypeInfo* rxPref, 00100 ArrayList* rx, 00101 ContentTypeInfo* txPref, 00102 ArrayList* tx, 00103 ArrayList* ct_Caps, 00104 DSMem* dsMem, 00105 SyncCap* syncCap); 00106 00107 /** 00108 * Gets the sourceRef properties 00109 * 00110 * @return the sourceRef properties 00111 */ 00112 SourceRef* getSourceRef(); 00113 00114 /** 00115 * Sets the reference URI 00116 * 00117 * @param sourceRef the reference URI 00118 * 00119 */ 00120 void setSourceRef(SourceRef* sourceRef); 00121 00122 /** 00123 * Gets the displayName properties 00124 * 00125 * @return the displayName properties 00126 */ 00127 const char* getDisplayName(); 00128 00129 /** 00130 * Sets the displayName property 00131 * 00132 * @param displayName the displauName property 00133 * 00134 */ 00135 void setDisplayName(const char* displayName); 00136 00137 /** 00138 * Gets the maxGUIDSize properties 00139 * 00140 * @return the maxGUIDSize properties 00141 */ 00142 long getMaxGUIDSize(); 00143 00144 void setMaxGUIDSize(long maxGUIDSize); 00145 00146 /** 00147 * Gets the ContentTypeInfo corresponds to <Rx-Pref> element 00148 * 00149 * @return the ContentTypeInfo corresponds to &l;tRx-Pref> element 00150 */ 00151 ContentTypeInfo* getRxPref(); 00152 00153 /** 00154 * Sets the preferred type and version of a content type received by the device 00155 * 00156 * @param rxPref the preferred type and version of a content type 00157 */ 00158 void setRxPref(ContentTypeInfo* rxPref); 00159 00160 /** 00161 * Gets the ContentTypeInfo corresponds to <Rx> element 00162 * 00163 * @return the ContentTypeInfo corresponds to <Rx> element 00164 */ 00165 ArrayList* getRx(); 00166 00167 /** 00168 * Sets the supported type and version of a content type received by the device 00169 * 00170 * @param rxCTI and array of supported type and version of a content type 00171 */ 00172 void setRx(ArrayList* rxCTI); 00173 00174 00175 /** 00176 * Gets the ContentTypeInfo corresponds to <Tx-Pref> element 00177 * 00178 * @return the ContentTypeInfo corresponds to <Tx-Pref> element 00179 */ 00180 ContentTypeInfo* getTxPref(); 00181 00182 /** 00183 * Sets the preferred type and version of a content type trasmitted by the device 00184 * 00185 * @param txPref the preferred type and version of a content type 00186 */ 00187 void setTxPref(ContentTypeInfo* txPref); 00188 00189 /** 00190 * Gets an array of ContentTypeInfo corresponds to <Tx> element 00191 * 00192 * @return an array of ContentTypeInfo corresponds to <Tx> element 00193 */ 00194 ArrayList* getTx(); 00195 00196 /** 00197 * Sets the supported type and version of a content type trasmitted by the device 00198 * 00199 * @param txCTI and array of supported type and version of a content type 00200 */ 00201 void setTx(ArrayList* txCTI); 00202 00203 /** 00204 * Gets the datastore memory information. 00205 * 00206 * @return the datastore memory information. 00207 */ 00208 DSMem* getDSMem(); 00209 00210 /** 00211 * Sets the datastore memory information 00212 * 00213 * @param dsMem the datastore memory information 00214 */ 00215 void setDSMem(DSMem* dsMem); 00216 00217 /** 00218 * Gets the synchronization capabilities of a datastore. 00219 * 00220 * @return the synchronization capabilities of a datastore. 00221 */ 00222 SyncCap* getSyncCap(); 00223 00224 /** 00225 * Sets the synchronization capabilities of a datastore. 00226 * 00227 * @param syncCap the synchronization capabilities of a datastore 00228 * 00229 */ 00230 void setSyncCap(SyncCap* syncCap); 00231 00232 /** 00233 * Gets an array of CtCaps corresponds to <CTCap> element 00234 * 00235 * @return an array of CTCaps corresponds to <CTCap> element 00236 */ 00237 ArrayList* getCtCaps(); 00238 00239 /** 00240 * Sets an array of CtCaps 00241 * 00242 * @param Ct_Caps an array of Ctcaps 00243 */ 00244 void setCtCaps(ArrayList* Ct_Caps); 00245 00246 00247 ArrayElement* clone(); 00248 00249 }; 00250 00251 00252 END_NAMESPACE 00253 00254 /** @endcond */ 00255 #endif