Main Page | Class Hierarchy | Class List | File List | Class Members | File Members

crypto_setup.h

Go to the documentation of this file.
00001 /*
00002 **  ClanLib SDK
00003 **  Copyright (c) 1997-2005 The ClanLib Team
00004 **
00005 **  This software is provided 'as-is', without any express or implied
00006 **  warranty.  In no event will the authors be held liable for any damages
00007 **  arising from the use of this software.
00008 **
00009 **  Permission is granted to anyone to use this software for any purpose,
00010 **  including commercial applications, and to alter it and redistribute it
00011 **  freely, subject to the following restrictions:
00012 **
00013 **  1. The origin of this software must not be misrepresented; you must not
00014 **     claim that you wrote the original software. If you use this software
00015 **     in a product, an acknowledgment in the product documentation would be
00016 **     appreciated but is not required.
00017 **  2. Altered source versions must be plainly marked as such, and must not be
00018 **     misrepresented as being the original software.
00019 **  3. This notice may not be removed or altered from any source distribution.
00020 **
00021 **  Note: Some of the libraries ClanLib link to may have additional
00022 **  requirements or restrictions.
00023 **
00024 **  File Author(s):
00025 **
00026 **    Magnus Norddahl
00027 */
00028 
00029 #ifndef header_crypto_setup
00030 #define header_crypto_setup
00031 
00032 #include <prio.h>
00033 #include <certt.h>
00034 #include <keyt.h>
00035 
00036 class CL_Certificate;
00037 class CL_PrivateKey;
00038 
00039 class PK11PasswordHandler
00040 {
00041 public:
00042         virtual ~PK11PasswordHandler() { return; }
00043         virtual bool get_password(PK11SlotInfo *slot, bool retry, CL_String &out_password)=0;
00044 };
00045 
00046 class PK11PasswordHandler_Password : public PK11PasswordHandler
00047 {
00048 public:
00049         PK11PasswordHandler_Password(const CL_String &password) : password(password) { return; }
00050         virtual bool get_password(PK11SlotInfo *slot, bool retry, CL_String &out_password)
00051         {
00052                 if (retry)
00053                         return false;
00054                 out_password = password;
00055                 return true;
00056         }
00057         CL_String password;
00058 };
00059 
00060 class CL_CryptoSetup
00061 {
00063 public:
00064         CL_CryptoSetup(const CL_String &config_dir, bool read_write = false);
00065         
00066         ~CL_CryptoSetup();
00067 
00069 public:
00070 
00072 public:
00073         void config_server_sid_cache(
00074                 int max_cache_entries = 256,
00075                 unsigned int timeout = 0,
00076                 unsigned int ssl3_timeout = 0,
00077                 const CL_String &directory = CL_String());
00078         
00079         CL_Certificate find_cert_from_nickname(
00080                 const CL_String &nickname,
00081                 PK11PasswordHandler *pw_handler);
00082         
00083         CL_Certificate find_cert_from_nickname(
00084                 const CL_String &nickname,
00085                 const CL_String &password = CL_String());
00086         
00087         CL_PrivateKey find_key_by_any_cert(
00088                 const CL_Certificate &cert,
00089                 PK11PasswordHandler *pw_handler);
00090 
00092 private:
00093         static CL_CryptoSetup *instance;
00094 
00095         static char *pk11_password_func(PK11SlotInfo *slot, PRBool retry, void *arg);
00096 };
00097 
00098 #endif

Generated on Sat Feb 19 22:51:15 2005 for npcore by  doxygen 1.4.1