os/persistentdata/loggingservices/eventlogger/LogServ/src/LOGCHNGE.CPP
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#include "LOGCHNGE.H"
sl@0
    17
#include <logwraplimits.h>
sl@0
    18
#include <logcntdef.h>
sl@0
    19
#include "LOGQUERY.H"
sl@0
    20
#include "logservpanic.h"
sl@0
    21
#include "LogServRecentList.h"
sl@0
    22
#include "LogServCacheConfig.h"
sl@0
    23
#include "LogServRecentListManager.h"
sl@0
    24
#include "LogServDatabaseTransactionInterface.h"
sl@0
    25
#include "LogServDatabaseChangeInterface.h"
sl@0
    26
#include "LOGDUP.H"
sl@0
    27
#include "LogServCacheStrings.h"
sl@0
    28
#include "LogServSqlStrings.h"
sl@0
    29
sl@0
    30
//**********************************
sl@0
    31
// CLogChangeEvent
sl@0
    32
//**********************************
sl@0
    33
sl@0
    34
CLogChangeEvent::CLogChangeEvent(MLogServDatabaseTransactionInterface& aDatabase, TInt aPriority)
sl@0
    35
: CLogActive(aPriority), iDatabase(aDatabase)
sl@0
    36
	{
sl@0
    37
	}
sl@0
    38
sl@0
    39
CLogChangeEvent::~CLogChangeEvent()
sl@0
    40
	{
sl@0
    41
	Cancel();
sl@0
    42
	//
sl@0
    43
	delete iEvent;
sl@0
    44
	delete iDuplicate;
sl@0
    45
	delete iDuplicateFilter;
sl@0
    46
	}
sl@0
    47
sl@0
    48
void CLogChangeEvent::ConstructL()
sl@0
    49
	{
sl@0
    50
	iEvent = CLogEvent::NewL();
sl@0
    51
	iDuplicate = CLogDuplicate::NewL(iDatabase, Priority());
sl@0
    52
	iDuplicateFilter = CLogFilter::NewL();
sl@0
    53
	}
sl@0
    54
sl@0
    55
CLogChangeEvent* CLogChangeEvent::NewL(MLogServDatabaseTransactionInterface& aDatabase, TInt aPriority)
sl@0
    56
	{
sl@0
    57
	CLogChangeEvent* self = new(ELeave)CLogChangeEvent(aDatabase, aPriority);
sl@0
    58
	CleanupStack::PushL(self);
sl@0
    59
	self->ConstructL();
sl@0
    60
	CleanupStack::Pop();
sl@0
    61
	return self;
sl@0
    62
	}
sl@0
    63
sl@0
    64
void CLogChangeEvent::StartL(const CLogEvent& aEvent, const CLogServRecentList* aRecentList, TRequestStatus& aStatus, const RMessage2& aMessage)
sl@0
    65
	{
sl@0
    66
	__ASSERT_ALWAYS(iState == ELogNone, Panic(ELogBadState2));
sl@0
    67
	__ASSERT_DEBUG(!IsActive(), Panic(ELogAlreadyActive3));
sl@0
    68
sl@0
    69
	iMessage = &aMessage;
sl@0
    70
	iEvent->CopyL(aEvent);
sl@0
    71
	iState = ELogChangeEvent;
sl@0
    72
	iRecentList = aRecentList; // Need to use this! (5yrs later - okay then :-)
sl@0
    73
	iOldRecentList = KLogNullRecentList;
sl@0
    74
sl@0
    75
	Queue(aStatus);
sl@0
    76
	TRequestStatus* status = &iStatus;
sl@0
    77
	User::RequestComplete(status, KErrNone);
sl@0
    78
	SetActive();
sl@0
    79
	}
sl@0
    80
sl@0
    81
