locationtriggering/ltserver/ltserverlogic/src/lbttriggerfirehandler.cpp
author hgs
Wed, 03 Nov 2010 23:28:39 +0530
changeset 56 4e949f03ecc5
child 39 3efc7a0e8755
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2006,2007 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Implementation to fire triggers, both session and startup
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// INCLUDE FILES
hgs
parents:
diff changeset
    20
#include <e32std.h>	// For RProcess
hgs
parents:
diff changeset
    21
#include <lbtstartuptrigger.h>
hgs
parents:
diff changeset
    22
#include <lbttriggerentry.h>
hgs
parents:
diff changeset
    23
#include <lbttriggerfilterbyattribute.h>
hgs
parents:
diff changeset
    24
#include "lbttriggerfirehandler.h"
hgs
parents:
diff changeset
    25
#include "lbtserverconsts.h"
hgs
parents:
diff changeset
    26
#include "lbtglobal.h"
hgs
parents:
diff changeset
    27
#include "lbtstartuptrigger.h"
hgs
parents:
diff changeset
    28
#include "lbtcontainer.h"
hgs
parents:
diff changeset
    29
#include "lbtcontainertriggerentry.h"
hgs
parents:
diff changeset
    30
#include "lbttriggerfiltercomposite.h"
hgs
parents:
diff changeset
    31
#include "lbtcontainerextendedtriggerinfo.h"
hgs
parents:
diff changeset
    32
#include "lbtnotificationmap.h"
hgs
parents:
diff changeset
    33
#include "lbtlogger.h"
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// ===================== MEMBER FUNCTIONS =====================
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
// CLbtTriggerFireHandler::NewL
hgs
parents:
diff changeset
    40
// Symbian Two - phase constructor
hgs
parents:
diff changeset
    41
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    42
//
hgs
parents:
diff changeset
    43
CLbtTriggerFireHandler* CLbtTriggerFireHandler::NewL( CLbtNotificationMap& aNotificationMap,
hgs
parents:
diff changeset
    44
			    									  CLbtContainer& aContainer )
hgs
parents:
diff changeset
    45
	{
hgs
parents:
diff changeset
    46
	FUNC_ENTER("CLbtTriggerFireHandler::NewL");
hgs
parents:
diff changeset
    47
	CLbtTriggerFireHandler* self = new (ELeave) CLbtTriggerFireHandler(aNotificationMap,
hgs
parents:
diff changeset
    48
																	   aContainer);
hgs
parents:
diff changeset
    49
	CleanupStack::PushL(self);
hgs
parents:
diff changeset
    50
	self->ConstructL();
hgs
parents:
diff changeset
    51
	CleanupStack::Pop(); // self
hgs
parents:
diff changeset
    52
	return self;
hgs
parents:
diff changeset
    53
	}
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    56
// CLbtTriggerFireHandler::~CLbtTriggerFireHandler
hgs
parents:
diff changeset
    57
// Destructor
hgs
parents:
diff changeset
    58
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    59
//
hgs
parents:
diff changeset
    60
CLbtTriggerFireHandler::~CLbtTriggerFireHandler()
hgs
parents:
diff changeset
    61
	{
hgs
parents:
diff changeset
    62
	FUNC_ENTER("CLbtTriggerFireHandler::~CLbtTriggerFireHandler");
hgs
parents:
diff changeset
    63
	Cancel();
hgs
parents:
diff changeset
    64
	iFireInfoArray.Reset();
hgs
parents:
diff changeset
    65
	iTriggerArray.ResetAndDestroy();
hgs
parents:
diff changeset
    66
	}
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    69
// CLbtTriggerFireHandler::CLbtTriggerFireHandler
hgs
parents:
diff changeset
    70
// C++ Default constructor
hgs
parents:
diff changeset
    71
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    72
//
hgs
parents:
diff changeset
    73
CLbtTriggerFireHandler::CLbtTriggerFireHandler( CLbtNotificationMap& aNotificationMap,	    									    
hgs
parents:
diff changeset
    74
	    									    CLbtContainer& aContainer )
hgs
parents:
diff changeset
    75
	: CActive( EPriorityHigh ), iNotificationMap(aNotificationMap),iContainer(aContainer)
hgs
parents:
diff changeset
    76
	{
hgs
parents:
diff changeset
    77
	
hgs
parents:
diff changeset
    78
	}
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    81
// CLbtTriggerFireHandler::FireTriggerL
hgs
parents:
diff changeset
    82
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    83
//
hgs
parents:
diff changeset
    84
void CLbtTriggerFireHandler::FireTriggerL(TLbtTriggerFireInfo aFireInfo)
hgs
parents:
diff changeset
    85
	{
hgs
parents:
diff changeset
    86
	FUNC_ENTER("CLbtTriggerFireHandler::FireTriggerL");
hgs
parents:
diff changeset
    87
	// queue the fire info into the array;
hgs
parents:
diff changeset
    88
	iFireInfoArray.Append(aFireInfo);
hgs
parents:
diff changeset
    89
	
hgs
parents:
diff changeset
    90
	if(!IsActive())
hgs
parents:
diff changeset
    91
		{
hgs
parents:
diff changeset
    92
		// Add this active object to the active scheduler
hgs
parents:
diff changeset
    93
		CActiveScheduler::Add(this);
hgs
parents:
diff changeset
    94
		
hgs
parents:
diff changeset
    95
		// Fire this trigger
hgs
parents:
diff changeset
    96
		FireNextTrigger();
hgs
parents:
diff changeset
    97
		}
hgs
parents:
diff changeset
    98
	}
