satengine/satserver/inc/MSatBIPUtils.h
author hgs
Fri, 17 Sep 2010 17:09:13 +0300
changeset 48 78df25012fda
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 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:  BIP Utils interface for BIP proactive commands.
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 MSATBIPUTILS_H
hgs
parents:
diff changeset
    21
#define MSATBIPUTILS_H
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
//  INCLUDES
hgs
parents:
diff changeset
    24
#include <e32std.h>
hgs
parents:
diff changeset
    25
#include <etelsat.h>
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// CLASS DECLARATION
hgs
parents:
diff changeset
    28
class MSatBIPDataChannel;
hgs
parents:
diff changeset
    29
class MSatApnHandler;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// CONSTANTS
hgs
parents:
diff changeset
    32
// These constants are used by BIP related objects
hgs
parents:
diff changeset
    33
// Used in terminal responses and DataAvailable envelope
hgs
parents:
diff changeset
    34
const TInt KSatBIPMoreThanMaxSize = 0xFF;
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// The minimum size of receive buffer is 1500 bytes.
hgs
parents:
diff changeset
    37
const TInt KSatBIPMinReceiveBufferSize = 0x5DC;
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
// Maximum buffer size from SIM in OpenChannel command is 1500.
hgs
parents:
diff changeset
    40
const TInt KSatBIPMaxBufferSize = 0x5DC;
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
// Maximum size of one ReceiveCommand TerminalResponse
hgs
parents:
diff changeset
    43
const TInt KSatBIPMaxResponseSize = 0xED;
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
/**
hgs
parents:
diff changeset
    46
*  BIP Utils interface. Provides functionality to
hgs
parents:
diff changeset
    47
*  BIP proactive command handlers.
hgs
parents:
diff changeset
    48
*
hgs
parents:
diff changeset
    49
*  @lib SatEngine
hgs
parents:
diff changeset
    50
*  @since Series 60 3.0
hgs
parents:
diff changeset
    51
*/
hgs
parents:
diff changeset
    52
class MSatBIPUtils
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
    public: // Enums
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
        // These values can be used straigth in TerminalResponses
hgs
parents:
diff changeset
    57
        // additional info with KBearerIndepProtocolError
hgs
parents:
diff changeset
    58
        enum TSatBIPErrors
hgs
parents:
diff changeset
    59
            {
hgs
parents:
diff changeset
    60
            ESatBIPSuccess                     = 0x00,
hgs
parents:
diff changeset
    61
            ESatBIPNoChannelAvail              = 0x01,
hgs
parents:
diff changeset
    62
            ESatBIPChannelClosed               = 0x02,
hgs
parents:
diff changeset
    63
            ESatBIPChannelIdNotValid           = 0x03,
hgs
parents:
diff changeset
    64
            ESatBIPReqBufSizeNotAvail          = 0x04,
hgs
parents:
diff changeset
    65
            ESatBIPSecurityError               = 0x05,
hgs
parents:
diff changeset
    66
            ESatBIPTransportLevelNotAvailable  = 0x06,
hgs
parents:
diff changeset
    67
            ESatBIPRemoteDeviceNotReachable    = 0x07,
hgs
parents:
diff changeset
    68
            ESatBIPServiceError                = 0x08,
hgs
parents:
diff changeset
    69
            ESatBIPServiceIdUnknown            = 0x09
hgs
parents:
diff changeset
    70
            };
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
        // This comes with OpenChannel command to identify the type
hgs
parents:
diff changeset
    73
        // of bearer in the data channel.
hgs
parents:
diff changeset
    74
        enum TSatBearerType
hgs
parents:
diff changeset
    75
            {
hgs
parents:
diff changeset
    76
            ESatDefault,    /* Default bearer type */
hgs
parents:
diff changeset
    77
            ESatGPRS,       /* GPRS */
hgs
parents:
diff changeset
    78
            ESatCSD         /* CSD, Not supported */
hgs
parents:
diff changeset
    79
            };
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
        // Defines the possible channel IDs. The values should be the same as are in
hgs
parents:
diff changeset
    82
        // etelsat.h and these values can be used in functions.
hgs
parents:
diff changeset
    83
        enum TSatChannelId
hgs
parents:
diff changeset
    84
            {
hgs
parents:
diff changeset
    85
            ESatNoChannel               = 0x00,
hgs
parents:
diff changeset
    86
            ESatChannel1                = 0x01,
hgs
parents:
diff changeset
    87
            ESatChannel2                = 0x02,
hgs
parents:
diff changeset
    88
            ESatChannel3                = 0x03,
hgs
parents:
diff changeset
    89
            ESatChannel4                = 0x04,
hgs
parents:
diff changeset
    90
            ESatChannel5                = 0x05,
hgs
parents:
diff changeset
    91
            ESatChannel6                = 0x06,
hgs
parents:
diff changeset
    92
            ESatChannel7                = 0x07
hgs
parents:
diff changeset
    93
            };
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
        // Supported status informations