void CLogChangeEvent::DoRunL()
sl@0
    82
	{
sl@0
    83
	__ASSERT_DEBUG(iState != ELogNone, Panic(ELogBadState3));
sl@0
    84
sl@0
    85
	switch (iState)
sl@0
    86
		{
sl@0
    87
		case ELogChangeEvent:
sl@0
    88
			DoChangeEventL();
sl@0
    89
            ResetDuplicatesL();
sl@0
    90
            UpdateDuplicateEventsL();
sl@0
    91
			break;
sl@0
    92
		case ELogPurgeRecent:
sl@0
    93
			{
sl@0
    94
            RArray<TLogId> logIds;
sl@0
    95
            ::LogGetRecentEventsLC(iDatabase, iRecentList->Id(), iDatabase.DTICacheConfig().Config().iMaxRecentLogSize, logIds); 
sl@0
    96
            ::LogPurgeRecentEventsL(iDatabase, logIds);
sl@0
    97
            CleanupStack::PopAndDestroy(&logIds);
sl@0
    98
			}
sl@0
    99
            break;
sl@0
   100
 		default:
sl@0
   101
 			__ASSERT_DEBUG(ETrue, Panic(ELogBadState4));
sl@0
   102
 			break;
sl@0
   103
		}
sl@0
   104
	}
sl@0
   105
sl@0
   106
void CLogChangeEvent::DoComplete(TInt& aStatus)
sl@0
   107
	{
sl@0
   108
	if (iDatabase.DTIInTransaction())
sl@0
   109
		{
sl@0
   110
		if (aStatus == KErrNone)
sl@0
   111
			aStatus = iDatabase.DTICommitAndEnd();
sl@0
   112
sl@0
   113
		if (aStatus < KErrNone)
sl@0
   114
			iDatabase.DTIRollBack();
sl@0
   115
		}
sl@0
   116
sl@0
   117
	iState = ELogNone;
sl@0
   118
	}
sl@0
   119
sl@0
   120
void CLogChangeEvent::ResetDuplicatesL()
sl@0
   121
    {
sl@0
   122
    // Was it in a recent list? Is it now changing lists?
sl@0
   123
    if (iOldRecentList > 0 && (!iRecentList || iOldRecentList != iRecentList->Id()))
sl@0
   124
        {
sl@0
   125
        ::LogResetDuplicatesL(iDatabase, iEvent->Id());
sl@0
   126
        }
sl@0
   127
    }
sl@0
   128
sl@0
   129
void CLogChangeEvent::UpdateDuplicateEventsL()
sl@0
   130
    {
sl@0
   131
    // Detect duplicate events if we've added an event to a recent list
sl@0
   132
    if (iOldRecentList > 0 && iRecentList && iOldRecentList != iRecentList->Id())
sl@0
   133
        {
sl@0
   134
        iRecentList->GetFilter(*iEvent, *iDuplicateFilter);
sl@0
   135
        // If we get here we have added an event to a recent list, which may need to be purged
sl@0
   136
        iState = ELogPurgeRecent;
sl@0
   137
        // Passing -1 into this will ensure that events are updated so the most recent duplicate is first
sl@0
   138
        if (!iDuplicate->StartL(-1, iRecentList->Id(), *iDuplicateFilter, iStatus))
sl@0
   139
            {
sl@0
   140
            // Complete ourselves
sl@0
   141
            TRequestStatus* status = &iStatus;
sl@0
   142
            User::RequestComplete(status, KErrNone);
sl@0
   143
            }
sl@0
   144
        SetActive();
sl@0
   145
        }
sl@0
   146
    }
sl@0
   147
sl@0
   148
void CLogChangeEvent::DoChangeEventL()
sl@0
   149
    {
sl@0
   150
    RLogEventDbTable tbl;
sl@0
   151
    tbl.OpenLC(iDatabase.DTIDatabase());
sl@0
   152
    User::LeaveIfError(tbl.SetIndex(KLogNameEventIdx1));
sl@0
   153
    if(!tbl.SeekL(TDbSeekKey((TInt)iEvent->Id())))
sl@0
   154
        {
sl@0
   155
        User::Leave(KErrNotFound);
sl@0
   156
        }
sl@0
   157
    User::LeaveIfError(iDatabase.DTIBegin());
sl@0
   158
    tbl.GetL();
sl@0
   159
    iOldRecentList = tbl.ColInt8(RLogEventDbTable::iRecentColNo);
sl@0
   160
    DoChangeL(tbl, iDatabase.DTICacheStrings().GetIdL(iEvent->Direction()), iDatabase.DTICacheStrings().GetIdL(iEvent->Status()));
sl@0
   161
    CleanupStack::PopAndDestroy();//tbl
sl@0
   162
    }
