syncsourceconfig.h
来自「funambol window mobile客户端源代码」· C头文件 代码 · 共 297 行
H
297 行
/*
* Funambol is a mobile platform developed by Funambol, Inc.
* Copyright (C) 2003 - 2007 Funambol, Inc.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by
* the Free Software Foundation with the addition of the following permission
* added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
* WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE
* WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program; if not, see http://www.gnu.org/licenses or write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA.
*
* You can contact Funambol, Inc. headquarters at 643 Bair Island Road, Suite
* 305, Redwood City, CA 94063, USA, or at email address info@funambol.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License
* version 3, these Appropriate Legal Notices must retain the display of the
* "Powered by Funambol" logo. If the display of the logo is not reasonably
* feasible for technical reasons, the Appropriate Legal Notices must display
* the words "Powered by Funambol".
*/
#ifndef INCL_SYNC_SOURCE_CONFIG
#define INCL_SYNC_SOURCE_CONFIG
/** @cond API */
/** @addtogroup Client */
/** @{ */
#include "spds/AbstractSyncSourceConfig.h"
#include "base/globalsdef.h"
BEGIN_NAMESPACE
/**
* This class is one possible implementation of the
* AbstractSyncSourceConfig API: it implements all attributes as
* read/write members.
*/
class SyncSourceConfig : public AbstractSyncSourceConfig {
protected:
char* name ;
char* uri ;
char* syncModes ;
char* type ;
char* sync ;
char* encodings ;
char* version ;
char* supportedTypes ;
char* encryption ;
// last anchor, set by the engine.
unsigned long last ;
// CTCap data
bool fieldLevel ;
ArrayList ctCaps ;
/**
* Create a new CTCap object, based on the current source configuration.
* To obtain a complete CTCap, the client must have set previously the
* list of CTCap properties with the method setCtCapProperties().
*/
CTCap* createCtCap(ArrayList *props, const char *ct_Type, const char *ver_CT, bool fLevel);
public:
/**
* Constructs a new SyncSourceConfig object
*/
SyncSourceConfig();
/**
* Destructor
*/
~SyncSourceConfig();
/**
* Returns the SyncSource name.
*/
const char* getName() const;
/**
* Sets the SyncSource name
*
* @param n the new name
*/
void setName(const char* n);
/**
* Returns the SyncSource URI (used in SyncML addressing).
*/
const char* getURI() const;
/**
* Sets the SyncSource URI (used in SyncML addressing).
*
* @param u the new uri
*/
void setURI(const char* u);
/**
* Returns a comma separated list of the possible syncModes for the
* SyncSource. Sync modes can be one of
* - slow
* - two-way
* - one-way-from-server
* - one-way-from-client
* - refresh-from-server
* - refresh-from-client
* - one-way-from-server
* - one-way-from-client
* - addrchange
*/
const char* getSyncModes() const;
/**
* Sets the available syncModes for the SyncSource as comma separated
* values.
*
* @param s the new list
*/
void setSyncModes(const char* s);
/**
* Returns the mime type of the items handled by the sync source.
*/
const char* getType() const;
/**
* Sets the mime type of the items handled by the sync source.
*
* @param t the mime type
*/
void setType(const char* t);
/**
* Gets the default syncMode as one of the strings listed in setSyncModes.
*/
const char* getSync() const;
/**
* Returns the default syncMode as one of the strings above.
*/
void setSync(const char* s);
/**
* Specifies how the content of an outgoing item should be
* encoded by the client library if the sync source does not
* set an encoding on the item that it created. Valid values
* are listed in SyncItem::encodings.
*/
const char* getEncoding() const;
void setEncoding(const char* s);
/**
* Returns the version of the source type used by client.
*/
const char* getVersion() const;
/**
* Sets the SyncSource version
*
* @param n the new version
*/
void setVersion(const char* n);
/**
* A string representing the source types (with versions) supported by the SyncSource.
* The string must be formatted as a sequence of "type:version" separated by commas ','.
* For example: "text/x-vcard:2.1,text/vcard:3.0".
* The version can be left empty, for example: "text/x-s4j-sifc:".
* Supported types will be sent as part of the DevInf.
*/
const char* getSupportedTypes() const;
/**
* Sets the supported source types for this source.
*
* @param s the supported types string
*/
void setSupportedTypes(const char* s);
/**
* Sets the last sync timestamp
*
* @param timestamp the last sync timestamp
*/
void setLast(unsigned long timestamp);
/**
* Returns the last sync timestamp
*/
unsigned long getLast() const;
/**
* Specifies if the content of an outgoing item should be encrypted.
* If this property is not empty and valid, the 'encodings' value is ignored
* for outgoing items. The only valid value is "des".
*/
const char* getEncryption() const;
/**
* Sets the encryption type
*
* @param n the encryption type
*/
void setEncryption(const char* n);
/**
* Sets the list of properties to use in the CTCap sent to the server in
* the DevInfo.
*
* @param props an ArrayList of Property
*/
//void setCtCapProperties(ArrayList* props);
/**
* Returns the list of properties to use in the CTCap sent to the server
* in the DevInfo.
*
* @returns an ArrayList of Property
*/
//ArrayList& getCtCapProperties();
/**
* Returns an array of CtCap with all the capabilities for this Source
*
* @return an ArrayList of CTCap
*/
const ArrayList& getCtCaps() const {return ctCaps;};
ArrayList& getCtCaps() {return ctCaps;};
/**
* add a CTCap to the ArrayList. If ctType, verCT and FieldLevel are null
* we set a CTCap with the default verCT, fieldLevel and ctType taken
* from the config
*
* the fieldLevel param has three status
* FLEVEL_DISABLED - to disable the FieldLevel param in the CtCap
* FLEVEL_ENABLED - to enable the FieldLevel param in the CtCap
* FLEVEL_UNDEFINED - not set. In this case the code sets the param to
* the value in the config. Now setted to disable the FieldLevel param
*
* @param ArrayList* props - the arrayList with the properties
* @param const char* ct_Type - optional
* @param const char* ver_CT - optional
* @param int fieldLevel - three different status
*/
void addCtCap(ArrayList* props, const char* ct_Type = 0 , const char* ver_CT = 0, int fLevel = FLEVEL_UNDEFINED);
/**
* Initialize this object with the given SyncSourceConfig
*
* @param sc the source config object
*/
void assign(const SyncSourceConfig& sc);
/**
* Return fieldLevel param. Not implemented yet. Now just returns false
*
* @return bool fieldLevel
*/
bool getFieldLevel(){ return false;}
/**
* Assign operator
*/
SyncSourceConfig& operator = (const SyncSourceConfig& sc) {
assign(sc);
return *this;
}
};
END_NAMESPACE
/** @} */
/** @endcond */
#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?