serviceproviders/sapi_sysinfo/tsrc/dev/providertests/tsysinfoprovidertests/src/tautolocknotifier.cpp
changeset 19 989d2f495d90
child 33 50974a8b132e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/serviceproviders/sapi_sysinfo/tsrc/dev/providertests/tsysinfoprovidertests/src/tautolocknotifier.cpp	Fri Jul 03 15:51:24 2009 +0100
@@ -0,0 +1,394 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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:   ?Description
+*
+*/
+
+
+
+#include <e32std.h>
+#include <LiwServiceHandler.h>
+
+#include "tsysinfoprovidertests.h"
+#include "Tautolocknotifier.h"
+#include "watchtimer.h"
+#include "entitykeys.h"
+#include "sysinfoaiwparams.hrh"
+
+using namespace LIW ;
+using namespace SysInfo;
+using namespace sysinfoaiwparams;
+
+CAutoLockNotifier* CAutoLockNotifier::NewL(CStifLogger* aLog,TInt aDrvNo)
+	{
+	CAutoLockNotifier* self = new(ELeave) CAutoLockNotifier(aLog,aDrvNo);
+	self->ConstructL();
+	return self;
+	}
+
+CAutoLockNotifier::~CAutoLockNotifier()
+	{
+	Cancel();
+	if(iWaitSchedular->IsStarted())
+		iWaitSchedular->AsyncStop();
+	
+	delete iTimer;
+
+	iInParamList->Reset();
+	iOutParamList->Reset();
+	iInterface->Close();
+	delete iServiceHandler;
+
+	delete iWaitSchedular;
+	}
+
+void CAutoLockNotifier::ConstructL()
+	{
+	iWaitSchedular  = new(ELeave) CActiveSchedulerWait();
+	iTimer			= CWatchTimer::NewL(EPriorityNormal,this);
+	CreateInterfaceL();
+	CActiveScheduler::Add(this);
+	}
+
+CAutoLockNotifier::CAutoLockNotifier(CStifLogger* aLog,TInt aAutoLockTime) :
+				CActive(EPriorityStandard),
+				iAutoLockTime(aAutoLockTime),
+				iRestoreAutoLockTime(15),
+				iLog(aLog)
+	{
+	}
+
+void CAutoLockNotifier::DoCancel()
+	{
+	//TRAPD(err1,iSysInfoService->GetInfoL(req1));
+	}
+
+void CAutoLockNotifier::RunL()
+	{
+	TestFuncL();
+	}
+
+void CAutoLockNotifier::Start()
+	{
+	SetActive();
+	TRequestStatus* temp = &iStatus;
+	User::RequestComplete(temp, KErrNone);
+	iWaitSchedular->Start();	
+	}
+
+TInt CAutoLockNotifier::Result()
+	{
+	return iResult;
+	}
+
+void CAutoLockNotifier::TestFuncL()
+	{
+	TInt RetVal(PASS);
+	TInt32 Err;
+
+//	Get autolocktime val
+//-------------------------------------------------------------------------
+	{
+	iLog->Log( _L("Reading initial autolocktime value .."));
+
+	iOutParamList->Reset();
+	iInParamList->Reset();
+
+	iInParamList->AppendL(TLiwGenericParam(KEntity,TLiwVariant(KDisplay)));
+	iInParamList->AppendL(TLiwGenericParam(KKey,TLiwVariant(KAutoLockTime)));
+
+	iInterface->ExecuteCmdL(KGetInfo,*iInParamList,*iOutParamList);	
+	
+	RetVal |= CheckErrorCode(*iOutParamList,Err);
+	if ( Err )
+		{
+		iLog->Log( _L("GetInfo retured error : %d"),Err );
+		User::Leave(Err);
+		} 
+	
+	TInt index=0;
+	const TLiwGenericParam* ret_val = iOutParamList->FindFirst(index,KReturnValue);
+	if(!ret_val)
+		{
+		iLog->Log( _L("Return value parameter not found"));
+		User::Leave(FAIL);
+		}
+	else
+		{
+		const CLiwMap* outmap = ret_val->Value().AsMap();
+		TLiwVariant autolocktime;
+		if( outmap->FindL(KStatus,autolocktime) )
+			iRestoreAutoLockTime = autolocktime.AsTInt32();
+		((CLiwMap*)outmap)->DecRef();
+		}
+	iLog->Log( _L("Inital autolocktime to be restored to: %d"),iRestoreAutoLockTime);
+	}
+
+
+//	SET AUTOLOCK TIME.
+//-------------------------------------------------------------------------
+	{
+	CLiwMap* inmap = CLiwDefaultMap::NewL();
+	iLog->Log( _L("Seting Autolock time .."));
+	
+	iOutParamList->Reset();
+	iInParamList->Reset();
+	
+	iInParamList->AppendL(TLiwGenericParam(KEntity,TLiwVariant(KDisplay)));
+	iInParamList->AppendL(TLiwGenericParam(KKey,TLiwVariant(KAutoLockTime)));
+
+	inmap->InsertL(KStatus,TLiwVariant((TInt32)iAutoLockTime));
+	iInParamList->AppendL(TLiwGenericParam(KSysData,TLiwVariant(inmap)));
+
+	iInterface->ExecuteCmdL(KSetInfo,*iInParamList,*iOutParamList);	
+	inmap->Remove(KStatus);	
+	RetVal |= CheckErrorCode(*iOutParamList,Err);
+	if ( Err )
+		{
+		iLog->Log( _L("SetInfo retured error : %d"),Err );
+		User::Leave(Err);
+		} 
+	inmap->DecRef();
+	}
+
+//	REGISTER FOR NOTIFICATION.
+//-------------------------------------------------------------------------
+	{
+	iLog->Log( _L("Issueing Notification request .."));
+	TInt RetVal(PASS);
+	TInt32 Err;
+	
+	iOutParamList->Reset();
+	iInParamList->Reset();
+	
+	iInParamList->AppendL(TLiwGenericParam(KEntity,TLiwVariant(KDisplay)));
+	iInParamList->AppendL(TLiwGenericParam(KKey,TLiwVariant(KAutoLockStatus)));
+
+	iInterface->ExecuteCmdL(KGetNotification,*iInParamList,*iOutParamList,KLiwOptASyncronous,this);	
+			
+	RetVal |= CheckErrorCode(*iOutParamList,Err);
+	if ( Err )
+		{
+		iLog->Log( _L("GetNotification retured error : %d"),Err );
+		User::Leave(Err);
+		} 
+	
+	TInt index=0;
+	const TLiwGenericParam* ret_val = iOutParamList->FindFirst(index,KTransactionId);
+	if(!ret_val)
+		{
+		iLog->Log( _L("Transaction ID not found"));
+		User::Leave(FAIL);
+		}
+	else
+		{
+		iTransID = ret_val->Value().AsTInt32();
+		iLog->Log( _L("TRANSACTION ID : %d"),iTransID );
+		}
+	
+	}
+
+	iOutParamList->Reset();
+	iInParamList->Reset();
+
+	const TInt OneMin(60000000);
+	iTimer->After(OneMin*iAutoLockTime*2);
+
+	}
+
+TInt CAutoLockNotifier::HandleNotifyL( TInt aTransID, TInt aEventId,
+            CLiwGenericParamList& aEventParamList,
+            const CLiwGenericParamList& )
+	{
+	aEventId=aEventId;
+	delete iTimer;
+	iTimer = NULL;
+
+//	RESTORE AUTOLOCK TIME.
+//-------------------------------------------------------------------------
+	{
+	TInt RetVal(PASS);
+	TInt32 Err(PASS);
+	
+	CLiwMap* inmap = CLiwDefaultMap::NewL();
+	iLog->Log( _L("Restoring Autolock time to %d"),iRestoreAutoLockTime);
+	
+	iOutParamList->Reset();
+	iInParamList->Reset();
+	
+	iInParamList->AppendL(TLiwGenericParam(KEntity,TLiwVariant(KDisplay)));
+	iInParamList->AppendL(TLiwGenericParam(KKey,TLiwVariant(KAutoLockTime)));
+
+	inmap->InsertL(KStatus,TLiwVariant((TInt32)iRestoreAutoLockTime));
+	iInParamList->AppendL(TLiwGenericParam(KSysData,TLiwVariant(inmap)));
+
+	iInterface->ExecuteCmdL(KSetInfo,*iInParamList,*iOutParamList);	
+	inmap->Remove(KStatus);	
+	RetVal |= CheckErrorCode(*iOutParamList,Err);
+	if ( Err )
+		{
+		iLog->Log( _L("SetInfo retured error : %d"),Err );
+		User::Leave(Err);
+		} 
+	inmap->DecRef();
+	}
+
+//	CHECK AUTOLOCK NOTIFICATION.
+//-------------------------------------------------------------------------
+	{
+	TInt index=0;
+	TPtrC entity,key;
+	TInt32 status;
+	const TLiwGenericParam* ret_val = aEventParamList.FindFirst(index,KReturnValue);
+	if(!ret_val)
+		{
+		iLog->Log( _L("Return value parameter not found"));
+		User::Leave(FAIL);
+		}
+	else
+		{
+		const CLiwMap* outmap = ret_val->Value().AsMap();
+		TLiwVariant ventity,vkey,vstatus;
+		if( !outmap->FindL(KEntity,ventity) )
+			{
+			iLog->Log( _L("Entity parameter not found"));
+			User::Leave(FAIL);
+			}
+		if( !outmap->FindL(KKey,vkey) )
+			{
+			iLog->Log( _L("Key parameter not found"));
+			User::Leave(FAIL);
+			}
+		
+		if( !outmap->FindL(KStatus,vstatus) )
+			{
+			iLog->Log( _L("Status parameter not found"));
+			User::Leave(FAIL);
+			}
+		ventity.Get(entity);
+		vkey.Get(key);
+		status = vstatus.AsTInt32();
+
+//		((CLiwMap)outmap)->DecRef();	
+		
+		if( !(entity.Compare(KDisplay) || key.Compare(KAutoLockStatus)) )
+			{
+			if(!(aTransID == iTransID))
+				{
+				iLog->Log(_L("Incorrect TransactionID: %d"),aTransID);				
+				iResult |= FAIL;
+				}
+
+			iLog->Log(_L("Autolock Notification.."));
+			if(status)
+				iLog->Log(_L("AutoLock ENABLED"));
+			else
+				iLog->Log(_L("AutoLock DISABLED"));
+			
+			iResult |= PASS;		
+			}
+
+		ventity.Reset();
+		vkey.Reset();
+		}
+	}
+
+	iWaitSchedular->AsyncStop();
+	return KErrNone;
+	}
+
+void CAutoLockNotifier::HandleTimeOut()
+{
+	iLog->Log(_L("TimeOut reached. Auto Lock Not Enabled.."));
+//	iSysInfoService->Cancel(1);
+//	RESTORE AUTOLOCK TIME.
+//-------------------------------------------------------------------------
+	{
+	TInt RetVal(PASS);
+	TInt32 Err(PASS);
+	
+	CLiwMap* inmap = CLiwDefaultMap::NewL();
+	iLog->Log( _L("Restoring Autolock time to %d"),iRestoreAutoLockTime);
+	
+	iOutParamList->Reset();
+	iInParamList->Reset();
+	
+	iInParamList->AppendL(TLiwGenericParam(KEntity,TLiwVariant(KDisplay)));
+	iInParamList->AppendL(TLiwGenericParam(KKey,TLiwVariant(KAutoLockTime)));
+
+	inmap->InsertL(KStatus,TLiwVariant((TInt32)iRestoreAutoLockTime));
+	iInParamList->AppendL(TLiwGenericParam(KSysData,TLiwVariant(inmap)));
+
+	iInterface->ExecuteCmdL(KSetInfo,*iInParamList,*iOutParamList);	
+	inmap->Remove(KStatus);	
+	RetVal |= CheckErrorCode(*iOutParamList,Err);
+	if ( Err )
+		{
+		iLog->Log( _L("SetInfo retured error : %d"),Err );
+		User::Leave(Err);
+		} 
+	inmap->DecRef();
+	}
+
+	iResult = FAIL;
+	iWaitSchedular->AsyncStop();
+}
+
+void CAutoLockNotifier::CreateInterfaceL() 
+	{
+    iServiceHandler = CLiwServiceHandler::NewL();
+    CleanupStack::PushL(iServiceHandler);
+
+    iInParamList = &(iServiceHandler->InParamListL());
+    iOutParamList = &(iServiceHandler->OutParamListL());
+      
+	CLiwCriteriaItem* crit = CLiwCriteriaItem::NewL(1,KIDataSource,KService);
+	CleanupStack::PushL(crit);
+	crit->SetServiceClass(TUid::Uid(KLiwClassBase));
+	RCriteriaArray a;
+	CleanupClosePushL(a);
+	a.AppendL(crit);
+	iServiceHandler->AttachL(a);
+	iServiceHandler->ExecuteServiceCmdL(*crit,*iInParamList,*iOutParamList);
+		
+	TInt Index = 0;
+	const TLiwGenericParam* param = iOutParamList->FindFirst(Index,KIDataSource);
+	if(!param)
+		{
+		iLog->Log( _L("Interface Not found "));
+		User::Leave(KErrGeneral);
+		}
+		
+	iInterface = param->Value().AsInterface();
+	CleanupStack::PopAndDestroy(&a);	
+	CleanupStack::PopAndDestroy (crit);
+	
+  	CleanupStack::Pop (iServiceHandler); 
+  	}	
+
+TInt CAutoLockNotifier::CheckErrorCode( const CLiwGenericParamList& aOutList, TInt32 &aError )
+	{
+	TInt Index = 0;
+	const TLiwGenericParam* errcode = aOutList.FindFirst(Index,KErrorCode);
+	if ( KErrNotFound == Index )
+		{
+		iLog->Log( _L("ErrorCode not found in output ArgList") );
+		return FAIL;
+		}
+	else
+		errcode->Value().Get(aError);
+	return PASS;
+	}
+//End of file.
+