btobexprofiles/obexsendservices/obexservicesendutils/inc/BTServiceClient.h
author hgs
Fri, 28 May 2010 17:03:06 +0300
changeset 32 19bd632b5100
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32
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:  Obex client
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 BT_SERVICE_CLIENT_H
hgs
parents:
diff changeset
    21
#define BT_SERVICE_CLIENT_H
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
//  INCLUDES
hgs
parents:
diff changeset
    24
#include "BTSUPassKeyRequest.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include <obex.h>
hgs
parents:
diff changeset
    27
#include <obexheaders.h>
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
 
hgs
parents:
diff changeset
    30
// FORWARD DECLARATION
hgs
parents:
diff changeset
    31
class CBTSUPasskeyRequest;
hgs
parents:
diff changeset
    32
class CBTConnectionTimer;
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
// CLASS DECLARATION
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/**
hgs
parents:
diff changeset
    37
*  An interface used to inform about BT service client events.
hgs
parents:
diff changeset
    38
*/
hgs
parents:
diff changeset
    39
class MBTServiceClientObserver
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    public:
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
        /**
hgs
parents:
diff changeset
    44
        * Informs the observer that a Connect operation has been completed. 
hgs
parents:
diff changeset
    45
        * @param aStatus The status of the operation.
hgs
parents:
diff changeset
    46
        * @return None.
hgs
parents:
diff changeset
    47
        */
hgs
parents:
diff changeset
    48
        virtual void ConnectCompleted( TInt aStatus ) = 0;
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
        /**
hgs
parents:
diff changeset
    51
        * Informs the observer that a Put operation has been completed. 
hgs
parents:
diff changeset
    52
        * @param aStatus The status of the operation.
hgs
parents:
diff changeset
    53
        * @param aPutResponse The response object.
hgs
parents:
diff changeset
    54
        * @return None.
hgs
parents:
diff changeset
    55
        */
hgs
parents:
diff changeset
    56
        virtual void PutCompleted( TInt aStatus,const  CObexHeaderSet* aPutResponse ) = 0;
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
        /**
hgs
parents:
diff changeset
    59
        * Informs the observer that a Get operation has been completed. 
hgs
parents:
diff changeset
    60
        * @param aStatus The status of the operation.
hgs
parents:
diff changeset
    61
        * @param aGetResponse The response object.
hgs
parents:
diff changeset
    62
        * @return None.
hgs
parents:
diff changeset
    63
        */
hgs
parents:
diff changeset
    64
        virtual void GetCompleted( TInt aStatus, CObexBufObject* aGetResponse ) = 0;
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
        /**
hgs
parents:
diff changeset
    67
        * Informs the observer that the client connection has been closed.
hgs
parents:
diff changeset
    68
        * @return None.
hgs
parents:
diff changeset
    69
        */
hgs
parents:
diff changeset
    70
        virtual void ClientConnectionClosed() = 0;
hgs
parents:
diff changeset
    71
        
hgs
parents:
diff changeset
    72
        /**
hgs
parents:
diff changeset
    73
        * Informs the observer that the client connect is timed out.
hgs
parents:
diff changeset
    74
        * @return None.
hgs
parents:
diff changeset
    75
        */
hgs
parents:
diff changeset
    76
        virtual void ConnectTimedOut() = 0;
hgs
parents:
diff changeset
    77
        
hgs
parents:
diff changeset
    78
      
hgs
parents:
diff changeset
    79
    };
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
/**
hgs
parents:
diff changeset
    82
*  An interface used to inform about BT Connection timeout
hgs
parents:
diff changeset
    83
*/    
hgs
parents:
diff changeset
    84
class MBTConTimeObserver    
hgs
parents:
diff changeset
    85
    {
hgs
parents:
diff changeset
    86
    public:
hgs
parents:
diff changeset
    87
        /**
hgs
parents:
diff changeset
    88
        * Informs the observer that the client connec is timeouted
hgs
parents:
diff changeset
    89
        * @return None.
hgs
parents:
diff changeset
    90
        */
hgs
parents:
diff changeset
    91
        virtual void ConnectionTimedOut()=0;
hgs
parents:
diff changeset
    92
    };
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
// CLASS DECLARATION
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
/**
hgs
parents:
diff changeset
    98
*  An interface used to ask client's progress status.
hgs
parents:
diff changeset
    99
*/
hgs
parents:
diff changeset
   100
class MBTServiceProgressGetter
hgs
parents:
diff changeset
   101
    {
hgs
parents:
diff changeset
   102
    public:
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
        /**
hgs
parents:
diff changeset
   105
        * Returns the progess status of the service client.
hgs
parents:
diff changeset
   106
        * @return The number of bytes sent.
hgs
parents:
diff changeset
   107
        */
hgs
parents:
diff changeset
   108
        virtual TInt GetProgressStatus() = 0;
hgs
parents:
diff changeset
   109
    };
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
// CLASS DECLARATION
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
/**
hgs
parents:
diff changeset
   114
*  An active object managing the Obex client.
hgs
parents:
diff changeset
   115
*/
hgs
parents:
diff changeset
   116
