browserutilities/downloadmgr/DownloadMgrClntSrv/inc/DownloadMgrHandler.h
author Kiiskinen Klaus (Nokia-D-MSW/Tampere) <klaus.kiiskinen@nokia.com>
Mon, 30 Mar 2009 12:54:55 +0300
changeset 0 dd21522fd290
child 36 0ed94ceaa377
permissions -rw-r--r--
Revision: 200911 Kit: 200912

/*
* Copyright (c) 2004 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: 
*     This file contains the definition of the  receive handler of Download Mgr Server.
*
*/



#ifndef __DOWNLOADMGR_RECEIVEHANDLER_H__
#define __DOWNLOADMGR_RECEIVEHANDLER_H__

#include "DownloadMgrClient.h"
#include <e32base.h>

// FORWARD DECLARATIONS
class RHttpDownload;
class RHttpDownloadMgr;
class MHttpDownloadMgrObserver;

// CLASS DECLARATION

/**
*  Handles the responses of the asyncron services.
*  It can be created by a RHttpDownloadMgr session or 
*  RHttpDownload subsession.
*
*  @lib -
*  @since Series 60 2.8
*/
NONSHARABLE_CLASS( CDownloadMgrHandler ) : public CActive
	{
    public:

        /**
        * C++ default constructor.
        */
        CDownloadMgrHandler( MHttpDownloadMgrObserver* aHandler,
                             RHttpDownload* aSubSession );

        /**
        * C++ default constructor.
        */
        CDownloadMgrHandler( RHttpDownloadMgr* aSession );

        /**
        * Destructor.
        */
        ~CDownloadMgrHandler();

    public:

        /**
        * Starts handle request completion event.
        * @param -
        * @return None.
        */
        void StartL();

        /**
        *  Handler type
        *
        *  @lib -
        *  @since Series 60 2.8
        */
        enum THandlerType
            {
            EHttpDownloadMgr,
            EHttpDownload
            };

    private: // New functions
    
        void AdjustPriority( THttpDownloadEvent& aCurrentDlEvent );
        
    private: // From CActive

        /**
        * Handles an active object’s request completion event.
        * @param -
        * @return None.
        */
        void RunL();

        /**
        * Implements cancellation of an outstanding request.
        * @param -
        * @return None.
        */
        void DoCancel();

    private:
        // Reference the owner
        RHttpDownload*            iDownloadSubSession;  ///< NOT Owned.
        RHttpDownloadMgr*         iDownloadSession;     ///< NOT Owned.
        // Points to the observer
        MHttpDownloadMgrObserver* iHandler;  ///< NOT Owned.
        // Possible event parameters.
        TPckgBuf<TInt32>           iDownloadState;
        TPckgBuf<TInt32>           iProgressState;
        TPckgBuf<TInt>             iHandle;		// Contains masked values of 'handle' and 'media index'
        										// Must be unmasked before use.
        HBufC8*                   iPackedEventAttribs; ///<Owned  Buffer for event attributes
        TPtr8                     iPtr;                ///<Client/Server framework needs this pointer to be saved        
        // Indicates that the corresponding download subsession is closed
        TBool*                    iClosed;
        // Indicates the owner of the handler
        THandlerType              iHandlerType;
        // Storage for the 'previous' download event. Used for priority adjustments.
        THttpDownloadEvent        iPrevDlEvent;
	};


#endif /* __DOWNLOADMGR_RECEIVEHANDLER_H__ */