|         |      1 /* | 
|         |      2 * Copyright (c) 2007-2009 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: | 
|         |     15 * | 
|         |     16 */ | 
|         |     17  | 
|         |     18  | 
|         |     19 #include <sbdefs.h> | 
|         |     20 #include <e32property.h> | 
|         |     21  | 
|         |     22 #include "contextengineao.h" | 
|         |     23 #include "contextengine.h" | 
|         |     24 #include "contextsnapshotitem.h" | 
|         |     25 #include "harvesterlog.h" | 
|         |     26 #include "mdsutils.h" | 
|         |     27 #include "harvesterdata.h" | 
|         |     28 #include "propertywatcher.h"  | 
|         |     29 #include "harvestercommon.h" | 
|         |     30  | 
|         |     31 // --------------------------------------------------------------------------- | 
|         |     32 // Default constructor for first phase construction. | 
|         |     33 // --------------------------------------------------------------------------- | 
|         |     34 // | 
|         |     35 CContextEngineAO::CContextEngineAO(  | 
|         |     36 		MContextInitializationObserver* aInitObserver, | 
|         |     37 		MContextSnapshotObserver* aSnapshotObserver ) :  | 
|         |     38 		CActive( KHarvesterPriorityContextEngine ),  | 
|         |     39 		iInitializationObserver( aInitObserver ),  | 
|         |     40 		iContextSnapshotObserver ( aSnapshotObserver ), | 
|         |     41 		iUninitializedPluginsCount( 0 ), | 
|         |     42 		iPluginSnapshotsLacking( 0 ), | 
|         |     43 		iItem( NULL ), | 
|         |     44 	    iState( EInitialization ), | 
|         |     45 	    iInitializationError( KErrNone ), | 
|         |     46 	    iSnapshotError( KErrNone ), | 
|         |     47 	    iMdESession( NULL ), | 
|         |     48 	    iPropertyWatcher( NULL ), | 
|         |     49 	    iLastPlugin( EFalse ) | 
|         |     50     { | 
|         |     51     WRITELOG( "CContextEngineAO::CContextEngineAO" ); // DEBUG INFO | 
|         |     52     } | 
|         |     53  | 
|         |     54 // --------------------------------------------------------------------------- | 
|         |     55 // Standard NewL. | 
|         |     56 // --------------------------------------------------------------------------- | 
|         |     57 // | 
|         |     58 CContextEngineAO* CContextEngineAO::NewL( | 
|         |     59     MContextInitializationObserver* aInitObserver, | 
|         |     60     MContextSnapshotObserver* aSnapshotObserver ) | 
|         |     61     { | 
|         |     62     WRITELOG( "CContextEngineAO::NewL" ); // DEBUG INFO | 
|         |     63  | 
|         |     64     CContextEngineAO* self = new (ELeave) CContextEngineAO( aInitObserver, aSnapshotObserver ); | 
|         |     65     CleanupStack::PushL( self ); | 
|         |     66     self->ConstructL(); | 
|         |     67     CleanupStack::Pop( self ); | 
|         |     68     return self; | 
|         |     69     } | 
|         |     70  | 
|         |     71 // --------------------------------------------------------------------------- | 
|         |     72 // 2nd phase construction. | 
|         |     73 // --------------------------------------------------------------------------- | 
|         |     74 // | 
|         |     75 void CContextEngineAO::ConstructL() | 
|         |     76     { | 
|         |     77     WRITELOG( "CContextEngineAO::ConstructL" ); // DEBUG INFO | 
|         |     78  | 
|         |     79     CActiveScheduler::Add( this ); | 
|         |     80  | 
|         |     81     iPropertyWatcher = CPropertyWatcher::GetInstanceL(); | 
|         |     82        | 
|         |     83   	// Want to listen when backup/restore starts. | 
|         |     84   	// Calls NotifyKeyL when key's state has changed.  | 
|         |     85   	iPropertyWatcher->ListenKeyChangesL(  | 
|         |     86   			KUidSystemCategory, | 
|         |     87   			conn::KUidBackupRestoreKey, this ); | 
|         |     88        | 
|         |     89      | 
|         |     90     if ( !iInitializationObserver ) | 
|         |     91         { | 
|         |     92         InitializeL(); | 
|         |     93         iState = EReady; | 
|         |     94         } | 
|         |     95     else  // same thing asyncronously | 
|         |     96         { | 
|         |     97         iState = EInitialization; | 
|         |     98         SetActive(); | 
|         |     99         TRequestStatus* status = &iStatus; | 
|         |    100         User::RequestComplete( status, KErrNone ); // "kick-start" this AO | 
|         |    101         } | 
|         |    102     } | 
|         |    103 // --------------------------------------------------------------------------- | 
|         |    104 // Destructor. | 
|         |    105 // --------------------------------------------------------------------------- | 
|         |    106 // | 
|         |    107 CContextEngineAO::~CContextEngineAO() | 
|         |    108     { | 
|         |    109     WRITELOG( "CContextEngineAO::~CContextEngineAO" ); // DEBUG INFO | 
|         |    110  | 
|         |    111     Cancel(); | 
|         |    112  | 
|         |    113     MdsUtils::CleanupPtrArray<CContextPlugin>( &iPlugins ); | 
|         |    114 	 | 
|         |    115     if( iPropertyWatcher ) | 
|         |    116 		{ | 
|         |    117 		 | 
|         |    118 	 	iPropertyWatcher->StopListeningKeyChanges(  | 
|         |    119 	  			KUidSystemCategory, | 
|         |    120 	  			conn::KUidBackupRestoreKey, this ); | 
|         |    121 		 | 
|         |    122 		iPropertyWatcher->Delete(); // Release connection to TLS object. | 
|         |    123 		} | 
|         |    124     } | 
|         |    125  | 
|         |    126 // --------------------------------------------------------------------------- | 
|         |    127 // Set MdeSession for context engine plugins. | 
|         |    128 // --------------------------------------------------------------------------- | 
|         |    129 // | 
|         |    130 void CContextEngineAO::SetMdeSession( CMdESession* aSession ) | 
|         |    131     { | 
|         |    132     iMdESession = aSession; | 
|         |    133  | 
|         |    134     for ( TInt i = 0; i < iPlugins.Count(); ++i ) | 
|         |    135         { | 
|         |    136         iPlugins[i]->SetMdeSession( *aSession ); | 
|         |    137         } | 
|         |    138     } | 
|         |    139  | 
|         |    140 // --------------------------------------------------------------------------- | 
|         |    141 // Start taking a context snapshot (for multiple objects). | 
|         |    142 // --------------------------------------------------------------------------- | 
|         |    143 // | 
|         |    144 void CContextEngineAO::StartSnapshot( CContextSnapshotItem* aItem ) | 
|         |    145     { | 
|         |    146     WRITELOG( "CContextEngineAO::StartSnapshot" ); // DEBUG INFO | 
|         |    147     iItem = aItem; | 
|         |    148     if ( !aItem ) return; | 
|         |    149     if ( !aItem->GetItem() && !aItem->GetItemArray() ) | 
|         |    150         { | 
|         |    151         // no items to do the snapshot for... stop. | 
|         |    152         aItem->GetObserver()->ContextSnapshotStatus( KErrNone ); | 
|         |    153         } | 
|         |    154  | 
|         |    155     iSnapshotError = KErrNone; | 
|         |    156     iPluginSnapshotsLacking = iPlugins.Count(); // reset, no snapshots taken yet | 
|         |    157  | 
|         |    158     if ( iPluginSnapshotsLacking <= 0 ) | 
|         |    159     	{ | 
|         |    160     	iState = EReady; | 
|         |    161     	iContextSnapshotObserver->ContextSnapshotStatus( KErrNone );     | 
|         |    162     	} | 
|         |    163     iLastPlugin = EFalse; | 
|         |    164      | 
|         |    165     iState = ESnapshot; | 
|         |    166     SetActive(); | 
|         |    167     TRequestStatus* status = &iStatus; | 
|         |    168     User::RequestComplete( status, KErrNone ); // "kick-start" this AO | 
|         |    169     } | 
|         |    170  | 
|         |    171 // --------------------------------------------------------------------------- | 
|         |    172 // Return loaded plugin count. | 
|         |    173 // --------------------------------------------------------------------------- | 
|         |    174 // | 
|         |    175 TInt CContextEngineAO::PluginCount() | 
|         |    176     { | 
|         |    177     return iPlugins.Count(); | 
|         |    178     } | 
|         |    179  | 
|         |    180 // --------------------------------------------------------------------------- | 
|         |    181 // From CActive. | 
|         |    182 // Start/continue taking a context snapshot (for multiple objects). | 
|         |    183 // Ask a snapshot from one plugin at a time. | 
|         |    184 // --------------------------------------------------------------------------- | 
|         |    185 // | 
|         |    186 void CContextEngineAO::RunL() | 
|         |    187 	{ | 
|         |    188 #ifdef _DEBUG | 
|         |    189     WRITELOG1( "CContextEngineAO::RunL iStatus: %d", iStatus.Int() ); // DEBUG INFO | 
|         |    190 #endif | 
|         |    191  | 
|         |    192     if ( iState == EInitialization ) | 
|         |    193         { | 
|         |    194         InitializeL(); | 
|         |    195         } | 
|         |    196     else if ( iState == ESnapshot ) | 
|         |    197         { | 
|         |    198         if ( iStatus.Int() != KErrNone ) | 
|         |    199             { | 
|         |    200             return; | 
|         |    201             } | 
|         |    202  | 
|         |    203         if ( iPluginSnapshotsLacking > 0 ) | 
|         |    204             { | 
|         |    205             TInt i = iPlugins.Count() - iPluginSnapshotsLacking; | 
|         |    206             if( iPluginSnapshotsLacking == 1 ) | 
|         |    207                 { | 
|         |    208                 iLastPlugin = ETrue; | 
|         |    209                 } | 
|         |    210             if ( iItem->GetItemArray() )  | 
|         |    211                 { | 
|         |    212                 iPlugins[i]->ContextSnapshot( *this, *iItem->GetItemArray() );   | 
|         |    213                 }                               // CContextEngineAO is instance of | 
|         |    214             else                                // MContextPluginObserver | 
|         |    215                 { | 
|         |    216                 iPlugins[i]->ContextSnapshot( *this, *iItem->GetItem() ); | 
|         |    217                 } | 
|         |    218             iPluginSnapshotsLacking--; | 
|         |    219             } | 
|         |    220         } | 
|         |    221     } | 
|         |    222  | 
|         |    223 // --------------------------------------------------------------------------- | 
|         |    224 // From CActive. | 
|         |    225 // --------------------------------------------------------------------------- | 
|         |    226 // | 
|         |    227 #ifdef _DEBUG | 
|         |    228 TInt CContextEngineAO::RunError( TInt aError ) | 
|         |    229 #else | 
|         |    230 TInt CContextEngineAO::RunError( TInt ) | 
|         |    231 #endif | 
|         |    232     { | 
|         |    233     WRITELOG1( "CContextEngineAO::RunError with error code: %d", aError ); // DEBUG INFO | 
|         |    234     return KErrNone; | 
|         |    235     } | 
|         |    236  | 
|         |    237 // --------------------------------------------------------------------------- | 
|         |    238 // From CActive.  | 
|         |    239 // --------------------------------------------------------------------------- | 
|         |    240 // | 
|         |    241 void CContextEngineAO::DoCancel() | 
|         |    242     { | 
|         |    243     WRITELOG( "CContextEngineAO::DoCancel" ); // DEBUG INFO | 
|         |    244  | 
|         |    245     iPluginSnapshotsLacking = 0; | 
|         |    246     iState = EReady; | 
|         |    247     } | 
|         |    248  | 
|         |    249 // --------------------------------------------------------------------------- | 
|         |    250 // From MContextPluginObserver. | 
|         |    251 // --------------------------------------------------------------------------- | 
|         |    252 // | 
|         |    253 void CContextEngineAO::PluginInitializationStatus( TInt aErrorCode ) | 
|         |    254     { | 
|         |    255     WRITELOG1( "CContextEngineAO::PluginInitializationStatus with error code: %d", aErrorCode ); // DEBUG INFO | 
|         |    256  | 
|         |    257     if ( aErrorCode != KErrNone && iInitializationError != KErrNone ) | 
|         |    258         { | 
|         |    259         iInitializationError = aErrorCode; | 
|         |    260         } | 
|         |    261  | 
|         |    262     iUninitializedPluginsCount--; | 
|         |    263     if ( iUninitializedPluginsCount <= 0 ) | 
|         |    264         { | 
|         |    265         iState = EReady; | 
|         |    266         // notify the client application by using MContextSnapshotObserver's | 
|         |    267         // method ContextInitializationStatus() | 
|         |    268         // Notice! Error code of the last plugin is returned... | 
|         |    269         if ( iInitializationObserver ) | 
|         |    270             { | 
|         |    271             iInitializationObserver->ContextInitializationStatus( iInitializationError ); | 
|         |    272             } | 
|         |    273         } | 
|         |    274     } | 
|         |    275  | 
|         |    276 // --------------------------------------------------------------------------- | 
|         |    277 // From MContextPluginObserver. | 
|         |    278 // --------------------------------------------------------------------------- | 
|         |    279 // | 
|         |    280 void CContextEngineAO::PluginSnapshotStatus( CHarvesterData* aHD ) | 
|         |    281     { | 
|         |    282     TInt errorCode = aHD->ErrorCode(); | 
|         |    283     WRITELOG1( "CContextEngineAO::PluginSnapshotStatus with error code: %d", errorCode ); // DEBUG INFO | 
|         |    284  | 
|         |    285     if ( errorCode != KErrNone && iSnapshotError != KErrNone ) | 
|         |    286         { | 
|         |    287         aHD->SetErrorCode( errorCode ); | 
|         |    288         } | 
|         |    289      | 
|         |    290     if( iLastPlugin ) | 
|         |    291         { | 
|         |    292         // Notice! Error code of the last plugin is returned... | 
|         |    293         iContextSnapshotObserver->ContextSnapshotStatus( aHD ); | 
|         |    294         } | 
|         |    295  | 
|         |    296     if ( iPluginSnapshotsLacking <= 0 ) | 
|         |    297         { | 
|         |    298         iState = EReady; | 
|         |    299         } | 
|         |    300     else  | 
|         |    301         {  // do this again for the next plugin/harvest data object | 
|         |    302         if( !IsActive() ) | 
|         |    303             { | 
|         |    304             SetActive(); | 
|         |    305             TRequestStatus* status = &iStatus; | 
|         |    306             User::RequestComplete( status, KErrNone ); // "kick-start" this AO | 
|         |    307             } | 
|         |    308         } | 
|         |    309     } | 
|         |    310  | 
|         |    311 // --------------------------------------------------------------------------- | 
|         |    312 // Called by CBlacklistBackupSubscriberAO when | 
|         |    313 // Backup&Restore is backing up or restoring. | 
|         |    314 // --------------------------------------------------------------------------- | 
|         |    315 // | 
|         |    316 void CContextEngineAO::BackupRestoreStart() | 
|         |    317     { | 
|         |    318     // stop context plugins | 
|         |    319     WRITELOG( "CContextEngineAO::BackupRestoreStart" ); | 
|         |    320   | 
|         |    321     iPlugins.ResetAndDestroy(); // remove any existing plugins, just in case | 
|         |    322     } | 
|         |    323  | 
|         |    324 // --------------------------------------------------------------------------- | 
|         |    325 // Called by CBlacklistBackupSubscriberAO when | 
|         |    326 // Backup&Restore has finished backup or restore. | 
|         |    327 // --------------------------------------------------------------------------- | 
|         |    328 // | 
|         |    329 void CContextEngineAO::BackupRestoreReady() | 
|         |    330     { | 
|         |    331     // restart plugins | 
|         |    332     WRITELOG( "CContextEngineAO::BackupRestoreReady" ); | 
|         |    333      | 
|         |    334     TRAP_IGNORE( InitializeL() ); | 
|         |    335      | 
|         |    336     if ( iMdESession ) | 
|         |    337     	{ | 
|         |    338     	SetMdeSession( iMdESession ); | 
|         |    339     	} | 
|         |    340      | 
|         |    341     iState = EReady; | 
|         |    342      | 
|         |    343     } | 
|         |    344  | 
|         |    345 // private methods | 
|         |    346  | 
|         |    347 // --------------------------------------------------------------------------- | 
|         |    348 // Load context plugins to the "iPlugins" array. | 
|         |    349 // --------------------------------------------------------------------------- | 
|         |    350 // | 
|         |    351 void CContextEngineAO::LoadPluginsL() | 
|         |    352     { | 
|         |    353     WRITELOG( "CContextEngineAO::LoadPluginsL" ); // DEBUG INFO | 
|         |    354  | 
|         |    355     if ( iPlugins.Count() > 0 ) | 
|         |    356         { | 
|         |    357         iPlugins.ResetAndDestroy(); // remove any existing plugins, just in case | 
|         |    358         } | 
|         |    359  | 
|         |    360     // read info about all implementations into infoArray | 
|         |    361     RImplInfoPtrArray infoArray; | 
|         |    362     TCleanupItem cleanupItem( MdsUtils::CleanupEComArray, &infoArray ); | 
|         |    363     CleanupStack::PushL( cleanupItem ); | 
|         |    364      | 
|         |    365     CContextPlugin::ListImplementationsL( infoArray ); | 
|         |    366  | 
|         |    367     CContextPlugin* plugin = NULL; | 
|         |    368     TInt err = KErrNone; | 
|         |    369     for ( TInt i = 0; i < infoArray.Count(); i++ ) | 
|         |    370         { | 
|         |    371         TUid uid = infoArray[i]->ImplementationUid();  | 
|         |    372         TRAP( err, plugin = CContextPlugin::NewL( uid ) ); // create the plug-ins | 
|         |    373         if ( err == KErrNone && plugin ) | 
|         |    374             { | 
|         |    375             CleanupStack::PushL( plugin ); | 
|         |    376             iPlugins.AppendL( plugin );        // and add them to an array | 
|         |    377             CleanupStack::Pop( plugin ); | 
|         |    378             } | 
|         |    379         } | 
|         |    380  | 
|         |    381 	CleanupStack::PopAndDestroy( &infoArray ); // infoArray, results in a call to CleanupEComArray		 | 
|         |    382     } | 
|         |    383  | 
|         |    384 // --------------------------------------------------------------------------- | 
|         |    385 // Initialize this object. Thus load and initialize plugins. | 
|         |    386 // --------------------------------------------------------------------------- | 
|         |    387 // | 
|         |    388 void CContextEngineAO::InitializeL() | 
|         |    389     { | 
|         |    390     WRITELOG( "CContextEngineAO::InitializeL" ); // DEBUG INFO | 
|         |    391  | 
|         |    392     iInitializationError = KErrNone; | 
|         |    393     LoadPluginsL(); | 
|         |    394     iUninitializedPluginsCount = iPlugins.Count(); // set this so we can later be sure that all | 
|         |    395                                                    // plug-ins are initialized. | 
|         |    396     if ( iUninitializedPluginsCount <= 0 ) // if no plugins were loaded | 
|         |    397         { | 
|         |    398         if ( iInitializationObserver ) | 
|         |    399             { | 
|         |    400             iInitializationObserver->ContextInitializationStatus( KErrNone ); | 
|         |    401             } | 
|         |    402         } | 
|         |    403  | 
|         |    404     const TInt KCount = iUninitializedPluginsCount; | 
|         |    405     for ( TInt i = 0; i < KCount; i++ ) | 
|         |    406         { | 
|         |    407         iPlugins[i]->Init( *this ); // CContextEngineAO is instance of MContextPluginObserver | 
|         |    408         } | 
|         |    409     } | 
|         |    410  | 
|         |    411 // ----------------------------------------------------------------------------- | 
|         |    412 // CRestoreWatcher::NotifyKeyL | 
|         |    413 // CPropertyWatcher's callback. From  | 
|         |    414 // ----------------------------------------------------------------------------- | 
|         |    415 // | 
|         |    416 void CContextEngineAO::NotifyKeyL(  | 
|         |    417 		const TInt aKeyValue, | 
|         |    418 		const TUid aPropertyCategory, | 
|         |    419 		const TUint aKey ) | 
|         |    420 	{ | 
|         |    421 	WRITELOG("CContextEngineAO::NotifyKeyL() - begin"); | 
|         |    422 	 | 
|         |    423 	if( aPropertyCategory == KUidSystemCategory && | 
|         |    424 			aKey == conn::KUidBackupRestoreKey )  | 
|         |    425 		{ | 
|         |    426 		HandleBackupRestoreKeyAction( aKeyValue ); | 
|         |    427 		} | 
|         |    428 	 | 
|         |    429 	 | 
|         |    430 	WRITELOG("CContextEngineAO::NotifyKeyL() - end"); | 
|         |    431 	} | 
|         |    432  | 
|         |    433 // ----------------------------------------------------------------------------- | 
|         |    434 // CContextEngineAO::HandleBackupKeyAction | 
|         |    435 // When user starts restore sets flag on. | 
|         |    436 // ----------------------------------------------------------------------------- | 
|         |    437 // | 
|         |    438 void CContextEngineAO::HandleBackupRestoreKeyAction( const TUint aKeyValue ) | 
|         |    439 	{	 | 
|         |    440 	WRITELOG("CRestoreWatcher::HandleBackupKeyAction() - begin"); | 
|         |    441 	 | 
|         |    442 	TInt backupStateValue = aKeyValue; | 
|         |    443 	backupStateValue &= conn::KBURPartTypeMask; | 
|         |    444 	 | 
|         |    445 	switch ( backupStateValue ) | 
|         |    446 		{ | 
|         |    447 		case conn::EBURBackupFull: | 
|         |    448 		case conn::EBURBackupPartial: | 
|         |    449 		case conn::EBURRestoreFull: | 
|         |    450 		case conn::EBURRestorePartial: | 
|         |    451 			{ | 
|         |    452 			BackupRestoreStart(); | 
|         |    453 			break; | 
|         |    454 			} | 
|         |    455 		 | 
|         |    456 		case conn::EBURNormal: | 
|         |    457 		case conn::EBURUnset: | 
|         |    458 		default: | 
|         |    459 			{ | 
|         |    460 			// backup or restore is completed, so resume normal operation. | 
|         |    461        		BackupRestoreReady(); | 
|         |    462 			} | 
|         |    463 		}	 | 
|         |    464 	 | 
|         |    465 	WRITELOG("CRestoreWatcher::HandleBackupKeyAction() - end"); | 
|         |    466 	} | 
|         |    467  |