dependencies/drmrightsinfo.h
author Christian Morlok <symbian.org@christianmorlok.de>
Wed, 07 Apr 2010 14:35:19 +0200
branchv5backport
changeset 54 666a2952b5b3
parent 31 a3e98f9c292b
permissions -rw-r--r--
renamed dlls+exe to prevent conflicts with existing files in emulator; changelog attached. * renamed dlls/exe: - aifw.dll to aifw_hs.dll - cputils to cputils_hs - aiidleint.dll to aiidleint_hs.dll - aiutils.dll to aiutils_hs.dll - MenuInterface.dll to MenuInterface_hs.dll - XCFW.dll to XCFW_hs.dll - homescreen.exe to homescreen_hs.exe - ailaunch.exe to ailaunch_hs.exe * new UID for Active Idle (aifw_hs.dll, aiidleint_hs.dll and homescreen.exe): #define AI_UID3_AIFW_COMMON 0xEDFF45C4 (was 0x102750F0 = 271012080) * new UID for cputils_hs.dll: 0xE3E7134E (was 0x20016B7F = 536963967) * new UID for AI Utilities Factory (aiutils_hs.dll): 0xEC55106C (was 0x10281865 = 271063141) * new UID for MenuInterface_hs.dll: 0xEEE24485 (was 0x10210EAB = 270601899) * new UID for XCFW_hs.dll: 0xEB12332F (was 0x10210EA0 = 270601888) * new UID for ailaunch_hs.exe: 0xEF5A047A (was 0x200286E3 = 537036515)

/*
* Copyright (c) 2006-2007 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:  Provides operations for rights information handling of DRM
 *                content
 *
*/


#ifndef CDRMRIGHTSINFO_H
#define CDRMRIGHTSINFO_H

//*** system include files go here:
#include <e32base.h>
#include <caf/caftypes.h>
#include <drmutilitytypes.h>

namespace DRM
    {

    //*** forward declarations go here:
    class CDrmUtility;
    class CDrmRightsInfoImpl;
    class MDrmAsyncObserver;

    /**
     *  Utility class for DRM related rights information handling
     *
     *  @lib drmrightsinfo.lib
     *  @since S60 v5.0
     */
NONSHARABLE_CLASS( CDrmRightsInfo ) : public CBase
    {

public:

    /**
     * Creates a new CDrmRightsInfo object and returns a pointer to it
     *
     * @return A functional CDrmRightsInfo -object
     * @leave System wide error code
     */
    IMPORT_C static CDrmRightsInfo* NewL();

    /**
     * Creates a new CDrmRightsInfo object and returns a pointer to it
     * Leaves the pointer to the cleanup stack
     *
     * @return A functional CDrmRightsInfo -object
     * @leave System wide error code
     */
    IMPORT_C static CDrmRightsInfo* NewLC();

    /**
     * Destructor
     */
    virtual ~CDrmRightsInfo();


    /**
     * Returns a reference to a CDrmUtility instance. The ownership
     * of the instance stays with the CDrmRightsInfo -class
     *
     * @since S60 v5.0
     *
     * @return A reference to a functional CDrmUtility instance
     *
     * @leave None
     *
     * @see CDrmUtility
     */
    IMPORT_C CDrmUtility& GetUtility() const;



    /**
     * Checks the rights and their status for a specific unique id
     *
     * @param[in]   aUniqueId   The unique identifier of the content
     * @param[in]   aIntent     The intent for the rights to check
     * @param[out]  aDetails    Details of the rights status
     * @return none
     * @leave System wide error code
     * @see ContentAccess::TIntent
     */
    IMPORT_C void CheckRightsL(
            const TDesC& aUniqueId,
            ContentAccess::TIntent aIntent,
            TDrmRightsInfo& aDetails );

    /**
     * Checks the rights and their status for a specific unique id
     *
     * @param[in]   aUniqueId   The unique identifier of the content
     * @param[in]   aIntent     The intent for the rights to check
     * @param[out]  aDetails    Details of the rights status, the
     *                          details are available via this
     *                          parameter, once the async call completes
     *                          successfully
     * @param[in]   aObserver   reference to observer
     *
     * @return Operation Identifier for the async request
     *         required for cancelling an operation and
     *         identifying which request has been completed
     *
     * @leave System wide error code
     * @see ContentAccess::TIntent
     */
    IMPORT_C TInt CheckRightsAsyncL(
            const TDesC& aUniqueId,
            ContentAccess::TIntent aIntent,
            TDrmRightsInfo& aDetails,
            MDrmAsyncObserver& aObserver );


    /**
     * Cancel an asyncronous operation
     *
     * @since S60 v5.0
     * @param[in]   aOperationId    identifier of the async operation
     *                              to be cancelled
     * @return KErrNotFound if the operation has already been executed
     *         or it does not exist
     */
    IMPORT_C TInt CancelOperation( TInt aOperationId );

private:

    //*** private, non-derived functions go here, starting with the C++
    //*** constructor and the Symbian second-phase constructor

    CDrmRightsInfo();

    void ConstructL();

private: // Data members

    /**
     * Implementation class pointer
     * Owned
     */
    CDrmRightsInfoImpl* iImplementation;


    /**
     * CDrmUtility class pointer
     * Owned
     */
    CDrmUtility* iUtility;

    };
    }


#endif // CDRMRIGHTSINFO_H