multimediacommsengine/tsrc/testdriver/testclient/net/src/CTcBtManager.h
changeset 0 1bce908db942
--- /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 <e32base.h>
+#include <btsdp.h>
+#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__