ipcm_pub/access_point_engine_api/inc/ActiveApDb.h
author hgs
Wed, 27 Oct 2010 17:43:56 +0300
changeset 70 ac5daea24fb0
permissions -rw-r--r--
201038
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
70
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 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 "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:  Declaration of classes CActiveApDb
hgs
parents:
diff changeset
    15
*               and MActiveApDbObserver.
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 ACTIVE_APDB_H
hgs
parents:
diff changeset
    21
#define ACTIVE_APDB_H
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
// Deprecation warning
hgs
parents:
diff changeset
    24
#warning This header file has been deprecated and will be fully removed between weeks 12 and 18 of 2010. See Polonium CR #153 for details.
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
//  INCLUDES
hgs
parents:
diff changeset
    27
#include <commdb.h>
hgs
parents:
diff changeset
    28
#include <ApEngineVer.h>
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
/*
hgs
parents:
diff changeset
    31
// Enum for DATABASE_TYPE field
hgs
parents:
diff changeset
    32
// Will be deprecated in 7.0
hgs
parents:
diff changeset
    33
enum TCommDbDatabaseType
hgs
parents:
diff changeset
    34
    {
hgs
parents:
diff changeset
    35
    EUnspecified = 0,   // not specifying which type it is - any type of 
hgs
parents:
diff changeset
    36
                        // database can be opened with this parameter
hgs
parents:
diff changeset
    37
    EIAP,
hgs
parents:
diff changeset
    38
    EISP
hgs
parents:
diff changeset
    39
    };
hgs
parents:
diff changeset
    40
*/
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
// CONSTANTS
hgs
parents:
diff changeset
    43
const TInt KErrActiveApDbObserverNotFound = -500;
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
// FORWARD DECLARATION
hgs
parents:
diff changeset
    46
class CActiveApDbNotifier;
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// CLASS DECLARATION
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
/**
hgs
parents:
diff changeset
    51
* Mixin protocol for handling events from a CCommsDatabase.
hgs
parents:
diff changeset
    52
* Events are related to database changes and availability.
hgs
parents:
diff changeset
    53
*/
hgs
parents:
diff changeset
    54
class MActiveApDbObserver
hgs
parents:
diff changeset
    55
    {
hgs
parents:
diff changeset
    56
    public:     // types
hgs
parents:
diff changeset
    57
        enum TEvent       /// Events reported to the database observer.
hgs
parents:
diff changeset
    58
            {
hgs
parents:
diff changeset
    59
            EDbChanged,   ///< Database has changed.
hgs
parents:
diff changeset
    60
            EDbClosing,   ///< Database is about to close.
hgs
parents:
diff changeset
    61
            EDbAvailable  ///< Database is available again.(E.g. after unlock)
hgs
parents:
diff changeset
    62
            };
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    public:     // new methods
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
        /**
hgs
parents:
diff changeset
    67
        * Derived classes should implement this method, and act accordingly
hgs
parents:
diff changeset
    68
        * to database events.
hgs
parents:
diff changeset
    69
        * @param anEvent Database-related event.
hgs
parents:
diff changeset
    70
        *
hgs
parents:
diff changeset
    71
        * @deprecated
hgs
parents:
diff changeset
    72
        */
hgs
parents:
diff changeset
    73
        IMPORT_C virtual void HandleApDbEventL( TEvent anEvent ) = 0;
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
    };
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
/**
hgs
parents:
diff changeset
    78
* This class manages and guards database integrity
hgs
parents:
diff changeset
    79
* by handling all events that are related to the database. These events
hgs
parents:
diff changeset
    80
* may originate from the system (Shutdown, Backup/Restore) and from the
hgs
parents:
diff changeset
    81
* database itself. The events are transformed into a simple protocol,
hgs
parents:
diff changeset
    82
* defined by MActiveApDbObserver.
hgs
parents:
diff changeset
    83
* Expects an active scheduler to be installed and running.
hgs
parents:
diff changeset
    84
*/
hgs
parents:
diff changeset
    85
