videofeeds/clientapi/inc/CIptvVodDlDownloadEvent.h
author William Roberts <williamr@symbian.org>
Mon, 08 Mar 2010 21:43:31 +0000
branchCompilerCompatibility
changeset 7 5794cea85c20
parent 0 96612d01cf9f
permissions -rw-r--r--
Create CompilerCompatibility branch

/*
* Copyright (c) 2006 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:    Vod Dl event object*
*/





#ifndef CIPTVVODDLDOWNLOADEVENT_H
#define CIPTVVODDLDOWNLOADEVENT_H

//  INCLUDES
#include <e32base.h>
#include "CIptvUtil.h"

#include "MIptvEvent.h"
#include "TIptvVodDlDownloadId.h"

// CONSTANTS


// MACROS

// DATA TYPES

// FUNCTION PROTOTYPES

// FORWARD DECLARATIONS

// CLASS DECLARATION
class RDesReadStream;
class RDesWriteStream;
class CIptvMyVideosGlobalFileId;

/**
*  Used for sending download events from VOD DL Manager to client.
*
*  @lib IptvClientApi.lib
*/
class CIptvVodDlDownloadEvent : public CBase, public MIptvEvent
    {
    public:
    
        /**
        * Identifies the type of the event. Type specifies which member fields contain
        * valid data.
        */
        enum TEvent
            {
            /**
            * VOD download state change event.
            * All members are valid.
            */ 
            EDownloadState = 0,
            
            /**
            * Response event to CIptvVodDlClient::DownloadReqL() method call.
            * iGlobalFileIsValid and iServiceIdAndContentIdAreValid members indicate which ids are usable.
            * iProgress and iState members do not contain valid data.
            * Download request failed, no download instance was created, iError and iGlobalError members
            * contain reason codes.
            */
            EDownloadReqFailed,

            /**
            * Response event to CIptvVodDlClient::DownloadReqL() method call.
            * iGlobalFileIsValid and iServiceIdAndContentIdAreValid members indicate which ids are usable.
            * iProgress and iState members do not contain valid data.
            * Download request succeeded, download instance was created, EDownloadState
            * messages will follow.
            */
            EDownloadReqSucceeded,
            
            /**
            * Response event to CIptvVodDlClient::CancelDownloadReqL() method call.
            * iGlobalFileIsValid and iServiceIdAndContentIdAreValid members indicate which ids are usable.
            * iProgress and iState members do not contain valid data.
            * Request failed, iError and iGlobalError members contain reason codes.
            */
            ECancelReqFailed,
            
            /**
            * Response event to CIptvVodDlClient::CancelDownloadReqL() method call.
            * iGlobalFileIsValid and iServiceIdAndContentIdAreValid members indicate which ids are usable.
            * iProgress and iState members do not contain valid data.
            * Request succeeded and cancel process started, EDownloadState messages
            * show when download is gone (iState = KIptvVodDlDownloadDeletedCompletely).
            * Notice that client might get ECancelReqSucceeded message after KIptvVodDlDownloadDeletedCompletely.
            */            
            ECancelReqSucceeded,
            
            /**
            * Event indicating that details of download item(s) has been modified. Occurs if EPG
            * data related to download has been modified during download. Forces client to rebuild
            * its information about on-going downloads.
            */
            EDownloadItemsModified,
            
            /**
            * Response event to CIptvVodDlClient::DownloadReqL() method call.
            * This is response for single file download.
            * iServiceId is only usable ident. iContentIndex will contain original request.
            * iState contain result. iProgress member do not contain valid data.
            * Download request is completed.
            */
            EDownloadSingleFileCompleted
            };
            
    public:  // Constructors and destructor
        
        /**
        * Two-phased constructor.
        */
        IMPORT_C static CIptvVodDlDownloadEvent* NewL();
        
        /**
        * Destructor.
        */
        IMPORT_C virtual ~CIptvVodDlDownloadEvent();

    public:
        
        //from MIptvEvent
        IMPORT_C void InternalizeL(RReadStream& aStream);
        IMPORT_C void ExternalizeL(RWriteStream& aStream);
        IMPORT_C TUint32 CountExternalizeSize();
        IMPORT_C MIptvEvent* GetCopyL();
        IMPORT_C void Destruct();

        IMPORT_C void Set(CIptvVodDlDownloadEvent& aEvent);
        
    private:

        /**
        * C++ default constructor.
        */
        CIptvVodDlDownloadEvent();

        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();

    public:     // Data
                
        /**
        * Identifies the type of the event. Type specifies which member fields contain
        * valid data.
        */
        TEvent iEvent;

        /**
        * ETrue if global file ID is valid and can be used.
        */
        TBool iGlobalFileIdIsValid;
        
        /**
        * File ID in My Videos.
        */
        CIptvMyVideosGlobalFileId* iGlobalFileId;

        /**
        * If ETrue, then iServiceId and iContentId contain valid data.
        */
        TBool iServiceIdAndContentIdAreValid;
                        
        /**
        * Service ID in Service Manager database.
        */
        TUint32 iServiceId;
        
        /**
        * Content ID in EPG database.
        */
        TUint32 iContentId;

        /**
        * Content index in EPG database.
        */
        TUint32 iContentIndex;
        
        /**
        * Download progress in percentages.
        */
        TUint8 iProgress;
        
        /**
        * Download state, see possible states from CIptvUtil.h
        */        
        TUint32 iState;
        
        /**
        * VOD DL specific error code is stored here.
        */        
        TIptvDlError iError;

        /**
        * Global error code is stored here. This variable is used
        * when functions leave or return error value and they are
        * not directly related to download, e.g memory runs out etc.
        * If iGlobalError != KErrNone then iError is EIptvDlGeneral. 
        */        
        TInt iGlobalError;
        
    };

#endif      // CIPTVVODDLEVENT_H   
            
// End of File