servicediscoveryandcontrol/pnp/test/upnp/SocketHandler/src/csockethandler.cpp
changeset 0 f5a58ecadc66
equal deleted inserted replaced
-1:000000000000 0:f5a58ecadc66
       
     1 // Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
       
     2 // All rights reserved.
       
     3 // This component and the accompanying materials are made available
       
     4 // under the terms of "Eclipse Public License v1.0"
       
     5 // which accompanies this distribution, and is available
       
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     7 //
       
     8 // Initial Contributors:
       
     9 // Nokia Corporation - initial contribution.
       
    10 //
       
    11 // Contributors:
       
    12 //
       
    13 // Description:
       
    14 //
       
    15 
       
    16 
       
    17 #include <in_sock.h>
       
    18 #include <eintsock.h>
       
    19 #include "rsockethandler.h"
       
    20 #include "csockethandler.h"
       
    21 
       
    22 
       
    23 
       
    24 const TInt KDefaultFlags = 0;
       
    25 /**
       
    26 Constructor.
       
    27 */
       
    28 CSocketHandler::CSocketHandler ( RInternalSocket& aSocket, MSocketHandlerObserver& aObserver )
       
    29 : CActive ( EPriorityStandard ),
       
    30 	iSocket ( aSocket ),
       
    31   iObserver ( aObserver )
       
    32 	{
       
    33 	CActiveScheduler::Add(this);	
       
    34 	}
       
    35 
       
    36 CSocketHandler::CSocketHandler ( MSocketHandlerObserver& aObserver )
       
    37 : CActive ( EPriorityNormal ),
       
    38 iObserver ( aObserver )
       
    39 	{
       
    40 	CActiveScheduler::Add(this);
       
    41 	}
       
    42 
       
    43 /** 
       
    44 Destructor.
       
    45 */
       
    46 CSocketHandler::~CSocketHandler ()
       
    47 	{
       
    48 	Cancel ();		
       
    49 	}
       
    50 
       
    51 /**
       
    52 Starts a socket operation on RInternalSocket.
       
    53 
       
    54 @param aParams. Socket operation parameters.
       
    55 */
       
    56 void CSocketHandler::Activate ( const TSocketHandlerParams& aParams )
       
    57 	{
       
    58 	iOperation = static_cast < TOperation > ( aParams.iArgs[0] );
       
    59 	TInt err = KErrNone;
       
    60 	switch ( iOperation )
       
    61 		{
       
    62 		case EConnect:
       
    63 			{
       
    64 			TSockAddr* addr = reinterpret_cast < TSockAddr* > ( aParams.iArgs[1] );
       
    65 			iSocket.Connect ( *addr, iStatus );
       
    66 			}
       
    67 		break;
       
    68 		
       
    69 		case EAccept:
       
    70 			{
       
    71 			err = iAcceptingSocket.Open ();
       
    72 			iSocket.Accept ( iAcceptingSocket, iStatus );
       
    73 			}
       
    74 		break;
       
    75 		
       
    76 		case EMBufSend:
       
    77 			{
       
    78 			iBufChain.Init ( );
       
    79 			RMBufChain* bufChain = reinterpret_cast < RMBufChain* > ( aParams.iArgs[1] );
       
    80 			iLength = 0;
       
    81 			iSocket.Send ( *bufChain, KDefaultFlags, iStatus, iLength );
       
    82 			}
       
    83 		break;
       
    84 		
       
    85 /*		case EOpenByName:
       
    86 			{
       
    87 			const TDesC* buf = reinterpret_cast < const TDesC* > ( aParams.iArgs[1] );
       
    88 			iSocket.Open ( *buf, iStatus );
       
    89 			}
       
    90 		break;
       
    91 				
       
    92 		case EDescSend:
       
    93 			{
       
    94 			const TDesC8* buf = reinterpret_cast < const TDesC8* > ( aParams.iArgs[1] );
       
    95 			iSocket.Send ( *buf, KDefaultFlags, iStatus );
       
    96 			}
       
    97 		break;
       
    98 		
       
    99 		case EDescSendTo:
       
   100 			{
       
   101 			const TDesC8* buf = reinterpret_cast < const TDesC8* > ( aParams.iArgs[1] );
       
   102 			iSockAddr = *(reinterpret_cast < TSockAddr* > ( aParams.iArgs[2] ));
       
   103 			iSocket.SendTo ( *buf, iSockAddr, KDefaultFlags, iStatus );
       
   104 			}
       
   105 		break; 
       
   106 		
       
   107 */		case EMBufSendTo:
       
   108 			{
       
   109 			iBufChain.Init ( );
       
   110 			iBufChain = *(reinterpret_cast < RMBufChain* > ( aParams.iArgs[1] ));
       
   111 			iSockAddr = *(reinterpret_cast < TSockAddr* > ( aParams.iArgs[2] ));
       
   112 			iLength = 0;
       
   113 			iSocket.SendTo ( iBufChain, iSockAddr, KDefaultFlags, iStatus, iLength );
       
   114 			}
       
   115 		break;
       
   116 
       
   117 		case ERecv:
       
   118 			{
       
   119 			iBufChain.Init ( );
       
   120 			iSocket.Recv ( iBufChain, KDefaultFlags, iStatus );
       
   121 			}
       
   122 		break;
       
   123 
       
   124 		case ERecvFrom:
       
   125 			{
       
   126 			iBufChain.Init ();
       
   127 			iSocket.RecvFrom ( iBufChain, iSockAddr, KDefaultFlags, iStatus );
       
   128 			}
       
   129 		break;
       
   130 
       
   131 		case EOpenByProtocol:
       
   132 			{
       
   133 			TUint addrFamily = static_cast < TUint> ( aParams.iArgs[1] );	
       
   134 			TUint sockType = static_cast < TUint> ( aParams.iArgs[2] );				
       
   135 			TUint prot = static_cast < TUint> ( aParams.iArgs[3] );
       
   136 			iSocket.Open ( addrFamily, sockType, prot, iStatus );
       
   137 			}
       
   138 		break;
       
   139 
       
   140 		default:
       
   141 			User::Invariant ();
       
   142 		};
       
   143 		
       
   144 	if ( KErrNone == err )
       
   145 		{
       
   146 		SetActive();
       
   147 		}
       
   148 	else
       
   149 		{
       
   150 		CompleteSelf ( err );
       
   151 		}
       
   152 	}
       
   153 
       
   154 void CSocketHandler::CompleteSelf ( TInt aError )
       
   155 	{
       
   156     TRequestStatus* pStat = &iStatus;
       
   157     User::RequestComplete ( pStat, aError );
       
   158 	SetActive ( );
       
   159     }
       
   160 	
       
   161 /**
       
   162 Handles this idle active object's request completion event.
       
   163 */
       
   164 void CSocketHandler::RunL ()
       
   165 	{
       
   166 	TInt err = iStatus.Int ();
       
   167 	if ( err == KErrNone )
       
   168 		{
       
   169 		NotifyCompletion ();
       
   170 		}
       
   171 	else
       
   172 		{
       
   173 		iObserver.Error ( iOperation, err );
       
   174 		}
       
   175 	}
       
   176 
       
   177 /**
       
   178 Cancellation of an outstanding request.
       
   179 */
       
   180 void CSocketHandler::DoCancel ()
       
   181 	{
       
   182 	CancelCurrent ();
       
   183 	}
       
   184 	
       
   185 void CSocketHandler::NotifyCompletion ( )
       
   186 	{
       
   187 	switch ( iOperation )
       
   188 		{
       
   189 		case EConnect:
       
   190 			{
       
   191 			iObserver.ConnectComplete();
       
   192 			}
       
   193 		break;
       
   194 		
       
   195 		case EAccept:
       
   196 			{
       
   197 			iObserver.AcceptComplete( iAcceptingSocket );
       
   198 			RInternalSocket sock;
       
   199 			iAcceptingSocket = sock;
       
   200 			}
       
   201 		break;
       
   202 		
       
   203 //		case EDescSend:
       
   204 		case EMBufSend:	
       
   205 			{
       
   206 			iObserver.SendComplete( iLength() );
       
   207 			}
       
   208 		break;
       
   209 
       
   210 //		case EDescSendTo:
       
   211 		case EMBufSendTo:
       
   212 			{
       
   213 			iObserver.SendToComplete( iLength() );
       
   214 			}
       
   215 		break;
       
   216 			
       
   217 		case ERecv:		
       
   218 			{
       
   219 			iObserver.RecvComplete( iBufChain );
       
   220 			}
       
   221 		break;
       
   222 		
       
   223 		case ERecvFrom:
       
   224 			{
       
   225 			iObserver.RecvFromComplete( iBufChain, iSockAddr );
       
   226 			}
       
   227 		break;
       
   228 
       
   229 		case EOpenByProtocol:
       
   230 //		case EOpenByName:
       
   231 			{
       
   232 			iObserver.OpenComplete(iSocket);
       
   233 			}
       
   234 		break;
       
   235 		
       
   236 /*		case EIoctl:
       
   237 			iObserver.IoctlComplete();
       
   238 		break;				
       
   239 */		 
       
   240 		};
       
   241 	}
       
   242 
       
   243 /**
       
   244 Determines whether the socket handler has a request outstanding
       
   245 */
       
   246 TBool CSocketHandler::IsRunning ( TOperation aOperation )
       
   247 	{
       
   248 	return ( IsActive() && ( aOperation == iOperation  ) );
       
   249 	}
       
   250 
       
   251 void CSocketHandler::CancelCurrent ()
       
   252 	{
       
   253 	switch ( iOperation )
       
   254 		{
       
   255 		case EConnect:
       
   256 			iSocket.CancelConnect ();
       
   257 		break;
       
   258 		
       
   259 		case EAccept:
       
   260 			iSocket.CancelAccept ();
       
   261 			iAcceptingSocket.Close ();
       
   262 		break;
       
   263 		
       
   264 //		case EDescSend:
       
   265 		case EMBufSend:	
       
   266 //		case EDescSendTo:
       
   267 		case EMBufSendTo:
       
   268 			iSocket.CancelSend ();
       
   269 		break;
       
   270 
       
   271 		case ERecv:
       
   272 		case ERecvFrom:
       
   273 			iSocket.CancelRecv ();
       
   274 		break;
       
   275 
       
   276 		case EOpenByProtocol:
       
   277 //		case EOpenByName:
       
   278 			iSocket.Close (); 
       
   279 		break;	
       
   280 		};
       
   281 	}