Show stream.h syntax highlighted
/*
* Copyright (C) 2001-2004 Peter J Jones (pjones@pmade.org)
* All Rights Reserved
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name of the Author nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
/** @file
* This file contains the definition of the Netxx::TLS::Stream class.
**/
#ifndef _netxx_tls_stream_h_
#define _netxx_tls_stream_h_
// Netxx includes
#include <netxx/types.h>
#include <netxx/streambase.h>
#include <netxx/tls/context.h>
namespace Netxx {
// forward declarations
class ProbeInfo;
namespace TLS {
// forward declaration
class Certificate;
struct tls_pimpl;
/**
* The Netxx::TLS::Stream class is used to send and receive data on a
* connected TLS socket. It has two constructors, one that connects to the
* given address and another that uses an already connected socket.
*
* When using the constructor that can take a socket descriptor you must
* specifiy whether the TLS::Stream should operate in server or client mode.
* This is due to the TLS protocol being a little different for a client
* than it is for a server.
**/
class Stream : public Netxx::StreamBase {
public:
/**
* The connection mode for the Netxx::TLS::Stream
*/
enum Mode {
mode_client, ///< This Netxx::TLS::Stream should act as a TLS client.
mode_server ///< This Netxx::TLS::Stream shoudl act as a TLS server.
};
//####################################################################
/**
* Construct a new Netxx::TLS::Stream object. This constructor will
* connect to the peer given in the Netxx::Address class.
*
* @param context The context to use for this stream.
* @param address The address to connect to.
* @param timeout The timeout to use for the connect and stream operations.
* @author Peter Jones
**/
//####################################################################
explicit Stream (Context &context, const Address &address, const Timeout &timeout=Timeout());
//####################################################################
/**
* Construct a new Netxx::TLS::Stream object. This constructor will
* connect to the given address. The given address string is passed to a
* Netxx::Address class.
*
* @param context The contect to use for this stream.
* @param addr The address to connect to.
* @param default_port The port to connect to if one is not given in addr.
* @param timeout The timeout to use for the connect and stream operations.
* @author Peter Jones
**/
//####################################################################
Stream (Context &context, const char *addr, port_type default_port, const Timeout &timeout=Timeout());
//####################################################################
/**
* Construct a new Netxx::TLS::Stream object and start TLS on the given
* socket file descriptor. This object will then own the socket file
* descriptor and will close it when it is done with it.
*
* A mode is needed so that the Netxx::TLS::Stream will know what parts
* of the TLS protocol to use, client or server. Default is client.
*
* @param context The TLS::Context to use for this stream.
* @param socketfd The socket file descriptor to use.
* @param mode Is this a TLS server or client?
* @param timeout The Timeout to use for stream operations.
* @author Peter Jones
**/
//####################################################################
Stream (Context &context, socket_type socketfd, Mode mode=mode_client, const Timeout &timeout=Timeout());
//####################################################################
/**
* Netxx::TLS::Stream destructor. Shutdown the TLS connection if
* necessary and clean things up.
*
* @author Peter Jones
**/
//####################################################################
~Stream (void);
//####################################################################
/**
* Read data from the TLS connection and place it into the given buffer.
* If an error occures this function will throw an exception.
*
* @param buffer The buffer to store the read data into.
* @param length The size of the given buffer.
* @return Greater than 0: The number of bytes stored in the buffer.
* @return 0: The connected peer closed the connection.
* @return -1: A timeout occured.
* @author Peter Jones
**/
//####################################################################
signed_size_type read (void *buffer, size_type length);
//####################################################################
/**
* Write data from the given buffer to the TLS conection. If an error
* occures this function will throw an exception.
*
* @param buffer The buffer to write to the connection.
* @param length The number of bytes to use from the buffer.
* @return Greater than 0: The number of bytes written to the connection.
* @return 0: The connected peer closed the connection.
* @return -1: A timeout occured.
* @author Peter Jones
**/
//####################################################################
signed_size_type write (const void *buffer, size_type length);
//####################################################################
/**
* Close the connection. Once you do this you can't call read or write
* anymore. This is normally done by the destructor.
*
* @author Peter Jones
**/
//####################################################################
void close (void);
//####################################################################
/**
* Get the connected peer's certificate.
*
* @return A valid certificate if the peer gave one to you
* @return An invalid certificate if the peer does not have one
* @author Alex Mitrofanov
**/
//####################################################################
const Certificate& get_peer_cert (void) const;
//####################################################################
/**
* Get the certificate for the issuer of the connected peer's
* certificate.
*
* @return A valid certificate if the peer gave one and it was signed by an issuer
* @return An invalid certificate if there was no peer cert or no issuer
* @author Alex Mitrofanov
**/
//####################################################################
const Certificate& get_issuer_cert (void) const;
//####################################################################
/**
* Return the current socket file descriptor in use.
*
* @author Alex Mitrofanov
**/
//####################################################################
socket_type get_socketfd (void) const;
//####################################################################
/**
* Get information about how this TLS::Stream should be probed from the
* Netxx::Probe class.
*
* @return A Netxx::ProbeInfo object.
* @author Peter Jones
**/
//####################################################################
const ProbeInfo* get_probe_info (void) const;
private:
tls_pimpl *pimpl_;
Stream (const Stream&);
Stream& operator= (const Stream&);
}; // end Netxx::TLS::Stream class
}} // end Netxx and TLS namespaces
#endif
See more files for this project here
AlphaMail is an accelerated web mail interface with a C++ middleware layer that is more effective than an IMAP proxy which is a highly scalable (10k+ users). The interface includes modern features, Section 508 compliance, and universal browser support.
Project homepage:
http://sourceforge.net/projects/alphamail
Programming language(s): C++,Java,JavaScript,Perl
License: other
certificate.h
context.h
netxx.h
stream.h