phoneapp/phoneuiview/src/cphoneringingtoneplayerao.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 21 Jun 2010 15:39:45 +0300
branchRCL_3
changeset 20 3c221667e687
parent 5 2a26698d78ba
permissions -rw-r--r--
Revision: 201023 Kit: 2010125

/*
* Copyright (c) 2002-2005,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:  Ringing tone player.
*
*/


// INCLUDE FILES
#include <cntdef.h>
#include <f32file.h>
#include <featmgr.h>
#include <utility.h>
#include <AudioPreference.h>
#include <data_caging_path_literals.hrh>
#include <MusicPlayerInternalCRKeys.h>
#include <ProfileEngineDomainCRKeys.h>
#include <telephonyvariant.hrh>
#include <UikonInternalPSKeys.h>
#include <DRMHelperServerInternalCRKeys.h>
#include <DRMHelper.h>
#include <activeidle2domainpskeys.h>

#include "cphoneringingtoneplayerao.h"
#include "phoneui.pan"
#include "phoneui.hrh"
#include "mphoneringingtoneobserver.h"
#include "cphonetimer.h"
#include "cphonecenrepproxy.h"
#include "phoneconstants.h"
#include "phonelogger.h"
#include "cphoneringingtone.h"
#include "tphonecmdparamringtone.h"
#include "cphonepubsubproxy.h"
#include "cphonecenrepproxy.h"

// CONSTANTS

// Minimum acceptable length of parsed DRM message.
const TInt KPhoneMinDRMTextLength = 3;
// Value field of parsed DRM string.

