ipsservices/ipssosplugin/src/ipsplgcreatereplymessageoperation.cpp
author hgs
Thu, 14 Oct 2010 17:33:43 +0300
changeset 76 38bf5461e270
parent 23 2dc6caa42ec3
permissions -rw-r--r--
201041

/*
* Copyright (c) 2006-2008 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: This file implements class CIpsPlgCreateReplyMessageOperation.
*
*/

// <qmail>

// INCLUDE FILES
#include "emailtrace.h"
#include "ipsplgheaders.h"

// <qmail> removed description

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

// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::CIpsPlgCreateReplyMessageOperation
// ----------------------------------------------------------------------------
//
//<qmail> aSmtpService to reference
CIpsPlgCreateReplyMessageOperation::CIpsPlgCreateReplyMessageOperation(
    CIpsPlgSmtpService& aSmtpService,
    CMsvSession& aMsvSession,
    TRequestStatus& aObserverRequestStatus,
    TMsvPartList aPartList,
    TFSMailMsgId aMailBoxId,
    TMsvId aOriginalMessageId, 
    MFSMailRequestObserver& aOperationObserver,
    TInt aRequestId ) 
    :
    CIpsPlgCreateMessageOperation(
        aSmtpService,
        aMsvSession,
        aObserverRequestStatus,
        aPartList,
        aMailBoxId,
        aOperationObserver,
        aRequestId),
    iOriginalMessageId(aOriginalMessageId)
    {
    FUNC_LOG;
    }
//</qmail>

// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::NewL
// ----------------------------------------------------------------------------
//
//<qmail> aSmtpService to reference
CIpsPlgCreateReplyMessageOperation* CIpsPlgCreateReplyMessageOperation::NewL(
    CIpsPlgSmtpService& aSmtpService,
    CMsvSession& aMsvSession,
    TRequestStatus& aObserverRequestStatus,
    TMsvPartList aPartList,
    TFSMailMsgId aMailBoxId,
    TMsvId aOriginalMessageId, 
    MFSMailRequestObserver& aOperationObserver,
    TInt aRequestId )
    {
    FUNC_LOG;
    CIpsPlgCreateReplyMessageOperation* self =
        new (ELeave) CIpsPlgCreateReplyMessageOperation(
            aSmtpService, 
            aMsvSession, 
            aObserverRequestStatus,
            aPartList, 
            aMailBoxId, 
            aOriginalMessageId, 
            aOperationObserver, 
            aRequestId );
    CleanupStack::PushL( self );
    self->ConstructL(); // Use base class constructor
    CleanupStack::Pop( self ); 
    return self;
    }
//</qmail>
// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::~CIpsPlgCreateReplyMessageOperation
// ----------------------------------------------------------------------------
//
CIpsPlgCreateReplyMessageOperation::~CIpsPlgCreateReplyMessageOperation()
    {
    }

// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::RunL
// ----------------------------------------------------------------------------
//
void CIpsPlgCreateReplyMessageOperation::RunL()
    {
    FUNC_LOG;

    if( iStatus.Int() == KErrNone )
        {
        CFSMailMessage* newMessage = NULL;
        
        // <qmail> removed TRAP 
        // new message creation has finished and we have an id...
        TMsvId msgId;
        msgId = GetIdFromProgressL( iOperation->FinalProgress() );
        //</qmail>
        
		//<qmail> 
        //  ...so we can create an FS type message
        newMessage = iSmtpService.CreateFSMessageAndSetFlagsL( 
                msgId, iOriginalMessageId, iFSMailboxId.Id() );
        CleanupStack::PushL( newMessage );
    
        // dig out new reply message's header
        CMsvEntry* cEntry = iMsvSession.GetEntryL( msgId );
        CleanupStack::PushL( cEntry );
        CMsvStore* store = cEntry->ReadStoreL();
        CleanupStack::PushL( store );
        if( store->IsPresentL( KUidMsgFileIMailHeader ) == EFalse )
             {
             User::Leave(KErrCorrupt);
             }
        CImHeader* header = CImHeader::NewLC();
        header->RestoreL( *store );
        
        // Start handling recipients
        HBufC* emailAddr( NULL );
        CFSMailAddress* fsAddr( NULL );
        
        // copy to recipients            
        TInt toRecipientCount( header->ToRecipients().Count() );
        for( TInt i = 0; i < toRecipientCount; i++ )
            {
            emailAddr = header->ToRecipients()[i].AllocLC();
            fsAddr = CFSMailAddress::NewL();
            fsAddr->SetEmailAddress( *emailAddr ); // Copy created
            newMessage->AppendToRecipient( fsAddr ); // No copy
            CleanupStack::PopAndDestroy( emailAddr ); // emailAddr not used
            }

        // get additional recipients (reply all case)
        if( iPartList & KMsvMessagePartRecipient )
            {
            // <qmail> code moved to own function
            RecipientsCallToOrderL( header, newMessage );
            // </qmail>
            }
                    
        CleanupStack::PopAndDestroy( 3, cEntry ); // header, store, cEntry
        CleanupStack::Pop( newMessage ); // fsMsg is given to client
        
        // save the added recipients to the message
        newMessage->SaveMessageL();
        
        // <qmail> removed bracket
    	//</qmail>
        // relay the created message (observer takes ownership)
        SignalFSObserver( iStatus.Int(), newMessage );        
        }
    
    // nothing left to process, so complete the observer
    TRequestStatus* status = &iObserverRequestStatus;
    User::RequestComplete( status, iStatus.Int() );
    }

// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::StartMessageCreationL
// ----------------------------------------------------------------------------
//
void CIpsPlgCreateReplyMessageOperation::StartMessageCreationL()
    {
    FUNC_LOG;
    delete iOperation;
    iOperation = NULL;
    
    // <qmail> removed useless parameter
    // Start a new operation, execution continues in RunL 
    // once the operation has finished.
    iOperation = CImEmailOperation::CreateReplyL(
            iStatus, 
            iMsvSession,
            iOriginalMessageId,
            KMsvDraftEntryId, 
            iPartList, 
            KIpsPlgReplySubjectFormat,
            KMsvEmailTypeListMHTMLMessage,
            KUidMsgTypeSMTP);
    // </qmail>
    }
//<qmail>
// ----------------------------------------------------------------------------
// CIpsPlgCreateReplyMessageOperation::RecipientsCallToOrderL
// ----------------------------------------------------------------------------
//
void CIpsPlgCreateReplyMessageOperation::RecipientsCallToOrderL( 
        CImHeader* aHeader,
        CFSMailMessage* aNewMessage
        )
    {
    // check if CC recipient read from header was present in To field
    // of original message. If so, copy it into To recipients.
    // 
    HBufC* emailAddr( NULL );
    CFSMailAddress* fsAddr( NULL );
    
    CMsvEntry* tmpEntry = iMsvSession.GetEntryL( iOriginalMessageId );
    CleanupStack::PushL( tmpEntry );
    CMsvStore* tmpStore = tmpEntry->ReadStoreL();
    CleanupStack::PushL( tmpStore );
    if( tmpStore->IsPresentL( KUidMsgFileIMailHeader ) )
        {
        CImHeader* tmpHeader = CImHeader::NewLC();
        tmpHeader->RestoreL( *tmpStore );
       
        TInt originalToRecipientsCount = tmpHeader->ToRecipients().Count(); 
        TBool present = EFalse;
        for( TInt i = 0; i < aHeader->CcRecipients().Count(); i++ )
            {
            emailAddr = aHeader->CcRecipients()[i].AllocLC();
            fsAddr = CFSMailAddress::NewLC();
            fsAddr->SetEmailAddress( *emailAddr ); // Copy created
           
            present = EFalse;
            for( TInt j = 0; j < originalToRecipientsCount; j++ )
                {
                if( emailAddr->Find( tmpHeader->ToRecipients()[j]) != KErrNotFound )
                    {
                    present = ETrue;
                    break;
                    }
                }
           
            CleanupStack::Pop( fsAddr ); // fsAddr belong now to fsMsg
            if( present )
                {
                aNewMessage->AppendToRecipient( fsAddr ); // No copy
                }
            else
                {
                aNewMessage->AppendCCRecipient( fsAddr ); // No copy
                }
           
            CleanupStack::PopAndDestroy( emailAddr ); // emailAddr not used
            }
        CleanupStack::PopAndDestroy( tmpHeader );
        }
    CleanupStack::PopAndDestroy( 2, tmpEntry );
   
    // copy bcc recipients
    for( TInt i = 0; i < aHeader->BccRecipients().Count(); i++ )
        {
        emailAddr = aHeader->BccRecipients()[i].AllocLC();
        fsAddr = CFSMailAddress::NewL();
        fsAddr->SetEmailAddress( *emailAddr ); // Copy created
        aNewMessage->AppendBCCRecipient( fsAddr ); // No copy
        CleanupStack::PopAndDestroy( emailAddr ); // emailAddr not used
        }
    }
//</qmail>
//  End of File

// </qmail>