NONSHARABLE_CLASS( CActiveApDb ) : public CBase
hgs
parents:
diff changeset
    86
    {
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
    public:     // Constructors and destructor
hgs
parents:
diff changeset
    89
        /**
hgs
parents:
diff changeset
    90
        * Two-phased constructor. Leaves on failure.
hgs
parents:
diff changeset
    91
        * @param aType The desired type of the CCommsDatabase object.
hgs
parents:
diff changeset
    92
        * Defaults to EDatabaseTypeIAP.
hgs
parents:
diff changeset
    93
        * @return The constructed CActiveApDb object.
hgs
parents:
diff changeset
    94
        *
hgs
parents:
diff changeset
    95
        * @deprecated
hgs
parents:
diff changeset
    96
        */
hgs
parents:
diff changeset
    97
        IMPORT_C static CActiveApDb* NewL
hgs
parents:
diff changeset
    98
            ( TCommDbDatabaseType aType = EDatabaseTypeIAP );
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
        /**
hgs
parents:
diff changeset
   103
        * Destructor.
hgs
parents:
diff changeset
   104
        *
hgs
parents:
diff changeset
   105
        * @deprecated
hgs
parents:
diff changeset
   106
        */
hgs
parents:
diff changeset
   107
        IMPORT_C virtual ~CActiveApDb();
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    protected:  // Constructors
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
        /**
hgs
parents:
diff changeset
   112
        * Second phase constructor. Leaves on failure.
hgs
parents:
diff changeset
   113
        * @param aType The desired type of the CCommsDatabase object.
hgs
parents:
diff changeset
   114
        * events.
hgs
parents:
diff changeset
   115
        */
hgs
parents:
diff changeset
   116
        void ConstructL();
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
    public:     // new methods
hgs
parents:
diff changeset
   119
        /**
hgs
parents:
diff changeset
   120
        * Adds an observer to the list of observers to be notified
hgs
parents:
diff changeset
   121
        * about the DB events.
hgs
parents:
diff changeset
   122
        * Also automatically starts observation and notification.
hgs
parents:
diff changeset
   123
        * The order of notification will be exactly the order of registration.
hgs
parents:
diff changeset
   124
        * @param anObserver Observer to be notified about database-related
hgs
parents:
diff changeset
   125
        * events.
hgs
parents:
diff changeset
   126
        *
hgs
parents:
diff changeset
   127
        * @deprecated
hgs
parents:
diff changeset
   128
        */
hgs
parents:
diff changeset
   129
        IMPORT_C void AddObserverL( MActiveApDbObserver* anObserver );
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
        /**
hgs
parents:
diff changeset
   133
        * Removes an observer. If not added, silently ignores.
hgs
parents:
diff changeset
   134
        * @param anObserver The observer.
hgs
parents:
diff changeset
   135
        *
hgs
parents:
diff changeset
   136
        * @deprecated
hgs
parents:
diff changeset
   137
        */
hgs
parents:
diff changeset
   138
        IMPORT_C void RemoveObserver( MActiveApDbObserver* anObserver );
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
        /**
hgs
parents:
diff changeset
   142
        * Returns the CCommsDatabase.
hgs
parents:
diff changeset
   143
        * Required because we can not derive from CCommsDatabase...
hgs
parents:
diff changeset
   144
        *
hgs
parents:
diff changeset
   145
        * @deprecated
hgs
parents:
diff changeset
   146
        */
hgs
parents:
diff changeset
   147
        IMPORT_C CCommsDatabase*  Database();
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    private:
hgs
parents:
diff changeset
   150
        /**
hgs
parents:
diff changeset
   151
        * Handle events from the database (DBMS).
hgs
parents:
diff changeset
   152
        * The order of notification is the order of registration.
hgs
parents:
diff changeset
   153
        * @param anEvent Event generated by DBMS. Values from
hgs
parents:
diff changeset
   154
        * RDbNotifier::TEvent, or KErrCancel.
hgs
parents:
diff changeset
   155
        */
hgs
parents:
diff changeset
   156
        void HandleDbEventL( TInt anEvent );
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
        /**
hgs
parents:
diff changeset
   160
        * Notify all observers about an event.
hgs
parents:
diff changeset
   161
        * @param anEvent Event to be sent to observers.
hgs
parents:
diff changeset
   162
        */
hgs
parents:
diff changeset
   163
        void NotifyObserversL( MActiveApDbObserver::TEvent anEvent );
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
    friend class CActiveApDbNotifier;
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
    private:    // types
hgs
parents:
diff changeset
   168
        /**
hgs
parents:
diff changeset
   169
        * Default constructor. Can not leave.
hgs
parents:
diff changeset
   170
        */
hgs
parents:
diff changeset
   171
        CActiveApDb();
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
        enum TState             /// State of the finite state machine.
hgs
parents:
diff changeset
   175
            {
hgs
parents:
diff changeset
   176
            EClosed,            ///< Closed and idle.
hgs
parents:
diff changeset
   177
            EReady,             ///< Open and ready for use.
hgs
parents:
diff changeset
   178
            EWaitClose,         ///< Closed, waiting for other users to close.
hgs
parents:
diff changeset
   179
            EWaitBackupRestore, ///< Closed, waiting Backup/Restore to finish.
hgs
parents:
diff changeset
   180
            EWaitShutdown       ///< Closed, waiting to die.
hgs
parents:
diff changeset
   181
            };
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
    private:        // Data
hgs
parents:
diff changeset
   184
        CArrayPtrFlat<MActiveApDbObserver>* iObservers;   ///< Observers.
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
        CCommsDatabase*     iDb;    // Creates & owns it !
hgs
parents:
diff changeset
   187
        // CommsDb has its own RDbNotifier...
hgs
parents:
diff changeset
   188
        TState iState;  ///< Current state of the database.
hgs
parents:
diff changeset
   189
        CActiveApDbNotifier*    iDbNotifier;
hgs
parents:
diff changeset
   190
    };
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
#endif
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
// End of File