/*
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
*      Declaration of class CHttpWapSession.
*      
*
*/
#ifndef HTTP_WAP_SESSION_H
#define HTTP_WAP_SESSION_H
// INCLUDES
#include <e32base.h>
#include <http/mhttpsessioneventcallback.h>
#include "HttpSessionBase.h"
// CLASS DECLARATION
/**
* WAP Session.
*/
NONSHARABLE_CLASS( CHttpWapSession )
: public CHttpSessionBase,
  public MHTTPSessionEventCallback
    {
    public:     // Constructors and destructor.
        /**
        * Two phased constructor. Leaves on failure.
        * @param aGateway WAP gateway.
        * @return The created session.
        */      
        static CHttpWapSession* NewL( const TDesC8& aGateway );
        
        /**
        * Destructor.
        */
        virtual ~CHttpWapSession();
    public:     // from CHttpSessionBase
        /**
        * Connect session.
        * @param aStatus Completes when done.
        */
        virtual void ConnectL( TRequestStatus* aStatus );
        /**
        * Disconnect session. Safe to call if not connected. Use this to
        * cancel an outstanding ConnectL.
        */
        virtual void Disconnect();
    protected:    // Constructors and destructor.
        /**
        * Constructor.
        */
        CHttpWapSession();
        /**
        * Second phase constructor. Leaves on failure.
        * @param aGateway WAP gateway.
        */      
        void ConstructL( const TDesC8& aGateway );
        
        /**
        * Handle session event.
        * @param aEvent The event that has occurred.
        */
        void MHFSessionRunL( const THTTPSessionEvent& aEvent );
        /**
        * Handle errors occured in MHFSessionRunL().
        * @param aError The leave code that MHFSessionRunL left with.
        * @param aEvent The Event that was being processed.
        * @return KErrNone.
        */
        TInt MHFSessionRunError
            ( TInt aError, const THTTPSessionEvent& aEvent );
    private:    // new methods
        /**
        * Clean up and notify parent.
        * @param aResult Result of the operation.
        */
        void Done( TInt aResult );
        /**
        * Get a shared string from the session stringpool.
        * @param aId Id of string.
        * @return Shared string from HTTP string table. No need to close.
        */
        inline RStringF StringF( HTTP::TStrings aId );
    private:    // types
        enum TState         ///< State.
            {
            EInit,          ///< Initial state (session is not open).
            EConnecting,    ///< Connecting.
            EConnected,     ///< Session is open and connected.
            EDisconnecting  ///< Disconnecting.
            };
    private:    // data
        TState iState;                  ///< State.
        TRequestStatus* iParentStatus;  ///< Parent status.
        RStringF iGateway;              ///< Gateway. Owned.
        TBool iGatewayOpen;             ///< ETrue if gateway string is open.
        CActiveSchedulerWait* iWait;    ///< Wait object (for disconnect).
    };
#include "HttpWapSession.inl"
#endif /* def HTTP_WAP_SESSION_H */