hgs
parents:
diff changeset
    96
        enum TSatChannelStatus
hgs
parents:
diff changeset
    97
            {
hgs
parents:
diff changeset
    98
            ESatNoFurtherInformation = 0x00,
hgs
parents:
diff changeset
    99
            ESatLinkDropped          = 0x05
hgs
parents:
diff changeset
   100
            };
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
    protected:  // Constructors and destructor
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
        /**
hgs
parents:
diff changeset
   105
        * C++ default constructor.
hgs
parents:
diff changeset
   106
        */
hgs
parents:
diff changeset
   107
        MSatBIPUtils() {};
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
        /**
hgs
parents:
diff changeset
   110
        * Destructor.
hgs
parents:
diff changeset
   111
        */
hgs
parents:
diff changeset
   112
        virtual ~MSatBIPUtils() {};
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
    public: // New functions
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
        /**
hgs
parents:
diff changeset
   117
        * Creates new data channel and returns reference to it.
hgs
parents:
diff changeset
   118
        * @param aBearerType identifies the type of data channel to create.
hgs
parents:
diff changeset
   119
        * @param TSatBIPError code indicating the execution status.
hgs
parents:
diff changeset
   120
        * @return Pointer to created data channel
hgs
parents:
diff changeset
   121
        */
hgs
parents:
diff changeset
   122
        virtual MSatBIPDataChannel* CreateChannelL(
hgs
parents:
diff changeset
   123
            const TSatBearerType aBearerType,
hgs
parents:
diff changeset
   124
            TInt& aErrCode ) = 0;
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
        /**
hgs
parents:
diff changeset
   127
        * Request to close specified data channel.
hgs
parents:
diff changeset
   128
        * @param aChannelId Identifies the channel to be closed.
hgs
parents:
diff changeset
   129
        * @return TSatBIPError code indicating the execution status.
hgs
parents:
diff changeset
   130
        */
hgs
parents:
diff changeset
   131
        virtual TInt CloseChannel( const TInt aChannelId ) = 0;
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
        /**
hgs
parents:
diff changeset
   134
        * Request to open new data channel
hgs
parents:
diff changeset
   135
        * @param aChannelId Identifies the channel.
hgs
parents:
diff changeset
   136
        * @param aErrCode TSatBIPError code indicating the execution status.
hgs
parents:
diff changeset
   137
        * @return Pointer to requested data channel
hgs
parents:
diff changeset
   138
        */
hgs
parents:
diff changeset
   139
        virtual MSatBIPDataChannel* DataChannel( const TInt aChannelId,
hgs
parents:
diff changeset
   140
            TInt& aErrCode ) = 0;
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
        /**
hgs
parents:
diff changeset
   143
        * Request to close specified data channel.
hgs
parents:
diff changeset
   144
        * @return Array containing all available data channels.
hgs
parents:
diff changeset
   145
        */
hgs
parents:
diff changeset
   146
        virtual CArrayPtrFlat<MSatBIPDataChannel>* DataChannels() = 0;
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
        /**
hgs
parents:
diff changeset
   149
        * Generates channel status object from given parameters to
hgs
parents:
diff changeset
   150
        * used in terminal responses.
hgs
parents:
diff changeset
   151
        * @param aChannelId Data channel identifier.
hgs
parents:
diff changeset
   152
        * @param aStatus Data channel's status.
hgs
parents:
diff changeset
   153
        * @return channel status object that can be put into terminal responses.
hgs
parents:
diff changeset
   154
        */
hgs
parents:
diff changeset
   155
        virtual RSat::TChannelStatus GenerateChannelStatusL(
hgs
parents:
diff changeset
   156
            const TInt aChannelId, TInt aStatus ) = 0;
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
        /**
hgs
parents:
diff changeset
   159
        * Reference to APN handler
hgs
parents:
diff changeset
   160
        * @return Interface reference to CSatApnHandler
hgs
parents:
diff changeset
   161
        */
hgs
parents:
diff changeset
   162
        virtual MSatApnHandler& ApnHandler() = 0;
hgs
parents:
diff changeset
   163
        
hgs
parents:
diff changeset
   164
        /**
hgs
parents:
diff changeset
   165
        * Status of the PDP Context
hgs
parents:
diff changeset
   166
        * @return ETrue, if there is active PDP Context
hgs
parents:
diff changeset
   167
        */
hgs
parents:
diff changeset
   168
        virtual TBool IsContextActive() = 0;
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
    private:
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
        // Prohibit copy constructor if not deriving from CBase.
hgs
parents:
diff changeset
   173
        MSatBIPUtils( const MSatBIPUtils& );
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
        // Prohibit assigment operator if not deriving from CBase.
hgs
parents:
diff changeset
   176
        MSatBIPUtils& operator=( const MSatBIPUtils& );
hgs
parents:
diff changeset
   177
    };
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
#endif      // MSATBIPUTILS_H
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
// End of File