src/include/common/spds/CredentialHandler.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 
00036  #ifndef INCL_CREDENTIAL_HANDLER
00037     #define INCL_CREDENTIAL_HANDLER
00038 
00040     #include "base/fscapi.h"
00041     #include "base/constants.h"
00042     #include "base/util/utils.h"
00043     #include "spds/constants.h"
00044     #include "syncml/core/TagNames.h"
00045     #include "syncml/core/ObjectDel.h"
00046 #include "base/globalsdef.h"
00047 
00048 BEGIN_NAMESPACE
00049 
00050     class CredentialHandler{
00051 
00052     private:
00053 
00054         char*  username;
00055         char*  password;
00056         char*  clientAuthType;
00057         char*  clientNonce;
00058 
00059         char*  serverID;
00060         char*  serverPWD;
00061         char*  serverAuthType;
00062         char*  serverNonce;
00063 
00064         bool isServerAuthRequired;
00065 
00069         void initialize();
00070         void  generateNonce(char nonce[16]);
00071 
00072     public:
00073         /*
00074          * Default constructor
00075          */
00076         CredentialHandler();
00077 
00078         ~CredentialHandler();
00079 
00080         /*
00081          * Constructs a new SyncItem identified by the given key. The key must
00082          * not be longer than DIM_KEY (see SPDS Constants).
00083          *
00084          * @param key - the key
00085          */
00086         CredentialHandler(const char*  key);
00087 
00088         /*
00089          * Returns the SyncItem's key. If key is NULL, the internal buffer is
00090          * returned; if key is not NULL, the value is copied in the caller
00091          * allocated buffer and the given buffer pointer is returned.
00092          *
00093          * @param key - buffer where the key will be stored
00094          */
00095 
00096         void setUsername(const char*  t);
00097         const char*  getUsername();
00098         void setPassword(const char*  t);
00099         const char*  getPassword();
00100         void setClientAuthType(const char*  t);
00101         void setClientNonce(const char*  t);
00102         const char*  getClientAuthType();
00103         const char*  getClientNonce();
00104 
00105         void setServerID(const char*  t);
00106         void setServerPWD(const char*  t);
00107         void setServerAuthType(const char*  t);
00108         void setServerNonce(const char*  t);
00109         const char*  getServerAuthType();
00110         const char*  getServerNonce();
00111 
00112         void setServerAuthRequired(bool t);
00113         bool getServerAuthRequired();
00114 
00115         Cred* getClientCredential();
00116         Cred* getServerCredential();
00117         Chal* getServerChal(bool isServerAuthenticated);
00118         bool  performServerAuth(Cred* cred);
00119 
00120     };
00121 
00122 
00123 END_NAMESPACE
00124 
00126 #endif

Generated on Wed Jan 14 17:15:36 2009 for Funambol C++ Client Library by  doxygen 1.5.2