homescreenpluginsrv/hspsmanager/inc/hspsthemeserver.h
changeset 0 79c6a41cd166
child 9 d0529222e3f0
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/homescreenpluginsrv/hspsmanager/inc/hspsthemeserver.h	Thu Dec 17 08:54:17 2009 +0200
@@ -0,0 +1,1083 @@
+/*
+* Copyright (c) 1020 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:  HSPS server
+* 
+*  Architecture
+*  ************
+*  ChspsThemeServer derives CPolicyServer when compiled on EKA2 based Symbian OS.
+*  ChspsThemeServer depends on the following classes:
+*  - ChspsInstallationHandler which implements MhspsInstallationHandler,
+*  - ChspsMaintenanceHandler which implements MhspsMaintenanceHandler,
+*  - ChspsClientRequestHandler which implements MhspsClientRequestHandler,
+*  - ChspsDefinitionRepository and ChspsODT from Xuikon, 
+*  - ChspsFileChangeListener,
+*  - ChspsAutoInstaller, and
+*  - CRepository from Symbian.
+*
+*  Functionality
+*  *************
+*  When client connects to hspsThemeServer, the access rights are checked. 
+*  If access is granted, a server session is created. Once connected, client may
+*  perform service requests as long as it is connected. Service requests are 
+*  served by initiating appropriate service handlers. These service handlers are
+*  Symbian active objects, based on CActive-class. In using active ojects, it is
+*  possible to perform long-lasting service requests without blocking others 
+*  clients getting served on-time. Active objects are also used to assist 
+*  services to perform asynchronous operations internally, for e.g. when service
+*  is executing slow media conversions. Furthermore, some of these services are
+*  extended to implement timer-functionality, based on CTimer-class. 
+*  These active timers are used to control different time-based server 
+*  operations and initiate service-state refreshing functionality.
+*  hspsThemeServer contains auto-install feature that can install Application
+*  Theme on SISX-packet exctraction.
+*    
+*  
+*  Installation Handler
+*  ====================
+*  ChspsInstallatioHandler-active object performs all installation related
+*  functionality. Installation concerns reading installation instructions from 
+*  manifest-file, utilizind Xuikon Definition Engine to parse xml- and 
+*  css-files, and apply style and localisation information defined in dtd-files
+*  into the DOM-document created. Installer also handles resources that theme 
+*  may include. Some resource types may need conversions to fit on the target
+*  device's screen or audio device etc. In this case, the installer performs 
+*  media conversions by its Media Converter. Conversions are asynchronous and
+*  they deploy MIME-types. For more information of media conversions, see 
+*  ChspsMediaConverter documentation. When installation is successful, 
+*  Installation Handler utilizes Xuikon Definition Repository to store the 
+*  results. The resulted objects are for e.g. unlocalised and localised 
+*  versions of application theme. Theme associated resources are also handled 
+*  in unlocalised and localised versions. Resources are stored on repository 
+*  and their related information is stored on the list of ChspsResource-objects
+*  - a resource list. This list of ChspsResource-objects is called Resource List.
+*  Definition Repository is located in hspsThemeServer private  folder. 
+*  Repository is organisized by theme header information. 
+*  For more information, see hspsResource documentation.
+*  On theme updates, i.e. installation over previous one, Installation Handler
+*  deploys ChspsSecurityEnforcer to control theme update rights.
+*  For more information, see ChspsSecurityEnforcer documentation and 
+*  ChspsInstallatioHandler documentation. 
+*  
+*  Maintenance Handler
+*  ===================
+*  ChspsMaintenanceHandler-active timer performs all theme maintenance related 
+*  functionality. Maintenance services includes theme listing, theme activation,
+*  theme removal and default theme restoring operations. Maintenance functions 
+*  deploy Xuikon Definition Repository and Symbian Central Repository. 
+*  Definition Repository maintains Application Themes in save place and Central
+*  Repository maintains the information about which theme is active for what 
+*  application. Information in Central Repository is presented in pairs of 
+*  application UID and active theme UID.
+*  For more information, see ChspsMaintenanceHandler documentation. 
+*
+*  Client Request Handler
+*  ======================
+*  ChspsClientRequestHandler-active timer performs all request accesses from 
+*  Rendering Engine. When request exists, the just right one application theme 
+*  is delivered to client process using memory chunk passing. Resource List is
+*  delivered too. Client Request Handler uses Xuikon Definition Repository and 
+*  Symbian Central Repository to get match theme on the request. Client Request
+*  Handler serves also resource accesses. In using file handle passing 
+*  introduced by Symbian Platform Security concept, Client Request Service 
+*  arranges a resource access to hspsThemeServer's private folder for the client 
+*  process. RFile handle passing is used. 
+*  For more information, see ChspsClientRequestHandler documentation.
+*
+*  File Change Listener
+*  ==================
+*  ChspsFileChangeListener listens to given file folder and notifies its observer
+*  if there is any file change. Observer is given as a parameter on 
+*  initialising the listener. Observer must implement MhspsFileChangeObserver-interface.
+*  FileChangeListener is asynchronous object that deploys Symbian RFs client-sideAutoInstaller
+*  handle on File Manager. FileChangeListener is intended to be used by any object
+*  that wants listen Symbian file system events.
+*
+*  Auto Installer
+*  ==============
+*  ChspsAutoInstaller installs theme from given location. It is intended
+*  to be used by hspsThemeServer directly. AutoInstaller is initiated
+*  when FileChangeListener finds installable theme source on given
+*  location. Theme source is set during the SISX-package exctraction. 
+*  AutoInstaller is deployed by calling its function InstallThemeL with manifest-file 
+*  of the installable theme source set.
+*  AutoInstaller deploys ChspsInstallationHandler. ChspsInstallationHandler
+*  is asynchronous object, there for AutoInstaller is asynchronous object
+*  as well capable to deploy asynchronous installation.
+*  When installation ends, AutoInstaller calls its observer with 
+*  ThspsServiceCompletedMessage-type parameter. Observer is given on
+*  initialising of AutoInstaller and it must be ChspsThemeServer-type.
+*  AutoInstaller have functions to get ODT-header of successfully installed
+*  theme and ChspsResult-typed object expressing errors in unsuccessful cases.   
+*
+*  Security Enforcer
+*  =================
+*  ChspsSecurityEnforcer performs all security related functions in Xuikon
+*  Application Theme Management services.
+*  These functions are the following:
+*  - locking policy functionality,
+*  - style locking policy functionality,
+*  - control user access on service request, and
+*  - validate content of user queries.
+*
+*  Performance accelerators
+*  ************************
+*
+*  HeaderListCache
+*  ---------------
+*  To speed up serving the theme request operations initiated by Rendering 
+*  Engine in theme usage cases, hspsThemeServer maintains cache of the header
+*  information of the themes stored in Definition Repository. When installation
+*  occurs, cache is updated. First time the cache is updated when hspsThemeServer
+*  starts - server is started by system starter service. This quaranties
+*  that cache is up to date and hit will occur on the very first access. 
+*  Cache is updated also by MaintenanceHandler and ClientRequestHandler on 
+*  the cases where content of repository is affected.
+* 
+*  Pre-initialized objects
+*  -----------------------
+*  hspsThemeServer speeds up the performance also by pre-initialized objects 
+*  which it passes to ChspsClientRequestHandler when one is initiated on new 
+*  Client Request Service server session. These objects are the following:
+*  - ChspsDefinitionRepository
+*  - CRepository for the KhspsThemeStatusRepositoryUid  {0x10207342} 
+*
+*
+*/
+
+
+#ifndef __hspsTHEMESERVER_H__
+#define __hspsTHEMESERVER_H__
+
+#include <e32base.h>
+#include <abclient.h>
+
+#include "hspsfilechangelistener.h"
+#include "hspscenreplistener.h"
+#if defined(WINSCW) || defined(__WINS__)
+#include "hspsfamilylistener.h"
+#endif // defined(WINSCW)
+#include "hspsthememanagement.h"
+#include "hspsodt.h"
+#include "hspsdefinitionrepository.h"
+#include "hspsbrobserver.h"
+#include "hspsbrhandler.h"
+
+#include "hsps_builds_cfg.hrh"
+
+/** hspsThemeServer name: */
+_LIT(KhspsThemeServerName,"hspsthemeserver");
+
+/** Supported manifest version */
+_LIT(KhspsSupportedManifestVersion,"1.0");
+
+/** hspsThemeServer Uid3 = SECUREID. */
+const TUid KhspsThemeServerUid3 = {0x200159C0}; //old uid 0x10207254};
+
+/** 
+*   KhspsThemeServerMajorVersionNumber, KhspsThemeServerMinorVersionNumber, 
+*   and KhspsThemeServerBuildVersionNumber.
+*   These constants define a version to be given for creating a session 
+*   with the hspsThemeServer.
+*/
+const TUint KhspsThemeServerMajorVersionNumber=1;
+const TUint KhspsThemeServerMinorVersionNumber=0;
+const TUint KhspsThemeServerBuildVersionNumber=0;
+
+/*
+*  KDefaultMessageSlots. Number of hspsThemeServer message slots.
+*  Server slots allocation rules: 1 for synchronous request, 1 for each
+*  concurrent outstanding asynchronous requests and 1 for each cancellation
+*  => 3 in this case.
+*/
+const TInt KDefaultMessageSlots = 3;
+
+// Forward declarations.
+class ChspsDefinitionRepository;
+class ChspsDefinitionEngineInterface;
+class CRepository;
+class ChspsSecurityEnforcer;
+class ChspsRomInstaller;
+class ChspsAutoInstaller;
+
+#ifdef HSPS_LOG_ACTIVE
+class ChspsLogBus;
+#endif
+
+// Keys for the Central Repository
+const TInt KCenrepKeyLang                = 100000001;      // Device language from previous startup
+const TInt KCenrepKeyPostRFS             = 100000002;      // Holds information whether the post RFS initializations have been done 
+const TInt KCenrepKeyCheckConf           = 100000003;      // Holds information whether the configuration states must be checked 
+const TInt KCenrepKeyAccessControlList   = 100000004;      // Holds information about security access control list
+
+const TInt KCenRepBufferSize = 255;   // Control Access List length
+
+/*
+* Server's policy.
+*/
+
+/* Total number of ranges */
+const TUint hspsThemeRangeCount = 4;
+
+/* Definition of the ranges of IPC numbers */
+const TInt hspsThemeRanges[hspsThemeRangeCount] = 
+        {
+        EhspsInstallationBase, 	/* installation messages (0,1,2 ) */
+        EhspsMaintenanceBase, 	/* maintenance messages (3,4,5,6,7,8) */
+        EhspsClientRequestBase, /* client request messages (9,10,11,12,13) */
+        EhspsNotSupported, 		/* and up; non implemented function end of range check ; ENotSupported */ 
+        }; 
+
+/* Policy to implement for each of the above ranges */       
+const TUint8 hspsThemeElementsIndex[hspsThemeRangeCount] = 
+        {
+        CPolicyServer::ECustomCheck, //applies to 0th range
+        CPolicyServer::ECustomCheck, //applies to 1st range
+        CPolicyServer::ECustomCheck, //applies to 2nd range
+        CPolicyServer::ENotSupported //applies to 3rd range (out of range IPC)
+        };
+
+/* Specific capability checks */
+const CPolicyServer::TPolicyElement hspsThemeElements[] = 
+        {
+        {_INIT_SECURITY_POLICY_C1(ECapabilityReadUserData), CPolicyServer::EFailClient},  
+        //policy "0"; fail call if ReadUserData not present
+        {_INIT_SECURITY_POLICY_C1(ECapabilityTCB), CPolicyServer::EFailClient} 
+        //policy "1"; fail call if TCB not present
+        };
+
+/* Package all the above together into a policy */
+const CPolicyServer::TPolicy hspsThemePolicy =
+        {
+        CPolicyServer::EAlwaysPass, /* specifies all connect attempts should pass */
+        hspsThemeRangeCount,  /* number of ranges */                                  
+        hspsThemeRanges,  /* ranges array */
+        hspsThemeElementsIndex, /* elements<->ranges index */
+        hspsThemeElements,    /* array of elements */
+        };
+
+// File filters related to imports folder
+_LIT( KFilterAllImportsV1, "*.dat");
+_LIT( KFilterAllAppImportsV1, "app_*.dat");
+_LIT( KFilterAllPluginImportsV1, "plugin_*.dat");
+_LIT( KFilterAllImportsV2, "*.*");
+
+#ifdef _hsps_SERVER_SHUTDOWN_ENABLED_
+/** 
+ * MShutdownObserver
+ * Observer for automatic shutdown class.
+ * 
+ * @since S60 5.0  
+ */
+class MShutdownObserver
+    {
+public:
+    /**
+    * Notifies observer that shutdown is initiating.
+    * 
+    * @since S60 5.0
+    */
+    virtual void ShutdownInitiating() = 0;
+    };
+
+/** 
+ * CShutdown.
+ * Auto shutdown class (standard pattern)
+ * 
+ * @since S60 5.0  
+ */
+class CShutdown : public CTimer
+    {    
+public:
+    /**
+    * Create new shutdown timer.
+    * 
+    * @since S60 5.0 
+    * @param aObserver Shutdown observer.
+    */    
+    static CShutdown* NewL( MShutdownObserver& aObserver );
+
+    /**
+    * Start shutdown timer.
+    * 
+    * @since S60 5.0
+    */        
+    void Start();
+  
+protected:
+    /**
+    * C++ constructor.
+    *
+    * @since S60 5.0  
+    * @param aObserver Shutdown observer.
+    */        
+    CShutdown( MShutdownObserver& aObserver );    
+    
+    /**
+    * Symbian 2nd phase constructor.
+    * 
+    * @since S60 5.0
+    */        
+    void ConstructL();
+
+private:
+    /**
+    * From CActive.
+    */        
+    void RunL();
+    
+private:
+    // Shutdown delay.
+    enum { KhspsShutdownDelay = 2000000 };
+    
+    // Shutdown observer.
+    MShutdownObserver& iObserver;
+  };
+#endif // _hsps_SERVER_SHUTDOWN_ENABLED_
+
+// States of the auto installer
+enum TAutoInstallerStates
+    {
+    EAutoInstallerStateIdle = 0,
+    EAutoInstallerStateInstall = 1,
+    EAutoInstallerUninstall = 2
+    };
+
+// Operations for header cache updates
+enum ThspsCacheOperations 
+    {
+    EhspsCacheAddHeader,
+    EhspsCacheRemoveHeader
+    };
+
+// Backup states
+enum ThspsBRStates 
+    {
+    EhspsBRNormal = 0,
+    EhspsBRBackup,
+    EhspsBRRestore
+    };
+
+
+/**
+ * @ingroup group_hspsserver
+ * ChspsThemeServer. 
+ * @since S60 5.0
+ **/
+class ChspsThemeServer : public CPolicyServer, 
+                       public MhspsFileChangeObserver,
+                       public MhspsDefinitionRepositoryObserver,
+                       public MhspsCenRepObserver
+#ifdef _hsps_SERVER_SHUTDOWN_ENABLED_
+                       , public MShutdownObserver
+#endif // _hsps_SERVER_SHUTDOWN_ENABLED_         
+#if defined(WINSCW) || defined(__WINS__)                         
+                       , public MhspsFamilyObserver
+#endif // defined(WINSCW)
+
+    {
+public:
+	
+    /**
+    * NewLC
+    * @since S60 3.1
+    */
+    static CServer2* NewLC();
+    
+    /**
+    * AddSession
+    * @since S60 3.1
+    */
+    void AddSession();
+    
+    /**
+    * DropSession
+    * @since S60 3.1
+    */
+    void DropSession();
+    
+public: // public functions
+	
+    /**
+    * UpdateHeaderListCacheL
+    * Re-scans the file system under the Plug-in Repository. 
+    * Execution is slow and should be used only when absolutely required. 
+    * Updates headerlist cache
+    * @since S60 5.0
+    */
+    void UpdateHeaderListCacheL();
+    
+    /**
+     * Updates the header list cache based on the provided ODT information.
+     * Should be preferred over the previous API.     
+     * @since S60 5.0
+     * @param aOperation is an enumeration of the cache operations
+     * @param aRootUid is an UID of the application/interface
+     * @param aProviderUid is an UID of the provider
+     * @param aConfUid is an UID of the plug-in configuration
+     */
+    TInt UpdateHeaderListCache(    
+        ThspsCacheOperations aOperation,
+        const TInt aRootUid,
+        const TInt aProviderUid,
+        const TInt aConfigurationUid );
+    
+    /**
+    * CleanupTemporaryFilesL
+    * Cleans temporary files
+    * @since S60 3.1
+    */
+    void CleanupTemporaryFilesL(TInt secureId = 0);
+    
+    /**
+    * IncreaseRequestClientCount
+    * Increases count of client requests
+    * @since S60 5.0
+    */
+    void IncreaseRequestClientCount();
+    
+    /**
+    * DecreaseRequestClientCount
+    * Decreases count of client requests
+    * @since S60 5.0
+    */
+    void DecreaseRequestClientCount();
+        
+    /**
+    * HandleAutoInstallerEvent
+    * Handles autoinstaller events
+    * @since S60 3.1
+    */
+    void HandleAutoInstallerEvent( ThspsServiceCompletedMessage aMsg );
+            
+    /**
+    * DefinitionRepository
+    * @since S60 3.1
+    */
+    ChspsDefinitionRepository& DefinitionRepository();
+    
+    /**
+    * SecurityEnforcer
+    * @since S60 3.1
+    */
+    ChspsSecurityEnforcer& SecurityEnforcer();
+    
+    /**
+    * CentralRepository
+    * @since S60 3.1
+    */
+    CRepository& CentralRepository();
+    
+    /**
+    * DeviceLanguage
+    * Returns device language
+    * @since S60 3.1
+    */
+    TLanguage DeviceLanguage();
+        
+    /**
+    * HeaderListCache
+    * Returns headerlist cache
+    * @since S60 3.1
+    */
+    CArrayPtrSeg<ChspsODT>& HeaderListCache();
+    
+    /**
+    * GetConfigurationL
+    * Retrieves a configuration with the provided UIDs.
+    * @since S60 5.0    
+    * @param aInterfaceUid An uid of the interface or application (e.g. AI3, Java etc), optional.
+    * @param aConfigurationUid An uid of the plugin configuration     
+    * @param aRetrievedODT Retrieved configuration
+    * @return KErrNone if operation succeeded
+    */
+    TInt GetConfigurationL(
+		const TInt aInterfaceUid,
+		const TInt aConfigurationUid,
+		ChspsODT& aRetrievedODT );
+
+    /**
+    * GetConfigurationHeaderL
+    * Retrieves a configuration header matching the search criteria
+    * @since S60 5.0    
+    * @param aSearchMask ODT header defining search criteria
+    * @param aConfHeader Found ODT header
+    * @param aPos Start/Found position
+    */
+    void GetConfigurationHeader(
+        ChspsODT& aSearchMask,
+        ChspsODT*& aConfHeader,
+        TInt& aPos );
+    
+    /**
+     * Localizes an ODT.
+     * Testing: change first two digits from \epoc32\RELEASE\WINSCW\udeb\
+     * Z\resource\BootData\Languages.txt file and reboot the emulator.     
+     * @since S60 5.0
+     * @param aEngine is a service for replacing DTD entities in XML.
+     * @param aOdt is an ODT instance to be localized.     
+     * @return ETrue if the ODT was successfully localized
+     */
+    TBool LocalizeL( 
+		ChspsDefinitionEngineInterface& aEngine,
+		ChspsODT& aOdt );
+    
+    /**
+     * Parses name of a manifest from the provided import's name.                      
+     * @since S60 5.0
+     * @param aImportFile is a name of the import to be parsed
+     * @param aPath is a path from which the import should be found
+     * @return descriptor holding name of the manifest or NULL     
+     */
+    HBufC* GetManifestFromImportLC(
+        const TDesC& aImportFile,
+        const TDesC& aPath );
+
+    /**
+     * Check the installed configurations
+     * @param aAppUid Application UID which configurations are checked
+     * @since S60 5.0
+     */
+    void CheckConfigurationL(
+        const TInt aAppUid );
+
+    /**
+     * Reinstalls defined configuration
+     * @param aAppUid Application UID which configuration is reinstalled
+     * @param aConfUid Configuration UID of reinstalled configuration
+     * @since S60 5.0
+     */
+    void ReinstallConfL(
+        TInt aAppUid,
+        TInt aConfUid );
+
+    /**
+     * Handles received backup event
+     * @since S60 5.0
+     * @param aEvent Backup event
+     */
+    void HandleBREventL( TInt aEvent );
+
+    /**
+     * Prepares backup data for passive backup
+     * @since S60 5.0
+     */
+    void CreateBackupDataL();
+
+
+    /**
+     * Check the installed plugin is used in some application configuration
+     * @since S60 5.0
+     * @param aPluginUid Plugin UID of installed configuration
+     */
+   TInt CheckInstalledPluginUsageL( const TInt aPluginUid );
+
+    /**
+     * Check if given plugin is in header cache.
+     * 
+     * @since S60 5.0
+     * @param aPluginUid Plugin UID to search from header cache.
+     */    
+    TBool PluginInHeaderCache( const TUid aPluginUid );
+
+   /**
+    * Cleanup server resources. This method is called when server is been
+    * shut down and active scheduler is still installed.
+    * 
+    * @since S60 5.0
+    */
+   void Cleanup();
+   
+   /**
+    * Activates provided application configuration. 
+    * @param aSetMask Identifies an application configuration which is to be activated.
+    * @param aOdt Activated application configuration
+    */
+   TInt ActivateThemeL(
+           const ChspsODT& aSetMask, 
+           ChspsODT& aOdt );
+
+   /**
+    * Retrieves active application configuration from Central Repository.
+    * @since S60 5.0
+    * @param aAppUid Identifies the application
+    * @param aOdt Contains currently active application configuration
+    */
+   TInt GetActivateAppConfigurationL(
+           const TInt aAppUid, 
+           ChspsODT& aOdt );
+   
+   /**
+    * Gets family information from an active application configuration.
+    * @since S60 5.0
+    * @param aAppUid Identifies the application    
+    * @returns The active family
+    */
+   TUint32 GetActiveFamilyL( 
+           const TInt aAppUid );      
+   
+public: // from MhspsFileChangeObserver
+	
+    /**
+    * HandleFileSystemChange
+    * Handles change of filesystem
+    * @since S60 3.1
+    */
+    void HandleFileSystemChange();
+    
+    /**
+    * HandleRepositoryChange
+    * Handles change of repository
+    * @since S60 3.1
+    */
+    inline void HandleRepositoryChange() {};
+
+#ifdef _hsps_SERVER_SHUTDOWN_ENABLED_
+public: // From MShutdownObserver
+    /**
+    * From MShutdownObserver.
+    */
+    void ShutdownInitiating();    
+#endif // _hsps_SERVER_SHUTDOWN_ENABLED_
+    
+    
+public: // from MhspsDefinitioRepositoryObserver
+	
+    /**
+    * HandleDefinitionRespositoryEvent
+    * Handles change events received from definition repository
+    * @since S60 3.1
+    */
+    TBool HandleDefinitionRespositoryEvent( ThspsRepositoryInfo aRepositoryInfo );
+    
+public: // from MhspsCenRepObserver
+         
+    void HandleCenRepChangeL( const TUint32 aId );    
+     
+#if defined(WINSCW) || defined(__WINS__)    
+public: // from MshspFamilyObserver    
+    TBool HandleFamilyChangeL( const ThspsFamily aNewFamily );
+#endif // defined(WINSCW)
+    
+private:
+	
+    /**
+    * ChspsThemeServer
+    * @since S60 3.1
+    */
+    ChspsThemeServer();
+    
+    /**
+    * ~ChspsThemeServer
+    * @since S60 3.1
+    */
+    ~ChspsThemeServer();
+    
+    /**
+    * ConstructL
+    * @since S60 3.1
+    */
+    void ConstructL();
+    
+    /**
+    * NewSessionL
+    * @since S60 3.1
+    */
+    CSession2* NewSessionL(const TVersion& aVersion, const RMessage2& aMessage) const;
+    
+    /**
+    * ComparePaths
+    * @since S60 3.1
+    */
+    TBool ComparePaths(const ChspsODT& aOldHeader, const ChspsODT& aNewHeader);
+    
+    /**
+    * GetHeaderListL
+    * Gets current headerlist from filesystem
+    * @param aHeaderList Destination for read headerlists from filesystem  
+    * @param aSearchMask SearchMask to use when reading headerlists from filesystem  
+    * @since S60 3.1
+    */
+    void GetHeaderListL(CArrayPtrSeg<ChspsODT>& aHeaderList, const ChspsODT& aSearchMask );
+                   
+    /**
+    * CheckActiveThemesL
+    * Check active themes from the central repository and if needed open path info file for them
+    * @since S60 3.1
+    */               
+    void CheckActiveThemesL();
+    
+    //From CPolicyServer
+    /**
+    * CustomSecurityCheckL
+    * @since S60 3.1
+    */
+    CPolicyServer::TCustomResult CustomSecurityCheckL(const RMessage2& aMsg, TInt& aAction,
+                              TSecurityInfo& aMissing);
+                              
+    /**
+    * HandleFileSystemChangeL
+    * Does the actual filesystem change handling
+    * @since S60 3.2
+    */
+    void HandleFileSystemChangeL(); 
+
+    /**
+    * RunAutoInstaller
+    * Runs auto installer
+    * @since S60 5.0
+    */    
+    TBool RunAutoInstaller( TAutoInstallerStates aState );
+
+    /**
+    * StopAutoInstaller
+    * Stops auto installer and does house keeping after installation
+    * @since S60 3.2
+    */        
+    void StopAutoInstaller();
+   
+   /**
+    * HandleThemeUpgrade;
+    * Handles the SIS theme upgrade
+    */        
+    void HandleThemeUpgradeL();
+    
+    /**
+    * Checks whether the device language has been changed and updates 
+	* configurations accordingly
+	*/
+    void HandleLanguageChangeL();
+    
+    /**
+     * Localizes ODT files according to the device language.
+     * @since S60 5.0
+     */
+    void LocalizeConfigurationsL();
+    
+    /**     
+     * Localizes an application configuration with a device language. 
+     * This function is used by the LocalizeL service.
+     * @since S60 5.0
+     * @param aEngine is a service for replacing DTD entities in XML.
+     * @param aRequestedLanguage is the requsted language
+     * @return ETrue if all the application and plugin configurations were localized
+     */
+    TBool LocalizeApplicationConfigurationL(
+        ChspsDefinitionEngineInterface& aEngine,
+        ChspsODT& aOdt,
+        const TLanguage aRequestedLanguage );
+    
+    /**
+     * Localizes a plugin configuration with a device language. 
+     * This function is used by the LocalizeL service.
+     * @since S60 5.0
+     * @param aEngine is a service for replacing DTD entities in XML.
+     * @param aRequestedLanguage is the requsted language
+     * @param aPluginUid is > 0 when LocalizeApplicationConfigurationL() is used 
+     * @return ETrue if the plugin configuration was localized
+     */
+    TBool LocalizePluginConfigurationL(
+        ChspsDefinitionEngineInterface& aEngine,
+        ChspsODT& aOdt,
+        const TLanguage aRequestedLanguage,
+        TInt aPluginUid );
+                
+    /**
+     * Handles installation of ROM based manifest files when a Restore Factory Settings (RFS)
+     * operation has been executed (controlled via the Central Repository).    
+     * This function is executed at bootup when the server starts. 
+     * @since S60 5.0 
+     */
+    void HandleRomInstallationsL();
+    
+    /**
+     * Executes installation of manifest files from the ROM drive.
+     * @since S60 5.0 
+     */
+    void InstallManifestsFromRomDriveL();
+                                
+    /**
+     * V2 method for finding manifest files from Z\private\200159C0\install subfolders,
+     * these folders should have a "hsps" subfolder.
+     * Appends iManifestFiles array. 
+     * @since S60 5.0     
+     * @param aPluginFolders holds names of the plugin folders which are V2 based
+     */
+    void FindRomInstallationsV2L(        
+        RPointerArray<HBufC>& aPluginFolders );
+    
+    /**
+     * Initiates uninstallation of a manifest file located under the imports folder.
+     * @since S60 5.0
+     * @param aFilelist is a list of dat files under the imports folder or NULL 
+     */
+    void UninstallImport( 
+		const CDir* aFilelist );
+                
+    /**
+     * Installs new configuration based on the information in imports name.
+     * @since S60 5.0
+     * @param aFilelist is a list of dat files to be parsed under the imports folder
+     */    
+    void InstallImportsL( 
+		const CDir& aFilelist );        
+    
+    /**
+     * Handles installation/uninstallation of imported configurations.
+     * A file filter controls which type of configurations are to be handled. 
+     * @since S60 5.0
+     * @param aFilePrefix is a prefix for finding either plugin or application configuration imports.
+     */
+    void HandleConfigurationImportsL(
+		const TDesC& aFilePrefix );    
+    
+    /**
+     * 
+     * @since S60 5.0
+     * @param aAppUid is an UID of the application
+     */
+    void UnlockSisxImportL( 
+            const TUint32 aAppUid );
+    
+    /**
+     * 
+     * @since S60 5.0
+     * @param aAppUid is an UID of the application
+ 	 * @param aConfUid is an UID of the active configuration
+     */
+    void LockSisxImportL( 
+            const TUint32 aAppUid,
+			const TInt aConfUid );
+
+    /**
+    * GetDeviceLanguage
+    * @since S60 5.0
+    */
+    TLanguage GetDeviceLanguage();
+    
+    /**     
+     * Retrieves a list of headers matching a iCacheMask search mask.
+     * @since S60 5.0
+     * @param aHeaderList is a list of headers found from the Plug-in Repository
+     * @return KErrNone if operation was successfull
+     */
+    TInt DoUpdateHeaderListCache(
+            CArrayPtrSeg<ChspsODT>& aHeaderList );       
+
+    
+    /**
+     * Adds specific header to the cache.
+     * An alternative to UpdateHeaderListCacheL API for updating the header 
+     * cache with a minimum performance hit. 
+     * @since S60 5.0
+     * @param aRootUid is an UID of the application/interface
+     * @param aProviderUid is an UID of the provider
+     * @param aConfUid is an UID of the plug-in configuration
+     */
+    void HeaderCacheAddL(
+            const TInt aRootUid,
+            const TInt aProviderUid,
+            const TInt aConfigurationUid );
+    
+    /**
+     * Removes specific header from the cache.
+     * An alternative to UpdateHeaderListCacheL API for updating the header 
+     * cache with a minimum performance hit. 
+     * @since S60 5.0
+     * @param aRootUid is an UID of the application/interface
+     * @param aProviderUid is an UID of the provider
+     * @param aConfUid is an UID of the plug-in configuration
+     */
+    TInt HeaderCacheRemove( 
+            const TInt aRootUid,
+            const TInt aProviderUid,
+            const TInt aConfigurationUid );   
+
+    /**
+     * Handles backup events in EhspsBRNormal backup state
+     * @since S60 5.0
+     * @param aEvent is a received backup event
+     */
+    void HandleBRNormalStateL(
+        TInt aEvent );
+
+    /**
+     * Handles backup events in EhspsBRBackup backup state
+     * @since S60 5.0
+     * @param aEvent is a received backup event
+     */
+    void HandleBRBackupStateL(
+        TInt aEvent );
+
+    /**
+     * Handles backup events in EhspsBRRestore backup state
+     * @since S60 5.0
+     * @param aEvent is a received backup event
+     */
+    void HandleBRRestoreStateL(
+        TInt aEvent );
+
+    /**
+     * Creates active backup and restore handler
+     * @since S60 5.0
+     * @param aEvent is a received backup event
+     */
+    void CreateBRHandlerL(
+        TInt aEvent );
+
+    /**
+     * Deletes active backup and restore handler
+     * @since S60 5.0
+     */
+    void DeleteBRHandler();
+
+    /**
+     * Enables autoinstallations
+     * @since S60 5.0
+     */
+    void EnableAutoInstallationL();
+
+    /**
+     * Disable autoinstallations
+     * @since S60 5.0
+     */
+    void DisableAutoInstallation();
+
+    /**
+     * Installs restored configurations from backup/import folder
+     * @since S60 5.0
+     */
+    void RestoreImportedConfigurationsL();
+
+    /**
+     * Restores application configurations from backup/themes folder
+     * @since S60 5.0
+     */
+    void RestoreApplicationConfigurationsL();
+
+    /**
+     * Validates restored application configuration
+     * @since S60 5.0
+     * @param aOdt is reference to application configuration to be validated
+     */
+    void ValidateRestoredConfigurationL(
+        ChspsODT& aOdt );
+
+    /**
+     * Restore configuration
+     * @since S60 5.0
+     * @param aOdt is reference to application configuration to be restored
+     */
+    void RestoreConfigurationL(
+        ChspsODT& aOdt );
+    
+#if defined(WINSCW) || defined(__WINS__)    
+
+    /**
+     * Executed at startup to activate root configurations which were designed
+     * for the current resolution.
+     * @since S60 5.0 
+     */
+    void ActivateRootConfigurationsL();
+           
+#endif // defined(WINSCW)
+    
+    
+private:
+    TInt iSessionCount;
+    
+#ifdef _hsps_SERVER_SHUTDOWN_ENABLED_    
+    CShutdown* iShutdown;
+#endif // _hsps_SERVER_SHUTDOWN_ENABLED_
+
+    /* 
+    * iRequestClientCount counts the number of RequestClientHandler instances
+    * when this number is 0, no resource file access exist and the temporary resource
+    * file instances can be removed safely
+    */
+    TInt iRequestClientCount;
+      
+    // Contents of the header cache
+    CArrayPtrSeg<ChspsODT>* iHeaderListCache;
+    TBool iHeaderListPending;
+           
+    RFs iFsSession;
+    ChspsDefinitionRepository* iDefinitionRepository;
+    CRepository* iCentralRepository;
+    ChspsSecurityEnforcer* iSecurityEnforcer;
+    ChspsFileChangeListener* iFileChangeListener;
+    
+    // Active device language
+    TLanguage iDeviceLanguage;
+        
+    ChspsODT* iCacheMask;
+    
+    // Installation handler for ROM imports 
+    ChspsRomInstaller* iRomInstaller;
+    
+    // Installation handler for SISX imports
+    ChspsAutoInstaller* iAutoInstaller;
+                               
+    // Array of installable *.dat files under the imports folder
+    RPointerArray<HBufC> iInstallableSisxThemes;
+    
+    // Array of installed *.dat files under the imports folder
+    RPointerArray<HBufC> iInstalledSisxThemes;        
+    
+    // Array of installable manifest files
+    RPointerArray<HBufC> iManifestFiles;
+    
+    // Index of a manifest in autoinstallation
+    TInt iCurrentManifestFile;
+    
+    // State of the SISX installer
+    TInt iAutoInstallerState;
+    
+    // Index of the theme to be removed
+    TInt iThemeIndexToRemove;
+    
+	// File locks for preventing uninstallation of active SISX configurations
+    RFile iFileAS;
+    RFile iFileAI;
+    RFile iFileLT;
+    
+    // Pointer to Central Repository Listener        
+    ChspsCenRepListener* iCenRepListener;
+
+    // Pointer to backup event listener
+    CHSPSBRObserver* iBRObserver;
+
+    // Backup state
+    ThspsBRStates iBRState;
+
+    // Active backup client
+    conn::CActiveBackupClient* iActiveBackupClient;
+    
+    // Backup handler
+    CHSPSBRHandler* iBRHandler;
+    
+
+#if defined(WINSCW) || defined(__WINS__)
+    // Listener for resolution and orientation changes
+    ChspsFamilyListener* iFamilyListener;
+#endif // defined(WINSCW)    
+    
+#ifdef HSPS_LOG_ACTIVE    
+    /**
+     * Log bus.
+     */        
+    ChspsLogBus* iLogBus;
+#endif    
+    };
+
+#endif //__hspsTHEMESERVER_H__