sl@0
   163
sl@0
   164
void CLogChangeEvent::DoChangeL(RLogEventDbTable& aTbl, TLogStringId aDirectionId, TLogStringId aStatusId)
sl@0
   165
	{
sl@0
   166
	if(!iDatabase.DTIIsAllowed(EWriteOp, *iMessage, iEvent->EventType())) 
sl@0
   167
		{
sl@0
   168
		User::Leave(KErrPermissionDenied);
sl@0
   169
		}
sl@0
   170
	
sl@0
   171
	aTbl.UpdateL();
sl@0
   172
sl@0
   173
	if (iEvent->RemoteParty().Length() > 0)
sl@0
   174
		aTbl.SetColL(RLogEventDbTable::iRemotePartyColNo, iEvent->RemoteParty());
sl@0
   175
	else
sl@0
   176
		aTbl.SetColNullL(RLogEventDbTable::iRemotePartyColNo);
sl@0
   177
sl@0
   178
	if (iEvent->Direction().Length() > 0)
sl@0
   179
	    aTbl.SetColL(RLogEventDbTable::iDirectionColNo, (TUint32)aDirectionId);
sl@0
   180
	else
sl@0
   181
	    aTbl.SetColNullL(RLogEventDbTable::iDirectionColNo);
sl@0
   182
sl@0
   183
	aTbl.SetColL(RLogEventDbTable::iTimeColNo, iEvent->Time());
sl@0
   184
	aTbl.SetColL(RLogEventDbTable::iDurationTypeColNo, (TInt32)iEvent->DurationType());
sl@0
   185
sl@0
   186
	if (iEvent->DurationType() != KLogNullDurationType)
sl@0
   187
	    aTbl.SetColL(RLogEventDbTable::iDurationColNo, iEvent->Duration());
sl@0
   188
	else
sl@0
   189
	    aTbl.SetColNullL(RLogEventDbTable::iDurationColNo);
sl@0
   190
sl@0
   191
	if (iEvent->Status().Length() > 0)
sl@0
   192
	    aTbl.SetColL(RLogEventDbTable::iStatusColNo, (TUint32)aStatusId);
sl@0
   193
	else
sl@0
   194
	    aTbl.SetColNullL(RLogEventDbTable::iStatusColNo);
sl@0
   195
sl@0
   196
	if (iEvent->Subject().Length() > 0)
sl@0
   197
	    aTbl.SetColL(RLogEventDbTable::iSubjectColNo, iEvent->Subject());
sl@0
   198
	else
sl@0
   199
	    aTbl.SetColNullL(RLogEventDbTable::iSubjectColNo);
sl@0
   200
sl@0
   201
	if (iEvent->Number().Length() > 0)
sl@0
   202
	    aTbl.SetColL(RLogEventDbTable::iNumberColNo, iEvent->Number());
sl@0
   203
	else
sl@0
   204
	    aTbl.SetColNullL(RLogEventDbTable::iNumberColNo);
sl@0
   205
sl@0
   206
	if (iEvent->Contact() != KLogNullContactId)
sl@0
   207
	    aTbl.SetColL(RLogEventDbTable::iContactColNo, iEvent->Contact());
sl@0
   208
	else
sl@0
   209
	    aTbl.SetColNullL(RLogEventDbTable::iContactColNo);
sl@0
   210
sl@0
   211
	if (iEvent->Link() != KLogNullLink)
sl@0
   212
	    aTbl.SetColL(RLogEventDbTable::iLinkColNo, iEvent->Link());
sl@0
   213
	else
sl@0
   214
	    aTbl.SetColNullL(RLogEventDbTable::iLinkColNo);
sl@0
   215
sl@0
   216
	if (iEvent->Data().Length() > 0)
sl@0
   217
	    aTbl.SetColL(RLogEventDbTable::iDataColNo, iEvent->Data());
sl@0
   218
	else
sl@0
   219
	    aTbl.SetColNullL(RLogEventDbTable::iDataColNo);
sl@0
   220
sl@0
   221
	// Set the flags
sl@0
   222
	TInt bit = KLogFlagsCount;
sl@0
   223
	while(bit--)
sl@0
   224
		{
sl@0
   225
        aTbl.SetColL(RLogEventDbTable::iFlagColNo[bit], (TUint32)((iEvent->Flags() & 0x1 << bit) ? 1 : 0));
sl@0
   226
		}
sl@0
   227
sl@0
   228
	// Set the recent list
sl@0
   229
	if (iOldRecentList > 0)
sl@0
   230
		{
sl@0
   231
		// Removing an event from all recent lists?
sl@0
   232
		if (!iRecentList)
sl@0
   233
			{
sl@0
   234
			aTbl.SetColNullL(RLogEventDbTable::iRecentColNo);
sl@0
   235
			aTbl.SetColNullL(RLogEventDbTable::iDuplicateColNo);
sl@0
   236
			}
sl@0
   237
		// Changing list?
sl@0
   238
		else if (iOldRecentList != iRecentList->Id())
sl@0
   239
			{
sl@0
   240
			__ASSERT_DEBUG(iRecentList->Id() != KLogNullRecentList, Panic(ELogNullRecentList));
sl@0
   241
			aTbl.SetColL(RLogEventDbTable::iRecentColNo, (TInt32)iRecentList->Id());
sl@0
   242
sl@0
   243
			// This is set to -1 to prevent it temporarily appearing in a recent or duplicate view
sl@0
   244
			// It gets updated properly later when detecting duplicates
sl@0
   245
			aTbl.SetColL(RLogEventDbTable::iDuplicateColNo, -1);
sl@0
   246
			}
sl@0
   247
		}
sl@0
   248
sl@0
   249
#ifdef SYMBIAN_ENABLE_EVENTLOGGER_DUALSIM	
sl@0
   250
	if(iEvent->SimId() != KLogNullSimId)
sl@0
   251
	    aTbl.SetColL(RLogEventDbTable::iSimIdColNo, iEvent->SimId());
sl@0
   252
	else
sl@0
   253
	    aTbl.SetColNullL(RLogEventDbTable::iSimIdColNo);
sl@0
   254
#endif	
sl@0
   255
	
sl@0
   256
	aTbl.PutL();
sl@0
   257
sl@0
   258
	iDatabase.DTIChangeInterface().DCISubmitChangedEventContextL(ELogChangeTypeEventChanged, iEvent->Id());
sl@0
   259
	}
