1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
// $Id: HTTPS_Context.h 91425 2010-08-23 11:59:32Z mcorino $
/**
* @file HTTPS_Context.h
*
* @author Martin Corino <mcorino@remedy.nl>
*/
#ifndef ACE_HTTPS_CONTEXT_H
#define ACE_HTTPS_CONTEXT_H
#include /**/ "ace/pre.h"
#include "ace/SString.h"
#include "ace/Auto_Ptr.h"
#include "ace/Singleton.h"
#include "ace/SSL/SSL_Context.h"
#include "ace/INet/SSL_CallbackManager.h"
#include "ace/INet/INet_SSL_Export.h"
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
namespace ACE
{
namespace HTTPS
{
/**
* @class ACE_HTTPS_Context
*
* @brief Implements security (SSL) context for HTTPS sessions.
*
*/
class ACE_INET_SSL_Export Context
{
public:
Context (bool verify_peer = Context::ssl_verify_peer_,
bool strict = Context::ssl_strict_,
bool once = Context::ssl_once_,
int depth = Context::ssl_depth_,
int ssl_mode = Context::ssl_mode_,
ACE_SSL_Context* ssl_ctx =
ACE_SSL_Context::instance (),
bool release = false,
ACE::INet::SSL_CallbackManager* ssl_cbmngr =
ACE::INet::SSL_CallbackManager::instance ());
Context (ACE_SSL_Context* ssl_ctx,
bool release = false,
ACE::INet::SSL_CallbackManager* ssl_cbmngr = 0);
~Context ();
operator bool (void) const;
bool operator ! (void) const;
ACE_SSL_Context& ssl_context (void);
const ACE_SSL_Context& ssl_context (void) const;
bool use_default_ca ();
bool set_key_files (const char* certificate_filename,
const char* private_key_filename,
int file_type = SSL_FILETYPE_PEM);
bool load_trusted_ca (const char* ca_location);
int has_trusted_ca ();
static void set_default_ssl_mode (int ssl_mode);
static void set_default_verify_mode (bool verify_peer);
static void set_default_verify_settings (bool strict,
bool once = true,
int depth = 0);
static Context& instance ();
private:
friend class ACE_Singleton<Context, ACE_SYNCH::MUTEX>;
//Context ();
Context (const Context&);
ACE_SSL_Context* ssl_ctx_;
ACE_Auto_Ptr<ACE_SSL_Context> alloc_safe;
static int ssl_mode_;
static bool ssl_strict_;
static bool ssl_once_;
static int ssl_depth_;
static bool ssl_verify_peer_;
};
}
}
ACE_END_VERSIONED_NAMESPACE_DECL
#if defined (__ACE_INLINE__)
#include "ace/INet/HTTPS_Context.inl"
#endif
#include /**/ "ace/post.h"
#endif /* ACE_SSL_CALLBACKMANAGER_H */
|