syncmlfw/common/obex/obexcommserver/src/NSmlObexCommSession.cpp
changeset 0 b497e44ab2fc
equal deleted inserted replaced
-1:000000000000 0:b497e44ab2fc
       
     1 /*
       
     2 * Copyright (c) 2002-2004 Nokia Corporation and/or its subsidiary(-ies). 
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  SyncML Obex server internal server module
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 // INCLUDE FILES
       
    20 #include <nsmldebug.h>
       
    21 #include "nsmlobexcommserver.h"
       
    22 #include "nsmlobexdefs.h"
       
    23 
       
    24 
       
    25 // ============================ MEMBER FUNCTIONS ===============================
       
    26 
       
    27 // -----------------------------------------------------------------------------
       
    28 // CNSmlObexCommSession::NewL
       
    29 // Two-phased constructor.
       
    30 // -----------------------------------------------------------------------------
       
    31 //
       
    32 CNSmlObexCommSession* CNSmlObexCommSession::NewL( CNSmlObexCommServer& aServer )
       
    33 	{
       
    34 	CNSmlObexCommSession* self = new (ELeave) CNSmlObexCommSession( aServer);
       
    35 	CleanupStack::PushL(self);
       
    36 	self->ConstructL();
       
    37 	CleanupStack::Pop(); // self
       
    38 	return self;
       
    39 	}
       
    40 
       
    41 // -----------------------------------------------------------------------------
       
    42 // CNSmlObexCommSession::ServiceL
       
    43 // -----------------------------------------------------------------------------
       
    44 //
       
    45 void CNSmlObexCommSession::ServiceL( const RMessage2& aMessage )
       
    46 	{
       
    47 	_DBG_FILE("CNSmlObexCommSession::ServiceL(): begin");
       
    48 	TRAP_IGNORE(DispatchMessageL(aMessage));
       
    49 	_DBG_FILE("CNSmlObexCommSession::ServiceL(): end");
       
    50 	}
       
    51 
       
    52 // -----------------------------------------------------------------------------
       
    53 // CNSmlObexCommSession::DispatchMessageL
       
    54 // -----------------------------------------------------------------------------
       
    55 //
       
    56 void CNSmlObexCommSession::DispatchMessageL( const RMessage2& aMessage )
       
    57 	{
       
    58 	_DBG_FILE("CNSmlObexCommSession::DispatchMessageL(): begin");
       
    59 	switch( aMessage.Function() )
       
    60         {
       
    61 	case ENSmlObexCommCommandDisconnect:
       
    62 		Disconnect(aMessage);
       
    63 		break;
       
    64 	case ENSmlObexCommCommandSend:
       
    65 		SendL(aMessage);
       
    66 		break;
       
    67 	case ENSmlObexCommCommandReceive:
       
    68 		ReceiveL(aMessage);
       
    69 		break;
       
    70 	case ENSmlObexCommCommandCancelReceive:
       
    71 		CancelReceive(aMessage);
       
    72 		break;
       
    73 	case ENSmlObexCommCommandSetReceivePacket:
       
    74 		SetReceivedPacketL(aMessage);
       
    75 		break;
       
    76 	case ENSmlObexCommCommandGetSendPacket:
       
    77 		GetSendPacketL(aMessage);
       
    78 		break;
       
    79 	case ENSmlObexCommCommandCancelGetSendPacket:
       
    80 		CancelGetSendPacket(aMessage);
       
    81 		break;
       
    82 	case ENSmlObexCommCommandListenDisconnect:
       
    83 		ListenDisconnect(aMessage);
       
    84 		break;
       
    85 	case ENSmlObexCommCommandCancelListenDisconnect:
       
    86 		CancelListenDisconnect(aMessage);
       
    87 		break;
       
    88 	default:
       
    89 		PanicClient(KErrNotSupported);
       
    90         }
       
    91 	_DBG_FILE("CNSmlObexCommSession::DispatchMessageL(): end");
       
    92 	}
       
    93 
       
    94 
       
    95 // -----------------------------------------------------------------------------
       
    96 // CNSmlObexCommSession::Disconnect
       
    97 // -----------------------------------------------------------------------------
       
    98 //
       
    99 void CNSmlObexCommSession::Disconnect( const RMessagePtr2& aMessage )
       
   100 	{
       
   101 	_DBG_FILE("CNSmlObexCommSession::Disconnect(): begin");
       
   102 	iServer.iClientReceiveTimeOut->Cancel();
       
   103 	iServer.iServerGetSendTimeOut->Cancel();
       
   104 	iServer.iClientDisconnected = ETrue;
       
   105 	if( iServer.iServerListeningDisconnect )
       
   106 		{
       
   107 		ServerHandleDisconnect(KErrNone);
       
   108 		}
       
   109 	aMessage.Complete(KErrNone);
       
   110 	_DBG_FILE("CNSmlObexCommSession::Disconnect(): end");
       
   111 	}
       
   112 
       
   113 
       
   114 // -----------------------------------------------------------------------------
       
   115 // CNSmlObexCommSession::SendL
       
   116 // -----------------------------------------------------------------------------
       
   117 //
       
   118 void CNSmlObexCommSession::SendL( const RMessagePtr2& aMessage )
       
   119 	{
       
   120 	_DBG_FILE("CNSmlObexCommSession::SendL(): begin");
       
   121 
       
   122 	HBufC8* tempPtr = NULL;
       
   123 	TRAP_IGNORE( tempPtr = HBufC8::NewL(aMessage.GetDesLength(0)) );
       
   124 	iServer.iSendBuffer = tempPtr;
       
   125 	
       
   126 	TPtr8 sendBufferPtr = iServer.iSendBuffer->Des();
       
   127 	aMessage.ReadL(0, sendBufferPtr, 0);
       
   128 	if( iServer.iServerWaitingSendPacket )
       
   129 		{
       
   130 		ServerGetSendPacketL();
       
   131 		}
       
   132 	else
       
   133 		{
       
   134 		iServer.iSendReady = ETrue;
       
   135 		}
       
   136 	aMessage.Complete(KErrNone);
       
   137 	_DBG_FILE("CNSmlObexCommSession::SendL(): end");
       
   138 	}
       
   139 
       
   140 // -----------------------------------------------------------------------------
       
   141 // CNSmlObexCommSession::ReceiveL
       
   142 // -----------------------------------------------------------------------------
       
   143 //
       
   144 void CNSmlObexCommSession::ReceiveL( const RMessagePtr2& aMessage )
       
   145 	{
       
   146 	_DBG_FILE("CNSmlObexCommSession::ReceiveL(): begin");
       
   147 	iServer.iClientReceiveTimeOut->StartTimeoutHandling(this, &CNSmlObexCommSession::ReceiveTimeout);
       
   148 	iServer.iClientReceiveMsg = aMessage;
       
   149 
       
   150 	if( iServer.iClientDisconnected )
       
   151 		{
       
   152 		DBG_FILE_CODE(iServer.iSessionCount, _S8("CNSmlObexCommSession::Receive(): canceling"));
       
   153 		iServer.iClientReceiveMsg.Complete( KErrCancel );
       
   154 		}
       
   155 	else if( iServer.iRecvReady )
       
   156 		{
       
   157 		_DBG_FILE("CNSmlObexCommSession before ClientReceivePacketL()");
       
   158 		ClientReceivePacketL();
       
   159 		}
       
   160 	else
       
   161 		{
       
   162 		_DBG_FILE("CNSmlObexCommSession:: updating iClientWaitingReceivePacket");
       
   163 		iServer.iClientWaitingReceivePacket = ETrue;
       
   164 		}
       
   165 	_DBG_FILE("CNSmlObexCommSession::ReceiveL(): end");
       
   166 	}
       
   167 
       
   168 // -----------------------------------------------------------------------------
       
   169 // CNSmlObexCommSession::CancelReceive
       
   170 // -----------------------------------------------------------------------------
       
   171 //
       
   172 void CNSmlObexCommSession::CancelReceive( const RMessagePtr2& aMessage )
       
   173 	{
       
   174 	_DBG_FILE("CNSmlObexCommSession::CancelReceive(): begin");
       
   175 	if( iServer.iClientWaitingReceivePacket )
       
   176 		{
       
   177 		iServer.iClientReceiveMsg.Complete(KErrCancel);
       
   178 		iServer.iClientWaitingReceivePacket = EFalse;
       
   179 		}
       
   180 	aMessage.Complete(KErrNone);
       
   181 	_DBG_FILE("CNSmlObexCommSession::CancelReceive(): end");
       
   182 	}
       
   183 
       
   184 // -----------------------------------------------------------------------------
       
   185 // CNSmlObexCommSession::ReceiveTimeout
       
   186 // -----------------------------------------------------------------------------
       
   187 //
       
   188 void CNSmlObexCommSession::ReceiveTimeout()
       
   189 	{
       
   190 	_DBG_FILE("CNSmlObexCommSession::ReceiveTimeout(): begin");
       
   191 	iServer.iClientWaitingReceivePacket = EFalse;
       
   192 	iServer.iClientReceiveMsg.Complete(KErrTimedOut);
       
   193 	_DBG_FILE("CNSmlObexCommSession::ReceiveTimeout(): end");
       
   194 	}
       
   195 
       
   196 // -----------------------------------------------------------------------------
       
   197 // CNSmlObexCommSession::SetReceivedPacketL
       
   198 // -----------------------------------------------------------------------------
       
   199 //
       
   200 void CNSmlObexCommSession::SetReceivedPacketL( const RMessagePtr2& aMessage )
       
   201 	{
       
   202 	_DBG_FILE("CNSmlObexCommSession::SetReceivedPacketL(): begin");
       
   203 	TInt err(0);
       
   204 	HBufC8* tempPtr = NULL;
       
   205 	TRAP( err,  tempPtr = HBufC8::NewL(aMessage.GetDesLength(0)) );
       
   206 	iServer.iRecvBuffer = tempPtr;
       
   207 	TPtr8 recvBufferPtr = iServer.iRecvBuffer->Des();
       
   208 	aMessage.ReadL(0, recvBufferPtr, 0);
       
   209 	
       
   210 	if( iServer.iClientWaitingReceivePacket )
       
   211 		{
       
   212 		ClientReceivePacketL();
       
   213 		}
       
   214 	else
       
   215 		{
       
   216 		iServer.iRecvReady = ETrue;
       
   217 		}
       
   218 	aMessage.Complete(KErrNone);
       
   219 	_DBG_FILE("CNSmlObexCommSession::SetReceivedPacketL(): end");
       
   220 	}
       
   221 	
       
   222 // -----------------------------------------------------------------------------
       
   223 // CNSmlObexCommSession::GetSendPacketL
       
   224 // -----------------------------------------------------------------------------
       
   225 //
       
   226 void CNSmlObexCommSession::GetSendPacketL( const RMessagePtr2& aMessage )
       
   227 	{
       
   228 	_DBG_FILE("CNSmlObexCommSession::GetSendPacketL(): begin");
       
   229 	iServer.iServerGetSendTimeOut->StartTimeoutHandling(this, &CNSmlObexCommSession::GetSendTimeout);
       
   230 	iServer.iServerGetSendMsg = aMessage;
       
   231 	if( iServer.iSendReady )
       
   232 		{
       
   233 		ServerGetSendPacketL();
       
   234 		}
       
   235 	else
       
   236 		{
       
   237 		iServer.iServerWaitingSendPacket = ETrue;
       
   238 		}
       
   239 	_DBG_FILE("CNSmlObexCommSession::GetSendPacketL(): end");
       
   240 	}
       
   241 
       
   242 // -----------------------------------------------------------------------------
       
   243 // CNSmlObexCommSession::CancelGetSendPacket
       
   244 // -----------------------------------------------------------------------------
       
   245 //
       
   246 void CNSmlObexCommSession::CancelGetSendPacket( const RMessagePtr2& aMessage )
       
   247 	{
       
   248 	_DBG_FILE("CNSmlObexCommSession::CancelGetSendPacket(): begin");
       
   249 	DoCancelGetSendPacket();
       
   250 	aMessage.Complete(KErrNone);
       
   251 	_DBG_FILE("CNSmlObexCommSession::CancelGetSendPacket(): end");
       
   252 	}
       
   253 
       
   254 // -----------------------------------------------------------------------------
       
   255 // CNSmlObexCommSession::DoCancelGetSendPacket
       
   256 // -----------------------------------------------------------------------------
       
   257 //
       
   258 void CNSmlObexCommSession::DoCancelGetSendPacket()
       
   259 	{
       
   260 	_DBG_FILE("CNSmlObexCommSession::DoCancelGetSendPacket(): begin");
       
   261 	if( iServer.iServerWaitingSendPacket )
       
   262 		{
       
   263 		iServer.iServerGetSendMsg.Complete(KErrCancel);
       
   264 		iServer.iServerWaitingSendPacket = EFalse;
       
   265 		}
       
   266 	_DBG_FILE("CNSmlObexCommSession::DoCancelGetSendPacket(): end");
       
   267 	}
       
   268 
       
   269 // -----------------------------------------------------------------------------
       
   270 // CNSmlObexCommSession::GetSendTimeout
       
   271 // -----------------------------------------------------------------------------
       
   272 //
       
   273 void CNSmlObexCommSession::GetSendTimeout()
       
   274 	{
       
   275 	_DBG_FILE("CNSmlObexCommSession::GetSendTimeout(): begin");
       
   276 	iServer.iServerWaitingSendPacket = EFalse;
       
   277 	iServer.iServerGetSendMsg.Complete(KErrTimedOut);
       
   278 	_DBG_FILE("CNSmlObexCommSession::GetSendTimeout(): end");
       
   279 	}
       
   280 
       
   281 // -----------------------------------------------------------------------------
       
   282 // CNSmlObexCommSession::ListenDisconnect
       
   283 // -----------------------------------------------------------------------------
       
   284 //
       
   285 void CNSmlObexCommSession::ListenDisconnect( const RMessagePtr2& aMessage )
       
   286 	{
       
   287 	_DBG_FILE("CNSmlObexCommSession::ListenDisconnect(): begin");
       
   288 	iServer.iServerListenDisconnectMsg = aMessage;
       
   289 	if( iServer.iClientDisconnected )
       
   290 		{
       
   291 		ServerHandleDisconnect(KErrNone);
       
   292 		}
       
   293 	else
       
   294 		{
       
   295 		iServer.iServerListeningDisconnect = ETrue;
       
   296 		}
       
   297 	_DBG_FILE("CNSmlObexCommSession::ListenDisconnect(): end");
       
   298 	}
       
   299 
       
   300 // -----------------------------------------------------------------------------
       
   301 // CNSmlObexCommSession::CancelListenDisconnect
       
   302 // -----------------------------------------------------------------------------
       
   303 //
       
   304 void CNSmlObexCommSession::CancelListenDisconnect( const RMessagePtr2& aMessage )
       
   305 	{
       
   306 	_DBG_FILE("CNSmlObexCommSession::CancelListenDisconnect(): begin");
       
   307 	if( iServer.iServerListeningDisconnect )
       
   308 		{
       
   309 		ServerHandleDisconnect(KErrCancel);
       
   310 		}
       
   311 	aMessage.Complete(KErrNone);
       
   312 	_DBG_FILE("CNSmlObexCommSession::CancelListenDisconnect(): end");
       
   313 	}
       
   314 
       
   315 // -----------------------------------------------------------------------------
       
   316 // CNSmlObexCommSession::ConstructL
       
   317 // Symbian 2nd phase constructor.
       
   318 // -----------------------------------------------------------------------------
       
   319 //
       
   320 void CNSmlObexCommSession::ConstructL()
       
   321 	{
       
   322 	_DBG_FILE("CNSmlObexCommSession::ConstructL(): begin");
       
   323 	iServer.IncrementSessions();
       
   324 	_DBG_FILE("CNSmlObexCommSession::ConstructL(): end");
       
   325 	}
       
   326 
       
   327 // -----------------------------------------------------------------------------
       
   328 // CNSmlObexCommSession::CNSmlObexCommSession
       
   329 // -----------------------------------------------------------------------------
       
   330 //
       
   331 CNSmlObexCommSession::CNSmlObexCommSession( CNSmlObexCommServer& aServer ) : iServer(aServer)
       
   332 	{
       
   333 	_DBG_FILE("CNSmlObexCommSession::CNSmlObexCommSession(): begin");
       
   334 	_DBG_FILE("CNSmlObexCommSession::CNSmlObexCommSession(): end");
       
   335 	}
       
   336 
       
   337 // -----------------------------------------------------------------------------
       
   338 // CNSmlObexCommSession::~CNSmlObexCommSession
       
   339 // Destructor.
       
   340 // -----------------------------------------------------------------------------
       
   341 //
       
   342 CNSmlObexCommSession::~CNSmlObexCommSession()
       
   343 	{
       
   344 	_DBG_FILE("CNSmlObexCommSession::~CNSmlObexCommSession(): begin");
       
   345 	iServer.DecrementSessions();
       
   346 	_DBG_FILE("CNSmlObexCommSession::~CNSmlObexCommSession(): end");
       
   347 	}
       
   348 
       
   349 // -----------------------------------------------------------------------------
       
   350 // CNSmlObexCommSession::PanicClient
       
   351 // -----------------------------------------------------------------------------
       
   352 //
       
   353 void CNSmlObexCommSession::PanicClient( TInt /*aReason*/ ) const
       
   354 	{
       
   355 	_DBG_FILE("CNSmlObexCommSession::PanicClient(): begin");
       
   356 	_DBG_FILE("CNSmlObexCommSession::PanicClient(): end");
       
   357 	}
       
   358 
       
   359 // -----------------------------------------------------------------------------
       
   360 // CNSmlObexCommSession::ClientReceivePacketL
       
   361 // -----------------------------------------------------------------------------
       
   362 //
       
   363 void CNSmlObexCommSession::ClientReceivePacketL()
       
   364 	{
       
   365 	_DBG_FILE("CNSmlObexCommSession::ClientReceivePacketL(): begin");
       
   366 	iServer.iClientReceiveTimeOut->Cancel();
       
   367 	iServer.iClientWaitingReceivePacket = EFalse;
       
   368 	iServer.iRecvReady = EFalse;
       
   369 	iServer.iClientReceiveMsg.WriteL(0, *iServer.iRecvBuffer, 0);
       
   370 	delete iServer.iRecvBuffer;
       
   371 	iServer.iRecvBuffer = 0;
       
   372 	iServer.iClientReceiveMsg.Complete(KErrNone);
       
   373 	_DBG_FILE("CNSmlObexCommSession::ClientReceivePacketL(): end");
       
   374 	}
       
   375 
       
   376 // -----------------------------------------------------------------------------
       
   377 // CNSmlObexCommSession::ServerGetSendPacketL
       
   378 // -----------------------------------------------------------------------------
       
   379 //
       
   380 void CNSmlObexCommSession::ServerGetSendPacketL()
       
   381 	{
       
   382 	_DBG_FILE("CNSmlObexCommSession::ServerGetSendPacketL(): begin");
       
   383 	iServer.iServerGetSendTimeOut->Cancel();
       
   384 	iServer.iServerWaitingSendPacket = EFalse;
       
   385 	iServer.iSendReady = EFalse;
       
   386 	iServer.iServerGetSendMsg.WriteL(0, *iServer.iSendBuffer, 0);
       
   387 	delete iServer.iSendBuffer;
       
   388 	iServer.iSendBuffer = 0;
       
   389 	iServer.iServerGetSendMsg.Complete(KErrNone);
       
   390 	_DBG_FILE("CNSmlObexCommSession::ServerGetSendPacketL(): end");
       
   391 	}
       
   392 
       
   393 // -----------------------------------------------------------------------------
       
   394 // CNSmlObexCommSession::ServerHandleDisconnect
       
   395 // -----------------------------------------------------------------------------
       
   396 //
       
   397 void CNSmlObexCommSession::ServerHandleDisconnect( TInt aResult )
       
   398 	{
       
   399 	_DBG_FILE("CNSmlObexCommSession::ServerHandleDisconnect(): begin");
       
   400 	DoCancelGetSendPacket();
       
   401 	iServer.iServerListenDisconnectMsg.Complete(aResult);
       
   402 	iServer.iServerListeningDisconnect = EFalse;
       
   403 	
       
   404 	if( iServer.iClientWaitingReceivePacket )
       
   405 		{
       
   406 		DBG_FILE_CODE(aResult, _S8("CNSmlObexCommSession::ServerHandleDisconnect() - signal client"));
       
   407 		iServer.iClientReceiveMsg.Complete( KErrCancel );
       
   408 		iServer.iClientWaitingReceivePacket = EFalse;
       
   409 		}
       
   410 	_DBG_FILE("CNSmlObexCommSession::ServerHandleDisconnect(): end");
       
   411 	}