brandingserver/BSServer/cbsinstallhandler.h
author hgs
Sun, 11 Apr 2010 15:33:49 +0530
changeset 31 9dbc70490d9a
permissions -rw-r--r--
201014
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2006 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 the License "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:  cbsinstallhandler.h
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
hgs
parents:
diff changeset
    20
#ifndef __CBSINSTALLHANDLER_H__
hgs
parents:
diff changeset
    21
#define __CBSINSTALLHANDLER_H__
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include <e32base.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    26
class RFs;
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
/**
hgs
parents:
diff changeset
    29
 * CBSInstallHandler
hgs
parents:
diff changeset
    30
 *
hgs
parents:
diff changeset
    31
 * Handles installation and uninstallation of brand packages.
hgs
parents:
diff changeset
    32
 * Calls external application "bsinstall.exe" to do the actual work.
hgs
parents:
diff changeset
    33
 * Can Observe the installation directory so that any sis installation
hgs
parents:
diff changeset
    34
 * can be detected while the server is running.
hgs
parents:
diff changeset
    35
 *
hgs
parents:
diff changeset
    36
 */
hgs
parents:
diff changeset
    37
NONSHARABLE_CLASS( CBSInstallHandler ): public CActive
hgs
parents:
diff changeset
    38
	{
hgs
parents:
diff changeset
    39
	public: 
hgs
parents:
diff changeset
    40
	    
hgs
parents:
diff changeset
    41
	    // Operations for folder synchronization:
hgs
parents:
diff changeset
    42
	    enum TInstallOperation
hgs
parents:
diff changeset
    43
	        {
hgs
parents:
diff changeset
    44
	        // copy files from source to destination if they don't
hgs
parents:
diff changeset
    45
	        // already exists. 
hgs
parents:
diff changeset
    46
	        EInstallCopyNewToDest,
hgs
parents:
diff changeset
    47
	        
hgs
parents:
diff changeset
    48
	        // Delete files from source directory if the same
hgs
parents:
diff changeset
    49
	        // files doesn't exist in destination directory.
hgs
parents:
diff changeset
    50
	        EInstallDeleteFromSrc
hgs
parents:
diff changeset
    51
	        };
hgs
parents:
diff changeset
    52
	
hgs
parents:
diff changeset
    53
	public: // constructors
hgs
parents:
diff changeset
    54
		
hgs
parents:
diff changeset
    55
		static CBSInstallHandler* NewL();
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
    	virtual ~CBSInstallHandler();
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
	private: // constructors
hgs
parents:
diff changeset
    60
	
hgs
parents:
diff changeset
    61
		void ConstructL();
hgs
parents:
diff changeset
    62
						 
hgs
parents:
diff changeset
    63
		CBSInstallHandler();
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
	public:
hgs
parents:
diff changeset
    66
	
hgs
parents:
diff changeset
    67
        /**
hgs
parents:
diff changeset
    68
        * Uninstall removed brands and installs new brands.
hgs
parents:
diff changeset
    69
        * This should be called right after construction to sync the
hgs
parents:
diff changeset
    70
        * installation state.
hgs
parents:
diff changeset
    71
        */
hgs
parents:
diff changeset
    72
        void InstallNewFilesL();
hgs
parents:
diff changeset
    73
        
hgs
parents:
diff changeset
    74
        /**
hgs
parents:
diff changeset
    75
        * Start observing installation folder. Detects new brands if they
hgs
parents:
diff changeset
    76
        * are installed while the server is active.
hgs
parents:
diff changeset
    77
        */
hgs
parents:
diff changeset
    78
        void StartObservingL();
hgs
parents:
diff changeset
    79
        
hgs
parents:
diff changeset
    80
        /**
hgs
parents:
diff changeset
    81
        * Stop observing installation folder. All new brands are installed
hgs
parents:
diff changeset
    82
        * only when calling InstallNewFilesL.
hgs
parents:
diff changeset
    83
        */
hgs
parents:
diff changeset
    84
        void StopObserving();
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
    private: // From CActive
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
        /**
hgs
parents:
diff changeset
    89
        * @see CActive
hgs
parents:
diff changeset
    90
        */
hgs
parents:
diff changeset
    91
        void RunL();
hgs
parents:
diff changeset
    92
        
hgs
parents:
diff changeset
    93
        /**
hgs
parents:
diff changeset
    94
        * @see CActive
hgs
parents:
diff changeset
    95
        */
hgs
parents:
diff changeset
    96
        void DoCancel();
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
    private: // new methods
hgs
parents:
diff changeset
    99
        
hgs
parents:
diff changeset
   100
        /**
hgs
parents:
diff changeset
   101
        * Launches external installer application. It should install all
hgs
parents:
diff changeset
   102
        * available brands into server.
hgs
parents:
diff changeset
   103
        */
hgs
parents:
diff changeset
   104
        void LaunchInstallerAppL();
hgs
parents:
diff changeset
   105
               
hgs
parents:
diff changeset
   106
        /**
hgs
parents:
diff changeset
   107
        * Sync files between aSrcDir and aDestDir, according to given 
hgs
parents:
diff changeset
   108
        * operation. See TInstallOperation for operations. Calls 
hgs
parents:
diff changeset
   109
        * OperationNotifyL before every operation.
hgs
parents:
diff changeset
   110
        *
hgs
parents:
diff changeset
   111
        * @param aSrcDir Source directory
hgs
parents:
diff changeset
   112
        * @param aDestDir Destination directory
hgs
parents:
diff changeset
   113
        * @param aOperation Sync operation to execute
hgs
parents:
diff changeset
   114
        * @return ETrue  - Something synchronized
hgs
parents:
diff changeset
   115
        *         EFalse - Nothing synchronized
hgs
parents:
diff changeset
   116
        */
hgs
parents:
diff changeset
   117
        TBool SyncFilesL( const TDesC& aSrcDir, const TDesC& aDestDir, 
hgs
parents:
diff changeset
   118
                          TInstallOperation aOperation );
hgs
parents:
diff changeset
   119
        
hgs
parents:
diff changeset
   120
        /**
hgs
parents:
diff changeset
   121
        * Notification that file is about to be synchronized. 
hgs
parents:
diff changeset
   122
        *
hgs
parents:
diff changeset
   123
        * @param aOperation operation type which will be executed
hgs
parents:
diff changeset
   124
        * @param aSrcFile file under operation
hgs
parents:
diff changeset
   125
        */
hgs
parents:
diff changeset
   126
        void OperationNotifyL( TInstallOperation aOperation, 
hgs
parents:
diff changeset
   127
                               const TDesC& aSrcFile );
hgs
parents:
diff changeset
   128
        
hgs
parents:
diff changeset
   129
        /**
hgs
parents:
diff changeset
   130
        * check if some version of given brand is installed in
hgs
parents:
diff changeset
   131
        * branding server. 
hgs
parents:
diff changeset
   132
        *
hgs
parents:
diff changeset
   133
        * @param aBrand brand installation file to check
hgs
parents:
diff changeset
   134
        *        this has to be brand file name without extension and 
hgs
parents:
diff changeset
   135
        *        version information.
hgs
parents:
diff changeset
   136
        */
hgs
parents:
diff changeset
   137
        TBool IsBrandInstalled( const TDesC& aBrand );                  
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
        /**
hgs
parents:
diff changeset
   140
        * Helper method to get servers private path
hgs
parents:
diff changeset
   141
        * @param aPath contains the path to servers private folder
hgs
parents:
diff changeset
   142
        * @param aAppend text to add into private path.
hgs
parents:
diff changeset
   143
        */
hgs
parents:
diff changeset
   144
        void GetPrivateFolder( TDes& aPath, const TDesC& aAppend = KNullDesC );
hgs
parents:
diff changeset
   145
	
hgs
parents:
diff changeset
   146
        /**
hgs
parents:
diff changeset
   147
        * To create a flag file if brand gets discarded
hgs
parents:
diff changeset
   148
        * @param aSrcFile file under operation
hgs
parents:
diff changeset
   149
        */
hgs
parents:
diff changeset
   150
		void CreateFlagFile(const TDesC& aSrcFile);
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
        /**
hgs
parents:
diff changeset
   153
        * Checks if an discarded brand exists.
hgs
parents:
diff changeset
   154
        * (It also writes the RProperty for the bsinstall.exe)
hgs
parents:
diff changeset
   155
        *
hgs
parents:
diff changeset
   156
        * @param aDir the folder of the data storages
hgs
parents:
diff changeset
   157
        * @return ETrue, in case a discarded brand was found, EFalse otherwise
hgs
parents:
diff changeset
   158
        */
hgs
parents:
diff changeset
   159
        TBool CheckForDiscardedBrandsL( const TDesC& aDir );
hgs
parents:
diff changeset
   160
        
hgs
parents:
diff changeset
   161
        
hgs
parents:
diff changeset
   162
        /**
hgs
parents:
diff changeset
   163
        * Updates the RProperty. The specified string is added to the
hgs
parents:
diff changeset
   164
        * RProperty only if RProperty does not contain the same string yet.
hgs
parents:
diff changeset
   165
        *
hgs
parents:
diff changeset
   166
        * @param aUninstallationString a string
hgs
parents:
diff changeset
   167
        */
hgs
parents:
diff changeset
   168
        void UpdateRPropertyL( const TDesC& aUninstallationString );
hgs
parents:
diff changeset
   169
        
hgs
parents:
diff changeset
   170
	private: // data
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
        // Own. File server session handle.
hgs
parents:
diff changeset
   173
        RFs     iFs;
hgs
parents:
diff changeset
   174
    };
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
#endif      //  __CBSINSTALLHANDLER_H__
hgs
parents:
diff changeset
   177
//  END OF FILE