diff -r 000000000000 -r 1bce908db942 multimediacommsengine/tsrc/testdriver/testclient/net/src/CTcBtManager.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/multimediacommsengine/tsrc/testdriver/testclient/net/src/CTcBtManager.h Tue Feb 02 01:04:58 2010 +0200 @@ -0,0 +1,148 @@ +/* +* Copyright (c) 2004 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: See class definition below. +* +*/ + +#ifndef __CTCBTMANAGER_H__ +#define __CTCBTMANAGER_H__ + +// INCLUDES +#include +#include +#include "MTcBearerManager.h" +#include "MTcBearerObserver.h" +#include "CTcBtConnection.h" + +// FORWARD DECLARATIONS +class TTcBtFactory; + +// CLASS DEFINITION +/** + * CTcBtManager implements Bluetooth specific connection management, + * like security settings and service advertisement. + * It also owns and controls the CTcBtConnection instance + */ +class CTcBtManager + : public CBase, + public MTcBearerManager, + public MTcBearerObserver + { + public: // Constructors and destructor + + /** + * Static constructor. + * + * @param aFactory Specifies the used bearer type + * @return An initialized instance of this class + */ + static CTcBtManager* NewL( const TTcBtFactory& aFactory ); + + /// Destructor + ~CTcBtManager(); + + private: // Constructors + + /** + * Constructor + * + * @param aFactory Specifies the used bearer type + */ + CTcBtManager( const TTcBtFactory& aFactory ); + + /// Default constructor. Not implemented. + CTcBtManager(); + + /// 2nd phase constructor. + void ConstructL(); + + public: // From MTcBearerManager + + void ConnectL( TInetAddr* aRemoteAddr ); + void Close(); + void Send( const TDesC8& aDes ); + void Receive( TDes8& aDes ); + void ReceiveOneOrMore( TDes8& aDes ); + void SetObserver( MTcBearerObserver* aObserver ); + void GetLocalAddressL( TDes& aDes ); + + public: // From MTcBearerObserver + + void BearerCompletion( MTcBearerObserver::TOperation aOp, + TInt aStatus ); + + private: // New methods + + /** + * Add our service to the Service Discovery Database (SDP) + * + * @param aChannel Bluetooth channel/port number of the service + */ + void StartAdvertiserL( TInt aChannel ); + + /// Remove our service from the SDP + void StopAdvertiser(); + + /** + * Mark our service as available or unavailable in the SDP. + * + * @param aIsAvailable ETrue for available, + * EFalse for unavailable + */ + void MakeAvailableL( TBool aIsAvailable ); + + /** + * Define security requirements for incoming connections. + * + * @param aChannel Bluetooth channel/port number + * @param aAuthentication ETrue = required, EFalse = not required + * @param aEncryption ETrue = required, EFalse = not required + * @param aAuthorisation ETrue = required, EFalse = not required + */ +#ifndef __BLUETOOTH_API_V2__ + void SetSecurityL( TInt aChannel, + TBool aAuthentication, + TBool aEncryption, + TBool aAuthorisation ); +#endif + /// Turn on BT if it's not already on. May result in a dialog + /// shown to the user. + void TurnOnBtL(); + + private: // Data + + /// Connection implementation. Owned. + CTcBtConnection iConn; + + /// Connection observer. Not owned. + MTcBearerObserver* iObserver; + + /// SDP session. Owned. + RSdp iSdpServ; + + /// SDP database handle. Owned. + RSdpDatabase iSdpDb; + + /// SDP record for our service + TSdpServRecordHandle iSdpRecord; + + /// State (bit like a version number) of SDP records + TInt iSdpRecordState; + + /// Socket server session. Owned. + RSocketServ iSockServ; + + }; + +#endif // __CTCBTMANAGER_H__