installationservices/swi/inc/pkgremover.h
author Santosh V Patil <santosh.v.patil@nokia.com>
Wed, 30 Jun 2010 11:01:26 +0530
branchADM
changeset 48 364021cecc90
parent 0 ba25891c3a9e
permissions -rw-r--r--
SmartInstaller contribution based on the Nokia Qt SDK 1.0 release

/*
* Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
* Interface class for listing/removing uninstalled packages from a removable drive
*
*/


/**
 @file 
 @publishedAll
 @released
*/

#ifndef __PKGREMOVER_H__
#define __PKGREMOVER_H__

#include <e32base.h>
#include <f32file.h>
#include <s32mem.h>

namespace Swi
{

class CUninstalledPackageEntry;


/**
 * This class provides static methods for managing uninstalled native packages
 * (SIS files) that are taking up space on removable drives.
 *
 * @publishedAll
 * @released
 */

NONSHARABLE_CLASS(UninstalledSisPackages)
{
public:

	/**
	 * Get the list of uninstalled packages on a specified removable drive. In
	 * this context uninstalled means 'not known by this phone'. This will list
	 * uninstalled PA & PP files found in the SWI Daemon's private directory, and
	 * will also search the sis registry files on the drive for uninstalled
	 * applications.
	 *
	 * @param aDrive    		Removable drive number (@see TDriveNumber)
	 * @param aPackageList      Array of pointers to the uninstalled packages
	 *							found on the specified drive (@see
	 *                          CUninstalledPackageEntry). This array is assumed to be empty.
	 *							The caller takes ownership of the elements added to the array.
	 * @leave					One of the system-wide error codes.
	 * @leave                   KErrNotRemovable If the drive is not removable or is substed
	 * @leave					KErrPackageFileCorrupt If an error occurs during the processing of files
	 * @capability              ReadDeviceData Required to access protected directories during listing operation
	 * @capability              ProtServ Required to access services of software installer
	 * @capability             	TrustedUI Required to access services of software installer
	 */
	IMPORT_C static void ListL(TDriveNumber aDrive, RPointerArray<CUninstalledPackageEntry>& aPackageList);

	/**
	 * Remove the specified uninstalled package. The following restrictions apply to the files that will be removed:
	 * <ul>
	 * <li> For security reasons only files on the same drive as the package controller will be removed. Files on other drives will be orphaned.
	 * <li> Files belonging to other packages will not be removed.
	 * </ul>
	 *
	 * @param aPackage			The uninstalled package to remove (@see CUninstalledPackageEntry)
	 * @leave					One of the system-wide error codes.
	 * @leave                   KErrNotRemovable If the drive is not removable or is substed
	 * @leave					KErrPackageIsInstalled If the specified package is installed on the device
	 * @leave					KErrPackageFileCorrupt If an error occurs during the processing of files
	 * @capability				WriteDeviceData Required to write to protected directories during remove operation
	 * @capability				ProtServ Required to access services of software installer
	 * @capability				TrustedUI Required to access services of software installer
	 */
	IMPORT_C static void RemoveL(const CUninstalledPackageEntry& aPackage);
};


/**
 * Uninstalled application entry class.
 *
 * This class is not externally instantiable. It is returned as a result of 
 * querying for a list of uninstalled packages present on a removable drive. 
 * Each object of this type represents one uninstalled package. Methods can 
 * be called on this object to retrieve the package details such as 
 * Package UID, Name, Vendor, Version and Type.
 *
 * @publishedAll
 * @released
 */

NONSHARABLE_CLASS(CUninstalledPackageEntry) : public CBase
{
public:
	enum TPackageType
	{
	    ESaPackage,       ///< Standard Application
		ESpPackage,       ///< Standard Patch (augmentation)
		EPuPackage,       ///< Partial Upgrade
		EPaPackage,       ///< Preinstalled Application
		EPpPackage        ///< Preinstalled Patch
	};

	/**
	 * Get the package Uid
	 *
	 * @return The Uid of this package
	 */
	IMPORT_C const TUid& Uid() const;

	/**
	 * Get the package name
	 *
	 * @return The name of this package as reference to TDesC
	 */
	IMPORT_C const TDesC& Name() const;

	/**
	 * Get the package unique vendor name
	 *
	 * @return The unique vendor name of this package as reference to TDesC
	 */
	IMPORT_C const TDesC& Vendor() const;

	/**
	 * Get the package version
	 *
	 * @return The version number of this package
	 */
	IMPORT_C const TVersion& Version() const;

	/**
	 * Get the package type
	 *
	 * @return The package type of this package
	 */
	IMPORT_C const TPackageType& PackageType() const;

	/**
	* Destructor
	*/
	virtual ~CUninstalledPackageEntry();

private:
	static CUninstalledPackageEntry* NewLC(const TUid& aUid, const TDesC& aPackageName,
		const TDesC& aVendorName, const TVersion& aVersion, const TPackageType aPackageType,
		const TDesC& aPackageFile, const TDesC& aAssocStubSisFile);

private:
	CUninstalledPackageEntry();

private:
	void ConstructL(const TUid& aUid, const TDesC& aPackageName, const TDesC& aVendorName, 
		const TVersion& aVersion, const TPackageType aPackageType, const TDesC& aPackageFile,
		const TDesC& aAssocStubSisFile);

	const TDesC& PackageFile() const;
	const TDesC& AssociatedStubSisFile() const;

private:
	/// The package Uid
	TUid iUid;

    /// The package name
	HBufC* iPackageName;

    /// The package unique vendor name
	HBufC* iVendorName;

    /// The package version
	TVersion iVersion; 

	/// The package type
	TPackageType iType;

	// The sis/controller file name with full path
	HBufC* iPackageFile;

	// The stub sis file name with full path (if the package file is a controller file)
	HBufC* iAssocStubSisFile;
private:
	friend class UninstalledSisPackages;
};

} // namespace Swi

#endif // __PKGREMOVER_H__