Msrp/MsrpClient/inc/CMSRPSession.h
author Petteri Saari <petteri.saari@digia.com>
Thu, 02 Dec 2010 15:23:48 +0200
branchMSRP_FrameWork
changeset 60 7634585a4347
parent 58 cdb720e67852
permissions -rw-r--r--
This release addresses the following: - Multiple concurrent file transfer bug fixes. i.e. one device is concurrently receiving multiple files from multiple devices

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

#ifndef CMSRPSESSION_H_
#define CMSRPSESSION_H_

// System Includes
#include <e32base.h>

// Forward Declarations
class CMSRPSessionImplementation;
class MMSRPSessionObserver;
class RMSRP;
class CMSRPMessage;
class CMSRPSessionParams;

// CLASS DECLARATION
/**
* Class provides an interface for MSRP clients to access MSRP functionality
*
*/
class CMSRPSession : public CBase
    {
    // friend class provides the actual implementation
    friend class CMSRPImplementation;
    
    public:    
        
        /** 
         * Object Creation. This is not exported to the client. It is called
         * while attempting to create an msrp session.
         * @param aRMSRP an instance of the client server session
         * @param aObserver the session observer that is created by the client
         * @param aIapId IAP id of the application
         * @param aSessionId session id of this MSRP session. This comes from the
         *        path SDP attribute where session id is used
         * @return session object
         */
        static CMSRPSession* NewL( RMSRP& aRMSRP,
                                            MMSRPSessionObserver& aObserver, 
                                            const TUint aIapId,
                                            const TDesC8& aSessionId );
            
        /** 
         * Object Creation. This is not exported to the client. It is called
         * while attempting to create an msrp session.
         * @param aRMSRP an instance of the client server session
         * @param aObserver the session observer that is created by the client
         * @param aIapId IAP id of the application
         * @param aSessionId session id of this MSRP session. This comes from the
         *        path SDP attribute where session id is used
         * @return session object
         */
        static CMSRPSession* NewLC( RMSRP& aRMSRP,
                                             MMSRPSessionObserver& aObserver,
                                             const TUint aIapId,
                                             const TDesC8& aSessionId );
        
    public:
    
        // === Post Creation; SDP negotiation parameter fetching.
                    
        /**
         * Gives the local MSRP path that is used in the "a" line of SDP
         * @return local msrp path
         */    
        IMPORT_C TDesC8& LocalMSRPPath();
    
        /**
         * Sets the various parameters related to an MSRP session
         * @param aSessionParams the session settings object from which the 
         * settings need to be incorporated into the msrp session.
         * Eg. SR and FR report headers can be set using this
         */    
        IMPORT_C void SetSessionParams( CMSRPSessionParams& aSessionParams );
        
        
        // === Post SDP Negotiation; Connection Setup.
            
        /**
         * Connects to the remote node
         * @param aRemoteMsrpPath the msrp path of the remote node
         * This is obtained through the SDP negotiation
         * @return KErrNone or system wide error codes
         */
        IMPORT_C TInt Connect( const TDesC8& aRemoteMsrpPath );
        
        /**
         * Listens for connections from the remote node
         * @param aRemoteMsrpPath the msrp path of the remote node
         * This is obtained through the SDP negotiation
         * @return KErrNone or system wide error codes
         */
        IMPORT_C TInt Listen ( const TDesC8& aRemoteMsrpPath );
        
        
        // === Post Connection setup; Data Trasfer. 
       
        /**
         * Sends a message to the currently connected client
         * Note: connection must be established before calling this
         * function
         * @param aMessage the data that needs to be sent
         * @param aMimeType the mime type of the data
         * @return the id of the message that was sent by the msrp stack
         *         NULL pointer if sending message failed
         */
        IMPORT_C HBufC8* SendBuffer( const TDesC8& aMessage, const TDesC8& aMimeType );
            
        /**
         * Cancels the send operation initiated by the client
         * @param aMessageId the id of the message that needs to be cancelled
         * @return KErrNone or system wide error codes
         */
        IMPORT_C TInt CancelSending( TDesC8& aMessageId );
    
        /**
         * Sends a message to the currently connected client. The message is given
         * in a file
         * Note: connection must be established before calling this
         * function
         * @param aFilename name of the file to be transmitted, must include file path
         * @param aMimeType the mime type of the data
         * @return the id of the message that was sent by the msrp stack
         *         NULL pointer if sending message failed
         */
        IMPORT_C HBufC8* SendFile( const TFileName& aFileName, const TDesC8& aMimeType );
        
        /**
         * Cancels the receiving of a given message
         * @param aMessageId the id of the message that needs to be cancelled
         * @return System-wide error message
         */
        IMPORT_C TInt CancelReceiving( TDesC8& aMessageId );
        
        /**
         * Client can use this function to indicate whether it wants to receive
         * progress reports or not
         * @param aFlag true if client wants progress reports, false otherwise,
         *        By default the progress reports are off
         */
        IMPORT_C void NotifyProgress( TBool aFlag );
    
    private:
    
        /**
         * Second phase constructor
         * @param aRMSRP RMSRP session class to server
         * @param aObserver SessionObserver interface
         * @param aIapId internet access point ID
         * @param aSessionId session id of this MSRP session. This comes from the
         *        path SDP attribute where session id is used
         */
        void ConstructL( RMSRP& aRMSRP,
                         MMSRPSessionObserver& aObserver,
                         const TUint aIapId,
                         const TDesC8& aSessionId );
        
        /**
         * class destructor
         */
        ~CMSRPSession();
            
    private:
    
        // Session implementation instance, owned
        CMSRPSessionImplementation* iMSRPSessionImpl;
    };

#endif /* CMSRPSESSION_H_ */

// End of File