// ============================ MEMBER FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::NewL
// -----------------------------------------------------------------------------
//
CPhoneRingingTonePlayerAO* CPhoneRingingTonePlayerAO::NewL()
    {
    CPhoneRingingTonePlayerAO* self = 
        new ( ELeave ) CPhoneRingingTonePlayerAO();

    CleanupStack::PushL( self );
    self->ConstructL();
    CleanupStack::Pop( self );

    return self;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::CPhoneRingingTonePlayerAO
// -----------------------------------------------------------------------------
//
CPhoneRingingTonePlayerAO::CPhoneRingingTonePlayerAO() :
    CActive( CActive::EPriorityStandard )
    {
    CActiveScheduler::Add( this );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::ConstructL
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::ConstructL()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::ConstructL()" );

    // Connect to the tone server
    User::LeaveIfError( iToneServer.Connect() );

    // Construct timer.
    iTimer = CPhoneTimer::NewL();

    // Checks if DRM extend security is needed
    TInt extSecNeeded = KErrNone;
    TInt err = CPhoneCenRepProxy::Instance()->GetInt(
        KCRUidMusicPlayerFeatures,
        KRequireDRMInPlayback,
        extSecNeeded );

    iExtSecNeeded = ( ( err == KErrNone ) && extSecNeeded ) ? ETrue : EFalse;
    iToneServer.SetExtendedSecurityNeeded( iExtSecNeeded );

    CPhoneCenRepProxy::Instance()->NotifyChangeL(
        KCRUidDRMHelperServer, 
        KDRMHelperServerNotificationPassive,
        this );

    // Check video player configuration.
    iArbitraryVideoScaling = 
    CPhoneCenRepProxy::Instance()->IsTelephonyFeatureSupported( 
            KTelephonyLVFlagArbitraryVideoScaling );

    // Construct the default ringing tone
    TBuf<KMaxFileName> defaultTone;
    err = CPhoneCenRepProxy::Instance()->GetString(
        KCRUidProfileEngine,
        KProEngDefaultRingingTone,
        defaultTone );

    if ( err == KErrNone )
        {
        iToneServer.SetDefaultRingingToneL( defaultTone );
        }

    // Get maximum tone file size
    GetMaxToneFileSizeL( iToneFileSizeLimitKB );

    // And set the tone size limit to the tone server too
    iToneServer.SetToneFileSizeLimit( iToneFileSizeLimitKB );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::~CPhoneRingingTonePlayerAO
// -----------------------------------------------------------------------------
//
CPhoneRingingTonePlayerAO::~CPhoneRingingTonePlayerAO()
    {
    Cancel();
    iToneServer.Close();

    delete iTimer;
    delete iAudioVideoRingingTone;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayRingToneL
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayRingToneL( 
    TPhoneCommandParam* aCommandParam )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::PlayRingToneL()" );

    // Check that the parameter is a ringing tone
    if ( aCommandParam->ParamId() == TPhoneCommandParam::EPhoneParamIdRingTone )
        {
        // Cast to get the ringing tone parameters
        TPhoneCmdParamRingTone* ringToneParam = 
            static_cast<TPhoneCmdParamRingTone*>( aCommandParam );

        // Get volume and ringing tone type
        const TInt volume = ringToneParam->Volume();
        TProfileRingingType ringingType = 
            static_cast<TProfileRingingType>( ringToneParam->RingingType() );

        // Set ringing tone file name to server
        iToneServer.SetRingingToneL( ringToneParam->RingTone() );

        if ( !iAudioVideoRingingTone )
            {
            iAudioVideoRingingTone = CPhoneRingingTone::NewL(
                ringToneParam->RingTone() );
            }
        else if ( iAudioVideoRingingTone->FileName().Compare(
            ringToneParam->RingTone() ) ) 
            {
            iAudioVideoRingingTone->SetFileName(
                ringToneParam->RingTone() );
            }

        // Caller contact text and image and image has
        // higher priority than video ringing tone set for caller.
        if ( iAudioVideoRingingTone->IsVideoRingingTone() &&
             ringToneParam->IsCallerImage() )
            {
            // Play only audio from video ringingtone
            PlayAudioRingTone(
                    volume,
                    ringingType );
            }
        else if ( iAudioVideoRingingTone->IsVideoRingingTone() &&
                !ringToneParam->IsCallerText() )
            {
            // Play video ring tone
            const TBool ringToneIsPersonal = ringToneParam->Type() ==
                EPhoneRingTonePersonal;
            PlayVideoRingingTone( 
                *iAudioVideoRingingTone, 
                volume, 
                ringingType,
                ringToneIsPersonal );
            }
        else
            {
            // Play text to speech, if available
            if ( ringToneParam->TextToSay().Length() )
                {
                PlayTtsTone(
                    ringToneParam->TextToSay(),
                    volume,
                    ringingType );
                }
            // Play audio ring tone
            PlayAudioRingTone( 
                volume, 
                ringingType );
            }
        }
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayAudioRingTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayAudioRingTone( 
    TInt aVolume, 
    TProfileRingingType aRingingType )
    {
    iToneServer.PlayAudioRingTone( aVolume, aRingingType );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::BeepOnce
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::BeepOnce( TInt aVolume )
    {
    iToneServer.BeepOnce( aVolume );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlaySilentTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlaySilentTone()
    {
    iToneServer.PlaySilentTone();
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayUnsecureVoIPTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayUnsecureVoIPTone()
    {
    iToneServer.PlayUnsecureVoIPTone();
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::MuteRingingToneOnAnswer
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::MuteRingingToneOnAnswer()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::MuteRingingToneOnAnswer()" );

    if ( iVideoPlayer &&
            ( iTonePlayingStatus == EVideoTonePlaying ||
              iTonePlayingStatus == EPersonalVideoTonePlaying ) )
        {
        // Mute the video audio
        iVideoPlayer->MuteVideoRingTone();
        iTonePlayingStatus = ESilentVideoTonePlaying;
        iVolume = 0;
        }
    else if ( iTonePlayingStatus != ESilentVideoTonePlaying )
        {
        iToneServer.MuteRingingTone();
        }
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::MuteRingingTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::MuteRingingTone()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::MuteRingingTone()" );

    if ( iVideoPlayer &&
            ( iTonePlayingStatus == EVideoTonePlaying ||
              iTonePlayingStatus == EPersonalVideoTonePlaying ) )
        {
        // Mute the video audio
        iVideoPlayer->MuteVideoRingTone();
        iTonePlayingStatus = ESilentVideoTonePlaying;
        iVolume = 0;
        }
    else if ( iTonePlayingStatus != ESilentVideoTonePlaying )
        {
        StopPlaying();
        }
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::StopPlaying
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::StopPlaying()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::StopPlaying()" );

    // Stop all playback

    iToneServer.StopPlaying();

    if ( iVideoPlayer )
        {
        iVideoPlayer->StopVideoRingTone();
        }

    iTimer->Cancel();

    iTonePlayingStatus = EIdle;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayTtsTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayTtsTone( 
    const TDesC& aTextToSay, 
    TInt aVolume,
    TProfileRingingType aRingingType )
    {
    iToneServer.PlayTtsTone( aTextToSay, aVolume, aRingingType );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::HandleTimeOutL
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::HandleTimeOutL()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::HandleTimeOutL()" );

    // Guarding timer for startup has expired
    if ( iTonePlayingStatus == EVideoTonePlaying ||
         iTonePlayingStatus == ESilentVideoTonePlaying || 
         iTonePlayingStatus == EPersonalVideoTonePlaying )
        {
        iVideoPlayer->CancelVideoRingTone(); // close video ringtone display
        PlayDefaultTone( iVolume, iRingingType );
        }
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayDefaultTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayDefaultTone( 
    TInt aVolume, 
    TProfileRingingType aRingingType )
    {
    iToneServer.PlayDefaultTone( aVolume, aRingingType );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayBackupTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayBackupTone( 
    TInt aVolume, 
    TProfileRingingType aRingingType )
    {
    iToneServer.PlayBackupTone( aVolume, aRingingType );
    }


// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::ConvertVideoRingingType
// -----------------------------------------------------------------------------
//
MPhoneVideoPlayer::TPlayMode CPhoneRingingTonePlayerAO::ConvertVideoRingingType(
    TProfileRingingType aRingingType )
    {
    MPhoneVideoPlayer::TPlayMode playMode;

    switch ( aRingingType )
        {
        case EProfileRingingTypeAscending:
            playMode = MPhoneVideoPlayer::EPlayAscending;
            break;
        case EProfileRingingTypeRingingOnce:
            playMode = MPhoneVideoPlayer::EPlayOnce;
            break;
        case EProfileRingingTypeRinging:
        default:
            playMode = MPhoneVideoPlayer::EPlayInLoop;
            break;
        }

    return playMode;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::RunL
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::RunL()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::RunL()" );

    switch ( iState )
        {
        case EPlayingDefaultVideo:
            {
            PlayAudioRingTone( iVolume, iRingingType );
            }
            break;

        case EIdleState:
        default:
            break;
        } // switch iState

    iState = EIdleState;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::DoCancel
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::DoCancel()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::DoCancel()" );
    // Request is completed immediately before SetActive.
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::SetVideoPlayer
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::SetVideoPlayer( 
    MPhoneVideoPlayer* aVideoPlayer )
    {
    iVideoPlayer = aVideoPlayer;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayVideoRingingTone
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayVideoRingingTone( 
    const CPhoneRingingTone& aRingingTone, 
    TInt aVolume, 
    TProfileRingingType aRingingType,
    TBool aPersonalTone )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::PlayVideoRingingTone()" );

    __ASSERT_DEBUG( iVideoPlayer, Panic( EPhoneViewGeneralError ) );

    iVolume = aVolume;
    iRingingType = aRingingType;
    TBool startTimer( ETrue );

     // Extended security check
    if ( ExtendedSecurity() )
        {
        if ( !aRingingTone.IsFileInRom() &&
             !aRingingTone.IsFileDrmProtected() )
            {
            __PHONELOG( EBasic, 
                        EPhoneUIView, 
                        "CPhoneRingingTonePlayerAO::HandleVideoPlayerError - PermissionDenied" );
            PlayDefaultTone( iVolume, iRingingType );
            return;
            }
        __PHONELOG( EBasic, 
                    EPhoneUIView, 
                    "CPhoneRingingTonePlayerAO::HandleVideoPlayerError - ExtSecChk ok" );
        }
 
    __PHONELOG( EBasic, EPhoneUIView, "CPhoneRingingTonePlayerAO::PlayVideoRingingTone - play" );
    switch( aRingingType )
        {
        case EProfileRingingTypeSilent:
            iVideoPlayer->PlayVideoRingTone( 
                aRingingTone.FileName(),
                ConvertVideoRingingType( aRingingType ),
                0,
                iArbitraryVideoScaling,
                this );
            iToneServer.PlaySilentTone(); // To start vibra, video may fail.
            iVolume = 0; // for repeat
            startTimer = EFalse; // no need for fallback
            break;

        case EProfileRingingTypeBeepOnce:
            iVideoPlayer->PlayVideoRingTone( 
                aRingingTone.FileName(),
                ConvertVideoRingingType( aRingingType ),
                0,
                iArbitraryVideoScaling,
                this );
            BeepOnce( iVolume );
            iVolume = 0; // for repeat
            startTimer = EFalse; // no need for fallback
            break;
        default:
            iVideoPlayer->PlayVideoRingTone( 
                aRingingTone.FileName(),
                ConvertVideoRingingType( aRingingType ),
                iVolume,
                iArbitraryVideoScaling,
                this );
            break;
        }

    if ( aPersonalTone )
        {
        iTonePlayingStatus = EPersonalVideoTonePlaying;
        }
    else
        {
        iTonePlayingStatus = EVideoTonePlaying;
        }

    if ( startTimer && !iTimer->IsActive() )
        {
        // Start timer to guard video opening
        iTimer->After( KPhoneMaxRingingWaiting, this );
        }

    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::HandleVideoPlayerError
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::HandleVideoPlayerError( 
    TPhoneVideoPlayerErrorEvent /*aEvent*/,
    TInt aError )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::HandleVideoPlayerError()" );

    if ( aError )
        {
        __PHONELOG1( EBasic, 
                     EPhoneUIView, 
                     "CPhoneRingingTonePlayerAO::HandleVideoPlayerError - error (%d)",
                     aError );
        }

    // cancel guarding timer
    iTimer->Cancel();

    // to remove video window
    iVideoPlayer->CancelVideoRingTone();

    if ( iTonePlayingStatus == EPersonalVideoTonePlaying )
        {
        // Play default tone (active profile tone).
        if ( iAudioVideoRingingTone &&
             !iAudioVideoRingingTone->IsVideoRingingTone() )
            {
            iToneServer.PlayAudioRingTone( iVolume, iRingingType );
            }
        else // audio/video tone is video
            {
            PlayDefaultVideoAsync();
            }
        }
    else
        {
        // Play backup tone
        PlayDefaultTone( iVolume, iRingingType );
        }

    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::HandleVideoPlayerInitComplete
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::HandleVideoPlayerInitComplete()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::HandleVideoPlayerInitComplete()" );

    // cancel guarding timer
    iTimer->Cancel();

    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::HandleVideoPlayerPlayingComplete
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::HandleVideoPlayerPlayingComplete()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::HandleVideoPlayerPlayingComplete()" );
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::PlayDefaultVideoAsync
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::PlayDefaultVideoAsync()
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::PlayDefaultVideoAsync()" );

    Cancel();

    iState = EPlayingDefaultVideo; 

    TRequestStatus* status = &iStatus;
    User::RequestComplete( status, KErrNone );
    SetActive();
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::ExtendedSecurity
// -----------------------------------------------------------------------------
//
TBool CPhoneRingingTonePlayerAO::ExtendedSecurity() const
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::ExtendedSecurity()" );
    return iExtSecNeeded;
    }


// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::CheckAndHandleToneSizeLimit
// -----------------------------------------------------------------------------
//
TBool CPhoneRingingTonePlayerAO::CheckAndHandleToneSizeLimit(
     CPhoneRingingTone* aRingingTone )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::CheckAndHandleToneSizeLimit()" );

    TBool bValidSize = ETrue;

    // If user has somehow managed to get a too large file as ringing tone,
    // play default tone instead.
    if ( iToneFileSizeLimitKB )
        {
        if ( CheckToneFileSize( aRingingTone->FileName(), iToneFileSizeLimitKB) != KErrNone )
            {
            bValidSize = EFalse;
            }
        }
    __PHONELOG1( 
        EBasic,
        EPhoneUIView, 
        "CPhoneRingingTonePlayerAO::CheckAndHandleToneSizeLimit - bValidSize(%d)",
        bValidSize);

    return bValidSize;
    }

// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::CheckToneFileSize
// -----------------------------------------------------------------------------
//
TInt CPhoneRingingTonePlayerAO::CheckToneFileSize( const TDesC& aFile, TInt aSizeLimitKB )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::CheckToneFileSize()" );

    // Get file size
    TInt size = 0;
    TInt error = KErrNone;
    RFs& fs = CCoeEnv::Static()->FsSession();
    TEntry entry;
    if (KErrNone == fs.Entry( aFile, entry ))
        {
        size = entry.iSize;
        }

    // Check
    aSizeLimitKB *= Kkilo;
    if ( aSizeLimitKB  &&  size > aSizeLimitKB )
        {
        error = KErrTooBig;
        }

    __PHONELOG1( 
        EBasic,
        EPhoneUIView, 
        "CPhoneRingingTonePlayerAO::CheckToneFileSize - size (%d)",
        size );
    return error;
    }


// -----------------------------------------------------------------------------
// CPhoneRingingTonePlayerAO::GetMaxToneFileSizeL
// -----------------------------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::GetMaxToneFileSizeL( TInt& aMaxSizeKB ) const
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::GetMaxToneFileSizeL()" );

    const TInt error = CPhoneCenRepProxy::Instance()->GetInt( 
            KCRUidProfileEngine,
            KProEngRingingToneMaxSize,
            aMaxSizeKB );

    if ( error != KErrNone )
        {
        aMaxSizeKB = 0;
        }
    if ( aMaxSizeKB < 0 )
        {
        aMaxSizeKB = 0;
        }

    __PHONELOG2( 
        EBasic,
        EPhoneUIView, 
        "CPhoneRingingTonePlayerAO::GetMaxToneFileSizeL - error (%d), aMaxSizeKB(%d)",
        error,
        aMaxSizeKB );
    }

// -----------------------------------------------------------
// CPhoneRingingTonePlayerAO::HandleCenRepChangeL
// -----------------------------------------------------------
//
void CPhoneRingingTonePlayerAO::HandleCenRepChangeL( 
    const TUid& aUid,
    const TUint /*aId*/ )
    {
    __LOGMETHODSTARTEND( EPhoneUIView, "CPhoneRingingTonePlayerAO::HandleCenRepChangeL()");

    if ( aUid == KCRUidDRMHelperServer )
        {
        TBuf<256> tempBuf16( KNullDesC );

        User::LeaveIfError( CPhoneCenRepProxy::Instance()->GetString(
            KCRUidDRMHelperServer,
            KDRMHelperServerNotificationPassive,
            tempBuf16 ) );

        const TBool idleIsTopApp = CPhonePubSubProxy::Instance()->Value(
            KPSUidAiInformation, KActiveIdleState ) == EPSAiForeground;

        // Quick validity check and
        // The first Tuint8 is the times the content has been informed.
        // Note should not shown until Idle.
        if ( idleIsTopApp && tempBuf16.Length() >= KPhoneMinDRMTextLength )
            { 
            TBuf8<256> tempBuf8;
            TPtrC8 ptr((TUint8*)tempBuf16.Ptr(), tempBuf16.Size());
            HBufC8* buf8 = HBufC8::NewLC( 256 );
            buf8->Des().Copy(ptr);
            // Extract URI etc. 
            // buf8 format:
            //<TUint8 aTimes><TUint8 aExpirationMark>
            //<TUint8 aPermissionType>
            //<TUint8 aAutomatedContentType><TDesC8 aContentID>
            TInt8 count = (TInt8)(*(buf8->Ptr())); 
            TChar mark = (TChar)(*(buf8->Ptr()+1));
            TInt8 permtype = (TChar)(*(buf8->Ptr()+2));
            TInt8 automcontenttype = (TChar)(*(buf8->Ptr()+3)); 
            TBuf8<256> curi = buf8->Right( buf8->Length()-4);

            if ( curi.Ptr()[curi.Size()-1] == 0 )
                {
                // The last character in the descriptor is 0, which means
                // that the original 16-bit desc was padded so
                // remove the last char...
                curi.SetLength(curi.Size()-1);
                }

            // Create DRM helper. 
            CDRMHelper* drmHelper = CDRMHelper::NewLC();
            // Show notification.
            drmHelper->SetAutomatedType( (CDRMHelper::TDRMHelperAutomatedType)automcontenttype );
            TInt error = drmHelper->CheckRightsAmountL( curi );

            __PHONELOG1( EBasic, EPhoneUIView, 
                "CPhoneRingingTonePlayerAO::HandleCenRepChangeL > CheckRightsAmountL, error: %d"
                , error );

            CleanupStack::PopAndDestroy( drmHelper ); 
            CleanupStack::PopAndDestroy( buf8 ); 
            } 
        }
    }

//  End of File