imservices/instantmessagingcache/imcacheclient/src/cimcacheeventhandler.cpp
changeset 0 e6b17d312c8b
child 1 b610b446cb01
equal deleted inserted replaced
-1:000000000000 0:e6b17d312c8b
       
     1 /*
       
     2 * Copyright (c) 2008 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:  cache message change observer
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 //  INCLUDE FILES
       
    20 
       
    21 #include "cimcacheeventhandler.h"
       
    22 #include "mimcacheclient.h"
       
    23 #include "mimcacheeventhandler.h"
       
    24 // logs
       
    25 #include "imcachedebugtrace.h"
       
    26 
       
    27 // -----------------------------------------------------------------------------
       
    28 // CIMCacheEventHandler::NewL
       
    29 // -----------------------------------------------------------------------------
       
    30 //
       
    31 CIMCacheEventHandler* CIMCacheEventHandler::NewL( 
       
    32 								MIMCacheClient& aRegistrar, 
       
    33 								MIMCacheEventHandler& aHandler)
       
    34     {
       
    35     TRACE( T_LIT("CIMCacheEventHandler::NewL() begin") );
       
    36 	CIMCacheEventHandler* self = new ( ELeave ) CIMCacheEventHandler( aRegistrar ,aHandler ) ;
       
    37     CleanupStack::PushL( self );
       
    38     self->ConstructL();
       
    39     CleanupStack::Pop( self );  //self
       
    40 	TRACE( T_LIT("CIMCacheEventHandler::NewL() end") );
       
    41     return self;
       
    42     }
       
    43 
       
    44 // -----------------------------------------------------------------------------
       
    45 // CIMCacheEventHandler::ConstructL
       
    46 // -----------------------------------------------------------------------------
       
    47 //
       
    48 void CIMCacheEventHandler::ConstructL()
       
    49     {
       
    50     TRACE( T_LIT("CIMCacheEventHandler::ConstructL() begin") );
       
    51     iContinueObserving = ETrue ;
       
    52    	CActiveScheduler::Add( this );
       
    53 	iRegistrar.RegisterObserverToServerL( iStatus ,EIMCacheObserveMessageUpdateRegister );
       
    54 	SetActive();
       
    55 	TRACE( T_LIT("CIMCacheEventHandler::ConstructL() end") );
       
    56     }
       
    57 
       
    58 // -----------------------------------------------------------------------------
       
    59 // CIMCacheEventHandler::~CIMCacheEventHandler
       
    60 // -----------------------------------------------------------------------------
       
    61 //
       
    62 CIMCacheEventHandler::~CIMCacheEventHandler()
       
    63 	{
       
    64 	TRACE( T_LIT("CIMCacheEventHandler::~CIMCacheEventHandler() begin") );
       
    65 	Cancel();
       
    66 	TRACE( T_LIT("CIMCacheEventHandler::~CIMCacheEventHandler() end") );
       
    67 	}
       
    68 
       
    69 // -----------------------------------------------------------------------------
       
    70 // CIMCacheEventHandler::CIMCacheEventHandler(
       
    71 // -----------------------------------------------------------------------------
       
    72 //
       
    73 CIMCacheEventHandler::CIMCacheEventHandler(
       
    74 								 MIMCacheClient& aRegistrar , 
       
    75 								 MIMCacheEventHandler& aHandler ) :
       
    76 	CActive( CActive::EPriorityIdle ),
       
    77   	iRegistrar( aRegistrar ),
       
    78   	iUpdateHandler( aHandler )
       
    79  	{
       
    80  	TRACE( T_LIT("CIMCacheEventHandler::CIMCacheEventHandler()") );
       
    81 	}
       
    82 // -----------------------------------------------------------------------------
       
    83 // CIMCacheEventHandler::RunL
       
    84 // -----------------------------------------------------------------------------
       
    85 //
       
    86 void CIMCacheEventHandler::RunL()
       
    87 	{
       
    88 	TRACE( T_LIT("CIMCacheEventHandler::RunL() begin") );
       
    89 	TRACE( T_LIT("CIMCacheEventHandler::RunL() iStatus code = "),iStatus.Int()  );
       
    90 
       
    91 	switch( iStatus.Int() )
       
    92 		{
       
    93 		case EIMOperationUnreadMessage :
       
    94 		case EIMOperationDataAvailable :
       
    95 		case EIMOperationMessageAdded :
       
    96 			{
       
    97 			// message data available get the data	
       
    98             GetBufferChatDataL();
       
    99 			break;	
       
   100 			}
       
   101 	   case EIMOperationCompleted :
       
   102 	   		{
       
   103 	   		iUpdateHandler.HandleIMCacheEventL( EIMCacheRequestCompleted, NULL );	
       
   104 	   		}
       
   105 	    case EIMOperationChatStarted :
       
   106 		    {
       
   107 		    iUpdateHandler.HandleIMCacheEventL( EIMCacheRequestCompleted, NULL );
       
   108 		    break;	
       
   109 		    }
       
   110 		case EIMOperationUnreadChange:
       
   111 			{
       
   112 			iUpdateHandler.HandleIMCacheEventL( EIMCacheRequestCompleted, NULL );
       
   113 			break;	
       
   114 			}
       
   115 		case EIMOperationChatAdded :
       
   116 			{
       
   117 			// chat information
       
   118 		    GetBufferedChatItemL(EIMCacheNewChat);
       
   119 			break;	
       
   120 			}
       
   121 		case EIMOperationChatDeleted :
       
   122 			{
       
   123 			// message data available get the data	
       
   124             GetBufferedChatItemL(EIMCacheChatClosed );		
       
   125 			break;	
       
   126 			}
       
   127 		 case EIMOperationAllChatDeleted:
       
   128 		     {
       
   129 		     iUpdateHandler.HandleIMCacheEventL( EIMCacheAllChatClosed, NULL );
       
   130 		     break;
       
   131 		     }
       
   132 		case EIMOperationUnRegistered:
       
   133 			{
       
   134 			TRACE( T_LIT("CIMCacheEventHandler::RunL() EIMOperationUnRegistered") );
       
   135 			iContinueObserving = EFalse;	
       
   136 			break;	
       
   137 			}
       
   138 		default :
       
   139 		    {
       
   140 		    TRACE( T_LIT("CIMCacheEventHandler::RunL() default") );
       
   141 		    break;	
       
   142 		    }
       
   143 		}	
       
   144 		
       
   145 	TRACE( T_LIT("CIMCacheEventHandler::RunL() iContinueObserving iContinueObserving = %d") ,iContinueObserving);
       
   146 	// check need to continue observing to server
       
   147 	if( iContinueObserving )
       
   148 		{
       
   149 		iRegistrar.RegisterObserverToServerL( iStatus ,EIMCacheObserveMessageUpdateRegister );
       
   150 		SetActive();
       
   151 		}
       
   152 	TRACE( T_LIT("CIMCacheEventHandler::RunL() end") );
       
   153 	}
       
   154 // -----------------------------------------------------------------------------
       
   155 // CIMCacheEventHandler::DoCancel
       
   156 // -----------------------------------------------------------------------------
       
   157 //	
       
   158 void CIMCacheEventHandler::DoCancel()
       
   159 	{
       
   160 	TRACE( T_LIT("CIMCacheEventHandler::DoCancel() ") );
       
   161 	if( IsActive() )
       
   162         {
       
   163         TRAP_IGNORE(iRegistrar.CancelRequestL( iStatus ,EIMCacheCancelRequest ));
       
   164         }
       
   165 	}
       
   166 // ---------------------------------------------------------
       
   167 // CIMCacheEventHandler::RunError()
       
   168 // ---------------------------------------------------------
       
   169 //
       
   170 TInt CIMCacheEventHandler::RunError( TInt /* aError */)
       
   171     {
       
   172     TRACE( T_LIT("CVIMPSTEngineCVListener::RunError() start"));
       
   173     return KErrNone;
       
   174     }
       
   175 // -----------------------------------------------------------------------------
       
   176 // CIMCacheEventHandler::UnRegisterObserver
       
   177 // -----------------------------------------------------------------------------
       
   178 //		
       
   179 void CIMCacheEventHandler::UnRegisterObserver()
       
   180 	{
       
   181 	TRACE( T_LIT("CIMCacheEventHandler::UnRegisterObserver() begin") );
       
   182 	if( IsActive() )
       
   183 		{
       
   184 		TRACE( T_LIT("CIMCacheEventHandler::UnRegisterObserver() active") );
       
   185 		TRAP_IGNORE(iRegistrar.UnRegisterObserverToServerL( iStatus ,EIMCacheObserveMessageUpdateUnRegister ));
       
   186 		}
       
   187 	TRACE( T_LIT("CIMCacheEventHandler::UnRegisterObserver() end") );	
       
   188 	}
       
   189 // -----------------------------------------------------------------------------
       
   190 // CIMCacheEventHandler::GetBufferChatDataL
       
   191 // -----------------------------------------------------------------------------
       
   192 //
       
   193 void CIMCacheEventHandler::GetBufferChatDataL( ) 
       
   194     {
       
   195     TRACE( T_LIT("CIMCacheEventHandler::GetBufferChatDataL() begin") );
       
   196 	TBool more = ETrue;
       
   197     while(more)
       
   198         {
       
   199         TPtr8 bufferPtr = iRegistrar.GetBufferedDataL( EIMCacheGetBufferedPackets );
       
   200         InternalizeChatDataL( bufferPtr , more );
       
   201         }
       
   202     TRACE( T_LIT("CIMCacheEventHandler::GetBufferChatDataL() end") );
       
   203     }
       
   204 // -----------------------------------------------------------------------------
       
   205 // CIMCacheEventHandler::InternalizeChatDataL
       
   206 // -----------------------------------------------------------------------------     
       
   207 void CIMCacheEventHandler::InternalizeChatDataL( TPtr8 aChatDataBuffer , TBool& aMore )
       
   208     {
       
   209     TRACE( T_LIT("CIMCacheEventHandler::InternalizeChatDataL() Start") );
       
   210     if( 0 == aChatDataBuffer.Length())
       
   211         {
       
   212         TRACE( T_LIT("CIMCacheEventHandler::InternalizeChatDataL()  aChatDataBuffer is zeor, hence returning ") );
       
   213         return;
       
   214         }
       
   215    	RDesReadStream readAllStream ;
       
   216 	RDesReadStream readStream ;    
       
   217 
       
   218 	readAllStream.Open( aChatDataBuffer );
       
   219 	CleanupClosePushL(readAllStream);
       
   220 
       
   221 	TInt messageCount = readAllStream.ReadInt16L();
       
   222 
       
   223 	for( TInt i=0; i< messageCount; i++)
       
   224 		{
       
   225 		SIMCacheMessageData chatData =
       
   226 		    {
       
   227 		    TIMCacheMessageType(0),
       
   228 		    };
       
   229 		        
       
   230 		TInt size = readAllStream.ReadInt16L() ;
       
   231 		HBufC8* mBuffer  = HBufC8::NewLC( size );
       
   232 		TPtr8 mBufferPtr = mBuffer->Des();
       
   233 		        
       
   234 		readAllStream.ReadL( mBufferPtr , size );
       
   235 
       
   236 		readStream.Open( *mBuffer );        
       
   237 		CleanupClosePushL(readStream) ;
       
   238 
       
   239 		chatData.iMessageType   = static_cast<TIMCacheMessageType>( readStream.ReadInt16L() );
       
   240 		chatData.iMessagerType  = static_cast<TIMCacheMessagerType>( readStream.ReadInt16L() );
       
   241 		chatData.iContentType   = static_cast<TIMCacheContentType>( readStream.ReadInt16L() );
       
   242 		chatData.iTime          = static_cast<TReal64>( readStream.ReadReal64L() );
       
   243 
       
   244 		TInt buddyLength = readStream.ReadInt16L();
       
   245 		HBufC* buddy     = HBufC::NewLC( buddyLength );
       
   246 		TPtr buddyPtr    = buddy->Des();
       
   247 		readStream.ReadL( buddyPtr , buddyLength );
       
   248 		chatData.iBuddyId = buddy;
       
   249 
       
   250 		TInt textSize = readStream.ReadInt16L();
       
   251 		HBufC* text  = HBufC::NewLC( textSize );
       
   252 		TPtr textPtr = text->Des(); 
       
   253 		readStream.ReadL( textPtr , textSize);            
       
   254 		chatData.iText = text;
       
   255 		
       
   256 		iUpdateHandler.HandleIMCacheEventL(EIMCacheNewMessage , &chatData);
       
   257 		
       
   258 		CleanupStack::PopAndDestroy(4);//close read stream, delete mBuffer, text, buddy 
       
   259 		}
       
   260 
       
   261 	aMore = static_cast<TBool>( readAllStream.ReadInt16L() );
       
   262 
       
   263 	CleanupStack::PopAndDestroy();//readAllStream.    
       
   264 	
       
   265     TRACE( T_LIT("CIMCacheEventHandler::InternalizeChatDataL() End") );
       
   266     }
       
   267 
       
   268 // -----------------------------------------------------------------------------
       
   269 // CIMCacheEventHandler::GetBufferedChatItemL
       
   270 // -----------------------------------------------------------------------------
       
   271 //
       
   272 void CIMCacheEventHandler::GetBufferedChatItemL( TIMCacheEventType aEventType )
       
   273     {
       
   274     TRACE( T_LIT("CIMCacheAccessEventHandler::GetBufferedChatItemL() begin") );
       
   275     
       
   276     TPtr8 bufferPtr = iRegistrar.GetBufferedDataL( EIMCacheGetBufferedPackets );
       
   277     
       
   278     InternalizeChatItemL( aEventType, bufferPtr );
       
   279     
       
   280     TRACE( T_LIT("CIMCacheAccessEventHandler::GetBufferedChatItemL() end") );
       
   281     }
       
   282 
       
   283 
       
   284 // -----------------------------------------------------------------------------
       
   285 // CIMCacheEventHandler::InternalizeChatItemL
       
   286 // -----------------------------------------------------------------------------
       
   287 //
       
   288 void CIMCacheEventHandler::InternalizeChatItemL( TIMCacheEventType aEventType, 
       
   289                                                  TPtr8 aContactBuffer )
       
   290     {
       
   291     TRACE( T_LIT("CIMCacheClient::InternalizeChatItemL() begin") );   
       
   292     if( 0 == aContactBuffer.Length())
       
   293           {
       
   294           TRACE( T_LIT("CIMCacheEventHandler::InternalizeChatDataL()  aChatDataBuffer is zeor, hence returning ") );
       
   295           return;
       
   296           }
       
   297     RDesReadStream readAllStream ;
       
   298     RDesReadStream readStream ;    
       
   299     
       
   300     readAllStream.Open( aContactBuffer );
       
   301     CleanupClosePushL(readAllStream);
       
   302     
       
   303     TInt messageCount = readAllStream.ReadInt16L();
       
   304     
       
   305     for( TInt i=0; i< messageCount; i++)
       
   306         {
       
   307         SIMCacheChatItem chatItem =
       
   308           {
       
   309           0,
       
   310           };
       
   311                 
       
   312         TInt size = readAllStream.ReadInt16L() ;
       
   313         HBufC8* mBuffer  = HBufC8::NewLC( size );
       
   314         TPtr8 mBufferPtr = mBuffer->Des();
       
   315                 
       
   316         readAllStream.ReadL( mBufferPtr , size );
       
   317         
       
   318         readStream.Open( *mBuffer );        
       
   319         CleanupClosePushL(readStream) ;
       
   320         
       
   321         chatItem.iServiceId  = static_cast<TInt>( readStream.ReadInt16L() );
       
   322         
       
   323         TInt textSize = readStream.ReadInt16L();
       
   324         HBufC* buddyId = HBufC::NewLC( textSize );
       
   325         TPtr buddyIdPtr = buddyId->Des(); 
       
   326         readStream.ReadL( buddyIdPtr , textSize);
       
   327         
       
   328         chatItem.iBuddyId = buddyId;
       
   329         
       
   330         iUpdateHandler.HandleIMCacheEventL( aEventType , &chatItem );
       
   331       
       
   332         CleanupStack::PopAndDestroy(3);//buddyId , close read stream, delete mBuffer.      
       
   333                   
       
   334         }
       
   335  
       
   336     CleanupStack::PopAndDestroy();//readAllStream.    
       
   337     
       
   338     TRACE( T_LIT("CIMCacheClient::InternalizeChatItemL() End") );
       
   339     }
       
   340 
       
   341 
       
   342 
       
   343 //  end of file
       
   344