sl@0
   260
sl@0
   261
//**********************************
sl@0
   262
// CLogChangeConfig
sl@0
   263
//**********************************
sl@0
   264
sl@0
   265
CLogChangeConfig::CLogChangeConfig(MLogServDatabaseTransactionInterface& aDatabase, const CLogServRecentListManager& aRecentSetup, TInt aPriority)
sl@0
   266
: CLogActive(aPriority), iDatabase(aDatabase), iRecentSetup(aRecentSetup)
sl@0
   267
	{
sl@0
   268
	}
sl@0
   269
sl@0
   270
CLogChangeConfig::~CLogChangeConfig()
sl@0
   271
	{
sl@0
   272
	Cancel();
sl@0
   273
	}
sl@0
   274
sl@0
   275
CLogChangeConfig* CLogChangeConfig::NewL(MLogServDatabaseTransactionInterface& aDatabase, const CLogServRecentListManager& aRecentSetup, TInt aPriority)
sl@0
   276
	{
sl@0
   277
	CLogChangeConfig* self = new(ELeave) CLogChangeConfig(aDatabase, aRecentSetup, aPriority);
sl@0
   278
	return self;
sl@0
   279
	}
sl@0
   280
sl@0
   281
void CLogChangeConfig::StartL(const TLogConfig& aConfig, TRequestStatus& aStatus)
sl@0
   282
	{
sl@0
   283
	__ASSERT_ALWAYS(iState == ELogNone, Panic(ELogBadState5));
sl@0
   284
	__ASSERT_DEBUG(!IsActive(), Panic(ELogAlreadyActive4));
sl@0
   285
sl@0
   286
	iState = ELogChange;
sl@0
   287
	iConfig = &aConfig;
sl@0
   288
sl@0
   289
	Queue(aStatus);
sl@0
   290
	TRequestStatus* status = &iStatus;
sl@0
   291
	User::RequestComplete(status, KErrNone);
sl@0
   292
	SetActive();
sl@0
   293
	}
