syncmlfw/ds/syncagent/src/nsmldsagent.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 13 Oct 2010 15:30:06 +0300
branchRCL_3
changeset 76 3cdbd92ee07b
parent 62 19bba8228ff0
permissions -rw-r--r--
Revision: 201039 Kit: 201041

/*
* Copyright (c) 2005 Nokia Corporation and/or its subsidiary(-ies). 
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "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:  DS Sync flow
*
*/

#define SYNCML_V3
// INCLUDE FILES
#include <SyncMLHistory.h>
#include <e32property.h>
#include <DataSyncInternalPSKeys.h>
#include <nsmlconstants.h>
#include <nsmldebug.h>

// common includes with DM
#include "nsmlagenttestdefines.h"
#include "nsmlcliagconstants.h"
#include "NSmlAgentBase.h" 
#include "NSmlCmdsBase.h"
#include "NSmlStatusContainer.h"
#include "NSmlResponseController.h"
#include "NSmlURI.h"
#include "NSmlHistoryArray.h"

// DS specific includes
#include "nsmldsagconstants.h"
#include "NSmlDSAgent.h"
#include "NSmlDSCmds.h"
#include "nsmldscontent.h"
#include "nsmldserror.h"
#include "nsmldssettings.h"
#include "nsmlagentlog.h"
#include "nsmlroam.h"
#include "NsmlOperatorErrorCRKeys.h"
//RD_AUTO_RESTART
#include <e32base.h>
#include <centralrepository.h> 
#include "SyncMLErr.h"
#include "nsmldsconstants.h"
#include <featmgr.h>
#include "nsmloperatordefines.h"
//RD_AUTO_RESTART
_LIT( KNetMon,"\\netmon.exe" );
_LIT( KAutoRestart,"netmon" );

#ifndef __WINS__
// This lowers the unnecessary compiler warning (armv5) to remark.
// "Warning:  #174-D: expression has no effect..." is caused by 
// DBG_ARGS8 macro in no-debug builds.
#pragma diag_remark 174
#endif

// CONSTANTS
const TInt KNSmlDsHTTPErrCodeBase = 1400;
const TInt KNSmlDsErrCodeFirst = 400;
const TInt KNSmlDsErrCodeLast = 516;

