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 "LogServServer.h"
|
sl@0
|
17 |
#include "logservsession.h"
|
sl@0
|
18 |
#include "logservpanic.h"
|
sl@0
|
19 |
#include "LogServShutdownTimer.h"
|
sl@0
|
20 |
#include "LogServDatabaseMarshall.h"
|
sl@0
|
21 |
#include "LogServDatabaseDriver.h"
|
sl@0
|
22 |
#include "LogServBackupManager.h"
|
sl@0
|
23 |
#include "LogServOperationQueue.h"
|
sl@0
|
24 |
#include "LogServResourceInterpreter.h"
|
sl@0
|
25 |
#include "LogServDatabaseChangeTracker.h"
|
sl@0
|
26 |
#include "LogServRecentListManager.h"
|
sl@0
|
27 |
|
sl@0
|
28 |
|
sl@0
|
29 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
30 |
// -----> CLogServServer (source)
|
sl@0
|
31 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
32 |
|
sl@0
|
33 |
CLogServServer::CLogServServer()
|
sl@0
|
34 |
: CServer2(CActive::EPriorityStandard, ESharableSessions)
|
sl@0
|
35 |
{
|
sl@0
|
36 |
}
|
sl@0
|
37 |
|
sl@0
|
38 |
CLogServServer::~CLogServServer()
|
sl@0
|
39 |
{
|
sl@0
|
40 |
LOGTEXT("CLogServServer::~CLogServServer()");
|
sl@0
|
41 |
TDblQueIter<CSession2> iter(iSessionIter);
|
sl@0
|
42 |
iter.SetToFirst();
|
sl@0
|
43 |
|
sl@0
|
44 |
for (CSession2* session = iter++; session != NULL; session = iter++)
|
sl@0
|
45 |
{
|
sl@0
|
46 |
delete session;
|
sl@0
|
47 |
}
|
sl@0
|
48 |
|
sl@0
|
49 |
// Order is important
|
sl@0
|
50 |
delete iOperationQueue;
|
sl@0
|
51 |
//
|
sl@0
|
52 |
delete iDatabaseDriver;
|
sl@0
|
53 |
delete iChangeTracker;
|
sl@0
|
54 |
delete iDatabaseMarshall;
|
sl@0
|
55 |
//
|
sl@0
|
56 |
delete iRecentListManager;
|
sl@0
|
57 |
delete iResourceInterpreter;
|
sl@0
|
58 |
//
|
sl@0
|
59 |
delete iBackupManager;
|
sl@0
|
60 |
delete iShutdownTimer;
|
sl@0
|
61 |
iFsSession.Close();
|
sl@0
|
62 |
|
sl@0
|
63 |
LOGTEXT("CLogServServer::~CLogServServer() - end");
|
sl@0
|
64 |
}
|
sl@0
|
65 |
|
sl@0
|
66 |
void CLogServServer::ConstructL()
|
sl@0
|
67 |
{
|
sl@0
|
68 |
LOGTEXT("CLogServServer::ConstructL() - about to connect to file server");
|
sl@0
|
69 |
User::LeaveIfError(iFsSession.Connect());
|
sl@0
|
70 |
|
sl@0
|
71 |
LOGTEXT("CLogServServer::ConstructL() - about to start server");
|
sl@0
|
72 |
StartL(KLogServerFullName);
|
sl@0
|
73 |
|
sl@0
|
74 |
// Low level objects
|
sl@0
|
75 |
LOGTEXT("CLogServServer::ConstructL() - about to create shutdown timer");
|
sl@0
|
76 |
iShutdownTimer = CLogServShutdownTimer::NewL(Priority() + 1);
|
sl@0
|
77 |
|
sl@0
|
78 |
LOGTEXT("CLogServServer::ConstructL() - about to create backup manager");
|
sl@0
|
79 |
iBackupManager = CLogServBackupManager::NewL(Priority());
|
sl@0
|
80 |
|
sl@0
|
81 |
LOGTEXT("CLogServServer::ConstructL() - about to create resource interpreter");
|
sl@0
|
82 |
iResourceInterpreter = CLogServResourceInterpreter::NewL(iFsSession);
|
sl@0
|
83 |
|
sl@0
|
84 |
LOGTEXT("CLogServServer::ConstructL() - about to create recent list manager");
|
sl@0
|
85 |
iRecentListManager = CLogServRecentListManager::NewL(*iResourceInterpreter, R_LOG_RECENT);
|
sl@0
|
86 |
|
sl@0
|
87 |
// Medium level objects
|
sl@0
|
88 |
LOGTEXT("CLogServServer::ConstructL() - about to create database marshall");
|
sl@0
|
89 |
iDatabaseMarshall = CLogServDatabaseMarshall::NewL(iFsSession, *iResourceInterpreter, *iBackupManager);
|
sl@0
|
90 |
|
sl@0
|
91 |
LOGTEXT("CLogServServer::ConstructL() - about to create change tracker");
|
sl@0
|
92 |
iChangeTracker = CLogServDatabaseChangeTracker::NewL(*iDatabaseMarshall, *iBackupManager, Priority() + 1);
|
sl@0
|
93 |
|
sl@0
|
94 |
// Setup the pointer to the change tracker from within the database marshall (since its underlying
|
sl@0
|
95 |
// mixin provides a means of submitting change events)
|
sl@0
|
96 |
LOGTEXT("CLogServServer::ConstructL() - about to set change interface for database marshall ");
|
sl@0
|
97 |
iDatabaseMarshall->SetChangeInterface(*iChangeTracker);
|
sl@0
|
98 |
|
sl@0
|
99 |
// These objects are quite high level... i.e. they use the engine objects above
|
sl@0
|
100 |
LOGTEXT("CLogServServer::ConstructL() - about to create database driver");
|
sl@0
|
101 |
iDatabaseDriver = CLogServDatabaseDriver::NewL(*iBackupManager, *iDatabaseMarshall, *iResourceInterpreter, *iRecentListManager, Priority() - 1);
|
sl@0
|
102 |
|
sl@0
|
103 |
LOGTEXT("CLogServServer::ConstructL() - about to create operation queue");
|
sl@0
|
104 |
iOperationQueue = CLogServOperationQueue::NewL(*iDatabaseDriver, Priority());
|
sl@0
|
105 |
|
sl@0
|
106 |
// Ensure that the server still exits even if the 1st client fails to connect
|
sl@0
|
107 |
// Only shutdown the server if it's transient - by default it isn't, but keeping
|
sl@0
|
108 |
// this code here in case this changes
|
sl@0
|
109 |
if (iTransient)
|
sl@0
|
110 |
iShutdownTimer->Start();
|
sl@0
|
111 |
|
sl@0
|
112 |
LOGTEXT("CLogServServer::ConstructL() - end");
|
sl@0
|
113 |
}
|
sl@0
|
114 |
|
sl@0
|
115 |
CLogServServer* CLogServServer::NewLC()
|
sl@0
|
116 |
{
|
sl@0
|
117 |
CLogServServer* self = new(ELeave) CLogServServer;
|
sl@0
|
118 |
CleanupStack::PushL(self);
|
sl@0
|
119 |
self->ConstructL();
|
sl@0
|
120 |
return self;
|
sl@0
|
121 |
}
|
sl@0
|
122 |
|
sl@0
|
123 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
124 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
125 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
126 |
|
sl@0
|
127 |
void CLogServServer::SLOHandleEvent(TLogServSessionId /*aId*/, TLogServSessionEvent aEvent)
|
sl@0
|
128 |
{
|
sl@0
|
129 |
switch(aEvent)
|
sl@0
|
130 |
{
|
sl@0
|
131 |
case ELogServSessionEventCreated:
|
sl@0
|
132 |
iShutdownTimer->Cancel();
|
sl@0
|
133 |
++iSessionCount;
|
sl@0
|
134 |
break;
|
sl@0
|
135 |
case ELogServSessionEventDestroyed:
|
sl@0
|
136 |
// Only shutdown the server if it's transient - by default it isn't
|
sl@0
|
137 |
if (--iSessionCount == 0 && iTransient)
|
sl@0
|
138 |
iShutdownTimer->Start();
|
sl@0
|
139 |
break;
|
sl@0
|
140 |
}
|
sl@0
|
141 |
|
sl@0
|
142 |
}
|
sl@0
|
143 |
|
sl@0
|
144 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
145 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
146 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
147 |
CSession2* CLogServServer::NewSessionL(const TVersion& /*aVersion*/,const RMessage2& /*aMessage*/) const
|
sl@0
|
148 |
//
|
sl@0
|
149 |
// Create a new client session. This should really check the version number.
|
sl@0
|
150 |
//
|
sl@0
|
151 |
{
|
sl@0
|
152 |
CLogServServer* self = const_cast<CLogServServer*>(this);
|
sl@0
|
153 |
const TLogServSessionId sessionId = ++self->iNextFreeSessionId;
|
sl@0
|
154 |
|
sl@0
|
155 |
LOGTEXT2("CLogServServer::NewSessionL() - session id is: %d", sessionId);
|
sl@0
|
156 |
//
|
sl@0
|
157 |
CLogServSession* session = new(ELeave) CLogServSession(sessionId,
|
sl@0
|
158 |
*self,
|
sl@0
|
159 |
*iBackupManager,
|
sl@0
|
160 |
*iDatabaseDriver,
|
sl@0
|
161 |
*iOperationQueue,
|
sl@0
|
162 |
*iChangeTracker,
|
sl@0
|
163 |
*iDatabaseMarshall);
|
sl@0
|
164 |
LOGTEXT("CLogServServer::NewSessionL() - end");
|
sl@0
|
165 |
return session;
|
sl@0
|
166 |
}
|
sl@0
|
167 |
|
sl@0
|
168 |
#ifdef _DEBUG
|
sl@0
|
169 |
void CLogServServer::MakeTransient(TBool aTransient)
|
sl@0
|
170 |
{
|
sl@0
|
171 |
iTransient = aTransient;
|
sl@0
|
172 |
}
|
sl@0
|
173 |
#endif//_DEBUG
|
sl@0
|
174 |
|
sl@0
|
175 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
176 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
177 |
/////////////////////////////////////////////////////////////////////////////////////////
|
sl@0
|
178 |
|