satengine/satserver/SatInternalClient/inc/RSatUiSession.h
author hgs
Fri, 15 Oct 2010 13:21:28 +0300
changeset 53 25b8d29b7c59
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2008 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:  The UI Client API of the SAT Server.
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 RSATUISESSION_H
hgs
parents:
diff changeset
    21
#define RSATUISESSION_H
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
//  INCLUDES
hgs
parents:
diff changeset
    24
#include <e32base.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// CONSTANTS
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// The name of the SatClient module for panic purposes
hgs
parents:
diff changeset
    29
_LIT( KSatCliName, "SatClient" );
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// DATA TYPES
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// The Sat Client Panic codes
hgs
parents:
diff changeset
    34
enum TSatClientPanic
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
    ESatInvalidResponse,
hgs
parents:
diff changeset
    37
    ESatSetUpMenuFailure,
hgs
parents:
diff changeset
    38
    ESelectedItemOutOfRange
hgs
parents:
diff changeset
    39
    };
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
class MSatUiObserver;
hgs
parents:
diff changeset
    44
class MSatUiAdapter;
hgs
parents:
diff changeset
    45
class CSatCCommandProcessor;
hgs
parents:
diff changeset
    46
class CSatCDisplayTextHandler;
hgs
parents:
diff changeset
    47
