diff -r 000000000000 -r b16258d2340f applayerpluginsandutils/httptransportplugins/httptransporthandler/csecuresocketcontroller.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/applayerpluginsandutils/httptransportplugins/httptransporthandler/csecuresocketcontroller.h Tue Feb 02 01:09:52 2010 +0200 @@ -0,0 +1,80 @@ +// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "Eclipse Public License v1.0" +// which accompanies this distribution, and is available +// at the URL "http://www.eclipse.org/legal/epl-v10.html". +// +// Initial Contributors: +// Nokia Corporation - initial contribution. +// +// Contributors: +// +// Description: +// + +#ifndef __CSECURESOCKETCONTROLLER_H__ +#define __CSECURESOCKETCONTROLLER_H__ + +#include + +#include "chttpsecuresocket.h" + +class CSecureSocket; + +class CSecureSocketController : public CHttpSecureSocket +/** + This controller class manages secure socket connections for the provided + socket. This class handles the connecting and handshaking of the secure + socket and allows the clients to continue using the secure socket as they + would a normal socket. + @internalComponent +*/ + { +public: // methods + + static CSecureSocketController* NewL(TAny* aInitParams); + + virtual ~CSecureSocketController(); + + void StartSecureHandshakeL(TRequestStatus& aStatus, const TDesC8& aHostName); + + void RecvOneOrMore(TDes8& aBuffer, TRequestStatus& aStatus, TSockXfrLength& aLength); + + void CancelRecv(); + + void Send(const TDesC8& aBuffer, TRequestStatus& aStatus); + + void CancelSend(); + + const CX509Certificate* ServerCert(); + + void CancelHandshake(); + + TInt CipherSuite(TDes8& aCipherSuite); + + TInt PendingBytesToRead (); + +private: // methods + + CSecureSocketController(RSocket& aSocket, MCommsInfoProvider& aCommsInfoProvider); + + +private: // attributes + +/** The socket that requires a secure connection, should already be opened and + takes ownership. +*/ + RSocket& iSocket; + +/** Reference to the Comms infomation provider for security preferences. +*/ + MCommsInfoProvider& iCommsInfoProvider; + +/** The secure socket layer. Created when once a connection has been made. +*/ + CSecureSocket* iTlsSocket; + + }; + +#endif // __CSECURESOCKETCONTROLLER_H__