Main Page   Class Hierarchy   Compound List   File List   Compound Members   Related Pages  

SecureChannel.hpp

00001 /* -*- C++ -*- */
00002 
00003 /*
00004  * The Apache Software License, Version 1.1
00005  *
00006  *
00007  * Copyright (c) 2002 The Apache Software Foundation.  All rights
00008  * reserved.
00009  *
00010  * Redistribution and use in source and binary forms, with or without
00011  * modification, are permitted provided that the following conditions
00012  * are met:
00013  *
00014  * 1. Redistributions of source code must retain the above copyright
00015  *    notice, this list of conditions and the following disclaimer.
00016  *
00017  * 2. Redistributions in binary form must reproduce the above copyright
00018  *    notice, this list of conditions and the following disclaimer in
00019  *    the documentation and/or other materials provided with the
00020  *    distribution.
00021  *
00022  * 3. The end-user documentation included with the redistribution,
00023  *    if any, must include the following acknowledgment:
00024  *       "This product includes software developed by the
00025  *        Apache Software Foundation (http://www.apache.org/)."
00026  *    Alternately, this acknowledgment may appear in the software itself,
00027  *    if and wherever such third-party acknowledgments normally appear.
00028  *
00029  * 4. The names "SOAP" and "Apache Software Foundation" must
00030  *    not be used to endorse or promote products derived from this
00031  *    software without prior written permission. For written
00032  *    permission, please contact apache@apache.org.
00033  *
00034  * 5. Products derived from this software may not be called "Apache",
00035  *    nor may "Apache" appear in their name, without prior written
00036  *    permission of the Apache Software Foundation.
00037  *
00038  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
00039  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00040  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00041  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
00042  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00043  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00044  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
00045  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00046  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00047  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
00048  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00049  * SUCH DAMAGE.
00050  * ====================================================================
00051  *
00052  * This software consists of voluntary contributions made by many
00053  * individuals on behalf of the Apache Software Foundation.  For more
00054  * information on the Apache Software Foundation, please see
00055  * <http://www.apache.org/>.
00056  */
00057 
00058 /*
00059  *
00060  *
00061  * @author 
00062 
00063  *
00064  */
00065 
00066 
00067 #if !defined(_AXIS_SECURECHANNEL_HPP)
00068 #define _AXIS_SECURECHANNEL_HPP
00069 
00070 #include <axis/server/AxisException.h>
00071 #include "Channel.hpp"
00072 #include <openssl/ssl.h>
00073 #include <openssl/err.h>
00074 
00075 
00076 class SecureChannel : public Channel
00077 {
00078     public:
00079     SecureChannel();
00080     virtual ~SecureChannel();
00081     bool Open(std::string& p_RemoteNode, unsigned short p_RemoteEnd) throw (ChannelException);
00082     const Channel& operator << (const std::string& msg);
00083     const Channel& operator >> (std::string& msg);
00085         const std::string& GetLastError(){return m_LastErr;}
00086 
00088         void SetTransportHandler(Transport* transport){m_pTransportHandler = transport;}
00089     void CloseChannel();
00090     
00091     private:
00092     bool Init();
00093     void Error(const char * err);
00094 
00095     //unsigned int      m_Sock;                         ///< Socket descriptor
00096     //std::string               m_RemoteNode;           ///< Remote address could be IP/host-name
00097     //unsigned short    m_RemoteEnd;            ///< Remote port number
00098     //std::string               m_LastErr;                      ///< Last error as a string
00099     //Transport * m_pTransportHandler;  ///< Transport handler for validation purpose
00100     SSL_CTX* m_sslContext;
00101     SSL* m_sslHandle;
00102 
00103 };    
00104 
00105 #endif // _AXIS_SECURECHANNEL_HPP

Generated on Fri Apr 9 12:21:29 2004 for axiscpp by doxygen1.2.18