class RSatSession;
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// CLASS DECLARATION
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
/**
hgs
parents:
diff changeset
    52
 *  UI sub-session to SatServer.
hgs
parents:
diff changeset
    53
 *  Use this to register your event observer object.
hgs
parents:
diff changeset
    54
 *
hgs
parents:
diff changeset
    55
 *  @lib SatClient.lib
hgs
parents:
diff changeset
    56
 *  @since Series 60 2.0
hgs
parents:
diff changeset
    57
 */
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
class RSatUiSession : public RSubSessionBase
hgs
parents:
diff changeset
    60
    {
hgs
parents:
diff changeset
    61
    public: // Constructors and destructor
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
        /**
hgs
parents:
diff changeset
    64
         * C++ default constructor.
hgs
parents:
diff changeset
    65
         */
hgs
parents:
diff changeset
    66
        IMPORT_C RSatUiSession();
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
    public: // New functions
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
        /**
hgs
parents:
diff changeset
    71
         * Registers the listener object for SAT events and connects to
hgs
parents:
diff changeset
    72
         * the Sat Server.
hgs
parents:
diff changeset
    73
         * @param aSat
hgs
parents:
diff changeset
    74
         * @param aObserver The observer.
hgs
parents:
diff changeset
    75
         */
hgs
parents:
diff changeset
    76
        IMPORT_C void RegisterL(
hgs
parents:
diff changeset
    77
            const RSatSession& aSatSession,
hgs
parents:
diff changeset
    78
            MSatUiObserver* aObserver );
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
        /**
hgs
parents:
diff changeset
    81
         * Returns a pointer to the object that implements the UI
hgs
parents:
diff changeset
    82
         * adapter interface.
hgs
parents:
diff changeset
    83
         * @return The adapter object pointer.
hgs
parents:
diff changeset
    84
         */
hgs
parents:
diff changeset
    85
        IMPORT_C MSatUiAdapter* Adapter() const;
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
        /**
hgs
parents:
diff changeset
    88
         * Unregisters the listener object and disconnects from the server.
hgs
parents:
diff changeset
    89
         */
hgs
parents:
diff changeset
    90
        void Unregister();
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
        /**
hgs
parents:
diff changeset
    93
         * The client API version
hgs
parents:
diff changeset
    94
         * @return The version of the current API.
hgs
parents:
diff changeset
    95
         */
hgs
parents:
diff changeset
    96
        IMPORT_C TVersion Version() const;
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
        /**
hgs
parents:
diff changeset
    99
         * Panics the client application
hgs
parents:
diff changeset
   100
         * @param aReason The reason code.
hgs
parents:
diff changeset
   101
         */
hgs
parents:
diff changeset
   102
        IMPORT_C void Panic( TSatClientPanic aReason ) const;
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
        /**
hgs
parents:
diff changeset
   105
         * Shuts down the server. Active in development use only.
hgs
parents:
diff changeset
   106
         */
hgs
parents:
diff changeset
   107
        IMPORT_C void KillServer() const;
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
        /**
hgs
parents:
diff changeset
   110
        * Create and send service request message to SAT server.
hgs
parents:
diff changeset
   111
        * @param aFunction Service request id.
hgs
parents:
diff changeset
   112
        * @param aArgs Service request arguments.
hgs
parents:
diff changeset
   113
        * @param aStatus Service request status.
hgs
parents:
diff changeset
   114
        */
hgs
parents:
diff changeset
   115
        IMPORT_C void CreateRequest(
hgs
parents:
diff changeset
   116
            TInt aFunction,
hgs
parents:
diff changeset
   117
            const TIpcArgs& aArgs,
hgs
parents:
diff changeset
   118
            TRequestStatus& aStatus ) const;
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
        /**
hgs
parents:
diff changeset
   121
         * Create and send service request message to SAT server.
hgs
parents:
diff changeset
   122
         * @param aFunction Service request id.
hgs
parents:
diff changeset
   123
         * @param aArgs Service request arguments.
hgs
parents:
diff changeset
   124
         */
hgs
parents:
diff changeset
   125
        IMPORT_C void CreateRequest(
hgs
parents:
diff changeset
   126
            TInt aFunction,
hgs
parents:
diff changeset
   127
            const TIpcArgs& aArgs ) const;
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
        /**
hgs
parents:
diff changeset
   130
        * Returns a pointer to the object that implements client observer
hgs
parents:
diff changeset
   131
        * object that receives SAT commands
hgs
parents:
diff changeset
   132
        * @return The client observer object pointer.
hgs
parents:
diff changeset
   133
        */
hgs
parents:
diff changeset
   134
        IMPORT_C MSatUiObserver* SatUiObserver();
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
        /**
hgs
parents:
diff changeset
   137
         * Returns a pointer to the object that implements Processor agent for
hgs
parents:
diff changeset
   138
         * SAT commands.
hgs
parents:
diff changeset
   139
         * @return The command processor object pointer.
hgs
parents:
diff changeset
   140
         */
hgs
parents:
diff changeset
   141
        CSatCCommandProcessor* CommandProcessor();
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
    public: // Functions from base classes
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
        /**
hgs
parents:
diff changeset
   146
         * From RHandleBase
hgs
parents:
diff changeset
   147
         *
hgs
parents:
diff changeset
   148
         * Close the handle.
hgs
parents:
diff changeset
   149
         */
hgs
parents:
diff changeset
   150
        IMPORT_C void Close();
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
    private:
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
        // Prohibited copy constructor.
hgs
parents:
diff changeset
   155
        RSatUiSession( const RSatUiSession& );
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
        // Prohibited assigment operator.
hgs
parents:
diff changeset
   158
        RSatUiSession& operator= ( const RSatUiSession& );
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
        /**
hgs
parents:
diff changeset
   161
        * Checks if the server is started.
hgs
parents:
diff changeset
   162
        * @return Interger value, is server started or not.
hgs
parents:
diff changeset
   163
        */
hgs
parents:
diff changeset
   164
        TBool IsServerStarted() const;
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
    private: // Data
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
        /**
hgs
parents:
diff changeset
   169
         * Processor agent for SAT commands
hgs
parents:
diff changeset
   170
         */
hgs
parents:
diff changeset
   171
        CSatCCommandProcessor* iCommandProcessor;
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
        /**
hgs
parents:
diff changeset
   174
         * The client observer object that receives SAT commands.
hgs
parents:
diff changeset
   175
         */        
hgs
parents:
diff changeset
   176
        MSatUiObserver* iSatUiObserver;
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
    };
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
#endif // RSATUISESSION_H
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
// End of File