hgs
parents:
diff changeset
    99
	
hgs
parents:
diff changeset
   100
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   101
// CLbtTriggerFireHandler::ConstructL
hgs
parents:
diff changeset
   102
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   103
//
hgs
parents:
diff changeset
   104
void CLbtTriggerFireHandler::ConstructL()
hgs
parents:
diff changeset
   105
	{
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
	}
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   110
// CLbtTriggerFireHandler::RunL
hgs
parents:
diff changeset
   111
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   112
//
hgs
parents:
diff changeset
   113
void CLbtTriggerFireHandler::RunL()
hgs
parents:
diff changeset
   114
	{
hgs
parents:
diff changeset
   115
	FUNC_ENTER("CLbtTriggerFireHandler::RunL");
hgs
parents:
diff changeset
   116
	// Got the response for List Triggers from container
hgs
parents:
diff changeset
   117
	if(iStatus.Int() == KErrNone)
hgs
parents:
diff changeset
   118
		{
hgs
parents:
diff changeset
   119
        // Notify the client that this trigger is fired.
hgs
parents:
diff changeset
   120
        NotifyTriggerFired();
hgs
parents:
diff changeset
   121
        
hgs
parents:
diff changeset
   122
    	// Start the client process if the trigger is an start up trigger
hgs
parents:
diff changeset
   123
    	CLbtTriggerEntry* triggerEntry = iTriggerArray[0]->TriggerEntry();
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    	// If the trigger is a startup trigger then start the trigger
hgs
parents:
diff changeset
   126
    	// handling process
hgs
parents:
diff changeset
   127
    	if(triggerEntry->Type() == CLbtTriggerEntry::ETypeStartup)
hgs
parents:
diff changeset
   128
    		{
hgs
parents:
diff changeset
   129
    		StartTriggerHandlingProcess(triggerEntry);
hgs
parents:
diff changeset
   130
    		}
hgs
parents:
diff changeset
   131
		}
hgs
parents:
diff changeset
   132
	else
hgs
parents:
diff changeset
   133
	    {
hgs
parents:
diff changeset
   134
        // Nothing to do in case the List Triggers returns error.
hgs
parents:
diff changeset
   135
        // So we just log this error case.
hgs
parents:
diff changeset
   136
        LBT_TRACE(KLbtLogError|KLbtLogServerLogic, __FILE__, __LINE__, "Error %d in List Triggers. Hence trigger %d not fired", iStatus.Int(),iFireInfoArray[0].iTriggerId);
hgs
parents:
diff changeset
   137
	    }
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
	// Removed the fired trigger from the fire info queue
hgs
parents:
diff changeset
   140
	iFireInfoArray.Remove(0);
hgs
parents:
diff changeset
   141
	
hgs
parents:
diff changeset
   142
	// If there are any more trigger fire requests then fire the next trigger
hgs
parents:
diff changeset
   143
	if(iFireInfoArray.Count())
hgs
parents:
diff changeset
   144
		{
hgs
parents:
diff changeset
   145
		FireNextTrigger();
hgs
parents:
diff changeset
   146
		}
hgs
parents:
diff changeset
   147
	else
hgs
parents:
diff changeset
   148
		{
hgs
parents:
diff changeset
   149
		// No trigger to be fired, so remove this AO from the 
hgs
parents:
diff changeset
   150
		// active scheduler queue
hgs
parents:
diff changeset
   151
		Deque();
hgs
parents:
diff changeset
   152
		}
hgs
parents:
diff changeset
   153
	}
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   156
// CLbtTriggerFireHandler::RunError
hgs
parents:
diff changeset
   157
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   158
//
hgs
parents:
diff changeset
   159
TInt CLbtTriggerFireHandler::RunError( TInt /*aError*/ )
hgs
parents:
diff changeset
   160
    {
hgs
parents:
diff changeset
   161
    return KErrNone;
hgs
parents:
diff changeset
   162
    }
hgs
parents:
diff changeset
   163
    
hgs
parents:
diff changeset
   164
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   165
// CLbtTriggerFireHandler::FireNextTrigger
hgs
parents:
diff changeset
   166
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   167
//
hgs
parents:
diff changeset
   168