// ============================ MEMBER FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// CNSmlDSAgent::CNSmlDSAgent
// C++ constructor.
// -----------------------------------------------------------------------------
//
CNSmlDSAgent::CNSmlDSAgent()
    {
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ConstructL
// Symbian 2nd phase constructor.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ConstructL( MSyncMLProgressObserver* aDSObserver )
    {
    DBG_FILE(_S8("CNSmlDSAgent::ConstructL begins")); 
	CNSmlAgentBase::ConstructL();
	iDSObserver = aDSObserver;
	iDSContent = CNSmlDSContent::NewL();
	iError = new ( ELeave ) TNSmlDSError;
	iSyncMLMIMEType = KNSmlDSAgentMIMEType().AllocL();
	iResultAlertCode = KNSmlDSAgentResultAlert().AllocL();
	iNextMessageCode = KNSmlDSAgentNextMessage().AllocL();
	iEndOfDataAlertCode = KNSmlDSAgentNoEndOfData().AllocL();
	iUpdateLastAnchor=ETrue;
	
	//RD_AUTO_RESTART
	//Check whether the Auto Restart Feature is enabled or not 
	TInt keyVal;
	iAutoRestartInitiatedSync = EFalse;
	TRAPD (err ,ReadRepositoryL(KNsmlDsAutoRestart, keyVal));
	if(err==KErrNone && keyVal==1)
	{	
		iDSNetmon = CNsmlDSNetmon::NewL(*this);  
		DBG_FILE(_S8("CNSmlDSAgent::ConstructL DSNetmon is Launched"));
		
		CNsmlProfileUtil* profileUtil = CNsmlProfileUtil::NewLC();	
		profileUtil->IsValidResumeL(iAutoRestartInitiatedSync);	
		profileUtil->WriteInterruptFlagL(0);
		CleanupStack::PopAndDestroy(profileUtil);
	}
	else
	{
		iDSNetmon = NULL;
		DBG_FILE(_S8("CNSmlDSAgent::ConstructL DSNetmon is not Launched"));
	}
	//RD_AUTO_RESTART
	
	// security policies for P&S reading and writing
	_LIT_SECURITY_POLICY_S0( KNSmlPSWritePolicy, KNSmlSOSServerPolicyUID.iUid ); // SID check (sosserver) when writing
	_LIT_SECURITY_POLICY_PASS( KNSmlPSReadPolicy ); // no checks done when reading
	
	// Define P&S data field for sync ON/OFF flag (may fail e.g. if exists already)
	RProperty::Define( KPSUidDataSynchronizationInternalKeys, // category
                       KDataSyncStatus, // field
                       RProperty::EInt, // type
                       KNSmlPSReadPolicy, // read policy
                       KNSmlPSWritePolicy ); // write policy

	//For Syncml Status Extended Error Codes
	FeatureManager::InitializeLibL();
	iIsExtendedServerErrorCodesSupported = EFalse;
	if(FeatureManager::FeatureSupported(KFeatureIdFfSyncmlStatusExtendedErrorCodes))
	  {
      InitializeServerStatusCodeList();
	  }
	TRAP_IGNORE( iErrorReportingRep = CRepository::NewL( KCRUidOperatorDatasyncErrorKeys ) );
	DBG_FILE(_S8("CNSmlDSAgent::ConstructL ends"));
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::NewL
// Symbian two-phased constructor.
// -----------------------------------------------------------------------------
//
CNSmlDSAgent* CNSmlDSAgent::NewL( MSyncMLProgressObserver* aDSObserver )
    {
	CNSmlDSAgent* self = new (ELeave) CNSmlDSAgent();
	CleanupStack::PushL( self );
    self->ConstructL( aDSObserver );
	CleanupStack::Pop(); // self
    return self;
    }

// -----------------------------------------------------------------------------
// CNSmlDSAgent::~CNSmlDSAgent
// Destructor.
// -----------------------------------------------------------------------------
//
CNSmlDSAgent::~CNSmlDSAgent()
    {   
    delete iSyncLog;
	delete iDSContent;	
	delete iDSServerId;	
	delete iServerAlertPackage;
		
	if ( iDSSyncTypeArray )
		{	
		iDSSyncTypeArray->Reset();		
		delete iDSSyncTypeArray;
		}	
	//RD_AUTO_RESTART
	if(iDSNetmon)
	{
		delete iDSNetmon;		
		iDSNetmon = NULL;
	}
    //RD_AUTO_RESTART
	if(iServerStatusCodeArray)
	    {
	    delete iServerStatusCodeArray;
	    }
	if(iRepositorySSC)
	    {
	    delete iRepositorySSC;
	    }
	
	if(iErrorReportingRep)
	    {
	    delete iErrorReportingRep;
	    }
	FeatureManager::UnInitializeLib();
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::Synchronise
// Starts the sync, returns immediately and the initiated sync continues in the 
// RunL() function.
// -----------------------------------------------------------------------------
//
EXPORT_C void CNSmlDSAgent::Synchronise( TRequestStatus& aStatus,
		                      			 TSmlProfileId aProfileId,
		                      			 TSmlConnectionId aConnectionId,
							  			 CArrayFix<TNSmlContentSpecificSyncType>* aTypeArray,
							  			 TNSmlSyncInitiation aSyncInitiation,
							  			 TInt aSessionId,
							  			 HBufC8* aAlertPackage )
	{
	
	CActiveScheduler::Add( this );
	
	iCallerStatus = &aStatus;
	iSyncInitiation = aSyncInitiation;
	iProfileID = aProfileId;
	iMediumType.iUid = aConnectionId;
	iSessionId = aSessionId;
	
	*iCallerStatus = KRequestPending;
	
	TRAPD( err, PrepareSyncL( aTypeArray ) );
	
	if ( err != KErrNone )
		{
		DoErrorEvent( MSyncMLProgressObserver::ESmlFatalError, err, iDSContent->TaskId(), 0, 0 );
		User::RequestComplete( iCallerStatus, err );
		return;
		}
		
	if ( iSyncInitiation == EServerAlerted && aAlertPackage )
		{
		TRAP( err, iServerAlertPackage = aAlertPackage->AllocL() );
		
		if ( err != KErrNone )
			{
			DoErrorEvent( MSyncMLProgressObserver::ESmlFatalError, err, iDSContent->TaskId(), 0, 0 );
			User::RequestComplete( iCallerStatus, err );
			return;
			}
		}

	SetActive();
	TRequestStatus* status = &iStatus;
	User::RequestComplete( status, KErrNone );
	}

//
//  Private member functions
//
//
//  Begin state sub-functions 
//
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubStartStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubStartStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubStartStateL() begins"));

	iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlConnecting, 0, 0 );
	iDSCurrBeginSubState = EBeginSubReadSettings;
	
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubStartStateL() ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubReadSettingsStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubReadSettingsStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubReadSettingsStateL() begins"));
	
	ReadSettingsL();
	iDSCurrBeginSubState = EBeginSubSyncmlCmdsInstance;
	
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubReadSettingsStateL() ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubSyncmlCmdsInstanceStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubSyncmlCmdsInstanceStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubSyncmlCmdsInstanceStateL() begins"));
	CreateSyncmlCmdsInstanceL();
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubSyncmlCmdsInstanceStateL() ends"));
	iDSCurrBeginSubState = EBeginSubServerAlerting;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubServerAlertingStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubServerAlertingStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubServerAlertingStateL() begins"));
	
	if ( iSyncInitiation == TNSmlSyncInitiation( EServerAlerted ) )
		{
		DBG_FILE(_S8("CNSmlDSAgent::BeginSubServerAlertingStateL() Before ServerAlertStateL"));
		ServerAlertStateL();
		}
		
	iDSContent->InitAllSyncLogEventsL( *iSyncLog );
	iDSCurrBeginSubState = EBeginSubOpenContentInstances; 
	
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubServerAlertingStateL() ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubOpenContentInstancesStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubOpenContentInstancesStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubOpenContentInstancesStateL() begins"));
	TBool endOfOpening = EFalse; 
	OpenDatabaseInstancesL( endOfOpening );
	if ( endOfOpening )
		{
		// <MAPINFO_RESEND_MOD_BEGIN>
		iDSCurrBeginSubState = EBeginSubScanMapInfo;
		// iDSCurrBeginSubState = EBeginSubCreateLUIDBuffers;
		// <MAPINFO_RESEND_MOD_END>
		}
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubOpenContentInstancesStateL() ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubCreateLUIDBuffersStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubCreateLUIDBuffersStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubCreateLUIDBuffersStateL() begins"));
	TBool endOfCreating( EFalse );
	
	CreateLUIDBuffersL( endOfCreating );
	
	if ( endOfCreating )
		{
		iCurrBeginningState = EBeginConnectingToServer;
		}
		
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubCreateLUIDBuffersStateL() ends"));
	}

//
//  Server Alert state functions 
//

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerAlertStateL
// Marks server alerted databases as alerted
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerAlertStateL()	
	{
	// parse syncml 1.1 server alert package
	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		TPtr8 buffer( iSyncMLCmds->BufferAreaForParsingL() );
		
		if ( iServerAlertPackage->Length() > buffer.MaxLength() )
			{
			return;
			}
			
		buffer.Copy( *iServerAlertPackage );
		delete iServerAlertPackage;
		iServerAlertPackage = NULL;
		
		iDSCurrServerAlertState = EServerAlertWaitingStartMessage;
		
		while ( iSyncMLCmds->ProcessReceivedDataL() ) { }
			
		if ( iDSCurrServerAlertState != EServerAlertMessageReceived )
			{
			User::Leave( TNSmlError::ESmlIncompleteMessage );
			}
		}
		
	iDSContent->RemoveNotServerAlertedContents();
	
	if ( iProtocolVer == ESmlVersion1_2 )
		{
		if ( iDSContent->AllDatabasesAreInterrupted() )
			{
			if ( iError->SyncLogErrorCode() )
				{
				User::Leave( iError->SyncLogErrorCode() );
				}
			else
				{
				User::Leave( TNSmlDSError::ESmlDSNoValidDatabases );
				}
			}
		}
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerAlertStartMessageStateL
// Handles SyncHdr in Server Alert Package from server.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerAlertStartMessageStateL( SmlSyncHdr_t* aSyncHdr )
	{
	if ( iDSCurrServerAlertState != EServerAlertWaitingStartMessage )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
		
	iSyncMLCmds->ProcessSyncHdrL( aSyncHdr );
	
	iDSCurrServerAlertState = EServerAlertWaitingAlerts;
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerAlertAlertCmdStateL
// Handles Alert command in Server Alert Package from server.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerAlertAlertCmdStateL( SmlAlert_t* aAlert )
	{
	if ( iDSCurrServerAlertState != EServerAlertWaitingAlerts ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}

	if ( iSyncMLCmds->AlertCode( aAlert ) == KNSmlAgentDisplayAlert )
		{
		iSyncMLCmds->ProcessAlertCmdL( aAlert, EFalse, EFalse, ETrue );
		}
	else
		{
		iSyncMLCmds->ProcessAlertCmdL( aAlert, EFalse, ETrue );
		}
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerAlertEndMessageStateL
// Processes the end of the alert command in server alert package.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerAlertEndMessageStateL( TBool /*aFinal*/ )
	{
	if ( iDSCurrServerAlertState != EServerAlertWaitingAlerts ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}

	iDSCurrServerAlertState = EServerAlertMessageReceived;
	}

//
//  Client Initialisation state functions 
//

// ---------------------------------------------------------
// CNSmlDSAgent::InitStartingMessageStateL()
// "Initialising" event to UI, initialises interruption flags
// set by possible first initialisation attempt, makes SyncHdr  
// ---------------------------------------------------------
void CNSmlDSAgent::InitStartingMessageStateL()
	{
	iDSContent->InitInterruptionFlags();
	iDSContent->SetToFirst();
	InitStartingMessageStateBaseL();
	}
	
//RD_SUSPEND_RESUME	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::MapAlertCode
// Maps the Alert code
// -----------------------------------------------------------------------------
// 
TPtrC8 CNSmlDSAgent::MapAlertCode(TNSmlPreviousSyncType aAlertCode)

{
   TPtrC8 prevAlert;
   if ( aAlertCode == ESyncDSTwoWay )
		{
		prevAlert.Set( KNSmlDSTwoWay);
		}
   else if ( aAlertCode == ESyncDSSlowSync)
		{
		prevAlert.Set(KNSmlDSSlowSync);
		}
   else if ( aAlertCode == ESyncDSOneWayFromClient)
		{
		prevAlert.Set(KNSmlDSOneWayFromClient);
		}
	else if ( aAlertCode == ESyncDSRefreshFromClient)
		{
		prevAlert.Set(KNSmlDSRefreshFromClient);
		}
	else if ( aAlertCode == ESyncDSOneWayFromServer  )
		{
		prevAlert.Set(KNSmlDSOneWayFromServer);
		}
	else if(aAlertCode ==ESyncDSRefreshFromServer )
	   {
		prevAlert.Set(KNSmlDSRefreshFromServer);
	   }		
	else if(aAlertCode ==ESyncDSTwoWayByServer )
	   {
		prevAlert.Set(KNSmlDSTwoWayByServer);
	   }   
    else if(aAlertCode ==ESyncDSOneWayFromClientByServer )
	   {
		prevAlert.Set(KNSmlDSOneWayFromClientByServer);
	   }
    else if(aAlertCode ==ESyncDSRefreshFromClientByServer )
	   {
		prevAlert.Set(KNSmlDSRefreshFromClientByServer);
	   }
    else if(aAlertCode ==ESyncDSOneWayFromServerByServer )
	   {
		prevAlert.Set(KNSmlDSOneWayFromServerByServer);
	   }
   else if(aAlertCode ==ESyncDSRefreshFromServerByServer )
	   {
		prevAlert.Set(KNSmlDSRefreshFromServerByServer);
	   }
  
  return(prevAlert);
	   	
	
}
//RD_SUSPEND_RESUME	

// CNSmlDSAgent::InitAlertingStateL
// Makes Alert command for each database. If there is a previously completed
// sync the client suggests two-way sync else slow sync is proposed.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::InitAlertingStateL()
	{

	if ( iDSClientNextSyncAnchor == TTime( 0 ) )
		{
		 iDSClientNextSyncAnchor.UniversalTime();
		}
	
	if ( iDSContent->SetToFirst() )	
		{
	
		 do
			{		
			   TBuf8<3> syncType( iDSContent->SyncType() ); 
			   TTime clientLastSyncAnchor( iDSContent->LastSyncAnchorL() );
			   TNSmlPreviousSyncType prevSyncType=iDSContent->PreviousClientSyncTypeL();
			   iDSContent->SetSessionResumedL(EFalse);		   
			    if (!iDSContent->Interrupted())
				{
				   	 //RD_SUSPEND_RESUME	
				    if(iDSContent->SuspendedStateL() == EStateNotStarted)
				     {				   				   	
				   	    if ( syncType == KNSmlDSTwoWay )
					    {
					   		// <MAPINFO_RESEND_MOD_BEGIN>
							if ( ( !iDSContent->HasSyncHistoryL() || iDSContent->SlowSyncRequestL() || clientLastSyncAnchor == TTime( 0 ) )&& !iDSContent->MapExists() )
							// if ( !iDSContent->HasSyncHistoryL() || iDSContent->SlowSyncRequestL() || clientLastSyncAnchor == TTime( 0 )   )
							// <MAPINFO_RESEND_MOD_BEGIN>
							{								
								syncType = KNSmlDSSlowSync;
							
							}
                		 }
                	  }
				    //checks for protocol version, stage of interruption ,sync history to send resume command
			        else if (iProtocolVer==ESmlVersion1_2 && iDSContent->HasSyncHistoryL() &&  
			                          prevSyncType!=ETypeNotSet && syncType!= KNSmlDSRefreshFromServer)
				     { 
				         //Client rejects to the Resume session when the Sync type is changed in the UI
				      	 //Based on the section "Refusing to Resume a session" in the OMA-Protocol spec
				      	 //Two way sync will be proposed by the client instead of the Resume session
				         if(syncType.Compare(MapAlertCode(prevSyncType))==0)
			  	            {
			  	               	 syncType = KNSmlDSResume;
			  	               	 iDSContent->SetSessionResumedL(ETrue);
			  	            }  
			  	         else 
			  	            {
			  	            	syncType=KNSmlDSSlowSync;
			  	            	iDSContent->SetSessionResumedL(EFalse);
			  	            }
					  }
					 //RD_SUSPEND_RESUME
                
				   iSyncMLCmds->DoAlertL( syncType, &clientLastSyncAnchor, &iDSClientNextSyncAnchor );
				   iDSContent->SetInitAlertWaiting();  	
				   	   	
			    }
			   	
		
			}	
		  while ( iDSContent->SetToNext() );
		}
	
	iCurrClientInitState = EInitDeviceInfo;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::InitDeviceInfoStateL
// If there is some database which is not previously synced with the server then
// DevInfo is sent in a Put command.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::InitDeviceInfoStateL()
	{
	if ( iDSContent->SetToFirst() )
		{
		do
			{
			if ( ( !iDSContent->HasSyncHistoryL() || iDSContent->LastSyncAnchorL() == TTime( 0 ) ) && !iDSContent->Interrupted() )
				{
				iSyncMLCmds->DoPutL();
				iDSDeviceInfoRequestByClient = ETrue;
				break;
				}
			}
		while ( iDSContent->SetToNext() );
		}

	iCurrClientInitState = EInitAskingDeviceInfo;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::InitAskingDeviceInfoStateL()
// If there is one database which is not previosly synced with the
// server, Device Info is asked Get command
// ---------------------------------------------------------
void CNSmlDSAgent::InitAskingDeviceInfoStateL()
	{
	if ( iDSDeviceInfoRequestByClient )
		{
		iSyncMLCmds->DoGetL();
		}
	iCurrClientInitState = EInitEndingMessage;
	}
	
//
//  Server Initialisation state functions 
//
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitialisationStateL()
// Main state function to read Sync Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitialisationStateL()
	{
	//DBG_FILE(_S8("CNSmlDSAgent::ServerInitialisationStateL begins"));
	
	TBool messageReceived( EFalse );
	
	if ( iDSCurrServerInitState == EServerInitEnd )
		{
		messageReceived = ETrue;
		}
	else
		{
		messageReceived = !iSyncMLCmds->ProcessReceivedDataL();
		}
		
	if ( messageReceived )
		{
		switch ( iDSCurrServerInitState )
			{
			case EServerInitMessageReceived:
				{			
				iBusyStatusReceived = iSyncMLCmds->BusyStatus();
				NextMainStateL();
				break;
				}
				
			case EServerInitPackageReceived:
				{
				if ( !iChallengeRequest )
					{
					CheckStatusCodesAreReceivedL();
					CheckCommandsAreReceivedL();
					TInt retVal( iDSContent->SetTypeAndDevCapsL() );
					
					if ( retVal != KErrNone )
						{
						InterruptL( iDSContent->CurrentIndex(), TNSmlError::ESmlTypeNotSupported, EFalse, EFalse );
						}
					}
					
				iDSLUIDBufferingStarted = EFalse;
				iDSCurrServerInitState = EServerInitEnd;
				break;
				}
				
			case EServerInitEnd:
				{
				TBool endOfInits( EFalse );
				TInt resultCode( KErrNone );

				iDSContent->SetDbAndTimeInitsL( endOfInits, resultCode, iDSLUIDBufferingStarted );
				iDSLUIDBufferingStarted = ETrue;
					
				User::LeaveIfError( resultCode );
				
				if ( endOfInits )
					{
					NextMainStateL();
					}
				break;
				}
				
			default:		
				{
				User::Leave( TNSmlError::ESmlIncompleteMessage );
				}
			}
		}
	//DBG_FILE(_S8("CNSmlDSAgent::ServerInitialisationStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitStartMessageStateL()
// Handles SyncHdr in Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitStartMessageStateL( SmlSyncHdr_t* aSyncHdr )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitStartMessageStateL begins"));
	if ( iDSCurrServerInitState != EServerInitWaitingStartMessage )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	iSyncMLCmds->ProcessSyncHdrL( aSyncHdr );
	iDSCurrServerInitState = EServerInitWaitingCommands;
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitStartMessageStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitStatusCmdStateL()
// Handles Status command in Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitStatusCmdStateL( SmlStatus_t* aStatus )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitStatusCmdStateL begins"));
	if ( iChallengeRequest  )
		{
		return;
		}
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitStatusCmdStateL ends"));
	iSyncMLCmds->ProcessStatusCmdL( aStatus );
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitResultsCmdStateL()
// Handles Results command in Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitResultsCmdStateL( SmlResults_t* aResults )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitResultsCmdStateL begins"));
	if ( iChallengeRequest  )
		{
		return;
		}
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	if ( !iDSDeviceInfoRequestByClient )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	else
		{
		iSyncMLCmds->ProcessResultsCmdL( aResults );
		iDSDeviceInfoRequestByClient = EFalse;
		}
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitResultsCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitAlertCmdStateL()
// Handles Alert command in Initialization Package from Server 
// ---------------------------------------------------------
void  CNSmlDSAgent::ServerInitAlertCmdStateL( SmlAlert_t* aAlert )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitAlertCmdStateL begins"));
	if ( iChallengeRequest  )
		{
		return;
		}
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	// Alert command may be init Alert, Next Alert or Display Alert
	TBool nextAlert = EFalse;
	TBool displayAlert = EFalse;

	if ( iSyncMLCmds->AlertCode( aAlert ) == KNSmlDSAgentNextMessage )
		{
		if ( !iFinalMessageFromClient )
			{
			nextAlert = ETrue;
			}
		}
	else
		{
		if ( iSyncMLCmds->AlertCode( aAlert ) == KNSmlAgentDisplayAlert )
			{
			displayAlert = ETrue;
			}
		}

	iSyncMLCmds->ProcessAlertCmdL( aAlert, nextAlert, EFalse, displayAlert );
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitAlertCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitPutCmdStateL()
// Handles Put command in Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitPutCmdStateL( SmlPut_t* aPut )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitPutCmdStateL begins"));
	if ( iChallengeRequest  )
		{
		return;
		}
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	iSyncMLCmds->ProcessPutCmdL( aPut );
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitPutCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitGetCmdStateL()
// Handles Get command in Initialization Package from Server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerInitGetCmdStateL( SmlGet_t* aGet )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitGetCmdStateL begins"));
	if ( iChallengeRequest  )
		{
		return;
		}
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	iSyncMLCmds->ProcessGetCmdL( aGet );
	iDSDeviceInfoRequestedByServer = ETrue;
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitGetCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerInitEndMessageStateL()
// 
// ---------------------------------------------------------
void  CNSmlDSAgent::ServerInitEndMessageStateL( TBool aFinal )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitEndMessageStateL begins"));
	if ( iDSCurrServerInitState != EServerInitWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	if ( aFinal )
		{
		iDSCurrServerInitState = EServerInitPackageReceived;
		}
	else
		{
		iDSCurrServerInitState = EServerInitMessageReceived;
		}
	DBG_FILE(_S8("CNSmlDSAgent::ServerInitEndMessageStateL ends"));
	}
	
//
//  Client Modifications state functions 
//
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModificationsStateL()
// Makes Client Modification Package to Server
// Navigate according to state code
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModificationsStateL()
	{
	switch ( iDSCurrClientModState )
		{
		case EClientModStartingMessage:
			ClientModStartingMessageStateL();
			break;
		case EClientModMakingStatus:
			ClientModMakingStatusStateL();
			break;
		case EClientModMakingResults:
			ClientModMakingResultsStateL();
			break;
		case EClientModStartingSync:
			ClientModStartingSyncStateL();
			break;
		case EClientModMakingUpdates:
			ClientModMakingUpdatesStateL();
			break;
		case EClientModEndingSync:
			ClientModEndingSyncStateL();
			break;
		case EClientModEndingMessage:
			ClientModEndingMessageStateL();
			break;
		default:
			User::Leave( KErrGeneral );
		} 
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModStartingMessageStateL()
// "Synchronising" event to UI, makes SyncHdr  
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModStartingMessageStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModStartingMessageStateL begins"));
	iSyncMLCmds->DoSyncHdrL();
	iBufferFull = EFalse;
	iDSCurrClientModState = EClientModMakingStatus;
	DBG_FILE(_S8("CNSmlDSAgent::ClientModStartingMessageStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModMakingStatusStateL()
// Writes all buffered status elements
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModMakingStatusStateL()
	{
	DBG_FILE(_S8("ClientModMakingStatusStateL begins"));
	iSyncMLCmds->StatusContainer()->Begin();
	TBool found( ETrue ); 
	
	while( found )
		{
		SmlStatus_t* status;
		found = iSyncMLCmds->StatusContainer()->NextStatusElement( status, ETrue ); 
		if ( found )
			{
			iSyncMLCmds->DoStatusL( status );
			}
		}
		
	iDSCurrClientModState = EClientModMakingResults;
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingStatusStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModMakingResultsStateL()
// Device Info to a server in Results command (if asked )
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModMakingResultsStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingResultsStateL begins"));
	if ( iDSDeviceInfoRequestedByServer && !iDSContent->AllDatabasesAreInterrupted() )
		{
		iSyncMLCmds->DoResultsL();
		iDSDeviceInfoRequestedByServer = EFalse;
		}
	if ( iFinalMessageFromClient )
		{
		iDSContent->SetToFirst();
		}
	else
		{
		iDSContent->SetIndexToSaved();
		}
	iDSCurrClientModState = EClientModStartingSync;
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingResultsStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModStartingSyncStateL()
// Makes Sync command 
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModStartingSyncStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModStartingSyncStateL begins"));
	CNSmlCmdsBase::TReturnValue ret;
	if ( !iDSContent->Interrupted() )
		{
		ret = iSyncMLCmds->DoStartSyncL();
		switch ( ret )
			{
			case CNSmlCmdsBase::EReturnOK:
				iDSCurrClientModState = EClientModMakingUpdates;
				if ( !iDSContent->ClientItemCountAsked() )
					{
					iDSContent->SetClientItemCountAsked();
					iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlSendingModificationsToServer, iDSContent->ClientItemCount(), 0 );
					}
				break;
			case CNSmlCmdsBase::EReturnBufferFull:
				iDSCurrClientModState = EClientModEndingMessage;
				iBufferFull = ETrue;
				break;
			default:
				break;
			}
		}
	else
		// skip interrupted database
		{
		if ( !iDSContent->SetToNext() )
			{
			iDSCurrClientModState = EClientModEndingMessage;
			}
		}
	DBG_FILE(_S8("CNSmlDSAgent::ClientModStartingSyncStateL ends"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::ClientModMakingUpdatesStateL()
// Makes Replace or Delete command
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModMakingUpdatesStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingUpdatesStateL begins"));
	
	//RD_SUSPEND_RESUME
	// Client modifications are not sent,if the previous session was interrupted at Server modifications state.Commented for Usability issue.
	/*if(iDSContent->SuspendedState()== EStateServerModification && iDSContent->GetSessionResumed())
		{
		  	iDSCurrClientModState = EClientModEndingSync;	
		}else */
	if ( iDSContent->SyncType() == KNSmlDSOneWayFromServer ||
		 iDSContent->SyncType() == KNSmlDSOneWayFromServerByServer ||
		 iDSContent->SyncType() == KNSmlDSRefreshFromServer ||
		 iDSContent->SyncType() == KNSmlDSRefreshFromServerByServer )
		{
		iDSCurrClientModState = EClientModEndingSync;
		}
	else
		{
		switch ( iSyncMLCmds->DoAddOrReplaceOrDeleteL() )
			{
			case CNSmlCmdsBase::EReturnEndData:
				iDSCurrClientModState = EClientModEndingSync;
				break;
				
			case CNSmlCmdsBase::EReturnBufferFull:
				iDSCurrClientModState = EClientModEndingSync;
				iBufferFull = ETrue;
				break;
				
			default:
				break;
			}
		}
		
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingUpdatesStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModEndingSyncStateL()
// End of Sync command 
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModEndingSyncStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModEndingSyncStateL begins"));

	iSyncMLCmds->DoEndSyncL();

	if ( iBufferFull )
		{
		iDSCurrClientModState = EClientModEndingMessage;
		}
	else
		{
		if ( iDSContent->SetToNext() )
			{
			iDSCurrClientModState = EClientModStartingSync;
			}
		else
			{
			iDSCurrClientModState = EClientModEndingMessage;
			}
		}

	DBG_FILE(_S8("CNSmlDSAgent::ClientModEndingSyncStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ClientModEndingMessageStateL()
// End of SyncMl Message, read amounts are notified to UI
// ---------------------------------------------------------
void CNSmlDSAgent::ClientModEndingMessageStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModEndingMessageStateL begins"));
	if ( iBufferFull )
		{
		iSyncMLCmds->DoEndMessageL( EFalse );
		iFinalMessageFromClient = EFalse;
		iDSContent->SaveCurrentIndex();
		}
	else
		{
		iSyncMLCmds->DoEndMessageL();
		iFinalMessageFromClient = ETrue;
		}
	NextMainStateL();
	DBG_FILE(_S8("CNSmlDSAgent::ClientModEndingMessageStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::ServerModificationsStateL(()
// Main state function to read Server Modifications to Client Package  
// ---------------------------------------------------------
void CNSmlDSAgent::ServerModificationsStateL()
	{
	DBG_FILE(_S8("ServerModificationsStateL begins"));
	
	if ( iCurrServerModState == EServerModWaitingStartMessage )
		{

// <MAPINFO_RESEND_MOD_BEGIN>
        iDSContent->SetMapRemovable();
		iDSContent->RemoveAllRemovableMap();
// <MAPINFO_RESEND_MOD_BEGIN>

		iDSContent->SetSyncStatusToAll( ENoServerDataUpdated );
		}
		
	if ( !iSyncMLCmds->ProcessReceivedDataL() )
		{
		if ( iCurrServerModState == EServerModMessageReceived )
			{
			iBusyStatusReceived = iSyncMLCmds->BusyStatus();
			CheckStatusCodesAreReceivedL( EFalse );
			}
		else
			{
			if ( iCurrServerModState == EServerModPackageReceived )
				{
				CheckStatusCodesAreReceivedL();
				CheckCommandsAreReceivedL();
				iDSContent->SetSyncStatusToAll( ECompletedOK );
				}
			else
				{
				User::Leave( TNSmlError::ESmlIncompleteMessage );
				}
			}
		NextMainStateL();
		}
	
	DBG_FILE(_S8("CNSmlDSAgent::ServerModificationsStateL ends"));
	}
	
//
// Server Modifications state functions
//
// ---------------------------------------------------------
// CNSmlDSAgent::ServerModStartSyncStateL(()
// Handles Sync command in Server Modifications to Client Package
// ---------------------------------------------------------
void CNSmlDSAgent::ServerModStartSyncStateL( SmlSync_t* aSync )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerModStartSyncStateL begins"));
	
	if ( iCurrServerModState != EServerModWaitingCommands )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	
	iSyncMLCmds->ProcessSyncL( aSync );
	
	iCurrServerModState = EServerModWaitingUpdateCommands;
	
	DBG_FILE(_S8("CNSmlDSAgent::ServerModStartSyncStateL ends"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::ServerModEndSyncStateL(()
// Handles end of Sync command
// ---------------------------------------------------------
void CNSmlDSAgent::ServerModEndSyncStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerModEndSyncStateL begins"));

	iSyncMLCmds->ProcessEndSyncL();

	iCurrServerModState = EServerModWaitingCommands;
	DBG_FILE(_S8("CNSmlDSAgent::ServerModEndSyncStateL ends"));
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerModStartAtomicStateL
// Handles the Atomic command.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerModStartAtomicStateL( SmlAtomic_t* aContent )
	{
	if ( ( iCurrServerModState != EServerModWaitingUpdateCommands ) && ( iCurrServerModState != EServerModWaitingCommands ) )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd );
		}
		
	if ( iNestedAtomicsCount > 0 )
		{
		iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentAtomic, aContent->cmdID, aContent->flags );
		WriteWarningL( TNSmlError::ESmlUnexpectedCmd );
		}
	else
		{
		iSyncMLCmds->ProcessAtomicL( aContent );
		}
		
	++iNestedAtomicsCount;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::ServerModEndAtomicStateL
// Handles the end of the Atomic command.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ServerModEndAtomicStateL()
	{
	if ( --iNestedAtomicsCount == 0 )
		{
		iSyncMLCmds->ProcessEndAtomicL();
		}
	}

//
//  Map Acknowledgement state functions 
//
// ---------------------------------------------------------
// CNSmlDSAgent::MapAcknowledgeStateL()
// Main state function to read Map Acknowledgement from Server Package
// ---------------------------------------------------------
void CNSmlDSAgent::MapAcknowledgeStateL()
	{
	if ( !iSyncMLCmds->ProcessReceivedDataL() )
		{
		if ( iDSCurrMapAcknowledgeState == EMapAckMessageReceived )
			{
			iBusyStatusReceived = iSyncMLCmds->BusyStatus();
			}
		else
			{
			if ( iDSCurrMapAcknowledgeState == EMapAckPackageReceived )
				{
				CheckStatusCodesAreReceivedL();
				iDSContent->SetSyncStatusToAll( ECompletedOK );
				}
			else
				{
				if ( iDSWaitingForMapAcknowledgement )
					{
					User::Leave( TNSmlError::ESmlIncompleteMessage );
					}
				}
			}
		NextMainStateL();
		}
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::MapAckStartMessageStateL
// Handles SyncHdr in Map Acknowledgement from Server Package
// ---------------------------------------------------------
void  CNSmlDSAgent::MapAckStartMessageStateL( SmlSyncHdr_t* aSyncHdr )
	{
	DBG_FILE(_S8("CNSmlDSAgent::MapAckStartMessageStateL begins"));
	if ( iDSCurrMapAcknowledgeState != EMapAckWaitingStartMessage )
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	iSyncMLCmds->ProcessSyncHdrL( aSyncHdr );
	iDSCurrMapAcknowledgeState = EMapAckWaitingCommands;
	DBG_FILE(_S8("CNSmlDSAgent::MapAckStartMessageStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::MapAckStatusCmdStateL()
// Handles Status command in Map Acknowledgement from Server Package 
// ---------------------------------------------------------
void CNSmlDSAgent::MapAckStatusCmdStateL( SmlStatus_t* aStatus )
	{
	DBG_FILE(_S8("CNSmlDSAgent::MapAckStatusCmdStateL begins"));
	if ( iDSCurrMapAcknowledgeState != EMapAckWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
	iSyncMLCmds->ProcessStatusCmdL ( aStatus );
	DBG_FILE(_S8("CNSmlDSAgent::MapAckStatusCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::MapAckAlertCmdStateL()
// Handles Alert command in Map Acknowledgement from Server Package 
// ---------------------------------------------------------
void  CNSmlDSAgent::MapAckAlertCmdStateL( SmlAlert_t* aAlert )
	{
	DBG_FILE(_S8("CNSmlDSAgent::MapAckAlertCmdStateL begins"));
	if ( iDSCurrMapAcknowledgeState != EMapAckWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}

	if ( iSyncMLCmds->AlertCode( aAlert ) == KNSmlAgentDisplayAlert )
		{
		iSyncMLCmds->ProcessAlertCmdL( aAlert, EFalse, EFalse, ETrue );
		}
	else
		{
		if ( !iFinalMessageFromClient )
			{
			iSyncMLCmds->ProcessAlertCmdL( aAlert, ETrue );
			}
		}

	DBG_FILE(_S8("CNSmlDSAgent::MapAckAlertCmdStateL ends"));
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::MapAckEndMessageStateL()
// Handles end of SyncML message
// ---------------------------------------------------------
void  CNSmlDSAgent::MapAckEndMessageStateL( TBool aFinal )
	{
	DBG_FILE(_S8("CNSmlDSAgent::MapAckEndMessageStateL begins"));
	
	if ( iDSCurrMapAcknowledgeState != EMapAckWaitingCommands ) 
		{
		User::Leave( TNSmlError::ESmlUnexpectedCmd ); 
		}
		
	if ( aFinal )
		{
			
// <MAPINFO_RESEND_MOD_BEGIN>
		iDSContent->RemoveAllRemovableMap();
// <MAPINFO_RESEND_MOD_BEGIN>
			
		iDSCurrMapAcknowledgeState = EMapAckPackageReceived;
		}
	else
		{
		iDSCurrMapAcknowledgeState = EMapAckMessageReceived;
		}
		
	DBG_FILE(_S8("CNSmlDSAgent::MapAckEndMessageStateL ends"));
	}

//
//  Finishing state functions 
//

// ---------------------------------------------------------
// CNSmlDSAgent::FinishingStateL()
// Finishing functions in the end of sync
// ---------------------------------------------------------
void CNSmlDSAgent::FinishingStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::FinishingStateL begins"));
	
	TInt index = iDSContent->CurrentIndex();
	TInt keyVal;
	TRAPD (srerr ,ReadRepositoryL(KNsmlDsSuspendResume, keyVal));
	
   if(srerr == KErrNone && keyVal == 1)
   {
		
	    TNSmlSyncSuspendedState suspendedState;
	    if(iDSContent->SetToFirst())
	    {
	        do
	        {
	           suspendedState = CurrentState();	
	           iDSContent->SetSuspendedStateL(suspendedState);
	        }while( iDSContent->SetToNext() );
	   }
	   
	    if(iDSContent->SetToFirst())
	    {
		   do
	  	   {
		    TBuf8<3> syncType( iDSContent->SyncType()); 
	        TNSmlPreviousSyncType prevSyncType=MapAlertCode(syncType);
	        //Sync Type of the Current Sync session is stored.
	        iDSContent->SetPreviousSyncTypeL( prevSyncType );	
		   }while( iDSContent->SetToNext() );
         }
	
	   if(iDSContent->SetToFirst())
	   { 
		   do
	       { 
		    TBuf8<3> clientSyncType( iDSContent->ClientSyncType());
	        TNSmlPreviousSyncType prevClientType=MapAlertCode(clientSyncType);
	        //Sync Type proposed by Client in the Current Sync session is stored.
	        iDSContent->SetPreviousClientSyncTypeL( prevClientType );	
		   }while( iDSContent->SetToNext() );
	   }
		
	}
	//RD_SUSPEND_RESUME
	iDSContent->SetIndex(index);
	if( !iPacketDataUnAvailable && iUpdateLastAnchor )
	     iDSContent->UpdateSyncAnchorsL( iDSClientNextSyncAnchor );
	iDSContent->FinalizeDatabasesL();
	FinishL();
	FinalizeSyncLogL();
	//RD_AUTO_RESTART (BPSS-7GBFF3)
	//Check whether the Auto Restart Feature is enabled or not
	TRAPD (arerr ,ReadRepositoryL(KNsmlDsAutoRestart, keyVal));
	
	if(arerr == KErrNone && keyVal == 1)
	{
		if(!iPacketDataUnAvailable && !iAutoRestartInitiatedSync )
		{
			DBG_FILE(_S8("CNSmlDSAgent::FinishingStateL About to check the Profile ID"));
			
			if(CheckProfileIdL())
			{
				TerminateAutoRestart();
			}	
		}
	}
	//RD_AUTO_RESTART
	
	DBG_FILE(_S8("CNSmlDSAgent::FinishingStateL ends"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::OpenDatabaseInstancesL
// Database instances (content data adapters are created)
// In the creation they are harcoded by the name,later on referenced
// by an index.
// ---------------------------------------------------------
void CNSmlDSAgent::OpenDatabaseInstancesL( TBool& aEnd )
	{
	TInt resultCode;
	TBool ret( EFalse );
		
	if ( !iDSDatabaseOpeningStarted )
		{
		ret = iDSContent->SetToFirst();
		iDSDatabaseOpeningStarted = ETrue;
		}
	else
		{
		ret = iDSContent->SetToNext();
		}
			
	if ( ret )
		{
		iDSContent->OpenContentInstanceL( resultCode );

		switch ( resultCode )
			{
			case KErrNone:
			    {
			    TBool status( EFalse );        
			    
			    TRAPD( error, status = iDSContent->IsSupportedSyncTypeL( iDSContent->SyncType() ));
			    if ( error == KErrNone )
			        {
			        if ( !status )
					    {
					    InterruptL( iDSContent->CurrentIndex(), TNSmlDSError::ESmlDSUnsupportedSyncType, ETrue, EFalse );
					    iDSContent->SetInterruptedBeforeSync();
					    }        
			        }
			    else
			        {
			        InterruptL( iDSContent->CurrentIndex(), error, ETrue, EFalse );
					iDSContent->SetInterruptedBeforeSync();    
			        }
				
			    }
				break;
				
			case KErrNotFound:
				InterruptL( iDSContent->CurrentIndex(), TNSmlDSError::ESmlDSLocalDatabaseError, ETrue, EFalse );
				iDSContent->SetInterruptedBeforeSync();
				break;
			
			default:
				User::Leave( resultCode );
			}
		}
	else
		{
		aEnd = ETrue;
		}	
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::CreateLUIDBuffersL
// 
// ---------------------------------------------------------
void CNSmlDSAgent::CreateLUIDBuffersL( TBool& aEnd )
	{
	TBool ret( EFalse );

	if ( !iDSLUIDBufferingStarted )
		{
		ret = iDSContent->SetToFirst();
		iDSLUIDBufferingStarted = ETrue;
		}
	else
		{
		ret = iDSContent->SetToNext();
		}
		
	if ( ret )
		{
		if ( !iDSContent->Interrupted() )
		    {
			TInt resultCode(KErrNone);
			TRAPD( error, iDSContent->CreateLUIDBufferL( resultCode ));

			if ( error != KErrNone || resultCode != KErrNone )
			    {
			    InterruptL( iDSContent->CurrentIndex(), TNSmlDSError::ESmlDSLocalDatabaseError, EFalse, ETrue );			    
			    }
			}
		}
	else
		{
		aEnd = ETrue;
		}
	}

// ---------------------------------------------------------
// CNSmlDSAgent::CreateSyncmlCmdsInstanceL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::CreateSyncmlCmdsInstanceL()
	{
	if ( !iSyncMLCmds )
		{
		TBool versionCheck( ETrue );
		TBuf8<16> sessionIdString;
		
		if ( iSessionId == 0 )
			{
			iSessionId = GetSessionIDL();
			++iSessionId;
			UpdateSessionIDL( iSessionId );
			}
			
		sessionIdString.Num( iSessionId );

		if ( iSyncInitiation == EServerAlerted )
			{
			versionCheck = EFalse;
			}

		if ( iProtocolVer == ESmlVersion1_1_2 )
			{
			iSyncMLCmds = CNSmlDSCmds::NewL( this, sessionIdString, KNSmlDSAgentVerProto, KNSmlSyncMLPublicId, *iSyncMLUserName, iSyncServer, *iDSContent, *iDSObserver, versionCheck );
			}
		else if ( iProtocolVer == ESmlVersion1_2 )
			{
			iSyncMLCmds = CNSmlDSCmds::NewL( this, sessionIdString, KNSmlDSAgentVerProto12, KNSmlSyncMLPublicId12, *iSyncMLUserName, iSyncServer, *iDSContent, *iDSObserver, versionCheck );		
			}
			
	    TInt value(0); 
		if ( !iSyncMLCmds ) 
		   User::Leave( KErrGeneral );
		
	    TRAPD (err , ReadRepositoryL(KNSmlMaxMsgSizeKey, value));	    
	    if ( ( iMediumType == KUidNSmlMediumTypeInternet ) && ( err == KErrNone ) )
	        {
            iSyncMLCmds->SetMaximumWorkspaceSize( value );	        
	        }
	    else if ( iMediumType != KUidNSmlMediumTypeInternet )
			{
			iSyncMLCmds->SetMaximumWorkspaceSize( KNSmlLocalSyncWorkspaceSize );
			}
		}
	}

// ---------------------------------------------------------
// CNSmlDSAgent::InfoMessageToSyncLogL()
// Info messages are written during the sync
// ---------------------------------------------------------
void CNSmlDSAgent::InfoMessageToSyncLogL( TInt appIndex, TInt aErrorCode )
	{
	iDSContent->SetIndex( appIndex );
	DoErrorEvent( MSyncMLProgressObserver::ESmlWarning, aErrorCode, iDSContent->TaskId(), 0, 0 );
	}

// ---------------------------------------------------------
// CNSmlDSAgent::ReadSettingsL()
// Reads sync settings
// ---------------------------------------------------------
void CNSmlDSAgent::ReadSettingsL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ReadSettingsL BEGIN"));                
	CNSmlDSProfile* profile = CNSmlDSSettings::NewLC()->ProfileL( iProfileID );
	//RD_AUTO_RESTART
	if(iDSNetmon)
	{
		iDSNetmon->iProfileID=iProfileID; 	
	}
	//RD_AUTO_RESTART
	if ( !profile )
		{
		User::Leave( TNSmlError::ESmlErrorInSettings );
		}

	CleanupStack::PushL( profile );
	
	SetDSSessionInfoL(profile);
		
	if ( iMediumType.iUid == -1 )
		{
		iMediumType.iUid = profile->IntValue( EDSProfileTransportId );  
		iIAPId = profile->IntValue( EDSProfileIAPId );
		}
    else if ( iMediumType.iUid == KUidNSmlMediumTypeInternet.iUid )
	    {
	    iIAPId = profile->IntValue( EDSProfileIAPId ); 
	    }
	//RD_AUTO_RESTART
	ReplaceIAPIdL();
 	//RD_AUTO_RESTART
	DBG_FILE_CODE(iIAPId , _S8("CNSmlDSAgent::ReadSettingsL, The Access Point ID for the Sync Session is :"));                
			
	iIAPIdArray = new ( ELeave ) CArrayFixFlat<TUint32>( KSmlArrayGranularity );
	iIAPIdArray->AppendL( iIAPId );

    if ( profile->IntValue( EDSProfileAutoChangeIAP ) )
        {            
		RDbNamedDatabase* dBase = CNSmlDSSettings::NewLC()->Database();
		CNSmlRoamTable* roam = CNSmlRoamTable::NewLC( *dBase );
		CNSmlIAPArray* iapArray( roam->GetItemsForIdL( iProfileID ) );
		CleanupStack::PushL( iapArray );

		for ( TInt index = 0 ; index < iapArray->Count() ; index++ )
			{
			iIAPIdArray->AppendL( iapArray->At( index ) );
			}
                
		iapArray->Reset();
		CleanupStack::PopAndDestroy( 3 ); // iapArray, roam, settings
		}

	iDSServerId = profile->StrValue( EDSProfileServerId ).AllocL();
	iSyncMLUserName = profile->StrValue( EDSProfileSyncServerUsername ).AllocL();
	iSyncMLPassword = profile->StrValue( EDSProfileSyncServerPassword ).AllocL();
	iSyncHTTPAuthUserName = profile->StrValue( EDSProfileHttpAuthUsername ).AllocL();	
	iSyncHTTPAuthPassword = profile->StrValue( EDSProfileHttpAuthPassword ).AllocL();	
	iSyncHTTPAuthUsed = profile->IntValue( EDSProfileHttpAuthUsed );						
	iProtocolVer = static_cast<TSmlProtocolVersion>( profile->IntValue( EDSProfileProtocolVersion ) );

	//For extended error code logging
    if(iRepositorySSC)
        {
        TBuf<KBufferLength> tempStr;
        //Get the Operator server ID configured in cenrep
        TInt error = iRepositorySSC->Get(KNsmlOperatorProfileServerId, tempStr);
        if(error == KErrNone)
            {
            if(tempStr.Compare(*iDSServerId)== KErrNone)
                {
                //Extended Server Error logging supported, set the the flag
                iIsExtendedServerErrorCodesSupported = ETrue;
                }
            }
        }
	// set sync started to P&S (if fails -> sync not interrupted)
	if ( iProtocolVer == ESmlVersion1_1_2 )
	    {
        RProperty::Set( KPSUidDataSynchronizationInternalKeys,
                        KDataSyncStatus,
                        EDataSyncRunning );	    
	    }
    else // TSmlProtocolVersion::ESmlVersion1_2
        {
        RProperty::Set( KPSUidDataSynchronizationInternalKeys,
                        KDataSyncStatus,
                        EDataSyncRunning12 );	    
        }
    
	if ( iErrorReportingRep )
	    {
        iErrorReportingRep->Set( KNsmlOpDsErrorCode, KErrNone );
        iErrorReportingRep->Set( KNsmlOpDsSyncProfUid, profile->IntValue( EDSProfileId ) );
        iErrorReportingRep->Set( KNsmlOpDsSyncInitiation, iSyncInitiation );
	    }

	TBool ifInternet = ETrue ; // CR: 403-1188
	if ( iMediumType == KUidNSmlMediumTypeInternet )
		{
		iSyncServer = CNSmlURI::NewL( profile->StrValue( EDSProfileServerURL ), ETrue );
		}
	else
		{
		iSyncServer = CNSmlURI::NewL( profile->StrValue( EDSProfileServerURL ), EFalse );
		ifInternet = EFalse ; // CR: 403-1188
		}
			
	if ( !profile->iContentTypes )
		{
		User::Leave( TNSmlError::ESmlErrorInSettings );
		}
	
	RArray<TSmlTaskId> taskIdArray;
	

	TBool isRemotedatabaseDefined(ETrue);
	for ( TInt i = 0; i < profile->iContentTypes->Count(); i++ )	
		{
		TBool addContent( EFalse );
		TBool serverAlert(EFalse);
		CNSmlDbCaps::ENSmlSyncTypes syncType( CNSmlDbCaps::EAllTypes );
        
        if ( iDSSyncTypeArray )
			{
			if ( iDSSyncTypeArray->Count() > 0 )
			    {
			    for ( TInt j = 0; j < iDSSyncTypeArray->Count(); j++ )
                    {
                    if ( (*profile->iContentTypes)[i]->IntValue( EDSAdapterTableId ) == iDSSyncTypeArray->At( j ).iTaskId)
                        {
                        if ( iSyncInitiation == EClientInitiated )
                        	{
                        	if ( (*profile->iContentTypes)[i]->IntValue( EDSAdapterEnabled ) )
                        		{
                             	addContent = ETrue;
                                serverAlert = ETrue;
                                syncType = iDSSyncTypeArray->At( j ).iType;
                        		}
	                       	}
                        else 
                        	{
                        	addContent = ETrue;
                            serverAlert = ETrue;
                            syncType = iDSSyncTypeArray->At( j ).iType;
                        	}
                        
                        break;
                        }
                    }
			    }
            else
    			{
    			addContent = (*profile->iContentTypes)[i]->IntValue( EDSAdapterEnabled );
    			}
			}
		else
			{
			addContent = (*profile->iContentTypes)[i]->IntValue( EDSAdapterEnabled );
			}
			
		if ( addContent )
			{
			iDSContent->AddNewContentL();
			iDSContent->SetImplementationUID( (*profile->iContentTypes)[i]->IntValue( EDSAdapterImplementationId ) );
			
			CNSmlURI* database = CNSmlURI::NewLC( *iImeiCode );				
			database->SetDatabaseL( (*profile->iContentTypes)[i]->StrValue( EDSAdapterClientDataSource ) );
			TRAPD( localDatabaseError, iDSContent->SetLocalDatabaseL( *database ) );
			
			if ((*profile->iContentTypes)[i]->StrValue( EDSAdapterClientDataSource )  != database->DataBaseWithoutRelativePrefix())
				{
				(*profile->iContentTypes)[i]->SetStrValue( EDSAdapterClientDataSource ,database->DataBaseWithoutRelativePrefix());
				profile->SaveL() ;
				}
			CleanupStack::PopAndDestroy(); // database

			if ( localDatabaseError )
			    {
			    DBG_ARGS(_S("CNSmlDSAgent::ReadSettingsL: local database error %d"), localDatabaseError);
			    iDSContent->RemoveContent();
			    /* CR: 403-1188 */
			    if ( ifInternet      == EFalse 		   &&
			    	 iSyncInitiation == EServerAlerted &&
			    	 (*profile->iContentTypes)[i]->IntValue( EDSAdapterImplementationId ) == KUidNSmlAdapterEMail.iUid) 
				    {
				    CNSmlDSContentType* type = profile->ContentType( KUidNSmlAdapterEMail.iUid );
					type->SetIntValue (EDSAdapterEnabled, EFalse) ;				    	
					profile->SaveL() ;
				    } // CR: 403-1188
				continue;
			    }
				 
			database = CNSmlURI::NewLC( iSyncServer->HostNameWithPortL() );
			database->SetDatabaseL( (*profile->iContentTypes)[i]->StrValue( EDSAdapterServerDataSource ) );
			if(database->Database().Length() < 1)
			    {
			    isRemotedatabaseDefined = EFalse;
			    }
			iDSContent->SetRemoteDatabaseL( *database );
			CleanupStack::PopAndDestroy(); //database

			if ( iProtocolVer == ESmlVersion1_1_2 )
				{
				HBufC* hostAddress = iSyncServer->HostName().AllocLC();

				if ( !iDSContent->InitContentInstanceL( *hostAddress ) )
					{
					iDSContent->RemoveContent();
					CleanupStack::PopAndDestroy(); // hostAddress
					continue;
					}
						
				CleanupStack::PopAndDestroy(); // hostAddress
				}
			else if ( iProtocolVer == ESmlVersion1_2 )
				{
				if ( !iDSContent->InitContentInstanceL( *iDSServerId ) )
					{
					iDSContent->RemoveContent();
					continue;
					}
					
			    RReadStream readStream( (*profile->iContentTypes)[i]->FilterReadStreamL() );
			    CleanupClosePushL( readStream );
				    
				TInt numberOfFilters(0);
				TInt error( KErrNone );
				TRAP(error, numberOfFilters = readStream.ReadInt32L() );    
			    
			    RPointerArray<CSyncMLFilter> filters;
			    CleanupStack::PushL( TCleanupItem( DeleteRPointerArray, &filters ) );
			    
                for ( TInt filterIndex = 0; filterIndex < numberOfFilters; filterIndex++ )
                    {
                    CSyncMLFilter* filter = CSyncMLFilter::NewLC( readStream );
                    filters.AppendL( filter );
                    CleanupStack::Pop(); // filter
                    }
                
                iDSContent->SetUsedFiltersL( filters, static_cast<TSyncMLFilterMatchType>( (*profile->iContentTypes)[i]->IntValue( EDSAdapterFilterMatchType ) ) );
				    
                // ownership of array items is moved to iDSContent -> no need for ResetAndDestroy
                filters.Close();
                
                CleanupStack::Pop(); // filters				    
			    CleanupStack::PopAndDestroy(); // readStream
				}

			if ( syncType == CNSmlDbCaps::EAllTypes )
				{
				TSmlSyncType type = static_cast<TSmlSyncType>( (*profile->iContentTypes)[i]->IntValue( EDSAdapterSyncType ) );
					
				switch ( type )
					{
					case ESmlTwoWay:
						syncType = CNSmlDbCaps::ETwoWaySync;
						break;
							
					case ESmlOneWayFromServer:
						syncType = CNSmlDbCaps::EOneWaySyncFromServer;
						break;
							
					case ESmlOneWayFromClient:
						syncType = CNSmlDbCaps::EOneWaySyncFromClient;
						break;
							
					case ESmlSlowSync:
						syncType = CNSmlDbCaps::ESlowTwoWaySync;
						break;
							
					case ESmlRefreshFromServer:
						syncType = CNSmlDbCaps::ERefreshSyncFromServer;
						break;
							
					case ESmlRefreshFromClient:
						syncType = CNSmlDbCaps::ERefreshSyncFromClient;
						break;
							
					default:
						User::Panic( _L("Sync type conversion error" ), type );
					}
				}
				
			if ( syncType != CNSmlDbCaps::ESyncTypeNone )
				{
				iDSContent->SetSyncTypeL( syncType );
				taskIdArray.Append( (*profile->iContentTypes)[i]->IntValue( EDSAdapterTableId ) );
				iDSContent->TaskId( (*profile->iContentTypes)[i]->IntValue( EDSAdapterTableId ) );
				
				if ( serverAlert && iProtocolVer == ESmlVersion1_2 )
					{
					iDSContent->SetAsServerAlerted();
					}
				}
			else
				{
				iDSContent->RemoveContent();
				}
			}
		}
	
	iSyncLog = CSyncMLHistoryJob::NewL( iProfileID, taskIdArray );

	if ( iDSContent->Count() == 0 && iSyncInitiation == EClientInitiated )
		{
		User::Leave( TNSmlError::ESmlErrorInSettings );
		}
		// BPSS-7NZESW : If remote database value is empty,leave
		//erorr log : Invalid remote database
	if(!isRemotedatabaseDefined)
	    {
	    User::Leave( TNSmlError::ESmlStatusNotFound );
	    }
	taskIdArray.Close();	
	CleanupStack::PopAndDestroy( 2 ); // profile, settings
	DBG_FILE(_S8("CNSmlDSAgent::ReadSettingsL END"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::ReplaceIAPIdL()
// Gets IAPID from the Cenrep and if necessary will Replace 
// the existing one
// ---------------------------------------------------------
void CNSmlDSAgent::ReplaceIAPIdL()
{
	//Check whether the Auto Restart Feature is enabled or not
	TInt keyVal;
	TRAPD (err ,ReadRepositoryL(KNsmlDsAutoRestart, keyVal));
	
	if(err==KErrNone && keyVal==1)
	{
		TInt LastUsedIAPId = 0;
		
		CNsmlProfileUtil* profileUtil = CNsmlProfileUtil::NewLC();	
				
		if(iAutoRestartInitiatedSync)
		{
			//Read the IAPID from the Cenrep
			profileUtil->AccessPointIdL(LastUsedIAPId);
			if(LastUsedIAPId > 0)
			{
				//Check Whether the IAPID still exists
		    	TApBearerType bearertype = CheckAPBearerTypeL(LastUsedIAPId);
		    	if(bearertype != TApBearerType(-1))
		    	{
		    		iIAPId = LastUsedIAPId;    	
		    		DBG_FILE_CODE(iIAPId , _S8("CNSmlDSAgent::ReadSettingsL, The Access Point ID Replaced from the CenRep:"));                
		    	}
		    	else
		    	{
		    		//Stop the DS Sync Session
		    		DBG_FILE(_S8("CNSmlDSAgent::ReadSettingsL, The Access Point ID is invalid so stopping the session"));
		    		iPacketDataUnAvailable = ETrue;
		    		StopDSSession();
		    	}	
			}
		}
		
		CleanupStack::PopAndDestroy(profileUtil);
	}
}

// ---------------------------------------------------------
// CNSmlDSAgent::GetSessionIDL()
// Gets SessionID from Agent Log
// ---------------------------------------------------------
TInt CNSmlDSAgent::GetSessionIDL()
	{
	CNSmlDSAgentLog* agentLog( CNSmlDSAgentLog::NewLC() );
	TInt sessionID( 0 );

	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey = iSyncServer->HostName().AllocLC();
		sessionID = agentLog->SessionIDL( *searchKey );
		CleanupStack::PopAndDestroy(); // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		sessionID = agentLog->SessionIDL( *iDSServerId );
		}

	CleanupStack::PopAndDestroy(); // agentLog

	return sessionID;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::UpdateSessionIDL()
// Updates SessionID in Agent Log
// ---------------------------------------------------------
void CNSmlDSAgent::UpdateSessionIDL( TInt aSessionID )
	{
	CNSmlDSAgentLog* agentLog( CNSmlDSAgentLog::NewLC() );

	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey = iSyncServer->HostName().AllocLC();
		agentLog->SetSessionIDL( *searchKey, aSessionID );
		CleanupStack::PopAndDestroy(); // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		agentLog->SetSessionIDL( *iDSServerId, aSessionID );
		}

	CleanupStack::PopAndDestroy(); // agentLog
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::FinishL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::FinishL()
	{
	iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlDisconnected, 0, 0 );
		
	if ( iDSContent->AllDatabasesAreInterrupted() )
		{
		DoErrorEvent( MSyncMLProgressObserver::ESmlFatalError, iError->SyncLogErrorCode(), 0, 0, 0 );
		User::RequestComplete( iCallerStatus, iError->SyncLogErrorCode() );
		}
	else if ( iDSContent->AnyDatabaseIsInterrupted()  )
		{
		DoErrorEvent( MSyncMLProgressObserver::ESmlWarning, iError->SyncLogErrorCode(), 0, 0, 0 );
		iError->SetErrorCode( KErrNone );
		User::RequestComplete( iCallerStatus, KErrNone );
		}	
	//RD_AUTO_RESTART (BPSS-7GBGHP)
	else if(iPacketDataUnAvailable)
	{
		DBG_FILE(_S8("CNSmlDSAgent::FinishL(), Setting the Dialog Text"));
		
		DoErrorEvent(MSyncMLProgressObserver::ESmlFatalError,
					 TNSmlError::ESmlCommunicationError, 0, 0, 0 );
		iError->SetErrorCode( TNSmlError::ESmlCommunicationError);
		User::RequestComplete( iCallerStatus, TNSmlError::ESmlCommunicationError );
	}
	//RD_AUTO_RESTART		
	else
		{
		User::RequestComplete( iCallerStatus, KErrNone );
		}
		
	iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlCompleted, 0, 0 );
	
	iEnd = ETrue;
	}

// ---------------------------------------------------------
// CNSmlDSAgent::DoCancel
// Cancels ongoing asynchronous operations.
// ---------------------------------------------------------
void CNSmlDSAgent::DoCancel()
	{
	if ( iCommandIssued )
		{
		TInt err( KErrNone );
		TRAP( err, iDSContent->CancelRequestL() );
		}
	CNSmlAgentBase::DoCancel();
	}

//
// Callback functions implementation
//
// ---------------------------------------------------------
// CNSmlDSAgent::smlAlertCmdFuncL
// Alert command from server.  
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlAlertCmdFuncL( SmlAlertPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	
	if ( iSyncMLCmds->AlertCode( aContent ) < KNSmlDSMeaningfulAlertMin ||
		 iSyncMLCmds->AlertCode( aContent ) > KNSmlDSMeaningfulAlertMax )
		{
		iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentAlert, aContent->cmdID, aContent->flags );
		}
	else
		{
		switch ( iCurrMainState )
			{
			case EBeginning:
				ServerAlertAlertCmdStateL( aContent );
				break;
				
			case EServerInitialisation:
				ServerInitAlertCmdStateL( aContent );
				break;
				
			case EServerAlertNext:
				ServerAlertNextAlertCmdStateL( aContent );
				break;
				
			case EServerModifications:
				ServerModAlertCmdStateL( aContent );
				break;
				
			case EMapAcknowledge:
				MapAckAlertCmdStateL( aContent );
				break;
				
			default: 
				iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentAlert, aContent->cmdID, aContent->flags );
			}
		}
		
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlGetCmdFuncL
// Get command from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlGetCmdFuncL( SmlGetPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerInitialisation:
			ServerInitGetCmdStateL( aContent );
			break;
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentGet, aContent->cmdID, aContent->flags );
		}
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlPutCmdFuncL
// Put command from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlPutCmdFuncL( SmlPutPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerInitialisation:
			ServerInitPutCmdStateL( aContent );
			break;
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentPut, aContent->cmdID, aContent->flags );
		}
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlResultsCmdFuncL
// Results command from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlResultsCmdFuncL( SmlResultsPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerInitialisation:
			ServerInitResultsCmdStateL( aContent );
			break;
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentResults, aContent->cmdID );
		}
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlStatusCmdFuncL
// Status command from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlStatusCmdFuncL( SmlStatusPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerInitialisation:
			ServerInitStatusCmdStateL( aContent );
			break;
		case EServerModifications:
			ServerModStatusCmdStateL( aContent );
			break;
		case EMapAcknowledge:
			MapAckStatusCmdStateL( aContent );
			break;
		case EServerAlertNext:
			ServerAlertNextStatusCmdStateL( aContent );
			break;
		default:
			User::Leave( TNSmlError::ESmlUnexpectedCmd );
		}
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlStartMessageFuncL
// SyncHdr from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlStartMessageFuncL( SmlSyncHdrPtr_t aContent )
	{
	iCallbackCalled = ETrue;
	
	switch ( iCurrMainState )
		{
		case EBeginning:
			ServerAlertStartMessageStateL( aContent );
			break;
			
		case EServerInitialisation:
			ServerInitStartMessageStateL( aContent );
			break;
			
		case EServerModifications:
			ServerModStartMessageStateL( aContent );
			break;
			
		case EMapAcknowledge:
			MapAckStartMessageStateL( aContent );
			break;
			
		case EServerAlertNext:
			ServerAlertNextStartMessageStateL( aContent );
			break;
			
		default:
			User::Leave( TNSmlError::ESmlUnexpectedCmd );
		}
		
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlEndMessageFuncL
// End of SyncML message was reached
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlEndMessageFuncL( Boolean_t aFinal )
	{
	iCallbackCalled = ETrue;
	
	switch ( iCurrMainState )
		{
		case EBeginning:
			ServerAlertEndMessageStateL( aFinal );
			break;
			
		case EServerInitialisation:
			ServerInitEndMessageStateL( aFinal );
			break;
			
		case EServerModifications:
			ServerModEndMessageStateL( aFinal );
			break;
			
		case EMapAcknowledge:
			MapAckEndMessageStateL( aFinal );
			break;
			
		case EServerAlertNext:
			ServerAlertNextEndMessageStateL( aFinal );
			break;
			
		default:
			User::Leave( TNSmlError::ESmlUnexpectedCmd );
		}
		
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlStartSyncFuncL
// Sync command from server
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlStartSyncFuncL( SmlSyncPtr_t aContent )
	{
	iCallbackCalled = ETrue;

	switch ( iCurrMainState )
		{
		case EServerModifications:
			ServerModStartSyncStateL( aContent );
			break;
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentSync, aContent->cmdID, aContent->flags );
		}
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlEndSyncFuncL
// End of Sync command was reached
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlEndSyncFuncL()
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerModifications:
			ServerModEndSyncStateL();
			break;
		default:
			break;
		}
	return 0;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::smlStartAtomicFuncL
// Atomic command from server.
// -----------------------------------------------------------------------------
//
Ret_t CNSmlDSAgent::smlStartAtomicFuncL( SmlAtomicPtr_t aContent )
	{
	iCallbackCalled = ETrue;

	switch ( iCurrMainState )
		{
		case EServerModifications:
			ServerModStartAtomicStateL( aContent );
			break;
			
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( EFalse, KNSmlAgentAtomic, aContent->cmdID, aContent->flags );
			break;
		}

	return 0;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::smlEndAtomicFuncL
// The end of the Atomic command was reached.
// -----------------------------------------------------------------------------
//
Ret_t CNSmlDSAgent::smlEndAtomicFuncL()
	{
	iCallbackCalled = ETrue;

	ServerModEndAtomicStateL();
	
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlStartSequenceFuncL
// Sequence command from server, Sequence is not supported
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlStartSequenceFuncL( SmlSequencePtr_t aContent )
	{
	iCallbackCalled = ETrue;
	iSyncMLCmds->StatusToUnsupportedCommandL( EFalse, KNSmlAgentSequence, aContent->cmdID, aContent->flags );
	return 0;
	}
	
// ---------------------------------------------------------
// CNSmlDSAgent::smlEndSequenceFuncL
// 
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlEndSequenceFuncL()
	{
	iCallbackCalled = ETrue;
	return 0;
	}


// ---------------------------------------------------------
// CNSmlDSAgent::smlMoveCmdFuncL
// 
// ---------------------------------------------------------
Ret_t CNSmlDSAgent::smlMoveCmdFuncL( SmlMovePtr_t aContent )
	{
	iCallbackCalled = ETrue;
	switch ( iCurrMainState )
		{
		case EServerModifications:
			ServerModUpdatesStateL( KNSmlAgentMove(), aContent );
			break;
		default:
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, KNSmlAgentAdd, aContent->cmdID, aContent->flags );
		}
	return 0;
	}

// ---------------------------------------------------------
// CNSmlDSAgent::NavigateMainStateL()
// Navigate according to state code
// ---------------------------------------------------------
void CNSmlDSAgent::NavigateMainStateL() 
    {
    switch ( iCurrMainState )
		{
		case EBeginning:
			BeginningStateL();
			break;
		case EClientInitialisation:
			ClientInitialisationStateL();
			break;
		case EServerInitialisation:
			ServerInitialisationStateL();
			break;
// <MAPINFO_RESEND_MOD_BEGIN>
		case EClientResendMapInfo:
			ClientResendMapInfoStateL();
			break;
// <MAPINFO_RESEND_MOD_END>
		case EClientModifications:
			ClientModificationsStateL();
			break;
		case EServerModifications:
			ServerModificationsStateL();
			break;
		case EDataUpdateStatus:
			DataUpdateStatusStateL();
			break;
		case EMapAcknowledge:
			MapAcknowledgeStateL();
			break;
		case EResultAlert:
			ResultAlertStateL();
			break;
		case EClientAlertNext:
			ClientAlertNextStateL();
			break;
		case EServerAlertNext:
			ServerAlertNextStateL();
			break;
		case EFinishing:
			FinishingStateL();
			break;
		case ESending:
			SendingStateL();
			break;
		case EReceiving:
			ReceivingStateL();
			break;
		default:
			User::Leave( KErrGeneral );
		}
    }

// ---------------------------------------------------------
// CNSmlDSAgent::NextMainStateL()
// Change main state
// ---------------------------------------------------------
void CNSmlDSAgent::NextMainStateL() 
	{
	switch ( iCurrMainState )
		{
		case EBeginning:
			if ( iSyncInitiation == EClientInitiated && iDSContent->AllDatabasesAreInterruptedImmediately() )
				{
				iCurrMainState = EFinishing;
				} 
			else
				{
				iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlConnected, 0, 0 );
				iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlLoggingOn, 0, 0 );
				iCurrMainState = EClientInitialisation;
				}
			break;
			
		case EClientInitialisation:
			iPrevSyncState = iCurrMainState;
			iCurrMainState = ESending;
			break;
			
		case EServerInitialisation:
			iPrevSyncState = iCurrMainState;
			if ( iDSContent->AllDatabasesAreInterruptedImmediately() )
				{
				iCurrMainState = EFinishing;
				}
			else
				{
				if ( iBusyStatusReceived )
					{
					iCurrMainState = EResultAlert;
					}
				else
					{
					if ( iChallengeRequest )
						{
						iCurrMainState = EClientInitialisation;
						}
					else
						{
						if ( iDSCurrServerInitState == EServerInitMessageReceived )
							{
							iCurrMainState = EClientAlertNext;
							}
						else
							{
							iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlLoggedOn, 0, 0 );
// <MAPINFO_RESEND_MOD_BEGIN>
							iCurrMainState = EClientResendMapInfo;
							DBG_FILE(_S8("CNSmlDSAgent::NextMainStateL Moved to EClientResendMapInfo..."));
							// iCurrMainState = EClientModifications;
// <MAPINFO_RESEND_MOD_END>
							}
						}
					}
				}
			break;
// <MAPINFO_RESEND_MOD_BEGIN>
		case EClientResendMapInfo:
			iPrevSyncState = iCurrMainState;
			if(iMapResendStatusPackage)
				{
				iCurrMainState = ESending;
				}
			else
				{
				iCurrMainState = EClientModifications;
				}
			break;
// <MAPINFO_RESEND_MOD_END>	
		case EClientModifications:
			iPrevSyncState = iCurrMainState;
			iCurrMainState = ESending;
			break;
			
		case EServerModifications:
			iPrevSyncState = iCurrMainState;
			if ( iDSContent->AllDatabasesAreInterruptedImmediately() )
				{
				iCurrMainState = EFinishing;
				}
			else
				{
				if ( iBusyStatusReceived )
					{
					iCurrMainState = EResultAlert;
					}
				else
					{
					if ( iCurrServerModState == EServerModMessageReceived )
						{
						iCurrMainState = EClientAlertNext;
						}
					else
						{
						iCurrMainState = EDataUpdateStatus;
						iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlSendingMappingsToServer, 0, 0 );
						}
					}
				}
			break;
			
		case EDataUpdateStatus:
			iPrevSyncState = iCurrMainState;
			if ( iStatusPackage  && ( !iDSContent->AllDatabasesOneWayFromClient() ) )
				{
				iCurrMainState = ESending;
				}
			else
				{
				iCurrMainState = EFinishing;
				}
			break;
			
		case EMapAcknowledge:
// <MAPINFO_RESEND_MOD_BEGIN>
			if(iPrevSyncState==EClientResendMapInfo)
				{
				iCurrMainState = EClientModifications;
				// If map exitst remove map info, think to implement.
				iDSContent->CleanMapInfo();
				}
			else
				{
// <MAPINFO_RESEND_MOD_END>
			iPrevSyncState = iCurrMainState;
			if ( iDSContent->AllDatabasesAreInterruptedImmediately() )
				{
				iCurrMainState = EFinishing;
				}
			else
				{
				if ( iBusyStatusReceived )
					{
					iCurrMainState = EResultAlert;
					}
				else
					{
					if ( iDSCurrMapAcknowledgeState == EMapAckMessageReceived )
						{	
						iCurrMainState = EClientAlertNext;
						}
					else
						{
						iCurrMainState = EFinishing;
						}
					}
				}
// <MAPINFO_RESEND_MOD_BEGIN>
				}
// <MAPINFO_RESEND_MOD_END>
			break;
			
		case EResultAlert:
			iCurrMainState = ESending;
			break;
			
		case EClientAlertNext:
			iCurrMainState = ESending;
			break;
			
		case EServerAlertNext:
			if ( iDSContent->AllDatabasesAreInterruptedImmediately() )
				{
				iCurrMainState = EFinishing;
				}
			else
				{
				iCurrMainState = iPrevSyncState;
				}
			break;
			
		case ESending:
			if ( iDSContent->AllDatabasesAreInterrupted() ) 
				{
				iCurrMainState = EFinishing;
				}
			else
				{
				iCurrMainState = EReceiving;
				}
			break;
			
		case EReceiving:
			if ( ( !iFinalMessageFromClient ) &&
				 ( iPrevSyncState == EClientModifications || iPrevSyncState == EDataUpdateStatus ) )
				{
				iCurrMainState = EServerAlertNext;
				}
			else
			if ( iPrevSyncState == EClientInitialisation || iPrevSyncState == EServerInitialisation )
				{
				iCurrMainState = EServerInitialisation;
				}
			else
			if ( iPrevSyncState == EClientModifications || iPrevSyncState == EServerModifications )
				{
				iCurrMainState = EServerModifications;
				}	
			else
				{
				iCurrMainState = EMapAcknowledge;
				};
				
			iDSContent->UpdateInterruptedFlags();
			break;
			
		default:
			break;
		}
		
	InitialiseSubStates();
	}

// ---------------------------------------------------------
// CNSmlDSAgent::InitialiseSubStates()
// 
// ---------------------------------------------------------
//
void CNSmlDSAgent::InitialiseSubStates()
	{
	iCurrBeginningState = EBegin;
	iDSCurrBeginSubState = EBeginSubStart;
	iCurrClientInitState = EInitStartingMessage;
	iDSCurrServerInitState = EServerInitWaitingStartMessage;
	iDSCurrClientModState = EClientModStartingMessage;
	iCurrResultAlertState = EResultAlertStartingMessage;
	iCurrServerModState = EServerModWaitingStartMessage;
	iCurrDataUpdateStatusState = EStatusStartingMessage;
	iDSCurrMapAcknowledgeState = EMapAckWaitingStartMessage;
	iCurrResultAlertState = EResultAlertStartingMessage;
	iCurrClientAlertNextState = EClientAlertNextStartingMessage;
	iCurrServerAlertNextState = EServerAlertNextWaitingStartMessage;
	}
	
//
// Beginning state functions 
//
//
// ---------------------------------------------------------
// CNSmlDSAgent::BeginStateL()
// 
// ---------------------------------------------------------
void CNSmlDSAgent::BeginStateL() 
	{
	switch ( iDSCurrBeginSubState )
		{
		case EBeginSubStart:
			BeginSubStartStateL();
			break;
		case EBeginSubReadSettings:
			BeginSubReadSettingsStateL();
			break;
		case EBeginSubSyncmlCmdsInstance:
			BeginSubSyncmlCmdsInstanceStateL();
			break;
		case EBeginSubServerAlerting:
			BeginSubServerAlertingStateL();
			break;
		case EBeginSubOpenContentInstances:
			BeginSubOpenContentInstancesStateL();
			break;
// <MAPINFO_RESEND_MOD_BEGIN>
		case EBeginSubScanMapInfo:
			BeginSubScanMapInfo();
			break;
// <MAPINFO_RESEND_MOD_END>
		case EBeginSubCreateLUIDBuffers:
			BeginSubCreateLUIDBuffersStateL();
			break;
		default:
			User::Leave( KErrGeneral );
		}
	}

//
//  Server Modifications state functions 
//
// ---------------------------------------------------------
// CNSmlDSAgent::ServerModUpdatesStateL(()
// Handles Add, Replace or Delete command from server 
// ---------------------------------------------------------
void CNSmlDSAgent::ServerModUpdatesStateL( const TDesC8& aCmd, SmlGenericCmd_t* aContent )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ServerModUpdatesStateL begins"));
	if ( iCurrServerModState != EServerModWaitingUpdateCommands )
		{
		iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, aCmd, aContent->cmdID, aContent->flags );
		}
	if ( iDSContent->ContentIndexIsSet() )
		{
		if ( iDSContent->SyncType() == KNSmlDSOneWayFromClient ||
			 iDSContent->SyncType() == KNSmlDSOneWayFromClientByServer ||
			 iDSContent->SyncType() == KNSmlDSRefreshFromClient ||
			 iDSContent->SyncType() == KNSmlDSRefreshFromClientByServer )
			{
			iSyncMLCmds->StatusToUnsupportedCommandL( ETrue, aCmd, aContent->cmdID, aContent->flags );
			}
		else
			{
			iSyncMLCmds->ProcessUpdatesL( aCmd, aContent );
			}
		}
	else
		{
		iSyncMLCmds->ProcessUpdatesL( aCmd, aContent );
		}
	DBG_FILE(_S8("CNSmlDSAgent::ServerModUpdatesStateL ends"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::DataUpdateStatusStartingMessageStateL()
// Notify "Finalising" to UI, makes SyncHdr 
// ---------------------------------------------------------
void CNSmlDSAgent::DataUpdateStatusStartingMessageStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::DataUpdateStatusStartingMessageStateL begins"));
	DataUpdateStatusStartingMessageStateBaseL();
	iDSContent->SetToFirst();
	DBG_FILE(_S8("CNSmlDSAgent::DataUpdateStatusStartingMessageStateL ends"));
	}

// ---------------------------------------------------------
// CNSmlDSAgent::DataUpdateStatusMakingMapStateL()
// Makes Map command(s)
// ---------------------------------------------------------
void CNSmlDSAgent::DataUpdateStatusMakingMapStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::DataUpdateStatusMakingMapStateL begins"));
	CNSmlCmdsBase::TReturnValue ret;
	ret = iSyncMLCmds->DoMapL();
	switch ( ret )
		{
		case CNSmlCmdsBase::EReturnOK:
			iDSWaitingForMapAcknowledgement = ETrue;
			// there is something to send
			iStatusPackage = ETrue;
			if ( !iDSContent->SetToNext() )
				{
				iCurrDataUpdateStatusState = EStatusEndingMessage;
				}
			break;
		case CNSmlCmdsBase::EReturnEndData:
			if ( !iDSContent->SetToNext() )
				{
				iCurrDataUpdateStatusState = EStatusEndingMessage;
				}
			break;
		case CNSmlCmdsBase::EReturnBufferFull:
			iBufferFull = ETrue;
			iCurrDataUpdateStatusState = EStatusEndingMessage;
			break;
		default:
			break;
		}
	DBG_FILE(_S8("CNSmlDSAgent::DataUpdateStatusMakingMapStateL ends"));
	}

//
// Alert for next state functions 
//

// -----------------------------------------------------------------------------
// CNSmlDSAgent::ClientAlertNextMakingMapStateL
// Makes Map command(s).
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::ClientAlertNextMakingMapStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientAlertNextMakingMapStateL begins"));
	
	iDSContent->SetToFirst();
	
	do
		{
		if ( iSyncMLCmds->DoMapL() == CNSmlCmdsBase::EReturnBufferFull )
			{
			break;
			}
		}
	while ( iDSContent->SetToNext() ); 
	
	iCurrClientAlertNextState = EClientAlertNextEndingMessage;
	
	DBG_FILE(_S8("CNSmlDSAgent::ClientAlertNextMakingMapStateL ends"));
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::NonceL
// Nonce (used in MD5 auth) from Agent Log 
// -----------------------------------------------------------------------------
//
HBufC* CNSmlDSAgent::NonceL() const
	{
	CNSmlDSAgentLog* agentLog = CNSmlDSAgentLog::NewLC();
	HBufC* nonce( NULL );
	
	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey( iSyncServer->HostName().AllocLC() );
		nonce = agentLog->NonceL( *searchKey );
		CleanupStack::PopAndDestroy();  // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		nonce = agentLog->NonceL( *iDSServerId );
		}

	CleanupStack::PopAndDestroy(); // agentLog

	return nonce;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::SetNonceL
// Nonce from the server's challenge is stored to the Agent Log.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::SetNonceL( const TDesC& aNonce ) const
	{
	CNSmlDSAgentLog* agentLog = CNSmlDSAgentLog::NewLC();

	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey( iSyncServer->HostName().AllocLC() );
		agentLog->SetNonceL( *searchKey, aNonce );
		CleanupStack::PopAndDestroy();  // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		agentLog->SetNonceL( *iDSServerId, aNonce );
		}

	CleanupStack::PopAndDestroy(); // agentLog
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::FinalizeSyncLog
// Writes the sync history after synchronisation.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::FinalizeSyncLog()
	{
	TInt err( KErrNone );
	TRAP( err, FinalizeSyncLogL() );
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::FinalizeSyncLogL
// Writes the sync history after synchronisation.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::FinalizeSyncLogL()
	{
	if ( iSyncLog )
		{
		iDSContent->FinalizeSyncLogEvents();
	
		TTime time;
		time.UniversalTime();
		if (iError)  
		iSyncLog->SetResult( time, iError->SyncLogErrorCode() );
		else
		iSyncLog->SetResult( time, KErrGeneral );    
	
		CNSmlDSSettings* settings = CNSmlDSSettings::NewLC();
		CNSmlDSProfile* profile = settings->ProfileL( iProfileID );
		CleanupStack::PushL( profile );
		CNSmlHistoryArray* array = CNSmlHistoryArray::NewL();
		CleanupStack::PushL( array );
		array->SetOwnerShip( ETrue );
	
		RReadStream& readStream = profile->LogReadStreamL();
		CleanupClosePushL( readStream );
		
		if ( readStream.Source()->SizeL() > 0 )
			{
			array->InternalizeL( readStream );
			}
			
		CleanupStack::PopAndDestroy(); // readStream
	
		array->AppendEntryL( iSyncLog );
		RWriteStream& writeStream = profile->LogWriteStreamL();
		CleanupClosePushL( writeStream );
		array->ExternalizeL( writeStream );
		CleanupStack::PopAndDestroy(); // writeStream
		profile->WriteStreamCommitL();
	
		CleanupStack::PopAndDestroy( 3 ); // array, settings, profile
		
		iSyncLog = NULL;
		}
    
    // Set sync stopped to P&S
    RProperty::Set( KPSUidDataSynchronizationInternalKeys, KDataSyncStatus, EDataSyncNotRunning );
  
    if ( iErrorReportingRep )
        {
        iErrorReportingRep->Set( KNsmlOpDsSyncInitiation, EDataSyncNotRunning );
        }
	
	ResetDSSessionInfoL();
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::WriteWarningL
// Sync level warning message to the Sync Log.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::WriteWarningL( TNSmlError::TNSmlAgentErrorCode aWarningCode )
	{
	iDSContent->SetToFirst();
	
	do
		{
		InfoMessageToSyncLogL( iDSContent->CurrentIndex(), aWarningCode );
		iDSContent->IncreaseWarnings();
		}
	while ( iDSContent->SetToNext() );	
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::WriteWarningL
// Datastore level warning message to the Sync Log.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::WriteWarningL( TInt appIndex, TNSmlError::TNSmlAgentErrorCode aWarningCode )
	{
	InfoMessageToSyncLogL( appIndex, aWarningCode );
	iDSContent->SetIndex( appIndex );
	iDSContent->IncreaseWarnings();
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::WriteWarningL
// Datastore level warning message to the Sync Log.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::WriteWarningL( TInt appIndex, TNSmlError::TNSmlSyncMLStatusCode aWarningCode )
	{
	InfoMessageToSyncLogL( appIndex, aWarningCode );
	iDSContent->SetIndex( appIndex );
	iDSContent->IncreaseWarnings();
	}

// ---------------------------------------------------------
// CNSmlDSAgent::CheckServerStatusCodeL()
// Status code validating
// ---------------------------------------------------------
void CNSmlDSAgent::CheckServerStatusCodeL( TInt aEntryID )
	{
	TDesC8& cmd = iSyncMLCmds->ResponseController()->Cmd( aEntryID );
	TNSmlError::TNSmlSyncMLStatusCode status = STATIC_CAST( TNSmlError::TNSmlSyncMLStatusCode, iSyncMLCmds->ResponseController()->StatusCode( aEntryID ) );
	TBool error( EFalse );
	if(iIsExtendedServerErrorCodesSupported)
	    {
	    StoreServerStatusCode(status);
	    }
	switch ( status )
		{
		case TNSmlError::ESmlStatusInProgress:
			if ( cmd != KNSmlAgentSyncHdr )
				{
				error = ETrue;
				}
			break;
			
		case TNSmlError::ESmlStatusOK: 
		case TNSmlError::ESmlStatusItemAdded:
		case TNSmlError::ESmlStatusAcceptedForProcessing:
		case TNSmlError::ESmlStatusNonAuthoriveResponse:
		case TNSmlError::ESmlStatusNoContent:
		case TNSmlError::ESmlStatusResetContent:
		case TNSmlError::ESmlStatusConflictResolvedWithMerge:
		case TNSmlError::ESmlStatusConflictResolvedWithClientsCommand:
		case TNSmlError::ESmlStatusConflictResolvedWithDuplicate:
		case TNSmlError::ESmlStatusConflict:
		case TNSmlError::ESmlStatusConflictResolvedWithServerData:
		case TNSmlError::ESmlStatusSoftDeleteUpdateConflict:
		case TNSmlError::ESmlStatusDeleteWithoutArchive:
		case TNSmlError::ESmlStatusItemIsNotDeleted:
		case TNSmlError::ESmlStatusItemAccepted:
		case TNSmlError::ESmlStatusAlreadyExists:
			break;
			
		case TNSmlError::ESmlStatusAuthenticationAccepted: // 212
			if ( cmd == KNSmlAgentSyncHdr ) 
				{ 
				iAlreadyAuthenticated = ETrue;
				}
			break;
			
		case  TNSmlError::ESmlStatusUnauthorized: // 401
			if ( cmd == KNSmlAgentSyncHdr && iCurrMainState == EServerInitialisation ) 
				{
				if ( iSyncMLCmds->ResponseController()->ChalType( aEntryID ).Length() != 0 )
					{
					if ( AuthenticationRequirementL( *iSyncMLCmds->ResponseController(), aEntryID ) )
						{
						iChallengeRequest = ETrue;
						SaveIfNonceL( *iSyncMLCmds->ResponseController(), aEntryID );
						iSyncMLCmds->ResponseController()->ResetL();
						return;
						}
					else
						{
						// If authentication has failed then rest of the package is not
					    // important anymore.
						User::Leave( status );
						}
					}
				else
					{
					// If authentication has failed then rest of the package is not
					// important anymore.
					User::Leave( status );
					}
				}
			break;
			
		case  TNSmlError::ESmlStatusClientAuthenticationRequired: // 407 
			if ( cmd == KNSmlAgentSyncHdr && iCurrMainState == EServerInitialisation ) 
				{
				if ( AuthenticationRequirementL( *iSyncMLCmds->ResponseController(), aEntryID ) )
					{
					iChallengeRequest = ETrue;
					SaveIfNonceL( *iSyncMLCmds->ResponseController(), aEntryID );
					iSyncMLCmds->ResponseController()->ResetL();
					return;
					}
				}
			error = ETrue;
			break;
			
		case TNSmlError::ESmlStatusRefreshRequired:
			if ( cmd == KNSmlAgentSync )
				{
				TInt appIndex( -1 );
				appIndex = iSyncMLCmds->ResponseController()->AppIndex( aEntryID );
				iDSContent->SetIndex( appIndex );
				iDSContent->SetSlowSyncReqForNextSyncL( ETrue ); 
				}
			//RD_SUSPEND_RESUME
		    if(iDSContent->SetToFirst())
		    {
		       do
		       {
		       	if ( iDSContent->GetSessionResumed() )
			    {
			      if(cmd==KNSmlAgentAlert)
			      {
			  		iDSContent->SetRefreshRequiredL(ETrue);
			  	  }
			     }
		       }while( iDSContent->SetToNext() );
		       	
			}	
			//RD_SUSPEND_RESUME	
			break;
			
		default:
			error = ETrue;
		}
		
    // Store status code to cenrep in case of error
    if ( error && iErrorReportingRep
         && (  status >= KNSmlDsErrCodeFirst && status <= KNSmlDsErrCodeLast ) )
        {
        iErrorReportingRep->Set( KNsmlOpDsErrorCode, status );
        }
        
	if ( cmd == KNSmlAgentSyncHdr )
		{
		SaveIfNonceL( *iSyncMLCmds->ResponseController(), aEntryID );
		}
		
	if ( cmd == KNSmlAgentAlert )
		{
		if ( iSyncMLCmds->ResponseController()->ResponseDetail( aEntryID ) == CNSmlResponseController::EResponseInitAlert )
			{ 
			if ( status == TNSmlError::ESmlStatusOptFeatureNotSupported )
				{
				status = (TNSmlError::TNSmlSyncMLStatusCode) TNSmlDSError::ESmlDSUnsupportedSyncType;
				}
			else
				{
				if ( status == TNSmlError::ESmlStatusCommandFailed ||
					 status == TNSmlError::ESmlStatusCommandNotAllowed ) 
					{
					iDSContent->SetIndex( iSyncMLCmds->ResponseController()->AppIndex ( aEntryID ) );
					if ( !iDSContent->IsSupportedSyncTypeByServerL() )
						{
						status = (TNSmlError::TNSmlSyncMLStatusCode) TNSmlDSError::ESmlDSUnsupportedSyncType;
						}
					else
						{
						if ( status == TNSmlError::ESmlStatusCommandFailed )
							{
							status = TNSmlError::ESmlStatusNotFound;
							}
						}
					}
				}
			}
		}
		
	if ( cmd == KNSmlAgentAdd || cmd == KNSmlAgentReplace || cmd == KNSmlAgentPartialReplace || cmd == KNSmlAgentDelete || cmd == KNSmlAgentMove || cmd == KNSmlAgentSoftDelete )
		{
		if ( !iSyncMLCmds->ResponseController()->MoreData( aEntryID ) )
			{
			iDSContent->SetIndex( iSyncMLCmds->ResponseController()->AppIndex ( aEntryID ) );
			TLex8 lex( iSyncMLCmds->ResponseController()->LUID( aEntryID ) );
			TInt val;
			lex.Val( val );
			iDSContent->SetAsReceivedL( val );
			}
		}
		
	if ( !error ) 
		{
		if ( cmd == KNSmlAgentAdd || cmd == KNSmlAgentReplace || cmd == KNSmlAgentPartialReplace )
			{
			if ( status == TNSmlError::ESmlStatusItemAdded )
				{
				iDSContent->IncreaseItemsAdded();
				}
			else
				{
				if ( status != TNSmlError::ESmlStatusItemAccepted )
					{
					iDSContent->IncreaseItemsChanged();
					}
				}
			}
			
		if ( cmd == KNSmlAgentDelete || cmd == KNSmlAgentSoftDelete ) 
			{
			if ( status != TNSmlError::ESmlStatusItemIsNotDeleted )
				{
				iDSContent->IncreaseItemsDeleted();
				}
			}
			
		if (cmd == KNSmlAgentMove)
			{
			if ( status == TNSmlError::ESmlStatusOK  )
				{
				iDSContent->IncreaseItemsMoved();
				}
			}
		}
	else
		{
		if ( cmd == KNSmlAgentAdd || cmd == KNSmlAgentReplace || cmd == KNSmlAgentPartialReplace || cmd == KNSmlAgentDelete || cmd == KNSmlAgentMove || cmd == KNSmlAgentSoftDelete )
			{
			iDSContent->IncreaseItemsFailed();
			}
		else
			{
			InterruptL( iSyncMLCmds->ResponseController()->AppIndex( aEntryID ), status, ETrue, ETrue );
			}
		}
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::CheckCommandsAreReceivedL
// Checks that server has sent all expected commands.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::CheckCommandsAreReceivedL()
	{
	if ( iDSDeviceInfoRequestByClient )
		{
		Interrupt( TNSmlDSError::ESmlDSDeviceInfoMissing, ETrue, EFalse );
		}

	iDSContent->SetToFirst();

	do
		{
		if ( !iDSContent->Interrupted() )
			{
			if ( iDSContent->WaitingInitAlert() )
				{
				InterruptL( iDSContent->CurrentIndex(), TNSmlError::ESmlAlertMissingInInitialisation, EFalse, EFalse );
				}
			}
		}
	while ( iDSContent->SetToNext() );	
	}	

//
// Authentications 
//

// -----------------------------------------------------------------------------
// CNSmlDSAgent::AuthTypeL
// Gets authentication type (basic/MD5) from the Agent Log.
// -----------------------------------------------------------------------------
//
CNSmlAgentBase::TAuthenticationType CNSmlDSAgent::AuthTypeL() const
	{
	CNSmlAgentBase::TAuthenticationType authType( ENoAuth );
	CNSmlDSAgentLog* agentLog = CNSmlDSAgentLog::NewLC();

	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey( iSyncServer->HostName().AllocLC() );
		authType = (CNSmlAgentBase::TAuthenticationType)agentLog->AuthTypeL( *searchKey );
		CleanupStack::PopAndDestroy(); // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		authType = (CNSmlAgentBase::TAuthenticationType)agentLog->AuthTypeL( *iDSServerId );
		}

	CleanupStack::PopAndDestroy(); // agentLog

	return authType;
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::SetAuthTypeL	
// Saves authentication type to the Agent Log.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::SetAuthTypeL( CNSmlAgentBase::TAuthenticationType aAuthType ) const
	{
	CNSmlDSAgentLog* agentLog = CNSmlDSAgentLog::NewLC();

	if ( iProtocolVer == ESmlVersion1_1_2 )
		{
		HBufC* searchKey( iSyncServer->HostName().AllocLC() );
		agentLog->SetAuthTypeL( *searchKey, (TNSmlAgentLogAuthenticationType)aAuthType );
		CleanupStack::PopAndDestroy(); // searchKey
		}
	else if ( iProtocolVer == ESmlVersion1_2 )
		{
		agentLog->SetAuthTypeL( *iDSServerId, (TNSmlAgentLogAuthenticationType)aAuthType );
		}

	CleanupStack::PopAndDestroy(); // agentLog
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::FreeResources
// Releases allocated resources.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::FreeResources()
	{
	FreeBaseResources();
	if(iEnd)
		{
		delete iDSContent;
		iDSContent = NULL;
		}
	}

//
// Error Handling functions
//
// ---------------------------------------------------------
// CNSmlDSAgent::Interrupt()
// Synchronisation with all databases is interrupted
// Synchronisation level error code to Sync Log.
// ---------------------------------------------------------
void CNSmlDSAgent::Interrupt( TInt aErrorCode, TBool aImmediatelyInterruption, TBool aStatusError )
	{
	DBG_FILE(_S8("CNSmlDSAgent::Interrupt()"));
	
	if ( !iDSContent->AllDatabasesAreInterrupted() || aStatusError )
		{
		// Error code is updated only once, except errors due to
		// error Status codes from the server
		DoErrorEvent( MSyncMLProgressObserver::ESmlFatalError, aErrorCode, iDSContent->TaskId(), 0, 0 );
		}

	TBool ret( iDSContent->SetToFirst() ); 
	
	while ( ret )
		{

		if ( !iDSContent->Interrupted() )
			{
			iDSContent->SetInterrupted();
			}
			
		if ( aImmediatelyInterruption )
			{
			// if immediately interrupted then no response is sent
			iDSContent->SetImmediatelyInterrupted();
			}
			
		if ( aStatusError )
			{
			// error due to error Status from a server
			iDSContent->SetServerStatusError();
			}
			
		ret = iDSContent->SetToNext();
		
		}
	}

//RD_SUSPEND_RESUME
// ---------------------------------------------------------
// CNSmlDSAgent::MapAlertCode()
// Maps the alert code
// ---------------------------------------------------------

TNSmlPreviousSyncType CNSmlDSAgent::MapAlertCode(TDes8& aAlertCode)
{
    TNSmlPreviousSyncType alertcode=ETypeNotSet;
    
	if ( aAlertCode == KNSmlDSTwoWay )
		{
		alertcode = ESyncDSTwoWay;
		}
	else if ( aAlertCode == KNSmlDSSlowSync )
		{
		alertcode = ESyncDSSlowSync;
		}
	else if ( aAlertCode == KNSmlDSOneWayFromClient )
		{
		alertcode = ESyncDSOneWayFromClient;
		}
	else if ( aAlertCode == KNSmlDSRefreshFromClient )
		{
		alertcode = ESyncDSRefreshFromClient;
		}
	else if ( aAlertCode == KNSmlDSOneWayFromServer )
		{
		alertcode = ESyncDSOneWayFromServer;
		}
	else if(aAlertCode ==KNSmlDSRefreshFromServer)
	   {
		alertcode =ESyncDSRefreshFromServer;
	   }		
	else if(aAlertCode ==KNSmlDSTwoWayByServer)
	   {
		alertcode =ESyncDSTwoWayByServer;
	   }   
    else if(aAlertCode ==KNSmlDSOneWayFromClientByServer)
	   {
		alertcode =ESyncDSOneWayFromClientByServer;
	   }
    else if(aAlertCode ==KNSmlDSRefreshFromClientByServer)
	   {
		alertcode =ESyncDSRefreshFromClientByServer;
	   }
    else if(aAlertCode ==KNSmlDSOneWayFromServerByServer)
	   {
		alertcode =ESyncDSOneWayFromServerByServer;
	   }
   else if(aAlertCode ==KNSmlDSRefreshFromServerByServer)
	   {
		alertcode =  ESyncDSRefreshFromServerByServer;
	   }
  
  return(alertcode);
	   	
}
//RD_SUSPEND_RESUME

// CNSmlDSAgent::InterruptL()
// Synchronisation with a given database is interrupted
// ---------------------------------------------------------
void CNSmlDSAgent::InterruptL( TInt appIndex, TInt aErrorCode, TBool aImmediatelyInterruption, TBool aStatusError )
	{
	DBG_FILE(_S8("CNSmlDSAgent::InterruptL()"));
	if ( !iDSContent->SetIndex( appIndex ) )
		{
		// if index does not point to a database, interrupt all databases
		Interrupt( aErrorCode, aImmediatelyInterruption, aStatusError );
		}
	else
		{
		iDSContent->SetIndex( appIndex );
		if ( ( !iDSContent->Interrupted() )  || 
			 ( aStatusError && !iDSContent->ServerStatusError() ) )
			{
			// only one message to Sync Log expect Status code errors from a server 
			iDSContent->SetInterrupted();
			InfoMessageToSyncLogL( appIndex, aErrorCode ); 
			if ( aStatusError )
				{
				iDSContent->SetServerStatusError();
				}
			}
		if ( aImmediatelyInterruption )
			{
			// if immediately, any respose is not send
			iDSContent->SetImmediatelyInterrupted();
			}
		}
	}
	
// -----------------------------------------------------------------------------
// CNSmlDSAgent::FinaliseWhenErrorL
// Gets called if sync is broken down immediately (Leave errors)
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::FinaliseWhenErrorL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::FinaliseWhenErrorL begins"));
	
	// Store error code to cenrep
	if ( iErrorReportingRep )
	    {
        TInt errCode = iError->SyncLogErrorCode();

        if ( errCode >= ( KNSmlDsHTTPErrCodeBase + KNSmlDsErrCodeFirst ) && 
                errCode <= ( KNSmlDsHTTPErrCodeBase + KNSmlDsErrCodeLast ) )
            {
            errCode -= KNSmlDsHTTPErrCodeBase;
            }

        if ( errCode >= KNSmlDsErrCodeFirst && errCode <= KNSmlDsErrCodeLast )
            {
            iErrorReportingRep->Set( KNsmlOpDsErrorCode, errCode );    	    
            }
	    }

// <MAPINFO_RESEND_MOD_BEGIN>
	if( iDSContent->ResendUsed() )
		{
		DBG_FILE(_S8("CNSmlDSAgent::FinaliseWhenErrorL - calling iDSContent->PackupRequestL..."));
		iDSContent->PackupRequestL( iDSClientNextSyncAnchor );
		}
// <MAPINFO_RESEND_MOD_END>
	
	//RD_SUSPEND_RESUME
	TInt keyVal;
	TRAPD (srerr ,ReadRepositoryL(KNsmlDsSuspendResume, keyVal));
	if(srerr == KErrNone && keyVal == 1)
	{
	    TNSmlSyncSuspendedState suspendedState;
	    if(iDSContent->SetToFirst())
	    {
	       do
	        {
	           suspendedState = CurrentState();	
	           iDSContent->SetSuspendedStateL(suspendedState);
	        }while( iDSContent->SetToNext() );
	   }
	   if(iDSContent->SetToFirst())
	   {
		 do
	    	{
		      TBuf8<3> syncType( iDSContent->SyncType()); 
	          TNSmlPreviousSyncType prevalertcode=MapAlertCode(syncType);
	          //Sync Type of the Current Sync session is stored.
	          iDSContent->SetPreviousSyncTypeL( prevalertcode );	
		     }while( iDSContent->SetToNext() );
	   }
       if(iDSContent->SetToFirst())
	   {
	      do
		  {
		     TBuf8<3> clientSyncType( iDSContent->ClientSyncType()); 
	         TNSmlPreviousSyncType prevClientType=MapAlertCode(clientSyncType);
	         //Sync Type proposed by Client in the Current Sync session is stored.
	         iDSContent->SetPreviousClientSyncTypeL( prevClientType );	
		  }while( iDSContent->SetToNext() );
	   }	
	}
	//RD_SUSPEND_RESUME
	
	iDSContent->FinalizeDatabasesL();
	
	iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlDisconnected, 0, 0 );

	if(iPacketDataUnAvailable)
	{
		DoErrorEvent(MSyncMLProgressObserver::ESmlFatalError,
					 TNSmlError::ESmlCommunicationError, 0, 0, 0 );
	}
	
	//RD_AUTO_RESTART (BPSS-7GBFF3)
	DBG_FILE_CODE(iPacketDataUnAvailable,_S8("CNSmlDSAgent::FinaliseWhenErrorL PacketData is"));
	//Check whether the Auto Restart Feature is enabled or not
	TRAPD (arerr ,ReadRepositoryL(KNsmlDsAutoRestart, keyVal));
	
	if(arerr == KErrNone && keyVal == 1)
	{
		if(!iPacketDataUnAvailable && !iAutoRestartInitiatedSync )
		{
		
			DBG_FILE(_S8("CNSmlDSAgent::FinaliseWhenErrorL About to check the Profile ID"));
			
			if(CheckProfileIdL())
			{
				TerminateAutoRestart();
			}	
		}
	}
	//RD_AUTO_RESTART
	
	DBG_FILE(_S8("CNSmlDSAgent::FinaliseWhenErrorL ends"));
	}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::Interrupted
// Checks if all datastores are interrupted.
// -----------------------------------------------------------------------------
//
TBool CNSmlDSAgent::Interrupted()
	{
	return iDSContent->AllDatabasesAreInterrupted();
	}
// -----------------------------------------------------------------------------
// CNSmlDSAgent::LaunchAutoRestart
// Launch the NETMON exe after saving the Profile Info to the CenRep and Killing
// the current DSSync session
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::LaunchAutoRestartL(TInt aError)
{
	DBG_FILE(_S8("CNSmlDSAgent::LaunchAutoRestart() begins"));
	
	
	//Check whether the Users' Network is in Roaming
	if(iDSNetmon)
	{
		if(iDSNetmon->IsRoaming())
		{
			DBG_FILE(_S8("CNSmlDSAgent::LaunchAutoRestart() Users' Network in Roaming Leaving the fuction"));
			User::Leave(aError);
		}
	}
	
	//Fix for BPSS-7H7JPF
	//Check whether the Auto-Restart is to be launched for the Profile that is already interrupted
	if(!iAutoRestartInitiatedSync)
	{
		TerminateAutoRestart();	
	}
	
		
	//Save the Profile Information
	SaveProfileInfoL();
	
	//Kill the DS Sync Sesssion
	StopDSSession();
	
	//Launch the NETMON exe
	LaunchNETMONL();
	
	DBG_FILE(_S8("CNSmlDSAgent::LaunchAutoRestart() ends"));
	
}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::SaveProfileInfo
// Save the Profile Information in to the Central Repository
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::SaveProfileInfoL()
{
	DBG_FILE(_S8("CNSmlDSAgent::SaveProfileInfo() begins"));
	
	CNsmlProfileUtil* profileUtil = CNsmlProfileUtil::NewLC();
	profileUtil->InternalizeFromSettingsDBL(this->iProfileID);
	profileUtil->ExternalizeToCenrepL();
	profileUtil->WriteAccessPointIdL(iNetmonAPId);
	
	//Error fix for BPSS-7GYDJV
	RArray<TSmlTaskId> taskIdArray;
	if ( iDSSyncTypeArray && iDSSyncTypeArray->Count() > 0)
	{
		TInt count = iDSSyncTypeArray->Count();
		DBG_FILE_CODE(count, _S8("CNSmlDSAgent::SaveProfileInfo() TaskId Count"));
		for ( TInt i = 0; i < count; i++ )
		{
			TSmlTaskId taskid;
			taskid = iDSSyncTypeArray->At( i ).iTaskId;
			taskIdArray.AppendL( taskid );
		}
	}
	else
	{
		DBG_FILE(_S8("CNSmlDSAgent::SaveProfileInfo() No TaskId"));
		taskIdArray.Reset();
	}	
	profileUtil->ExternalizeTaskIdL(taskIdArray);	
	taskIdArray.Close();	
	
	CleanupStack::PopAndDestroy(profileUtil);
	
	DBG_FILE(_S8("CNSmlDSAgent::SaveProfileInfo() ends"));
}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::LaunchNETMON
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::LaunchNETMONL()
{	
	DBG_FILE(_S8("CNSmlDSAgent::LaunchNETMONL() begins"));
	 //Kill if any existing NetMon exe is running
	 //TerminateAutoRestart();
	 //Starts the new Netmon process to register for the Connmon events
     //This exe will start the Sync session once the Network is available
     RProcess rp;
     TInt err = rp.Create(KNetMon,KNullDesC);
     User::LeaveIfError(err);
     rp.Resume();
     
     DBG_FILE(_S8("CNSmlDSAgent::LaunchNETMONL() ends"));
}

// -----------------------------------------------------------------------------
// CNSmlDSAgent::StopDSSession
// Kill the current DS Sync Session
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::StopDSSession()
{
	DBG_FILE(_S8("CNSmlDSAgent::StopDSSession() begins"));
	
	iCurrMainState = EFinishing;	
	Cancel();

	DBG_FILE(_S8("CNSmlDSAgent::StopDSSession() ends"));
}


// -----------------------------------------------------------------------------
// CNSmlDSAgent::DoErrorEvent
// Unsures error event
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::DoErrorEvent( MSyncMLProgressObserver::TErrorLevel
                                 aErrorLevel,
                                 TInt aError, TInt aTaskId,
                                 TInt aInfo1, TInt aInfo2 )
    {
    if ( !iErrorNotified )
        {
        iDSObserver->OnSyncMLSyncError( aErrorLevel, aError,
                                        aTaskId, aInfo1, aInfo2 );    
        iErrorNotified = ETrue;
        }    
    }
    
// -----------------------------------------------------------------------------
// CNSmlDSAgent::PrepareSyncL
// Prepares sync.
// -----------------------------------------------------------------------------
//
void CNSmlDSAgent::PrepareSyncL( CArrayFix<TNSmlContentSpecificSyncType>* aTypeArray )
	{
	iDSContent->InitContentDataL();
	
	if ( aTypeArray )
		{
		iDSSyncTypeArray = new ( ELeave ) CArrayFixFlat<TNSmlContentSpecificSyncType>( 4 );
		
		for ( TInt i = 0; i < aTypeArray->Count(); i++ )
			{
			TNSmlContentSpecificSyncType type;
			type.iTaskId = aTypeArray->At( i ).iTaskId;
			type.iType = aTypeArray->At( i ).iType;
			iDSSyncTypeArray->AppendL( type );
			}
		}
	}

// <MAPINFO_RESEND_MOD_BEGIN>

// ---------------------------------------------------------
// CNSmlDSAgent::BeginSubScanMapInfo()
//
// ---------------------------------------------------------
void CNSmlDSAgent::BeginSubScanMapInfo()
	{
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubScanMapInfo() begins"));
	TBool endOfMapLoading = EFalse;
	TRAPD( err,ScanMapInfoL( endOfMapLoading ) );
	if( err != KErrNone || endOfMapLoading )
		{
		DBG_FILE_CODE(  endOfMapLoading, _S8("CNSmlDSAgent::BeginSubScanMapInfo(): endOfMapLoading: ") );
		DBG_FILE_CODE(  err, _S8("CNSmlDSAgent::BeginSubScanMapInfo(): Moved to SubCreateLUIDBuffers...") );
		iDSCurrBeginSubState = EBeginSubCreateLUIDBuffers;
		}
	DBG_FILE(_S8("CNSmlDSAgent::BeginSubScanMapInfo() ends"));
	}

//
//  Client Resend MapInformation state functions
//
// ---------------------------------------------------------
// CNSmlDSAgent::ClientResendMapInfoStateL()
// If mapinfo exists as a result of unsuccessfull last sync,
// it Makes Client Map Informtaion Package to be resent to Server
// Navigate according to state code
// ---------------------------------------------------------
void CNSmlDSAgent::ClientResendMapInfoStateL()
	{
	switch ( iCurrClientResendMapInfoState )
		{
		case EResendMapInfoStartingMessage:
			ClientResendMapInfoStartingMessageStateL();
			break;
		case EResendMapInfoMakingStatus:
			ClientResendMapInfoMakingStatusStateL();
			break;
		case EResendMapInfoMakingResults:
			ClientResendMapInfoMakingResultsStateL();
			break;
		case EResendMapInfoStartingSync:
			ClientResendMapInfoStartingSyncStateL();
			break;
		case EResendMapInfoEndingSync:
			ClientResendMapInfoEndingSyncStateL();
			break;
		case EResendMapInfoMakingMap:
			ClientResendMapInfoMakingMapStateL();
			break;
		case EResendMapInfoEndingMessage:
			ClientResendMapInfoEndingMessageStateL();
			break;
		}
	}

void CNSmlDSAgent::ClientResendMapInfoStartingMessageStateL()
	{
	DBG_FILE(_S8("CNSmlAgentBase::ClientResendMapInfoStartingMessageStateL begins"));
	iMapResendStatusPackage=EFalse;
	iBufferFull = EFalse;
	TBool mapFound=EFalse;
	iDSContent->SetToFirst();
	if(iDSContent->MapExists())
		{
		mapFound=ETrue;
		}
	while(iDSContent->SetToNext() && !mapFound)
		{
		if(iDSContent->MapExists())
			{
			mapFound=ETrue;
			}
		}
	if(mapFound)
		{
		DBG_FILE(_S8("CNSmlAgentBase::ClientResendMapInfoStartingMessageStateL Mapfound"));
		iSyncMLCmds->DoSyncHdrL();
		iDSContent->SetToFirst();
		iCurrClientResendMapInfoState = EResendMapInfoMakingStatus;
		}
	else
		{
		NextMainStateL();
		}
	DBG_FILE(_S8("CNSmlAgentBase::ClientResendMapInfoStartingMessageStateL ends"));
	}

void CNSmlDSAgent::ClientResendMapInfoMakingStatusStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientResendMapInfoMakingStatusStateL begins"));
	iSyncMLCmds->StatusContainer()->Begin();
	TBool found( ETrue );
	while( found )
		{
		SmlStatus_t* status;
		found = iSyncMLCmds->StatusContainer()->NextStatusElement( status, ETrue );
		if ( found )
			{
			iSyncMLCmds->DoStatusL( status );
			}
		}
	iCurrClientResendMapInfoState = EResendMapInfoMakingResults;
	DBG_FILE(_S8("CNSmlAgent::ClientResendMapInfoMakingStatusStateL ends"));
	}


void CNSmlDSAgent::ClientResendMapInfoMakingResultsStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientModMakingResultsStateL begins"));
	if ( iDSDeviceInfoRequestedByServer && !iDSContent->AllDatabasesAreInterrupted() )
		{
		iSyncMLCmds->DoResultsL();
		iDSDeviceInfoRequestedByServer = EFalse;
		}
	if ( iFinalMessageFromClient )
		{
		iDSContent->SetToFirst();
		}
	else
		{
		iDSContent->SetIndexToSaved();
		}
	iCurrClientResendMapInfoState = EResendMapInfoStartingSync;
	DBG_FILE(_S8("CNSmlAgent::ClientResendMapInfoMakingResultsStateL ends"));
	}
// ---------------------------------------------------------
// CNSmlDSAgent::ClientResendMapInfoEndingSyncStateL()
// Makes Sync command
// ---------------------------------------------------------
void CNSmlDSAgent::ClientResendMapInfoStartingSyncStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientResendMapInfoStartingSyncStateL begins"));
	CNSmlCmdsBase::TReturnValue ret;
	if ( !iDSContent->Interrupted() )
		{
		ret = iSyncMLCmds->DoStartSyncL();
		switch ( ret )
			{
			case CNSmlCmdsBase::EReturnOK:
				iCurrClientResendMapInfoState = EResendMapInfoEndingSync;
	                	iDSObserver->OnSyncMLSyncProgress( MSyncMLProgressObserver::ESmlSendingMappingsToServer, 0, 0 );
				break;
			case CNSmlCmdsBase::EReturnBufferFull:
				iCurrClientResendMapInfoState = EResendMapInfoEndingSync;
				iBufferFull = ETrue;
				break;
			default:
				break;
			}
		}
	else
		// skip interrupted database
		{
		if ( !iDSContent->SetToNext() )
			{
			iCurrClientResendMapInfoState = EResendMapInfoEndingSync;
			}
		}
	DBG_FILE(_S8("CNSmlDSAgent::ClientResendMapInfoStartingSyncStateL ends"));
	}
// ---------------------------------------------------------
// CNSmlDSAgent::ClientResendMapInfoEndingSyncStateL()
// End of Sync command
// ---------------------------------------------------------
void CNSmlDSAgent::ClientResendMapInfoEndingSyncStateL()
	{
	DBG_FILE(_S8("CNSmlDSAgent::ClientResendMapInfoEndingSyncStateL begins"));
	iSyncMLCmds->DoEndSyncL();
	if ( iBufferFull )
		{
		iCurrClientResendMapInfoState = EResendMapInfoEndingMessage;
		}
	else
		{
		if ( iDSContent->SetToNext() )
			{
			iCurrClientResendMapInfoState = EResendMapInfoStartingSync;
			}
		else
			{
			iCurrClientResendMapInfoState = EResendMapInfoMakingMap;
			iDSContent->SetToFirst();
			}
		}
	DBG_FILE(_S8("CNSmlDSAgent::ClientResendMapInfoEndingSyncStateL ends"));
	}

void CNSmlDSAgent::ClientResendMapInfoMakingMapStateL()
	{
	DBG_FILE(_S8("CNSmlAgent::ClientResendMapInfoMakingMapStateL begins"));
	CNSmlCmdsBase::TReturnValue ret=CNSmlCmdsBase::EReturnOK;
	ret = iSyncMLCmds->DoMapL();
	switch ( ret )
		{
		case CNSmlCmdsBase::EReturnOK:
			iDSWaitingForMapAcknowledgement = ETrue;
			// there is something to send
			iMapResendStatusPackage = ETrue;
			if ( !iDSContent->SetToNext() )
				{
				iCurrClientResendMapInfoState = EResendMapInfoEndingMessage;
				}
			break;
		case CNSmlCmdsBase::EReturnEndData:
			if ( !iDSContent->SetToNext() )
				{
				iCurrClientResendMapInfoState = EResendMapInfoEndingMessage;
				}
			break;
		case CNSmlCmdsBase::EReturnBufferFull:
			iBufferFull = ETrue;
			iCurrClientResendMapInfoState = EResendMapInfoEndingMessage;
			break;
		default:
			break;
		}
	DBG_FILE(_S8("CNSmlAgent::ClientResendMapInfoMakingMapStateL ends"));
	}


void CNSmlDSAgent::ClientResendMapInfoEndingMessageStateL()
	{
	DBG_FILE(_S8("CNSmlAgentBase::ClientResendMapInfoEndingMessageStateL begins"));
	iSyncMLCmds->DoEndMessageL( EFalse );

	if ( iBufferFull )
		{
		iFinalMessageFromClient = EFalse;
		}
	else
		{
		iFinalMessageFromClient = ETrue;
		}

	NextMainStateL();
	DBG_FILE(_S8("CNSmlAgentBase::ClientResendMapInfoEndingMessageStateL ends"));
	}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::ScanMapInfoL
// Map information is searched for all the databases physical storage and calls functions to load map if exists
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::ScanMapInfoL( TBool& aEnd )
	{
	DBG_FILE(_S8("CNSmlDSAgent::ScanMapInfoL() begins"));

	if ( !iCommandIssued )
		{
		TBool ret = EFalse;
		if ( !iDSMapOpeningStarted )
			{
			ret = iDSContent->SetToFirst();
			iDSMapOpeningStarted = ETrue;
			}
		else
			{
			ret = iDSContent->SetToNext();
			}
		if ( ret )
			{
			iDSContent->ScanMapContentL(iStatus);
			iCommandIssued = ETrue;
			}
		else
			{
			aEnd = ETrue;
			}
		}
	else // command was completed
		{
		iCommandIssued = EFalse;
		if ( iStatus.Int() == KErrNotFound )
			{
			DBG_FILE_CODE(  iStatus.Int(), _S8("CNSmlDSAgent::ScanMapInfoL(): Error! (1)") );
			//InterruptL( iDSContent->CurrentIndex(), TNSmlDSError::ESmlDSLocalDatabaseError, ETrue, EFalse );
			//iDSContent->SetInterruptedBeforeSync();
			}
		else
			{
			DBG_FILE_CODE(  iStatus.Int(), _S8("CNSmlDSAgent::ScanMapInfoL(): Error! (2)") );
			User::LeaveIfError( iStatus.Int() );
			}
		}
	DBG_FILE(_S8("CNSmlDSAgent::ScanMapInfoL() ends"));
	}
// <MAPINFO_RESEND_MOD_END>

// CreateDSAgentL( MNSmlDSAgentObserver* aDSObserver )
// Return the instance of the CNSmlDSAgent
// ---------------------------------------------------------
//
EXPORT_C CNSmlDSAgent* CreateDSAgentL( MSyncMLProgressObserver* aDSObserver )
	{
	return CNSmlDSAgent::NewL( aDSObserver );
	}


//RD_SUSPEND_RESUME
// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::SyncFailure()
// 
// ------------------------------------------------------------------------------------------------------------------
TBool  CNSmlDSAgent::SyncFailure()
{
   DBG_FILE_CODE(iError->SyncLogErrorCode(),_S8("CNSmlDSAgent::SyncFailure( ).Error code"));
   if(iError->SyncLogErrorCode())
      return(ETrue);
   else
      return(EFalse);
}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CurrentStateInFinishing()
// 
// ------------------------------------------------------------------------------------------------------------------

TNSmlSyncSuspendedState CNSmlDSAgent::CurrentStateInFinishing()
{
    TNSmlSyncSuspendedState state=EStateNotStarted;
    
    TBool chk=SyncFailure();
	DBG_FILE_CODE(chk,_S8("CNSmlDSAgent::CurrentStateInFinishing( )..Network failure check"));
	 
	if(iDSContent->AnyDatabaseIsInterrupted() || iPacketDataUnAvailable
			                             || chk )
			{
				switch(iPrevSyncState)
				{
					case EBeginning:
					case EClientInitialisation:
					case EServerInitialisation:
					case EResultAlert:
					     //if any sync failure occurs at pkt#1/pkt#2 stage, do not update
					     //sync anchors	     
					     if(chk)
					     	iUpdateLastAnchor=EFalse;	
					     state = EStateNotStarted;
						break;
					case EClientResendMapInfo:
					case EClientModifications:
						state = EStateClientModification;
						break;
					case EServerModifications:
						state = EStateServerModification;
						break;
					case EDataUpdateStatus:
						state = EStateDataUpdateStatus;
						break;
					case EMapAcknowledge:
						state = EStateMapAcknowledge;
						break;
						
				}
			}
			else
			{
				state = EStateNotStarted;
			}
			
	return(state);
}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CurrentStateInReceiving()
// 
// ------------------------------------------------------------------------------------------------------------------

TNSmlSyncSuspendedState CNSmlDSAgent::CurrentStateInReceiving()
{
   TNSmlSyncSuspendedState state=EStateNotStarted;
   if (iPrevSyncState == EClientInitialisation || iPrevSyncState == EServerInitialisation
						|| iPrevSyncState == EClientResendMapInfo )
	{
				state = EStateNotStarted;
	}
	else if(iPrevSyncState == EClientModifications)
	{
			state = EStateClientModification;
	}
	else if (iPrevSyncState == EDataUpdateStatus)
	{
			state = EStateDataUpdateStatus;
	}
	else if (iPrevSyncState == EServerModifications )
	{
			state = EStateServerModification;
	}
	else if (iPrevSyncState == EMapAcknowledge )
	{
			state = EStateMapAcknowledge;
	}
	
	return state;
}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CurrentStateInClientAlertNext()
// 
// ------------------------------------------------------------------------------------------------------------------

TNSmlSyncSuspendedState CNSmlDSAgent::CurrentStateInClientAlertNext()
{
	TNSmlSyncSuspendedState state=EStateNotStarted;
	if (iPrevSyncState == EServerModifications)
	{
	   state = EStateServerModification;
	}
	else if (iPrevSyncState == EMapAcknowledge)
	{
		state = EStateMapAcknowledge;
	}
	return(state);
}


// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CurrentStateInServerAlertNext()
// 
// ------------------------------------------------------------------------------------------------------------------

TNSmlSyncSuspendedState CNSmlDSAgent::CurrentStateInServerAlertNext()
{
	TNSmlSyncSuspendedState state=EStateNotStarted;
    if(iPrevSyncState == EClientModifications)
	{
	  state = EStateClientModification;
	}
	else if (iPrevSyncState == EDataUpdateStatus)
	{
	  state = EStateDataUpdateStatus;
	}
	return(state);
}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CurrentState()
// 
// ------------------------------------------------------------------------------------------------------------------


TNSmlSyncSuspendedState CNSmlDSAgent::CurrentState( )
{

	TNSmlSyncSuspendedState state = EStateNotStarted;	
	
	switch(iCurrMainState)
		{
		case EBeginning:
		case EClientInitialisation:
		case EServerInitialisation:
		case EResultAlert:
		     if(SyncFailure())
		     {
		       iUpdateLastAnchor=EFalse;	
		     }
		     state=EStateNotStarted;
		     break;
		case EFinishing:
			 state=CurrentStateInFinishing();
			 break;
	// <MAPINFO_RESEND_MOD_BEGIN>
		case EClientResendMapInfo:
// <MAPINFO_RESEND_MOD_END>
		case EClientModifications:
			state = EStateClientModification;
			break;
		case EServerModifications:
			state = EStateServerModification;
			break;
		case EDataUpdateStatus:
			state = EStateDataUpdateStatus;
			break;
		case EMapAcknowledge:
			state = EStateMapAcknowledge;
			break;
		
		case EClientAlertNext:
		     state=CurrentStateInClientAlertNext();
		     break;
		   
		case EServerAlertNext:
		     state=CurrentStateInServerAlertNext();
			 break;
		case ESending:
		case EReceiving:
		 	 {
	 		  state=CurrentStateInReceiving();			
			  break;
			 }
		default:
			state = EStateNotStarted;
			break;
		
		}
		DBG_FILE_CODE(state,_S8("CNSmlDSAgent::CurrentStateInFinishing( )..Network failure check"));
		if(state!=EStateNotStarted && iUpdateLastAnchor)
		   iUpdateLastAnchor=EFalse;
		return state;
	}
// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::ReadRepositoryL()
// 
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::ReadRepositoryL(TInt aKey, TInt& aValue)
{
	const TUid KRepositoryId = KCRUidDataSyncInternalKeys;
	
    CRepository* rep = CRepository::NewLC(KRepositoryId);
    TInt err = rep->Get(aKey, aValue);
	User::LeaveIfError(err);
	CleanupStack::PopAndDestroy(rep);
}
//RD_SUSPEND_RESUME

//RD_AUTO_RESTART
// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::CheckProfileIdL()
// 
// ------------------------------------------------------------------------------------------------------------------
TBool CNSmlDSAgent::CheckProfileIdL()
{
	DBG_FILE(_S8("CNSmlDSAgent::CheckProfileId() begins"));
	
	CNsmlProfileUtil* profileUtil = CNsmlProfileUtil::NewLC();	
	profileUtil->InternalizeFromCenrepL();
	TInt cachedprofileId = profileUtil->ProfileId();
	CleanupStack::PopAndDestroy(profileUtil);
	
	DBG_FILE_CODE(iProfileID, _S8("CNSmlDSAgent::CheckProfileId() Profile ID is"));
	DBG_FILE_CODE(cachedprofileId, _S8("CNSmlDSAgent::CheckProfileId() cached Profile ID is"));
	
	if(iProfileID == cachedprofileId)
	{
		return ETrue;
	}
		
	else
	{
		return EFalse;
	}
}

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::TerminateAutoRestart()
// 
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::TerminateAutoRestart()
{
	DBG_FILE(_S8("CNSmlDSAgent::TerminateAutoRestart() begins"));
	
	TFullName processName;
	TFindProcess process;
	while ( process.Next( processName ) != KErrNotFound )
	{
		//DBG_ARGS(_S("CNSmlDSAgent::TerminateAutoRestart() The Process name is %S"), &processName);
		
		if ( ( processName.Find( KAutoRestart ) != KErrNotFound ) )
		{
			RProcess rprocess;
			if (rprocess.Open(process, EOwnerProcess) == KErrNone)
			{
				DBG_FILE(_S8("CNSmlDSAgent::TerminateAutoRestart() Process is found, Killing the Process"));
				rprocess.Terminate(KErrNone);
				rprocess.Close();				
				DBG_FILE(_S8("CNSmlDSAgent::TerminateAutoRestart() Process killed successfully"));				
			}
		}
	}
	
	DBG_FILE(_S8("CNSmlDSAgent::TerminateAutoRestart() ends"));
}
// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::IsSyncClientInitiated()
// 
// ------------------------------------------------------------------------------------------------------------------
TBool CNSmlDSAgent::IsSyncClientInitiated()
{
	DBG_FILE_CODE(iSyncInitiation, _S8("CNSmlDSAgent::IsSyncClientInitiated() The Sync Initiation status is"));
	
	if(iSyncInitiation == EClientInitiated)
		return ETrue;
	else
		return EFalse;
}
//RD_AUTO_RESTART

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::SetDSSessionInfoL()
// 
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::SetDSSessionInfoL(CNSmlDSProfile* aProfile)
    {
            
    CRepository* rep = CRepository::NewLC(KNsmlDsSessionInfoKey);
    TInt err = rep->Set(EDSSessionProfileId, aProfile->IntValue( EDSProfileId ));
    err = rep->Set(EDSSessionProfileName, aProfile->StrValue( EDSProfileDisplayName ));
    err = rep->Set(EDSSessionServerId, aProfile->StrValue( EDSProfileServerId ));
    User::LeaveIfError(err);
    CleanupStack::PopAndDestroy(rep);
    
    
    }

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::ResetDSSessionInfoL()
// 
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::ResetDSSessionInfoL()
    {
	
    CRepository* rep = CRepository::NewLC(KNsmlDsSessionInfoKey);
    TInt err = rep->Set(EDSSessionProfileId, KErrNotFound);
    err = rep->Set(EDSSessionProfileName, _L(""));
    err = rep->Set(EDSSessionServerId, _L(""));
    User::LeaveIfError(err);
    CleanupStack::PopAndDestroy(rep);
    }

// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::InitializeServerStatusCodeList()
// @description This function reads list of configured server status codes
//              from cenrep and stores them locally in an array for later comparision during sync
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::InitializeServerStatusCodeList()
    {
    DBG_FILE(_S8("CNSmlDSAgent::InitializeServerStatusCodeList() begins"));
    TRAPD(error, iRepositorySSC = CRepository::NewL(KNsmlOperatorCenrepUID));
    if(error == KErrNone && iRepositorySSC!= NULL)
        {
        TBuf<KBufferLength> tempStr;
        error = iRepositorySSC->Get(KNsmlExtendedServerStatusCodeList, tempStr);
        if(error == KErrNone)
            {
            TInt commaPos = -1;
            TInt codesCount = 0;
            while ((commaPos = tempStr.Locate(',')) > KErrNotFound)
                {
                ++codesCount;
                tempStr.Replace(commaPos,1,KSpace);
                }
            TRAPD(error, iServerStatusCodeArray = new (ELeave) RArray<TInt>(codesCount));
            if(error == KErrNone && iServerStatusCodeArray!= NULL)
                {
				TLex lex(tempStr);
				while(!lex.Eos())
					{
					TPtrC token=lex.NextToken();
					TLex temp(token);
					TInt val;
					temp.Val(val);
					TRAP(error, iServerStatusCodeArray->AppendL(val));
					if(error !=KErrNone)
						{
						DBG_FILE(_S8("Item Could not be appended to array"));
						}
					}
                }
            else
                {
                iServerStatusCodeArray = NULL;
                DBG_FILE(_S8("Error creating iServerStatusCodeArray"));
                }
            }
        else
            {
	        DBG_FILE(_S8("Could not find ServerStatusCodeList Key in cenrep"));
            }
        }
    else
        {
        iRepositorySSC = NULL;
        DBG_FILE(_S8("Error opening cenrep to store Server Status Codes"));
        }
    DBG_FILE(_S8("CNSmlDSAgent::InitializeServerStatusCodeList() ends"));
    }
// ------------------------------------------------------------------------------------------------------------------
// CNSmlDSAgent::StoreServerStatusCode(TInt aServerStatusCode)
// @description This function stores Sync ML Server Status code to cenrep for Operator profile sync if matched with configured list of codes,
//              and the same code can be used by any client for error logging.
//              If there are multiple status codes during sync, the last server status code is stored.
// @param aServerStatusCode Sync ML server status code while sync ongoing.
// ------------------------------------------------------------------------------------------------------------------
void CNSmlDSAgent::StoreServerStatusCode(TInt aServerStatusCode) const
    {
    DBG_FILE(_S8("CNSmlDSAgent::StoreServerStatusCode() begins"));
	if(iServerStatusCodeArray)
	    {
	    if(iServerStatusCodeArray->Find(aServerStatusCode) != KErrNotFound)
	        {
	        if(iRepositorySSC)
	            {
	            TInt error = iRepositorySSC->Set(KNsmlExtendedServerStatusCode, aServerStatusCode);
	            if (error != KErrNone)
	                {
	                DBG_FILE(_S8("Error in storing the server status code in cenrep"));
	                }
	            }
	        else
	            {
	            DBG_FILE(_S8("Repository for SSC could not be found"));
	            }
	        }
	    }
    DBG_FILE(_S8("CNSmlDSAgent::StoreServerStatusCode() ends"));
    }
// End of file