EPos_CPosLmDatabaseManagerPluginBase.h

Go to the documentation of this file.
00001 /*
00002 * ==============================================================================
00003 *  Name        : EPos_CPosLmDatabaseManagerPluginBase.h
00004 *  Part of     : Mobile Location Framework/Landmarks
00005 *  Interface   : SDK/S60, Landmarks Database Management API
00006 *  Description : CPosLmDatabaseManagerPluginBase class
00007 *  Version     : %version: 2 % 
00008 *
00009 *  Copyright © 2005-2006 Nokia.  All rights reserved.
00010 *  This material, including documentation and any related computer
00011 *  programs, is protected by copyright controlled by Nokia.  All
00012 *  rights are reserved.  Copying, including reproducing, storing,
00013 *  adapting or translating, any or all of this material requires the
00014 *  prior written consent of Nokia.  This material also contains
00015 *  confidential information which may not be disclosed to others
00016 *  without the prior written consent of Nokia.
00017 * ============================================================================
00018 * Template version: 4.0
00019 */
00020 
00021 #ifndef CPOSLMDATABASEMANAGERPLUGINBASE_H
00022 #define CPOSLMDATABASEMANAGERPLUGINBASE_H
00023 
00024 #include <e32base.h>
00025 #include <badesca.h>
00026 #include <EPos_TPosLmDatabaseEvent.h>
00027 #include <EPos_TPosLmDatabaseSettings.h>
00028 #include <EPos_HPosLmDatabaseInfo.h>
00029 
00030 class CPosLmDbManPluginBaseExtension;
00031 class RPosLandmarkServer;
00032 
00039 /*
00040 *  This class is the base class which has to be subclassed in order to write a
00041 *  plug-in for database management for a specific protocol. It is reserved for
00042 *  for future extensions.
00043 *
00044 *  @p CPosLmDatabaseManagerPluginBase contains functions for listing,
00045 *  registering, unregistering, creating, deleting, copying landmark databases,
00046 *  etc.
00047 *
00048 *  @lib eposlmdbmanlib.lib
00049 *  @since S60 3.0
00050 */
00051 class CPosLmDatabaseManagerPluginBase : public CBase
00052     {
00053     public:
00054 
00055         /*
00056         * Destructor.
00057         */
00058         IMPORT_C virtual ~CPosLmDatabaseManagerPluginBase();
00059 
00060     public:
00061 
00062         /*
00063         * Retrieves the type of media where a landmark database resides.
00064         *
00065         * This function does not validate the URI. If the URI is invalid, this
00066         * function will just return @p EMediaUnknown.
00067         *
00068         * @param[in] aDatabaseUri The URI of the database to check media for.
00069         * @return Type of storage media.
00070         */
00071         virtual TMediaType DatabaseMedia( const TDesC& aDatabaseUri ) = 0;
00072 
00073         /*
00074         * Retrieves the drive letter for the drive where a landmark database
00075         * resides.
00076         *
00077         * If the landmark database is remote or otherwise the drive letter is
00078         * not applicable, 0 is returned.
00079         *
00080         * This function does not validate the URI. If the URI is invalid, this
00081         * function will just return 0.
00082         *
00083         * @param[in] aDatabaseUri The URI of the database to check drive letter
00084         *   for.
00085         * @return The drive letter, or 0 if drive letter is not applicable.
00086         */
00087         virtual TChar DatabaseDrive( const TDesC& aDatabaseUri ) = 0;
00088 
00089         /*
00090         * Returns the protocol which the plug-in handles.
00091         *
00092         * The returned descriptor pointer is valid until the plug-in is
00093         * unloaded.
00094         *
00095         * @return Pointer to the protocol descriptor, e.g. "file"
00096         */
00097         virtual TPtrC Protocol() = 0;
00098 
00099         /*
00100         * Lists the URIs to all landmark databases handled by this
00101         * plug-in.
00102         *
00103         * The client takes ownership of the returned array.
00104         *
00105         * If no databases are found, an empty array is returned.
00106         *
00107         * This function requires @p ReadUserData capability.
00108         *
00109         * @return The list of database URIs.
00110         */
00111         virtual CDesCArray* ListDatabasesLC() = 0;
00112 
00113         /*
00114         * Lists information about each landmark database handled by this
00115         * plug-in.
00116         *
00117         * The client specifies an array which is populated by this function.
00118         * The client takes ownership of all information objects in the array.
00119         *
00120         * If no databases are found, the input array is not modified.
00121         *
00122         * This function requires @p ReadUserData capability.
00123         *
00124         * @param[out] aDatabaseInfoArray On return, contains information about
00125         *   the landmark databases.
00126         */
00127         virtual void ListDatabasesL(
00128             RPointerArray<HPosLmDatabaseInfo>& aDatabaseInfoArray
00129         ) = 0;
00130 
00131         /*
00132         * Registers a landmark database.
00133         *
00134         * The landmark database is then returned when listing landmark
00135         * databases.
00136         *
00137         * Some protocols like "file" does not allow registering of databases
00138         * and will leave with error code @p KErrNotSupported. To add a
00139         * database of such protocol, the client must call @ref CreateDatabaseL.
00140         *
00141         * The client supplies an information object containing the URI of the
00142         * database to register. The information object can also contain
00143         * database settings, e.g. a display name for the database.
00144         *
00145         * This function requires @p ReadUserData and @p WriteUserData
00146         * capabilities.
00147         *
00148         * @param[in,out] aDatabaseInfo Information about the landmark database to
00149         *   register.
00150         *
00151         * @leave KErrNotSupported The protocol specified in the URI is not
00152         *   supported by this plug-in or the protocol does not allow
00153         *   registering landmark databases.
00154         * @leave KErrArgument The URI is incorrect.
00155         * @leave KErrAlreadyExists The database already exists in the registry.
00156         */
00157         virtual void RegisterDatabaseL( HPosLmDatabaseInfo& aDatabaseInfo ) = 0;
00158 
00159         /*
00160         * Unregisters a landmark database.
00161         *
00162         * After this, the landmark database will not be returned when listing
00163         * landmark databases.
00164         *
00165         * Some protocols like "file" does not allow unregistering of databases
00166         * and will leave with error code @p KErrNotSupported. To remove a
00167         * database of such protocol, the client must call @ref DeleteDatabaseL.
00168         *
00169         * This function requires @p ReadUserData and @p WriteUserData
00170         * capabilities.
00171         *
00172         * @param[in] aDatabaseUri The URI of the database to register.
00173         *
00174         * @leave KErrNotSupported The protocol specified in the URI is not
00175         *   supported by this plug-in or the protocol does not allow
00176         *   unregistering landmark databases.
00177         * @leave KErrArgument The URI is incorrect.
00178         */
00179         virtual void UnregisterDatabaseL( const TDesC& aDatabaseUri ) = 0;
00180 
00181         /*
00182         * Unregisters all landmark database which are accessed through this
00183         * plug-in.
00184         *
00185         * After this, the landmark databases will not be returned when listing
00186         * landmark databases.
00187         *
00188         * Some protocols like "file" does not allow unregistering of databases
00189         * and will leave with error code @p KErrNotSupported. To remove a
00190         * "file"-protocol database, the client must call @ref DeleteDatabaseL.
00191         *
00192         * This function requires @p ReadUserData and @p WriteUserData
00193         * capabilities.
00194         *
00195         * @leave KErrNotSupported This plug-in does not allow unregistering
00196         *   landmark databases.
00197         */
00198         virtual void UnregisterAllDatabasesL() = 0;
00199 
00200         /*
00201         * Modifies the settings for a landmark database.
00202         *
00203         * This function requires @p ReadUserData and @p WriteUserData
00204         * capabilities.
00205         *
00206         * @param[in] aDatabaseUri The URI of the database to modify settings for.
00207         * @param[in] aDatabaseSettings The new settings for the database.
00208         *
00209         * @leave KErrNotSupported The protocol specified in the URI is not
00210         *   supported by this plug-in.
00211         * @leave KErrNotFound The specified database is not found.
00212         */
00213         virtual void ModifyDatabaseSettingsL(
00214             const TDesC& aDatabaseUri,
00215             const TPosLmDatabaseSettings& aDatabaseSettings
00216         ) = 0;
00217 
00218         /*
00219         * Retrieve information about a landmark database.
00220         *
00221         * This function requires @p ReadUserData capability.
00222         *
00223         * @param[in,out] aDatabaseInfo An information object containing the URI of the
00224         *   landmark database. On return, the object contains information about
00225         *   the landmark database, including any database settings.
00226         *
00227         * @leave KErrNotSupported The protocol specified in the URI is not
00228         *   supported by this plug-in.
00229         * @leave KErrNotFound The specified database is not found.
00230         */
00231         virtual void GetDatabaseInfoL( HPosLmDatabaseInfo& aDatabaseInfo ) = 0;
00232 
00233         /*
00234         * Checks if the specified landmark database exists.
00235         *
00236         * The database to check is specified by passing a URI to this function.
00237         * URI construction is described in the class description for
00238         * @ref CPosLmDatabaseManager.
00239         *
00240         * This function requires @p ReadUserData capability. If the database is
00241         * remote, @p NetworkServices capability is also needed.
00242         *
00243         * @param[in] aDatabaseUri The URI of the database which should be checked
00244         *   for existence.
00245         * @return @p ETrue if the database exists, otherwise @p EFalse.
00246         * 
00247         * @leave KErrArgument The URI is incorrect or the protocol specified in the
00248         *   URI is not supported by this plug-in.
00249         */
00250         virtual TBool DatabaseExistsL( const TDesC&  aDatabaseUri ) = 0;
00251 
00252         /*
00253         * Creates a landmark database.
00254         *
00255         * This function requires @p ReadUserData and @p WriteUserData
00256         * capabilities. If the database is remote, @p NetworkServices
00257         * capability is also needed.
00258         *
00259         * @param[in,out] aDatabaseInfo Information about the landmark database to
00260         *   create.
00261         *
00262         * @leave KErrNotSupported The protocol is not supported or the create
00263         *   operation is not supported by the protocol plug-in.
00264         * @leave KErrArgument The URI is incorrect or the protocol specified in the
00265         *   URI is not supported by this plug-in.
00266         * @leave KErrAlreadyExists There is already a database at this URI.
00267         */
00268         virtual void CreateDatabaseL( HPosLmDatabaseInfo& aDatabaseInfo ) = 0;
00269 
00270         /*
00271         * Deletes a landmark database.
00272         *
00273         * The database to delete is specified by passing a URI to this
00274         * function. URI construction is described in the class description for
00275         * @ref CPosLmDatabaseManager. The URI must specify the protocol which
00276         * is handled by this database manager plug-in.
00277         *
00278         * If the specified database does not exist, the call is ignored.
00279         *
00280         * This function requires @p ReadUserData and @p WriteUserData
00281         * capabilities. If the database is remote, @p NetworkServices
00282         * capability is also needed.
00283         *
00284         * @param[in] aDatabaseUri The URI of the database to delete.
00285         *
00286         * @leave KErrNotSupported The protocol is not supported or the delete
00287         *   operation is not supported by the plug-in.
00288         * @leave KErrArgument The URI is incorrect or the protocol specified in the
00289         *   URI is not supported by this plug-in.
00290         * @leave KErrInUse The database is in use by some client.
00291         * @leave KErrAccessDenied The database is read-only.
00292         */
00293         virtual void DeleteDatabaseL( const TDesC& aDatabaseUri ) = 0;
00294 
00295         /*
00296         * Copies a landmark database to a new location.
00297         *
00298         * Database locations are specified as URIs. URI construction is
00299         * described in the class description for @ref CPosLmDatabaseManager.
00300         * The target and source URIs must specify the protocol which is handled
00301         * by this database manager plug-in.
00302         *
00303         * This function requires @p ReadUserData and @p WriteUserData
00304         * capabilities. If the database is remote, @p NetworkServices
00305         * capability is also needed.
00306         *
00307         * @param[in] aSourceUri The URI of the database to copy.
00308         * @param[in] aTargetUri The URI of the new database location.
00309         * 
00310         * @leave KErrNotSupported The operation is not supported by the plug-in.
00311         * @leave KErrArgument A URI is incorrect or the protocol specified in a
00312         *   URI is not supported by this plug-in.
00313         * @leave KErrInUse There is a write-lock on the database, e.g. some client
00314         *   is currently modifying the database.
00315         * @leave KErrNotFound There is no database at the source URI.
00316         */
00317         virtual void CopyDatabaseL(
00318             const TDesC& aSourceUri,
00319             const TDesC& aTargetUri
00320         ) = 0;
00321 
00322     protected:
00323 
00324         /*
00325         * C++ constructor.
00326         */
00327         IMPORT_C CPosLmDatabaseManagerPluginBase();
00328 
00329         /*
00330         * Creates the internals of the manager.
00331         *
00332         * This function must be called first in the manager's @b ConstructL()
00333         * method.
00334         *
00335         * @param[in] aConstructionParameters The construction parameters supplied
00336         *   in the factory call.
00337         */
00338         IMPORT_C void BaseConstructL( TAny* aConstructionParameters );
00339 
00340     protected:
00341 
00342         /*
00343         * Returns a reference to an open landmark server session.
00344         *
00345         * @return The server session.
00346         */
00347         IMPORT_C RPosLandmarkServer& Session() const;
00348 
00349     private:
00350 
00351         // Prohibit copy constructor
00352         CPosLmDatabaseManagerPluginBase(
00353             const CPosLmDatabaseManagerPluginBase& );
00354         // Prohibit assigment operator
00355         CPosLmDatabaseManagerPluginBase& operator=(
00356             const CPosLmDatabaseManagerPluginBase& );
00357 
00358     private:
00359 
00360         CPosLmDbManPluginBaseExtension* iExtension;
00361     };
00362 
00363 #endif      // CPOSLMDATABASEMANAGERPLUGINBASE_H
00364 
00365 

Copyright © Nokia Corporation 2001-2007
Back to top