void CLbtTriggerFireHandler::FireNextTrigger()
hgs
parents:
diff changeset
   169
	{
hgs
parents:
diff changeset
   170
	FUNC_ENTER("CLbtTriggerFireHandler::FireNextTrigger");
hgs
parents:
diff changeset
   171
	// Check if any trigger is in the process of being fired	
hgs
parents:
diff changeset
   172
	if(!IsActive())
hgs
parents:
diff changeset
   173
		{
hgs
parents:
diff changeset
   174
		// Clear the array before it can be used again
hgs
parents:
diff changeset
   175
		iTriggerArray.ResetAndDestroy();
hgs
parents:
diff changeset
   176
		
hgs
parents:
diff changeset
   177
		// Get the trigger entry from container
hgs
parents:
diff changeset
   178
		RArray<TLbtTriggerId> triggerId;
hgs
parents:
diff changeset
   179
		triggerId.Append( iFireInfoArray[0].iTriggerId );
hgs
parents:
diff changeset
   180
		iContainer.GetTriggers( triggerId, 
hgs
parents:
diff changeset
   181
								iTriggerArray, 
hgs
parents:
diff changeset
   182
								iAOIdentificationNum,
hgs
parents:
diff changeset
   183
								iStatus);
hgs
parents:
diff changeset
   184
		SetActive();
hgs
parents:
diff changeset
   185
		
hgs
parents:
diff changeset
   186
		triggerId.Close();		
hgs
parents:
diff changeset
   187
		}
hgs
parents:
diff changeset
   188
	}
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   191
// CLbtTriggerFireHandler::DoCancel
hgs
parents:
diff changeset
   192
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   193
//
hgs
parents:
diff changeset
   194
void CLbtTriggerFireHandler::DoCancel()
hgs
parents:
diff changeset
   195
	{
hgs
parents:
diff changeset
   196
	FUNC_ENTER("CLbtTriggerFireHandler::DoCancel");
hgs
parents:
diff changeset
   197
	iContainer.CancelAsyncOperation(iAOIdentificationNum);
hgs
parents:
diff changeset
   198
	}
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   201
// CLbtTriggerFireHandler::NotifyTriggerFired
hgs
parents:
diff changeset
   202
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   203
//
hgs
parents:
diff changeset
   204
void CLbtTriggerFireHandler::NotifyTriggerFired()
hgs
parents:
diff changeset
   205
    {
hgs
parents:
diff changeset
   206
    FUNC_ENTER("CLbtTriggerFireHandler::NotifyTriggerFired");
hgs
parents:
diff changeset
   207
	// Search the message array if the process has registered for 
hgs
parents:
diff changeset
   208
	// trigger fire notification
hgs
parents:
diff changeset
   209
	RMessage2 message;
hgs
parents:
diff changeset
   210
	CLbtContainerTriggerEntry* trigger = iTriggerArray[0];
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
    // Write the trigger fire info in the message
hgs
parents:
diff changeset
   213
    TPckg<TLbtTriggerFireInfo> fireInfo(iFireInfoArray[0]);
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
	while( !iNotificationMap.Retreive(message,trigger->ExtendedTriggerInfo()->OwnerSid(),
hgs
parents:
diff changeset
   216
                       ELbtNotifyTriggerFired) )
hgs
parents:
diff changeset
   217
	    {
hgs
parents:
diff changeset
   218
        TInt retVal = LbtGlobal::Write(message, KParamTriggerFireInfo, fireInfo);
hgs
parents:
diff changeset
   219
        // Complete the message with the error code.
hgs
parents:
diff changeset
   220
        LbtGlobal::RequestComplete(message, retVal);
hgs
parents:
diff changeset
   221
	    }
hgs
parents:
diff changeset
   222
    }
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   225
// CLbtTriggerFireHandler::StartTriggerHandlingProcess
hgs
parents:
diff changeset
   226
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   227
//
hgs
parents:
diff changeset
   228
void CLbtTriggerFireHandler::StartTriggerHandlingProcess(
hgs
parents:
diff changeset
   229
    CLbtTriggerEntry* aTriggerEntry)
hgs
parents:
diff changeset
   230
    {
hgs
parents:
diff changeset
   231
    FUNC_ENTER("CLbtTriggerFireHandler::StartTriggerHandlingProcess");
hgs
parents:
diff changeset
   232
	CLbtStartupTrigger* startupTrigger = 
hgs
parents:
diff changeset
   233
	                        static_cast<CLbtStartupTrigger*>(aTriggerEntry);
hgs
parents:
diff changeset
   234
    
hgs
parents:
diff changeset
   235
	TSecureId secureId;
hgs
parents:
diff changeset
   236
	TFileName fileName;
hgs
parents:
diff changeset
   237
	startupTrigger->GetProcessId(fileName, secureId);
hgs
parents:
diff changeset
   238
	
hgs
parents:
diff changeset
   239
	RProcess proc;
hgs
parents:
diff changeset
   240
	TInt retVal = proc.Create(fileName, startupTrigger->CommandLine());
hgs
parents:
diff changeset
   241
	if(retVal == KErrNone)
hgs
parents:
diff changeset
   242
		{
hgs
parents:
diff changeset
   243
		proc.Resume();
hgs
parents:
diff changeset
   244
		}
hgs
parents:
diff changeset
   245
	proc.Close();
hgs
parents:
diff changeset
   246
	}
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
hgs
parents:
diff changeset
   249
// end of file