sl@0
   294
sl@0
   295
void CLogChangeConfig::DoRunL()
sl@0
   296
	{
sl@0
   297
	switch (iState)
sl@0
   298
		{
sl@0
   299
		case ELogChange:
sl@0
   300
			{
sl@0
   301
			// Start a transaction
sl@0
   302
			User::LeaveIfError(iDatabase.DTIBegin());
sl@0
   303
			// Change the config, using the existing transaction
sl@0
   304
			iDatabase.DTICacheConfig().UpdateL(*iConfig);
sl@0
   305
			//Purge old events
sl@0
   306
            RLogEventDbTable tbl;
sl@0
   307
            tbl.OpenLC(iDatabase.DTIDatabase());
sl@0
   308
            ::LogPurgeMainL(iDatabase, tbl, iConfig->iMaxLogSize, 0);
sl@0
   309
            CleanupStack::PopAndDestroy(&tbl);
sl@0
   310
            iRecent = 0;
sl@0
   311
            //
sl@0
   312
			iState = ELogPurgeRecent;
sl@0
   313
			TRequestStatus* status = &iStatus;
sl@0
   314
			User::RequestComplete(status, KErrNone);
sl@0
   315
			SetActive();
sl@0
   316
			break;
sl@0
   317
			}
sl@0
   318
		case ELogPurgeRecent:
sl@0
   319
			{
sl@0
   320
			// Are there any more recent lists to check
sl@0
   321
			if(iRecent >= iRecentSetup.Count())
sl@0
   322
			    {
sl@0
   323
				break;
sl@0
   324
			    }
sl@0
   325
            RArray<TLogId> logIds;
sl@0
   326
            ::LogGetRecentEventsLC(iDatabase, iRecentSetup.List(iRecent).Id(), iConfig->iMaxRecentLogSize, logIds); 
sl@0
   327
            ::LogPurgeRecentEventsL(iDatabase, logIds);
sl@0
   328
            CleanupStack::PopAndDestroy(&logIds);
sl@0
   329
            // Purge next recent list?
sl@0
   330
            if (++iRecent < iRecentSetup.Count())
sl@0
   331
                {
sl@0
   332
                iState = ELogPurgeRecent;
sl@0
   333
                TRequestStatus* status = &iStatus;
sl@0
   334
                User::RequestComplete(status, KErrNone);
sl@0
   335
                SetActive();
sl@0
   336
                }
sl@0
   337
            break;
sl@0
   338
			}
sl@0
   339
		default:
sl@0
   340
			__ASSERT_DEBUG(ETrue, Panic(ELogBadState6));
sl@0
   341
			break;
sl@0
   342
		}
sl@0
   343
	}
sl@0
   344
sl@0
   345
void CLogChangeConfig::DoComplete(TInt& aStatus)
sl@0
   346
	{
sl@0
   347
	// Try and commit the transaction
sl@0
   348
	if (iDatabase.DTIInTransaction())
sl@0
   349
		{
sl@0
   350
		if	(aStatus == KErrNone)
sl@0
   351
			aStatus = iDatabase.DTICommitAndEnd();
sl@0
   352
sl@0
   353
		if	(aStatus < KErrNone)
sl@0
   354
			{
sl@0
   355
			iDatabase.DTICacheConfig().Rollback();
sl@0
   356
			iDatabase.DTIRollBack();
sl@0
   357
			}
sl@0
   358
		else
sl@0
   359
		    {
sl@0
   360
		    iDatabase.DTICacheConfig().Commit();
sl@0
   361
		    }
sl@0
   362
		}
sl@0
   363
    __ASSERT_DEBUG(!iDatabase.DTICacheConfig().InTransaction(), Panic(ELogChangeConfigLogicError));
sl@0
   364
	iState = ELogNone;
sl@0
   365
	}