connectivitylayer/isce/p2prouter_dll/inc/p2prouterchannelifs.h
author mikaruus
Tue, 19 Oct 2010 13:16:20 +0300
changeset 9 8486d82aef45
parent 0 63b37f68c1ce
permissions -rw-r--r--
modemadaptation release 2010wk40

/*
* Copyright (c) 2009 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: 
*
*/



#ifndef __P2PROUTERCHANNELIFS_H__
#define __P2PROUTERCHANNELIFS_H__

#include <e32def.h>     // For TInt, TAny

/*
* Abstract interface for router to use channel services.
*/
class MP2PRouterChIf
    {

    public:

        /*
        * Closes the connection and interface.
        * Called in P2P router ext thread context.
        */
        virtual void ConnectionLost() = 0;

        /*
        * Enques channel request completing DFC.
        * Called in P2P router ext thread context.
        * @param aRequest, request to be completed
        * @param aStatusToComplete, status to complete to client.
        */
        virtual void EnqueChannelRequestCompleteDfc( TInt aRequest, TInt aStatusToComplete ) = 0;

        /*
        * Receive a message from router.
        * Responsibility to deallocate the message is transferred to channel.
        * Can be called in 1..N thread contextes.
        * Cat no be called with FM held.
        * Same restríctions than in IST API (see from MTrxMuxIf).
        * @param aMessage, message to receive
        */
        virtual void ReceiveMsg( const TDesC8& aMessage ) = 0;

    };

/*
* Abstract interface for channel to use router services.
*/
class MP2PChRouterIf
    {

    public:

        // Enumerations for different threads.
        enum TP2PDfcThread
            {
            EP2PDfcThread = 0,
            EP2PLddDfcThread,
            EAmountOfP2PDfcThreads
            };

        /*
        * Informs router that channel is closed.
        * @param aProtocolId, closing protocol id
        */
        virtual void Close( const TUint8 aProtocolId ) = 0;

        /*
        * Return ETrue if the connection is lost.
        * Called in P2P router ext thread context.
        */
        virtual TBool ConnectionExist( const TUint8 aProtocolId ) = 0;

        /*
        * Returns thread according to TP2PDfcThread enums.
        * @param aThreadIndex, threads index in table
        * @return pointer to thread
        */
        virtual TDfcQue* GetDfcThread( const TP2PDfcThread aThreadIndex ) = 0;

        /*
        * Returns the interface.
        * @return pointer to the interface
        */
        static MP2PChRouterIf* GetIf();

        /*
        * Informs router that channel is ready to be open.
        * If transceiver is not found sets the open pending.
        * Router shall complete the pending opens when transceiver is ready.
        * @param aProtocolId, channels unique P2P identifier
        * @param aCallback, pointer to channel interface
        */
        virtual void Connect( const TUint8 aProtocolId, MP2PRouterChIf* aCallback ) = 0;

        /*
        * Sends a message to router.
        * Responsibility to deallocate the message is transferred router.
        * @param aMessage, messages reference
        * @aProtocolId, channels unique P2P identifier
        * @return, KErrNone if succesfull, KErrNotReady if transceiver is not present.
        */
        virtual TInt Send( TDes8& aMessage, const TUint8 aProtocolId ) = 0;

    };

#endif /* __P2PROUTERCHANNELIFS_H__ */