PECengine/ListLibrary2/ContactListSrc/CPEngContactListTransBase.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:31:13 +0100
branchRCL_3
changeset 17 a941bc465d9f
parent 0 094583676ce7
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201010 Kit: 201035

/*
* Copyright (c) 2005 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:  Base class for contact list create and synchronize handlers
*
*/

#ifndef __CPENGCONTACTLISTTRANSBASE_H__
#define __CPENGCONTACTLISTTRANSBASE_H__

//  INCLUDES
#include "MPEngOutgoingTransactionHandler.h"
#include "PEngWVCspVersion.h"
#include <e32base.h>
#include <badesca.h>


// FORWARD DECLARATIONS
class   CPEngTransactionStatus;
class   MPEngXMLParser;
class   CPEngContactListModBase;
class   CPEngSessionSlotId;
class   MPEngXMLSerializer;
class   MPEngContactListTransactionManager;


// CLASS DECLARATION

/**
 * Base class for contact list create and synchronize handlers
 *
 * @lib PEngListLib2
 * @since 3.0
 */
NONSHARABLE_CLASS( CPEngContactListTransBase ):
        public CBase,
        public MPEngOutgoingTransactionHandler
    {
protected:  // Enumerations

    /**
     * Contact list synhronization state.
     */
    enum TPengCntListSyncState
        {
        EPEngCntListCreate,
        EPEngCntListFetch,
        EPEngSubscribeCntList,
        EPEngTransactionCompleted
        };


public:

    /**
     * Destructor.
     */
    virtual ~CPEngContactListTransBase();


protected: // Constructors

    /**
     *  C++ constructor.
     */
    CPEngContactListTransBase( CPEngContactListModBase& aContactList,
                               CPEngSessionSlotId& aSessionSlotId,
                               MPEngContactListTransactionManager& aManager,
                               TPEngWVCspVersion& aCSPVersion,
                               TInt aOperationId );


    /**
     * Symbian constructor
     */
    void ConstructL();


public: // From MPEngOutgoingTransactionHandler

    /**
     * Synchronous method, get Outgoing transaction request
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void RequestL( TDes8& aSendBuffer );


    /**
     * Signals to the transaction handler that this it is last
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void LastRunningTransactionHandler();


    /**
     * Process the response to the request.
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void ProcessResponseL( const TDesC8& aResponse,
                           TRequestStatus& aStatus );

    /**
     * Cancels asynchronous processing of the request
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void CancelProcessing();


    /**
     * Support for simultaneous transaction handling
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void NewTransactionHandlersL(
        RPointerArray<MPEngOutgoingTransactionHandler>& aHandlers );

    /**
     * Function to signal completing of the transaction
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    TBool TransactionCompleted( );


    /**
     * Gets transaction status result class
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    CPEngTransactionStatus* TransactionResult( );


    /**
     * Releases the handler
     * @see <MPEngOutgoingTransactionHandler.h>
     */
    void ReleaseHandler();


protected: // New functions


    /**
     * Template function to create XML message to create contact list
     *
     * @since 3.0
     * @param aXmlSerializer XML serializer
     */
    virtual void DoGetXMLCreateCntListL(
        MPEngXMLSerializer& aXmlSerializer ) = 0;

    /**
     * Template function to create XML message to fetch contact list
     *
     * @since 3.0
     * @param aXmlSerializer XML serializer
     */
    virtual void DoGetXMLFetchCntListL(
        MPEngXMLSerializer& aXmlSerializer ) = 0;


    /**
     * Template function to parse XML message from creating contact list
     *
     * @since 3.0
     * @param aResponse XML request response buffer
     * @param aXMLparser XML parser
     */
    virtual void DoParseCreateCntListResponseL(
        const TDesC8& aResponse,
        MPEngXMLParser& aXMLparser ) = 0;


    /**
     * Template function to parse XML message from fetching contact list
     *
     * @since 3.0
     * @param aResponse XML request response buffer
     * @param aXMLparser XML parser
     */
    virtual void DoParseFetchCntListResponseL(
        const TDesC8& aResponse,
        MPEngXMLParser& aXMLparser ) = 0;

    /**
     * Complete contact list transaction,
     * update contact list properties
     *
     * @since 3.0
     */
    void CompleteCntListTransactionL();



private: // New functions

    /**
     * Create XML message to subscribe contact
     *
     * @since 3.0
     * @param aXmlSerializer XML serializer
     */
    void GetXMLSubscribeListL( MPEngXMLSerializer& aXmlSerializer );


    /**
     * Parse Subscribe contact list response
     *
     * @since 3.0
     * @param aResponse XML request response buffer
     * @param aXMLparser XML parser
     */
    void ParseSubscribeListResponseL( const TDesC8& aResponse,
                                      MPEngXMLParser& aXMLparser );


protected:  // Data


    /// OWN: Contact list model
    CPEngContactListModBase&            iContactList;

    /// REF: Session slot
    CPEngSessionSlotId&                 iSessionSlotId;

    /// REF: Contact List Transaction manager
    MPEngContactListTransactionManager& iManager;

    /// OWN: Transaction status class
    CPEngTransactionStatus*             iTransactionStatus;

    /// OWN: State of the presence contact list synchronization
    TPengCntListSyncState               iContactListSyncState;

    /// REF: CPS Version
    TPEngWVCspVersion&                  iCSPVersion;

    /// OWN: Operation Id
    TInt                                iOperationId;
    };

#endif      //  __CPENGCONTACTLISTTRANSBASE_H__

//  End of File