NONSHARABLE_CLASS (CBTServiceClient) : public CActive,
hgs
parents:
diff changeset
   117
                         public MBTServiceProgressGetter,
hgs
parents:
diff changeset
   118
                         public MObexAuthChallengeHandler,
hgs
parents:
diff changeset
   119
                         public MBTConTimeObserver
hgs
parents:
diff changeset
   120
                         
hgs
parents:
diff changeset
   121
    {
hgs
parents:
diff changeset
   122
    public:  // Constructors and destructor
hgs
parents:
diff changeset
   123
        
hgs
parents:
diff changeset
   124
        /**
hgs
parents:
diff changeset
   125
        * Two-phased constructor.
hgs
parents:
diff changeset
   126
        * @param aObserver A pointer to the client observer.
hgs
parents:
diff changeset
   127
        * @param aRemoteDevice The address of the remote device.
hgs
parents:
diff changeset
   128
        * @param aRemotePort The port of the remote device.
hgs
parents:
diff changeset
   129
        * @param aHeaderList The headers to be associated with connect object.
hgs
parents:
diff changeset
   130
        * @return None.
hgs
parents:
diff changeset
   131
        */
hgs
parents:
diff changeset
   132
        static CBTServiceClient* NewL( MBTServiceClientObserver* aObserver,
hgs
parents:
diff changeset
   133
                                       const TBTDevAddr& aRemoteDevice,
hgs
parents:
diff changeset
   134
                                       const TUint aRemotePort,
hgs
parents:
diff changeset
   135
                                       RArray<CObexHeader*> aHeaderList );
hgs
parents:
diff changeset
   136
        
hgs
parents:
diff changeset
   137
        /**
hgs
parents:
diff changeset
   138
        * Destructor.
hgs
parents:
diff changeset
   139
        */
hgs
parents:
diff changeset
   140
        virtual ~CBTServiceClient();
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
    public: // New functions
hgs
parents:
diff changeset
   143
        
hgs
parents:
diff changeset
   144
        /**
hgs
parents:
diff changeset
   145
        * Issues an Obex Get-request.
hgs
parents:
diff changeset
   146
        * @param aHeaderList The headers to be associated with the object.
hgs
parents:
diff changeset
   147
        * @param aFileName A filename of the Get Object.
hgs
parents:
diff changeset
   148
        * @return None.
hgs
parents:
diff changeset
   149
        */
hgs
parents:
diff changeset
   150
        void GetObjectL( RArray<CObexHeader*>& aHeaderList, 
hgs
parents:
diff changeset
   151
                         const TDesC& aFileName = KNullDesC );
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
        /**
hgs
parents:
diff changeset
   154
        * Issues an Obex Put-request.        
hgs
parents:
diff changeset
   155
        * @param aHeaderList The headers to be associated with the object.
hgs
parents:
diff changeset
   156
        * @param aFileName A filename of the Put Object.
hgs
parents:
diff changeset
   157
        * @return None.
hgs
parents:
diff changeset
   158
        */
hgs
parents:
diff changeset
   159
        void PutObjectL( RArray<CObexHeader*>& aHeaderList, 
hgs
parents:
diff changeset
   160
                         const TDesC& aFileName  );
hgs
parents:
diff changeset
   161
                         
hgs
parents:
diff changeset
   162
        /**
hgs
parents:
diff changeset
   163
        * Issues an Obex Put-request.        
hgs
parents:
diff changeset
   164
        * @param aHeaderList The headers to be associated with the object.
hgs
parents:
diff changeset
   165
        * @param aFile A filehandle of the Put Object.
hgs
parents:
diff changeset
   166
        * @return None.
hgs
parents:
diff changeset
   167
        */
hgs
parents:
diff changeset
   168
        void PutObjectL( RArray<CObexHeader*>& aHeaderList, 
hgs
parents:
diff changeset
   169
                         RFile&  );
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
        /**
hgs
parents:
diff changeset
   172
        * Closes Obex Client connection.
hgs
parents:
diff changeset
   173
        * @param None.
hgs
parents:
diff changeset
   174
        * @return None.
hgs
parents:
diff changeset
   175
        */
hgs
parents:
diff changeset
   176
        void CloseClientConnection();
hgs
parents:
diff changeset
   177
        
hgs
parents:
diff changeset
   178
        /**
hgs
parents:
diff changeset
   179
        * Send abort command to remote device
hgs
parents:
diff changeset
   180
        * @param None.
hgs
parents:
diff changeset
   181
        * @return None.
hgs
parents:
diff changeset
   182
        */
hgs
parents:
diff changeset
   183
        void Abort();        
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
    private: // Functions from base classes
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
        /**
hgs
parents:
diff changeset
   188
        * From MBTServiceProgressGetter Returns the progess status.
hgs
parents:
diff changeset
   189
        * @return The number of bytes sent.
hgs
parents:
diff changeset
   190
        */
hgs
parents:
diff changeset
   191
        TInt GetProgressStatus();
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
        
hgs
parents:
diff changeset
   194
    private: // Functions from base classes
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
        /**
hgs
parents:
diff changeset
   197
        * From MObexAuthChallengeHandler The Obex Passkey is requested.
hgs
parents:
diff changeset
   198
        * @param aRealm The realm/challenge specified by the unit forcing 
hgs
parents:
diff changeset
   199
        * the authentication.
hgs
parents:
diff changeset
   200
        * @return None.
hgs
parents:
diff changeset
   201
        */
hgs
parents:
diff changeset
   202
        void GetUserPasswordL( const TDesC& aRealm );
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
        /**
hgs
parents:
diff changeset
   205
        * From CActive Get's called when a request is cancelled.
hgs
parents:
diff changeset
   206
        * @param None.
hgs
parents:
diff changeset
   207
        * @return None.
hgs
parents:
diff changeset
   208
        */
hgs
parents:
diff changeset
   209
        void DoCancel();
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
        /**
hgs
parents:
diff changeset
   212
        * From CActive Get's called when a request is completed.
hgs
parents:
diff changeset
   213
        * @param None.
hgs
parents:
diff changeset
   214
        * @return None.
hgs
parents:
diff changeset
   215
        */
hgs
parents:
diff changeset
   216
	    void RunL();
hgs
parents:
diff changeset
   217
	    
hgs
parents:
diff changeset
   218
	    /**
hgs
parents:
diff changeset
   219
        * From MBTConTimeObserver  Get's called if bt connection is timed out.
hgs
parents:
diff changeset
   220
        * @param None.
hgs
parents:
diff changeset
   221
        * @return None.
hgs
parents:
diff changeset
   222
        */
hgs
parents:
diff changeset
   223
	    void ConnectionTimedOut();
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
    private:    // Data definitions
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
        enum TBTServiceClientState
hgs
parents:
diff changeset
   228
            {
hgs
parents:
diff changeset
   229
            EBTSCliIdle,
hgs
parents:
diff changeset
   230
            EBTSCliConnecting,
hgs
parents:
diff changeset
   231
            EBTSCliPutting,
hgs
parents:
diff changeset
   232
            EBTSCliGetting,
hgs
parents:
diff changeset
   233
            EBTSCliDisconnecting
hgs
parents:
diff changeset
   234
            };
hgs
parents:
diff changeset
   235
hgs
parents:
diff changeset
   236
    private:
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
        /**
hgs
parents:
diff changeset
   239
        * C++ default constructor.
hgs
parents:
diff changeset
   240
        */
hgs
parents:
diff changeset
   241
        CBTServiceClient( MBTServiceClientObserver* aObserver );
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
        /**
hgs
parents:
diff changeset
   244
        * By default Symbian 2nd phase constructor is private.
hgs
parents:
diff changeset
   245
        */
hgs
parents:
diff changeset
   246
        void ConstructL( const TBTDevAddr& aRemoteDevice,
hgs
parents:
diff changeset
   247
                         const TUint aRemotePort,
hgs
parents:
diff changeset
   248
                         RArray<CObexHeader*> aHeaderList );
hgs
parents:
diff changeset
   249
hgs
parents:
diff changeset
   250
    private:    // Data
hgs
parents:
diff changeset
   251
hgs
parents:
diff changeset
   252
        TBTServiceClientState       iClientState;
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
        CObexClient*                iClient;
hgs
parents:
diff changeset
   255
        CBufFlat*                   iObjectBuffer;
hgs
parents:
diff changeset
   256
        CObexBufObject*             iGetObject;
hgs
parents:
diff changeset
   257
        CObexFileObject*            iPutObject;        
hgs
parents:
diff changeset
   258
        CObexNullObject*            iConnectObject;
hgs
parents:
diff changeset
   259
        TInt                        iTotalBytesSent;
hgs
parents:
diff changeset
   260
        CBTSUPasskeyRequest*        iPasskeyRequest;
hgs
parents:
diff changeset
   261
        CBufFlat                    *iBuffer;
hgs
parents:
diff changeset
   262
        CObexBufObject*             iPutBufObject;
hgs
parents:
diff changeset
   263
        CBTConnectionTimer*         iConnectionTimer;
hgs
parents:
diff changeset
   264
        // Not owned
hgs
parents:
diff changeset
   265
        //
hgs
parents:
diff changeset
   266
        MBTServiceClientObserver*   iObserver;
hgs
parents:
diff changeset
   267
    };
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
#endif      // BT_SERVICE_CLIENT_H
hgs
parents:
diff changeset
   270
            
hgs
parents:
diff changeset
   271
// End of File