creator/engine/src/creator_log.cpp
changeset 17 4f2773374eff
child 19 4b22a598b890
equal deleted inserted replaced
15:e11368ed4880 17:4f2773374eff
       
     1 /*
       
     2 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: 
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 #include <cntdef.h>
       
    21 
       
    22 #include "engine.h"
       
    23 #include "enginewrapper.h"
       
    24 #include "creator_log.h" 
       
    25 #include "creator_traces.h"
       
    26 
       
    27 static const TInt KLogsFieldLength = 256;
       
    28 
       
    29 //_LIT(KCreatorLogsPrefixName, "CR_");
       
    30 
       
    31 //----------------------------------------------------------------------------
       
    32 
       
    33 CLogsParameters::CLogsParameters()
       
    34     {
       
    35     LOGSTRING("Creator: CLogsParameters::CLogsParameters");
       
    36 
       
    37     iPhoneNumber = HBufC::New(KLogsFieldLength);
       
    38     /*iMissedCallPhoneNumber = HBufC::New(KLogsFieldLength);
       
    39     iReceivedCallPhoneNumber = HBufC::New(KLogsFieldLength);
       
    40     iDialledNumberPhoneNumber = HBufC::New(KLogsFieldLength);*/
       
    41     }
       
    42 
       
    43 CLogsParameters::~CLogsParameters()
       
    44     {
       
    45     LOGSTRING("Creator: CLogsParameters::~CLogsParameters");
       
    46 
       
    47     delete iPhoneNumber;
       
    48     /*delete iDialledNumberPhoneNumber;
       
    49     delete iReceivedCallPhoneNumber;
       
    50     delete iMissedCallPhoneNumber;*/
       
    51     }
       
    52 
       
    53 //----------------------------------------------------------------------------
       
    54 
       
    55 CCreatorLogs* CCreatorLogs::NewL(CCreatorEngine* aEngine)
       
    56     {
       
    57     CCreatorLogs* self = CCreatorLogs::NewLC(aEngine);
       
    58     CleanupStack::Pop(self);
       
    59     return self;
       
    60     }
       
    61 
       
    62 CCreatorLogs* CCreatorLogs::NewLC(CCreatorEngine* aEngine)
       
    63     {
       
    64     CCreatorLogs* self = new (ELeave) CCreatorLogs;
       
    65     CleanupStack::PushL(self);
       
    66     self->ConstructL(aEngine);
       
    67     return self;
       
    68     }
       
    69 
       
    70 CCreatorLogs::CCreatorLogs() : CActive(0)
       
    71     {
       
    72     }
       
    73 
       
    74 void CCreatorLogs::ConstructL(CCreatorEngine* aEngine)
       
    75     {
       
    76     LOGSTRING("Creator: CCreatorLogs::ConstructL");
       
    77 
       
    78     iEngine = aEngine;
       
    79 
       
    80     iLogClient = CLogClient::NewL(CEikonEnv::Static()->FsSession());
       
    81     iLogEvent = CLogEvent::NewL();
       
    82 
       
    83 	CActiveScheduler::Add(this); // needed by CActive
       
    84     }
       
    85 
       
    86 CCreatorLogs::~CCreatorLogs()
       
    87     {
       
    88     LOGSTRING("Creator: CCreatorLogs::~CCreatorLogs");
       
    89 
       
    90     Cancel(); //from CActive
       
    91 
       
    92     if ( iEngine && iEntryIds.Count() )
       
    93         {
       
    94         TRAP_IGNORE( iEngine->WriteEntryIdsToStoreL( iEntryIds, KUidDictionaryUidLogs ) );
       
    95         }
       
    96     iEntryIds.Reset();
       
    97     iEntryIds.Close();
       
    98     
       
    99     delete iLogEvent;
       
   100     delete iLogClient;
       
   101 
       
   102     if (iParameters)
       
   103         delete iParameters;
       
   104     }
       
   105 
       
   106 //----------------------------------------------------------------------------
       
   107 
       
   108 TBool CCreatorLogs::AskDataFromUserL(TInt aCommand, TInt& aNumberOfEntries)
       
   109     {
       
   110     LOGSTRING("Creator: CCreatorLogs::AskDataFromUserL");
       
   111     if ( aCommand == ECmdDeleteLogs )
       
   112         {
       
   113         return iEngine->GetEngineWrapper()->YesNoQueryDialog( _L("Delete all log entries?") );
       
   114         }
       
   115     else if ( aCommand ==  ECmdDeleteCreatorLogs )
       
   116         {
       
   117         return iEngine->GetEngineWrapper()->YesNoQueryDialog( _L("Delete all log entries created with Creator?") );
       
   118         }
       
   119     return iEngine->GetEngineWrapper()->EntriesQueryDialog( aNumberOfEntries, _L("How many entries to create?") );
       
   120     }
       
   121 
       
   122 //----------------------------------------------------------------------------
       
   123 
       
   124 void CCreatorLogs::RunL()
       
   125 	{
       
   126     LOGSTRING("Creator: CCreatorLogs::RunL");
       
   127 
       
   128     // log writing finished, stop the async waiting
       
   129     iLogWriteWait.AsyncStop();
       
   130     }
       
   131 
       
   132 //----------------------------------------------------------------------------
       
   133 
       
   134 void CCreatorLogs::DoCancel()
       
   135 	{
       
   136     }
       
   137 
       
   138 //----------------------------------------------------------------------------
       
   139 
       
   140 TInt CCreatorLogs::CreateMissedCallEntryL(CLogsParameters *aParameters)
       
   141     {
       
   142     LOGSTRING("Creator: CCreatorLogs::CreateMissedCallEntryL");
       
   143 
       
   144     // clear any existing parameter definations
       
   145     delete iParameters;
       
   146     iParameters = NULL;
       
   147     
       
   148     CLogsParameters* parameters = aParameters;
       
   149     
       
   150     // random data needed if no predefined data available
       
   151     if (!parameters)
       
   152         {
       
   153         iParameters = new(ELeave) CLogsParameters;
       
   154         parameters = iParameters;
       
   155 
       
   156         /*iParameters->iMissedCallPhoneNumber->Des().Zero();
       
   157         iParameters->iMissedCallPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   158 
       
   159         iParameters->iMissedCallEventTime.UniversalTime();
       
   160         iParameters->iMissedCallEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );*/
       
   161         parameters->iPhoneNumber->Des().Zero();
       
   162         parameters->iPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   163         
       
   164         parameters->iEventTime.UniversalTime();
       
   165         parameters->iEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );
       
   166 
       
   167         }
       
   168     
       
   169     // defaults
       
   170     iLogEvent->SetId( KLogNullId );
       
   171     iLogEvent->SetEventType( KNullUid );
       
   172     iLogEvent->SetRemoteParty( KNullDesC );
       
   173     iLogEvent->SetDirection( KNullDesC );
       
   174     iLogEvent->SetTime( Time::NullTTime() );
       
   175     iLogEvent->SetDurationType( KLogNullDurationType );
       
   176     iLogEvent->SetDuration( KLogNullDuration );
       
   177     iLogEvent->SetStatus( KNullDesC );
       
   178     iLogEvent->SetSubject( KNullDesC );
       
   179     iLogEvent->SetNumber( KNullDesC );
       
   180     iLogEvent->SetContact( KNullContactId );
       
   181     iLogEvent->SetLink( KLogNullLink );
       
   182     iLogEvent->SetDescription( KNullDesC );
       
   183     iLogEvent->SetFlags( KLogNullFlags );
       
   184     iLogEvent->SetEventType(KLogCallEventTypeUid);
       
   185     iLogEvent->SetSubject(_L("A"));
       
   186 
       
   187     // set direction
       
   188     TLogString missed;
       
   189     iLogClient->GetString(missed, R_LOG_DIR_MISSED);
       
   190     iLogEvent->SetDirection(missed);
       
   191 
       
   192     // set duration
       
   193     iLogEvent->SetDurationType( KLogDurationNone );
       
   194     TLogDuration duration = 0;
       
   195     iLogEvent->SetDuration(duration);
       
   196 
       
   197     // set the phone number
       
   198     //iLogEvent->SetNumber( iParameters->iMissedCallPhoneNumber->Des() );
       
   199     iLogEvent->SetNumber( parameters->iPhoneNumber->Des() );
       
   200 
       
   201     // set event time
       
   202     //iLogEvent->SetTime( iParameters->iMissedCallEventTime );
       
   203     iLogEvent->SetTime( parameters->iEventTime );
       
   204 
       
   205     // start writing
       
   206     __ASSERT_ALWAYS(!IsActive(), User::Panic(_L("LogWriter"), 150));
       
   207 	iLogClient->AddEvent(*iLogEvent, iStatus);
       
   208 	SetActive();
       
   209 
       
   210     // wait till adding has finished
       
   211     iLogWriteWait.Start();
       
   212 
       
   213     // id has been generated, store it for being able to delete
       
   214     // entries created only with Creator
       
   215     iEntryIds.Append( iLogEvent->Id() );
       
   216 
       
   217     return iStatus.Int();  // should be KErrNone if writing was succesful
       
   218     }
       
   219 
       
   220 //----------------------------------------------------------------------------
       
   221 
       
   222 TInt CCreatorLogs::CreateReceivedCallEntryL(CLogsParameters *aParameters)
       
   223     {
       
   224     LOGSTRING("Creator: CCreatorLogs::CreateReceivedCallEntryL");
       
   225 
       
   226     // clear any existing parameter definations
       
   227     delete iParameters;
       
   228     iParameters = NULL;
       
   229     
       
   230     CLogsParameters* parameters = aParameters;
       
   231         
       
   232     // random data needed if no predefined data available
       
   233     if (!parameters)
       
   234         {
       
   235         iParameters = new(ELeave) CLogsParameters;
       
   236         parameters = iParameters;
       
   237 
       
   238         /*iParameters->iReceivedCallPhoneNumber->Des().Zero();
       
   239         iParameters->iReceivedCallPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   240 
       
   241         iParameters->iReceivedCallEventTime.UniversalTime();
       
   242         iParameters->iReceivedCallEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );
       
   243 
       
   244         iParameters->iReceivedCallDuration = iEngine->RandomNumber(7200);*/
       
   245         parameters->iPhoneNumber->Des().Zero();
       
   246         parameters->iPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   247         
       
   248         parameters->iEventTime.UniversalTime();
       
   249         parameters->iEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );
       
   250         
       
   251         parameters->iDuration = iEngine->RandomNumber(7200);
       
   252         }
       
   253    
       
   254     // defaults
       
   255     iLogEvent->SetId( KLogNullId );
       
   256     iLogEvent->SetEventType( KNullUid );
       
   257     iLogEvent->SetRemoteParty( KNullDesC );
       
   258     iLogEvent->SetDirection( KNullDesC );
       
   259     iLogEvent->SetTime( Time::NullTTime() );
       
   260     iLogEvent->SetDurationType( KLogNullDurationType );
       
   261     iLogEvent->SetDuration( KLogNullDuration );
       
   262     iLogEvent->SetStatus( KNullDesC );
       
   263     iLogEvent->SetSubject( KNullDesC );
       
   264     iLogEvent->SetNumber( KNullDesC );
       
   265     iLogEvent->SetContact( KNullContactId );
       
   266     iLogEvent->SetLink( KLogNullLink );
       
   267     iLogEvent->SetDescription( KNullDesC );
       
   268     iLogEvent->SetFlags( KLogNullFlags );
       
   269     iLogEvent->SetEventType(KLogCallEventTypeUid);
       
   270     iLogEvent->SetSubject(_L("A"));
       
   271 
       
   272     // set direction
       
   273     TLogString incoming;
       
   274     iLogClient->GetString(incoming, R_LOG_DIR_IN);
       
   275     iLogEvent->SetDirection(incoming);
       
   276 
       
   277     // set duration
       
   278     iLogEvent->SetDurationType( KLogDurationValid );
       
   279     //iLogEvent->SetDuration( iParameters->iReceivedCallDuration );
       
   280     iLogEvent->SetDuration( parameters->iDuration );
       
   281 
       
   282     // set the phone number
       
   283     //iLogEvent->SetNumber( iParameters->iReceivedCallPhoneNumber->Des() );
       
   284     iLogEvent->SetNumber( parameters->iPhoneNumber->Des() );
       
   285 
       
   286     // set event time
       
   287     //iLogEvent->SetTime( iParameters->iReceivedCallEventTime );
       
   288     iLogEvent->SetTime( parameters->iEventTime );
       
   289 
       
   290     // start writing
       
   291     __ASSERT_ALWAYS(!IsActive(), User::Panic(_L("LogWriter"), 151));
       
   292 	iLogClient->AddEvent(*iLogEvent, iStatus);
       
   293 	SetActive();
       
   294 
       
   295     // wait till adding has finished
       
   296     iLogWriteWait.Start();
       
   297 
       
   298     // id has been generated, store it for being able to delete
       
   299     // entries created only with Creator
       
   300     iEntryIds.Append( iLogEvent->Id() );
       
   301 
       
   302     return iStatus.Int();  // should be KErrNone if writing was succesful
       
   303     }
       
   304 
       
   305 //----------------------------------------------------------------------------
       
   306 
       
   307 
       
   308 TInt CCreatorLogs::CreateDialledNumberEntryL(CLogsParameters *aParameters)
       
   309     {
       
   310     LOGSTRING("Creator: CCreatorLogs::CreateDialledNumberEntryL");
       
   311 
       
   312     // clear any existing parameter definations
       
   313     delete iParameters;
       
   314     iParameters = NULL;
       
   315     
       
   316     CLogsParameters* parameters = aParameters; 
       
   317         
       
   318     // random data needed if no predefined data available
       
   319     if (!parameters)
       
   320         {
       
   321         iParameters = new(ELeave) CLogsParameters;
       
   322         parameters = iParameters;
       
   323 
       
   324         /*iParameters->iDialledNumberPhoneNumber->Des().Zero();
       
   325         iParameters->iDialledNumberPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   326 
       
   327         iParameters->iDialledNumberEventTime.UniversalTime();
       
   328         iParameters->iDialledNumberEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );
       
   329 
       
   330         iParameters->iDialledNumberDuration = iEngine->RandomNumber(7200);*/
       
   331         parameters->iPhoneNumber->Des().Zero();
       
   332         parameters->iPhoneNumber->Des().AppendNum( iEngine->RandomNumber(1000000, 9999999) );
       
   333 
       
   334         parameters->iEventTime.UniversalTime();
       
   335         parameters->iEventTime -= TTimeIntervalMinutes( iEngine->RandomNumber(12000) );
       
   336 
       
   337         parameters->iDuration = iEngine->RandomNumber(7200);
       
   338 
       
   339         }
       
   340    
       
   341     // defaults
       
   342     iLogEvent->SetId( KLogNullId );
       
   343     iLogEvent->SetEventType( KNullUid );
       
   344     iLogEvent->SetRemoteParty( KNullDesC );
       
   345     iLogEvent->SetDirection( KNullDesC );
       
   346     iLogEvent->SetTime( Time::NullTTime() );
       
   347     iLogEvent->SetDurationType( KLogNullDurationType );
       
   348     iLogEvent->SetDuration( KLogNullDuration );
       
   349     iLogEvent->SetStatus( KNullDesC );
       
   350     iLogEvent->SetSubject( KNullDesC );
       
   351     iLogEvent->SetNumber( KNullDesC );
       
   352     iLogEvent->SetContact( KNullContactId );
       
   353     iLogEvent->SetLink( KLogNullLink );
       
   354     iLogEvent->SetDescription( KNullDesC );
       
   355     iLogEvent->SetFlags( KLogNullFlags );
       
   356     iLogEvent->SetEventType(KLogCallEventTypeUid);
       
   357     iLogEvent->SetSubject(_L("A"));
       
   358 
       
   359     // set direction
       
   360     TLogString outgoing;
       
   361     iLogClient->GetString(outgoing, R_LOG_DIR_OUT);
       
   362     iLogEvent->SetDirection(outgoing);
       
   363 
       
   364     // set duration
       
   365     iLogEvent->SetDurationType( KLogDurationValid );
       
   366     //iLogEvent->SetDuration( iParameters->iDialledNumberDuration );
       
   367     iLogEvent->SetDuration( parameters->iDuration );
       
   368 
       
   369     // set the phone number
       
   370     //iLogEvent->SetNumber( iParameters->iDialledNumberPhoneNumber->Des() );
       
   371     iLogEvent->SetNumber( parameters->iPhoneNumber->Des() );
       
   372 
       
   373     // set event time
       
   374     //iLogEvent->SetTime( iParameters->iDialledNumberEventTime );
       
   375     iLogEvent->SetTime( parameters->iEventTime );
       
   376 
       
   377     // start writing
       
   378     __ASSERT_ALWAYS(!IsActive(), User::Panic(_L("LogWriter"), 152));
       
   379 	iLogClient->AddEvent(*iLogEvent, iStatus);
       
   380 	SetActive();
       
   381 
       
   382     // wait till adding has finished
       
   383     iLogWriteWait.Start();
       
   384 
       
   385     // id has been generated, store it for being able to delete
       
   386     // only entries created with Creator
       
   387     iEntryIds.Append( iLogEvent->Id() );
       
   388     
       
   389     return iStatus.Int();  // should be KErrNone if writing was succesful
       
   390     }
       
   391 
       
   392 //----------------------------------------------------------------------------
       
   393 void CCreatorLogs::DeleteAllL()
       
   394     {
       
   395     LOGSTRING("Creator: CCreatorLogs::DeleteAllL");
       
   396     iLogClient->ClearLog( TTime( Time::MaxTTime() ), iStatus ); 
       
   397     SetActive();
       
   398     
       
   399     // wait till delete has finished
       
   400     iLogWriteWait.Start();
       
   401     User::LeaveIfError( iStatus.Int() );
       
   402 
       
   403     // reset must be done here, because iEntryIds is stored in destructor
       
   404     iEntryIds.Reset();
       
   405     
       
   406     // all entries deleted, remove the Logs related registry
       
   407     iEngine->RemoveStoreL( KUidDictionaryUidLogs );
       
   408     }
       
   409 
       
   410 //----------------------------------------------------------------------------
       
   411 void CCreatorLogs::DeleteAllCreatedByCreatorL()
       
   412     {
       
   413     LOGSTRING("Creator: CCreatorLogs::DeleteAllCreatedByCreatorL");
       
   414     iEntryIds.Reset();
       
   415     
       
   416     // fetch ids of entries created by Creator
       
   417     iEngine->ReadEntryIdsFromStoreL( iEntryIds, KUidDictionaryUidLogs );
       
   418     
       
   419     // delete entries
       
   420     for ( TInt i = 0; i < iEntryIds.Count(); i++ )
       
   421         {
       
   422         // This could be implemented with while loop
       
   423         // with additional cancel flag. That would enable 
       
   424         // using CancelOp() and cancelling would be bit smoother.
       
   425         // With this for loop implementation all entries will be
       
   426         // deleted whether or not user cancels during logs operation.
       
   427 
       
   428         iLogClient->DeleteEvent( iEntryIds[i], iStatus );
       
   429         SetActive();        
       
   430         // wait till delete has finished
       
   431         iLogWriteWait.Start();
       
   432         }
       
   433     
       
   434     // reset must be done here, because iEntryIds is stored in destructor
       
   435     iEntryIds.Reset();
       
   436     
       
   437     // all entries deleted, remove the Logs related registry
       
   438     iEngine->RemoveStoreL( KUidDictionaryUidLogs );
       
   439     }