convergedconnectionhandler/cchclientapi/inc/cchserviceimpl.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 18 Jan 2010 20:12:36 +0200
changeset 0 a4daefaec16c
child 9 bddb6d4447db
permissions -rw-r--r--
Revision: 201001 Kit: 201003

/*
* Copyright (c) 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:  cch client api implementation class
*
*/



#ifndef C_CCHSERVICEIMPL_H
#define C_CCHSERVICEIMPL_H

#include <e32base.h>
#include <ccherror.h>
#include <cchtypes.h>
//from cchclient
#include "cchimpl.h"
#include "cch.h"


class CCchClientObserver;
class CCchImpl;

#ifdef CCHAPI_USE_CCHUI
class CCchUiPrivateApi;
#else 
#define CCchUiPrivateApi TInt 
#endif

/**
 *  Class for basic cch functionality, getting services
 *
 *  @code
 *   ?good_class_usage_example(s)
 *  @endcode
 *
 *  @lib cch
 */
class CCchServiceImpl : public CCchService
    {

public:

    /**
     * Two-phased constructor.
     * 
     * @param aCch Cch service factory
     * @param aServiceId Id of the service
     * @param aCchUi CCH connectivity UI handling API
     */
    static CCchServiceImpl* NewL( CCchImpl& aCch, 
                                  TInt aServiceId,
                                  CCchUiPrivateApi& aCchUi );
    
    /**
     * Two-phased constructor.
     * 
     * @param aCch Cch service factory
     * @param aServiceId Id of the service
     * @param aCchUi CCH connectivity UI handling API
     */
    static CCchServiceImpl* NewLC( CCchImpl& aCch, 
                                   TInt aServiceId,
                                   CCchUiPrivateApi& aCchUi );
    
    /**
     * Destructor.
     */
    ~CCchServiceImpl();

public: // from CCchService

    /**
     * Launches service enable. See CCchServiceObserver for status changes.
     *
     * @param aType Type of service
     * @return Symbian error
     */
    TInt Enable( TCCHSubserviceType aType );
    
    /**
     * Launches service disable. See CCchServiceObserver for status changes.
     *
     * @param aType Type of service
     * @return Symbian error
     */
    TInt Disable( TCCHSubserviceType aType );
    
    /**
     * Returns the current service state
     *
     * @param aType Type of service
     * @param aStatus Status of the service, return value
     * @return Symbian error code
     */
    TInt GetStatus( TCCHSubserviceType aType, TCchServiceStatus& aStatus ) const;
    
    /**
     * Returns the connection parameters
     *
     * @param aType Type of service
     * @param aParameter Connection parameter of the service
     * @param aValue value of the parameter
     * @return Symbian error code
     */
    TInt GetConnectionParameter( TCCHSubserviceType aType, TCchConnectionParameter aParameter, TInt& aValue ) const;
    
    /**
     * Returns the connection parameters
     *
     * @param aType Type of service
     * @param aParameter Connection parameter of the service
     * @param aValue value of the parameter
     * @return Symbian error code
     */
    TInt GetConnectionParameter( TCCHSubserviceType aType, 
                                 TCchConnectionParameter aParameter, 
                                 RBuf& aValue ) const;
    
    /**
     * Sets the connection parameters
     *
     * @param aType The type of service
     * @param aParameter Connection parameter of the service
     * @param aValue value of the parameter
     * @return Symbian error code
     */
    TInt SetConnectionParameter( TCCHSubserviceType aType, 
                                 TCchConnectionParameter aParameter, 
                                 TInt aValue );
    
    /**
     * Sets the connection parameters
     *
     * @param aType The type of service
     * @param aParameter Connection parameter of the service
     * @param aValue value of the parameter
     * @return Symbian error code
     */
    TInt SetConnectionParameter( TCCHSubserviceType aType, 
                                 TCchConnectionParameter aParameter, 
                                 const TDesC& aValue );
    
    /**
     * Reserves the service for exclusive usage
     *
     * @param aType Type of service
     * @return Symbian error code
     */
    TInt Reserve( TCCHSubserviceType aType );
    
    /**
     * Frees the service of exclusive usage
     *
     * @param aType Type of service
     * @return Symbian error code
     */
    TInt Free( TCCHSubserviceType aType );
    
    /**
     * Is the service reserved
     *
     * @param aType Type of service
     * @param aReserved True if the service is reserved
     * @return Symbian error code
     */
    TInt IsReserved( TCCHSubserviceType aType, 
                     TBool& aReserved ) const;
    
    /**
     * Returns the service id
     *
     * @return Service id
     */
    TInt ServiceId() const;
    
    /**
     * @deprecated Do not use this anymore, change to AddObserver!
     *
     * Adds observer for listening service events
     *
     * @param aObserver Event observing class
     */
    void SetObserver( MCchServiceStatusObserver& aObserver );
    
    /**
     * @deprecated Do not use this anymore, change to 
     * RemoveObserver method with paramater
     * 
     * Removes the observer of service events
     */
    void RemoveObserver( );

    /**
     * Adds observer for listening service events
     *
     * @param aObserver Event observing class
     * @return KErrAlreadyExist Observer already added
     *         KErrNone Observer was added
     */
    TInt AddObserver( MCchServiceStatusObserver& aObserver );
    
    /**
     * Removes the observer of service events
     *
     * @param aObserver Event observing class
     * @return KErrNotFound Observer was not found
     *         KErrNone Observer was removed
     */
    TInt RemoveObserver( MCchServiceStatusObserver& aObserver );
    
    /**
     * Checks if the type is supported
     *
     * @param aType Type of service
     * @param aSupported True if the service type is supported
     * @return Symbian error code
     */
    TInt IsSupported( TCCHSubserviceType aType, TBool& aSupported ) const;
    
private:
    
    /**
     * The constructor
     * 
     * @param aCch Cch service factory
     * @param aServiceId The id of the service
     */
	CCchServiceImpl( CCchImpl& aCch, 
	                 TInt aServiceId, 
                     CCchUiPrivateApi& aCchUi );
    
    /**
     * By default Symbian 2nd phase constructor is private.
     */
    void ConstructL();

public:

	CCchImpl* CchImpl() const;
	
private: // data

	/**
	 * cch service factory, not own
	 */
	CCchImpl& iCch;
	
	/**
	 * Service Id
	 */
	TInt iServiceId; 
	
	/**
	 * Service observer
	 */
	CCchClientObserver* iObserver;
	/**
	 * CCH connectivity UI handling private API
	 */	
	CCchUiPrivateApi& iCchUi;

#ifdef CCHUNITTEST
    friend class UT_CCchService;
#endif
    };

#endif // C_CCHSERVICEIMPL_H