btobexprofiles/obexreceiveservices/bip/src/BIPController.cpp
author hgs
Fri, 28 May 2010 17:03:06 +0300
changeset 32 19bd632b5100
child 40 997690c3397a
child 42 b72428996822
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) 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:  Obex Server image receiver module implementation
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
// INCLUDE FILES
hgs
parents:
diff changeset
    20
#include    <avkon.hrh>                    // AVKON components
hgs
parents:
diff changeset
    21
#include    "BIPController.h"
hgs
parents:
diff changeset
    22
#include    "BIPCapabilityHandler.h"
hgs
parents:
diff changeset
    23
#include    "BIPImageHandler.h"
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include    <e32base.h>
hgs
parents:
diff changeset
    27
#include    <StringLoader.h>               // Series 60 localisation stringloader
hgs
parents:
diff changeset
    28
#include    <obexutilsmessagehandler.h>
hgs
parents:
diff changeset
    29
#include    <obexutilsuilayer.h>
hgs
parents:
diff changeset
    30
#include    <obexutilsdialog.h>
hgs
parents:
diff changeset
    31
#include    <UiklafInternalCRKeys.h>
hgs
parents:
diff changeset
    32
#include    <Obexutils.rsg>
hgs
parents:
diff changeset
    33
#include    <sysutil.h>
hgs
parents:
diff changeset
    34
#include    <bautils.h>
hgs
parents:
diff changeset
    35
#include    <driveinfo.h>                   
hgs
parents:
diff changeset
    36
#include    <AknWaitDialog.h>
hgs
parents:
diff changeset
    37
#include    <btengdomaincrkeys.h> 
hgs
parents:
diff changeset
    38
#include    <e32math.h> 
hgs
parents:
diff changeset
    39
#include    <es_sock.h>
hgs
parents:
diff changeset
    40
#include    <bt_sock.h>
hgs
parents:
diff changeset
    41
#include    <msvids.h>
hgs
parents:
diff changeset
    42
#include    "debug.h"
hgs
parents:
diff changeset
    43
        
hgs
parents:
diff changeset
    44
// CONSTANTS
hgs
parents:
diff changeset
    45
_LIT8(KBipCapabilityType, "x-bt/img-capabilities\0");
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
const TInt    KBufferSize = 0x10000;  // 64 kB
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
CBIPController* CBIPController::NewL()
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
    CBIPController* self = new ( ELeave ) CBIPController();
hgs
parents:
diff changeset
    55
	CleanupStack::PushL( self );
hgs
parents:
diff changeset
    56
	self->ConstructL();
hgs
parents:
diff changeset
    57
	CleanupStack::Pop(self); 
hgs
parents:
diff changeset
    58
	return self;
hgs
parents:
diff changeset
    59
    }
hgs
parents:
diff changeset
    60
    
hgs
parents:
diff changeset
    61
// ---------------------------------------------------------
hgs
parents:
diff changeset
    62
// CBIPController()
hgs
parents:
diff changeset
    63
// ---------------------------------------------------------
hgs
parents:
diff changeset
    64
//
hgs
parents:
diff changeset
    65
CBIPController::CBIPController()
hgs
parents:
diff changeset
    66
    {
hgs
parents:
diff changeset
    67
    }
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// ---------------------------------------------------------
hgs
parents:
diff changeset
    70
// ConstructL()
hgs
parents:
diff changeset
    71
// ---------------------------------------------------------
hgs
parents:
diff changeset
    72
//
hgs
parents:
diff changeset
    73
void CBIPController::ConstructL()
hgs
parents:
diff changeset
    74
    {
hgs
parents:
diff changeset
    75
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
    76
    iBIPImageHandler = CBIPImageHandler::NewL();
hgs
parents:
diff changeset
    77
    iLowMemoryActiveCDrive = CObexUtilsPropertyNotifier::NewL(this, ECheckPhoneMemory);
hgs
parents:
diff changeset
    78
    iLowMemoryActiveMMC = CObexUtilsPropertyNotifier::NewL(this, ECheckMMCMemory);
hgs
parents:
diff changeset
    79
    iDevMan = CBTEngDevMan::NewL(this);
hgs
parents:
diff changeset
    80
    iResultArray = new(ELeave) CBTDeviceArray(1);
hgs
parents:
diff changeset
    81
    // Get default folder from CenRep 
hgs
parents:
diff changeset
    82
    TObexUtilsMessageHandler::GetCenRepKeyStringValueL(KCRUidBluetoothEngine, KLCReceiveFolder, iCenRepFolder);
hgs
parents:
diff changeset
    83
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
    84
    }
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
// ---------------------------------------------------------
hgs
parents:
diff changeset
    87
// ~CBIPController()
hgs
parents:
diff changeset
    88
// ---------------------------------------------------------
hgs
parents:
diff changeset
    89
//
hgs
parents:
diff changeset
    90
CBIPController::~CBIPController()
hgs
parents:
diff changeset
    91
    {   
hgs
parents:
diff changeset
    92
    TRACE_FUNC_ENTRY    
hgs
parents:
diff changeset
    93
    delete iGetObject;    
hgs
parents:
diff changeset
    94
    delete iBIPCapabilityHandler;    
hgs
parents:
diff changeset
    95
    delete iBIPImageHandler;    
hgs
parents:
diff changeset
    96
    delete iLowMemoryActiveCDrive;    
hgs
parents:
diff changeset
    97
    delete iLowMemoryActiveMMC;    
hgs
parents:
diff changeset
    98
    delete iBuf;
hgs
parents:
diff changeset
    99
    delete iProgressDialog;
hgs
parents:
diff changeset
   100
    delete iWaitDialog;
hgs
parents:
diff changeset
   101
    delete iBTObject;
hgs
parents:
diff changeset
   102
    delete iDevMan;
hgs
parents:
diff changeset
   103
    if (iResultArray)
hgs
parents:
diff changeset
   104
        {
hgs
parents:
diff changeset
   105
        iResultArray->ResetAndDestroy();
hgs
parents:
diff changeset
   106
        delete iResultArray;
hgs
parents:
diff changeset
   107
        }
hgs
parents:
diff changeset
   108
    iFs.Close();
hgs
parents:
diff changeset
   109
    TRACE_FUNC_EXIT    
hgs
parents:
diff changeset
   110
    }
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
// ---------------------------------------------------------
hgs
parents:
diff changeset
   113
// ErrorIndication()
hgs
parents:
diff changeset
   114
// ---------------------------------------------------------
hgs
parents:
diff changeset
   115
//
hgs
parents:
diff changeset
   116
void CBIPController::ErrorIndication(TInt TRACE_ONLY(aError))
hgs
parents:
diff changeset
   117
    {
hgs
parents:
diff changeset
   118
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   119
    TRACE_ERROR((_L("[obexreceiveservicebip] CBIPController: ErrorIndication error:\t %d"), aError));
hgs
parents:
diff changeset
   120
    HandleError(EFalse); // false because this is not an explicit abort
hgs
parents:
diff changeset
   121
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   122
    }
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
// ---------------------------------------------------------
hgs
parents:
diff changeset
   125
// AbortIndication()
hgs
parents:
diff changeset
   126
// ---------------------------------------------------------
hgs
parents:
diff changeset
   127
//
hgs
parents:
diff changeset
   128
void CBIPController::AbortIndication()
hgs
parents:
diff changeset
   129
    {
hgs
parents:
diff changeset
   130
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   131
    HandleError(ETrue); // true because this is an explicit abort
hgs
parents:
diff changeset
   132
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   133
    }
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
void CBIPController::HandleError(TBool aAbort)
hgs
parents:
diff changeset
   136
    {
hgs
parents:
diff changeset
   137
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   138
    
hgs
parents:
diff changeset
   139
    if( iBTTransferState == ETransferPut || (!aAbort && iBTTransferState == ETransferPutDiskError) )
hgs
parents:
diff changeset
   140
        {
hgs
parents:
diff changeset
   141
        if(iBTObject)
hgs
parents:
diff changeset
   142
            {
hgs
parents:
diff changeset
   143
            iBTObject->Reset();
hgs
parents:
diff changeset
   144
            }
hgs
parents:
diff changeset
   145
        CancelTransfer();
hgs
parents:
diff changeset
   146
        TRAP_IGNORE(TObexUtilsUiLayer::ShowGlobalConfirmationQueryL( R_BT_FAILED_TO_RECEIVE));
hgs
parents:
diff changeset
   147
        }
hgs
parents:
diff changeset
   148
    delete iBuf;
hgs
parents:
diff changeset
   149
    iBuf = NULL;
hgs
parents:
diff changeset
   150
    
hgs
parents:
diff changeset
   151
    iBTTransferState = ETransferIdle;
hgs
parents:
diff changeset
   152
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveInboxEntriesL(iBTObject,iMsvIdParent));
hgs
parents:
diff changeset
   153
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveTemporaryRFileL(iFullPathFilename));
hgs
parents:
diff changeset
   154
    
hgs
parents:
diff changeset
   155
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   156
    }
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
// ---------------------------------------------------------
hgs
parents:
diff changeset
   159
// CancelTransfer()
hgs
parents:
diff changeset
   160
// ---------------------------------------------------------
hgs
parents:
diff changeset
   161
//
hgs
parents:
diff changeset
   162
void CBIPController::CancelTransfer()
hgs
parents:
diff changeset
   163
    {
hgs
parents:
diff changeset
   164
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   165
    CloseReceivingIndicator();
hgs
parents:
diff changeset
   166
    if(iBTTransferState == ETransferPut)
hgs
parents:
diff changeset
   167
        {
hgs
parents:
diff changeset
   168
        iBTTransferState = ETransferPutCancel;
hgs
parents:
diff changeset
   169
        }
hgs
parents:
diff changeset
   170
    else // go to idle for all other states
hgs
parents:
diff changeset
   171
        {
hgs
parents:
diff changeset
   172
        iBTTransferState = ETransferIdle;
hgs
parents:
diff changeset
   173
        }
hgs
parents:
diff changeset
   174
    }
hgs
parents:
diff changeset
   175
// ---------------------------------------------------------
hgs
parents:
diff changeset
   176
// TransportUpIndication()
hgs
parents:
diff changeset
   177
// ---------------------------------------------------------
hgs
parents:
diff changeset
   178
//
hgs
parents:
diff changeset
   179
void CBIPController::TransportUpIndication()
hgs
parents:
diff changeset
   180
    {
hgs
parents:
diff changeset
   181
    TRACE_FUNC
hgs
parents:
diff changeset
   182
    if (!iFs.Handle())
hgs
parents:
diff changeset
   183
        {
hgs
parents:
diff changeset
   184
        TRACE_INFO( (_L( "[bipreceiveservice] TransportUpIndication iFs.Connect()" )) ); 
hgs
parents:
diff changeset
   185
        if (iFs.Connect())   // error value not checked, iFs.Handle() checked one more time before first useage
hgs
parents:
diff changeset
   186
            {
hgs
parents:
diff changeset
   187
            TRACE_INFO( (_L( "[bipreceiveservice] TransportUpIndication iFs.Connect() failed" )) ); 
hgs
parents:
diff changeset
   188
            }
hgs
parents:
diff changeset
   189
        }
hgs
parents:
diff changeset
   190
    
hgs
parents:
diff changeset
   191
    iFile = RFile();
hgs
parents:
diff changeset
   192
    iFullPathFilename.Zero();
hgs
parents:
diff changeset
   193
    iCapabilityFileName.Zero();
hgs
parents:
diff changeset
   194
    }
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
// ---------------------------------------------------------
hgs
parents:
diff changeset
   197
// ObexConnectIndication()
hgs
parents:
diff changeset
   198
// ---------------------------------------------------------
hgs
parents:
diff changeset
   199
//
hgs
parents:
diff changeset
   200
TInt CBIPController::ObexConnectIndication( const TObexConnectInfo& /*aRemoteInfo*/, const TDesC8& /*aInfo*/ )
hgs
parents:
diff changeset
   201
    {
hgs
parents:
diff changeset
   202
    TRACE_FUNC
hgs
parents:
diff changeset
   203
    
hgs
parents:
diff changeset
   204
    // Get remote device socket address and bluetooth name
hgs
parents:
diff changeset
   205
    // Remote bluetooth name will be displayed in the new message in inbox.
hgs
parents:
diff changeset
   206
    //
hgs
parents:
diff changeset
   207
    TSockAddr addr;
hgs
parents:
diff changeset
   208
    iBTObexServer->RemoteAddr(addr);
hgs
parents:
diff changeset
   209
    TBTDevAddr tBTDevAddr = static_cast<TBTSockAddr>(addr).BTAddr();
hgs
parents:
diff changeset
   210
    
hgs
parents:
diff changeset
   211
    TBTRegistrySearch nameSearch;
hgs
parents:
diff changeset
   212
    nameSearch.FindAddress(tBTDevAddr);
hgs
parents:
diff changeset
   213
    
hgs
parents:
diff changeset
   214
    iResultArray->Reset();
hgs
parents:
diff changeset
   215
    // Ignore any errors here, if we don't get the name, we don't get the name.
hgs
parents:
diff changeset
   216
    // It is also possible that the name is received too late....
hgs
parents:
diff changeset
   217
    static_cast<void>(iDevMan->GetDevices(nameSearch, iResultArray));
hgs
parents:
diff changeset
   218
    
hgs
parents:
diff changeset
   219
    return KErrNone;
hgs
parents:
diff changeset
   220
    }
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
// ---------------------------------------------------------
hgs
parents:
diff changeset
   223
// ObexDisconnectIndication()
hgs
parents:
diff changeset
   224
// ---------------------------------------------------------
hgs
parents:
diff changeset
   225
//
hgs
parents:
diff changeset
   226
void CBIPController::ObexDisconnectIndication(const TDesC8& /*aInfo*/)
hgs
parents:
diff changeset
   227
    {
hgs
parents:
diff changeset
   228
    TRACE_FUNC
hgs
parents:
diff changeset
   229
    }
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
// ---------------------------------------------------------
hgs
parents:
diff changeset
   232
// TransportDownIndication()
hgs
parents:
diff changeset
   233
// ---------------------------------------------------------
hgs
parents:
diff changeset
   234
//
hgs
parents:
diff changeset
   235
void CBIPController::TransportDownIndication()
hgs
parents:
diff changeset
   236
    {
hgs
parents:
diff changeset
   237
    TRACE_FUNC   
hgs
parents:
diff changeset
   238
    // Remove receiving buffer and files used during file receiving.
hgs
parents:
diff changeset
   239
    //
hgs
parents:
diff changeset
   240
    delete iBTObject;
hgs
parents:
diff changeset
   241
    iBTObject = NULL;
hgs
parents:
diff changeset
   242
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveTemporaryRFileL (iFullPathFilename));  
hgs
parents:
diff changeset
   243
    iFs.Close();
hgs
parents:
diff changeset
   244
    }
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
// ---------------------------------------------------------
hgs
parents:
diff changeset
   247
// PutRequestIndication()
hgs
parents:
diff changeset
   248
// ---------------------------------------------------------
hgs
parents:
diff changeset
   249
//
hgs
parents:
diff changeset
   250
CObexBufObject* CBIPController::PutRequestIndication()
hgs
parents:
diff changeset
   251
    {   
hgs
parents:
diff changeset
   252
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   253
    iLengthHeaderReceived = EFalse; // New put request so clear header based state
hgs
parents:
diff changeset
   254
    iBTTransferState = ETransferPut;
hgs
parents:
diff changeset
   255
    
hgs
parents:
diff changeset
   256
    // Checking if backup is running now - if backup process is active, then we
hgs
parents:
diff changeset
   257
    // need to cancel transfer - otherwise phone will freeze during receiving
hgs
parents:
diff changeset
   258
    // data
hgs
parents:
diff changeset
   259
    if ( TObexUtilsUiLayer::IsBackupRunning() )
hgs
parents:
diff changeset
   260
        {
hgs
parents:
diff changeset
   261
        TRACE_INFO ( _L ("Backup in progress! Canceling incoming transfer."));
hgs
parents:
diff changeset
   262
        iBTTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   263
        return NULL;
hgs
parents:
diff changeset
   264
        }
hgs
parents:
diff changeset
   265
        
hgs
parents:
diff changeset
   266
    TRAPD(err, HandlePutImageRequestL());
hgs
parents:
diff changeset
   267
    if (err == KErrNone)
hgs
parents:
diff changeset
   268
        {
hgs
parents:
diff changeset
   269
        return iBTObject;
hgs
parents:
diff changeset
   270
        }
hgs
parents:
diff changeset
   271
    if (iBTTransferState != ETransferPutInitError)
hgs
parents:
diff changeset
   272
        {
hgs
parents:
diff changeset
   273
        iBTTransferState = ETransferPutDiskError;
hgs
parents:
diff changeset
   274
        }
hgs
parents:
diff changeset
   275
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   276
    return NULL;
hgs
parents:
diff changeset
   277
    }
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
// ---------------------------------------------------------
hgs
parents:
diff changeset
   280
// PutPacketIndication() 
hgs
parents:
diff changeset
   281
// ---------------------------------------------------------
hgs
parents:
diff changeset
   282
//
hgs
parents:
diff changeset
   283
TInt CBIPController::PutPacketIndication()
hgs
parents:
diff changeset
   284
    {
hgs
parents:
diff changeset
   285
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   286
    if(iBTTransferState == ETransferPutCancel)
hgs
parents:
diff changeset
   287
        {
hgs
parents:
diff changeset
   288
        // User cancelled the put request, so error the next packet to terminate the put request.
hgs
parents:
diff changeset
   289
        // BIP considers the Unauthorized error response suitable for this...
hgs
parents:
diff changeset
   290
        HandleError(ETrue); // reset state and clear up
hgs
parents:
diff changeset
   291
        return KErrIrObexRespUnauthorized;
hgs
parents:
diff changeset
   292
        }
hgs
parents:
diff changeset
   293
    
hgs
parents:
diff changeset
   294
    if (iBTObject)
hgs
parents:
diff changeset
   295
        {
hgs
parents:
diff changeset
   296
        iTotalSizeByte = iBTObject->Length();     // get size of receiving file
hgs
parents:
diff changeset
   297
        iReceivingFileName = iBTObject->Name();   // get name of receiving file
hgs
parents:
diff changeset
   298
        
hgs
parents:
diff changeset
   299
        // Check that capacity is suitable as soon as possible
hgs
parents:
diff changeset
   300
        if(!iLengthHeaderReceived && iTotalSizeByte > 0)
hgs
parents:
diff changeset
   301
            {
hgs
parents:
diff changeset
   302
            iLengthHeaderReceived = ETrue; // total size value is from length header
hgs
parents:
diff changeset
   303
            TBool capacity = ETrue;
hgs
parents:
diff changeset
   304
            TRAPD(retTrap, capacity = CheckCapacityL());
hgs
parents:
diff changeset
   305
            if(retTrap != KErrNone)
hgs
parents:
diff changeset
   306
                {
hgs
parents:
diff changeset
   307
                return KErrGeneral;
hgs
parents:
diff changeset
   308
                }
hgs
parents:
diff changeset
   309
            if(!capacity)
hgs
parents:
diff changeset
   310
                {
hgs
parents:
diff changeset
   311
                TRAP_IGNORE(TObexUtilsUiLayer::ShowGlobalConfirmationQueryL(R_OUT_OF_MEMORY));
hgs
parents:
diff changeset
   312
                return KErrDiskFull;
hgs
parents:
diff changeset
   313
                }
hgs
parents:
diff changeset
   314
            }
hgs
parents:
diff changeset
   315
        if(iBTObject->Name().Length() > KMaxFileName)
hgs
parents:
diff changeset
   316
            {
hgs
parents:
diff changeset
   317
            return KErrAccessDenied;
hgs
parents:
diff changeset
   318
            }
hgs
parents:
diff changeset
   319
        if(iBTTransferState == ETransferPutDiskError)
hgs
parents:
diff changeset
   320
            {
hgs
parents:
diff changeset
   321
            return KErrDiskFull;
hgs
parents:
diff changeset
   322
            }
hgs
parents:
diff changeset
   323
        // successfully received put packet if we reached here
hgs
parents:
diff changeset
   324
        iBTTransferState = ETransferPut;
hgs
parents:
diff changeset
   325
        
hgs
parents:
diff changeset
   326
        // Now we need to either create (in the first instance) or update the dialog on the UI.
hgs
parents:
diff changeset
   327
        if(ReceivingIndicatorActive())
hgs
parents:
diff changeset
   328
            {
hgs
parents:
diff changeset
   329
            UpdateReceivingIndicator();
hgs
parents:
diff changeset
   330
            }
hgs
parents:
diff changeset
   331
        else if(!iNoteDisplayed)
hgs
parents:
diff changeset
   332
            {
hgs
parents:
diff changeset
   333
            // No note launched yet, so try to launch
hgs
parents:
diff changeset
   334
            TRAPD(err, LaunchReceivingIndicatorL());
hgs
parents:
diff changeset
   335
            iNoteDisplayed = (err == KErrNone);
hgs
parents:
diff changeset
   336
            }
hgs
parents:
diff changeset
   337
        }
hgs
parents:
diff changeset
   338
    
hgs
parents:
diff changeset
   339
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   340
    return KErrNone;
hgs
parents:
diff changeset
   341
    }
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
// ---------------------------------------------------------
hgs
parents:
diff changeset
   344
// PutCompleteIndication() 
hgs
parents:
diff changeset
   345
// ---------------------------------------------------------
hgs
parents:
diff changeset
   346
//
hgs
parents:
diff changeset
   347
TInt CBIPController::PutCompleteIndication()  // Once receive has completed.
hgs
parents:
diff changeset
   348
    {
hgs
parents:
diff changeset
   349
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   350
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   351
    if(iBTTransferState == ETransferPutCancel)
hgs
parents:
diff changeset
   352
        {
hgs
parents:
diff changeset
   353
        retVal = KErrIrObexRespUnauthorized;
hgs
parents:
diff changeset
   354
        HandleError(ETrue);
hgs
parents:
diff changeset
   355
        }
hgs
parents:
diff changeset
   356
    else
hgs
parents:
diff changeset
   357
        {
hgs
parents:
diff changeset
   358
        retVal = HandlePutCompleteIndication();
hgs
parents:
diff changeset
   359
        iBTTransferState = ETransferIdle;
hgs
parents:
diff changeset
   360
        CloseReceivingIndicator();
hgs
parents:
diff changeset
   361
        }
hgs
parents:
diff changeset
   362
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   363
    return retVal;
hgs
parents:
diff changeset
   364
    }
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
// ---------------------------------------------------------
hgs
parents:
diff changeset
   367
// GetRequestIndication()
hgs
parents:
diff changeset
   368
// ---------------------------------------------------------
hgs
parents:
diff changeset
   369
//
hgs
parents:
diff changeset
   370
CObexBufObject* CBIPController::GetRequestIndication( CObexBaseObject* aRequiredObject )
hgs
parents:
diff changeset
   371
    {
hgs
parents:
diff changeset
   372
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   373
    iBTTransferState = ETransferGet;
hgs
parents:
diff changeset
   374
    TInt err = RemoveCapabilityObject();
hgs
parents:
diff changeset
   375
    if (err == KErrNone)
hgs
parents:
diff changeset
   376
        {
hgs
parents:
diff changeset
   377
        if( aRequiredObject->Type() == KBipCapabilityType )
hgs
parents:
diff changeset
   378
            {
hgs
parents:
diff changeset
   379
            TRAP( err, HandleGetCapabilityRequestL( ) );
hgs
parents:
diff changeset
   380
            if( err == KErrNone )
hgs
parents:
diff changeset
   381
                {
hgs
parents:
diff changeset
   382
                return iGetObject;
hgs
parents:
diff changeset
   383
                }
hgs
parents:
diff changeset
   384
            }
hgs
parents:
diff changeset
   385
        }
hgs
parents:
diff changeset
   386
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   387
    return NULL;
hgs
parents:
diff changeset
   388
    }
hgs
parents:
diff changeset
   389
hgs
parents:
diff changeset
   390
// ---------------------------------------------------------
hgs
parents:
diff changeset
   391
// GetPacketIndication()
hgs
parents:
diff changeset
   392
// ---------------------------------------------------------
hgs
parents:
diff changeset
   393
//
hgs
parents:
diff changeset
   394
TInt CBIPController::GetPacketIndication()
hgs
parents:
diff changeset
   395
    {
hgs
parents:
diff changeset
   396
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   397
    return KErrNone;
hgs
parents:
diff changeset
   398
    }
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
// ---------------------------------------------------------
hgs
parents:
diff changeset
   401
// GetCompleteIndication()
hgs
parents:
diff changeset
   402
// ---------------------------------------------------------
hgs
parents:
diff changeset
   403
//
hgs
parents:
diff changeset
   404
TInt CBIPController::GetCompleteIndication()
hgs
parents:
diff changeset
   405
    {
hgs
parents:
diff changeset
   406
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   407
    delete iGetObject;
hgs
parents:
diff changeset
   408
    iGetObject=NULL;
hgs
parents:
diff changeset
   409
    TInt err = RemoveCapabilityObject();
hgs
parents:
diff changeset
   410
    if (err != KErrNone)
hgs
parents:
diff changeset
   411
        {
hgs
parents:
diff changeset
   412
        err = KErrGeneral;
hgs
parents:
diff changeset
   413
        }
hgs
parents:
diff changeset
   414
    iBTTransferState = ETransferIdle;
hgs
parents:
diff changeset
   415
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   416
    return err;
hgs
parents:
diff changeset
   417
    }
hgs
parents:
diff changeset
   418
hgs
parents:
diff changeset
   419
// ---------------------------------------------------------
hgs
parents:
diff changeset
   420
// SetPathIndication()
hgs
parents:
diff changeset
   421
// ---------------------------------------------------------
hgs
parents:
diff changeset
   422
//
hgs
parents:
diff changeset
   423
TInt CBIPController::SetPathIndication( const CObex::TSetPathInfo& /*aPathInfo*/, 
hgs
parents:
diff changeset
   424
                                        const TDesC8& /*aInfo*/)
hgs
parents:
diff changeset
   425
    {
hgs
parents:
diff changeset
   426
    TRACE_FUNC
hgs
parents:
diff changeset
   427
    // SetPath is not implemented in BIP - so following IrOBEX guidance, return
hgs
parents:
diff changeset
   428
    // the Forbidden response code.
hgs
parents:
diff changeset
   429
    return KErrIrObexRespForbidden;
hgs
parents:
diff changeset
   430
    }
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
/**
hgs
parents:
diff changeset
   433
* This function is implementation for mixin-class for Obexutils.
hgs
parents:
diff changeset
   434
* It is called every time another instance modifies disk status,
hgs
parents:
diff changeset
   435
* for example when it cross warning/critical level.
hgs
parents:
diff changeset
   436
* Parameters:
hgs
parents:
diff changeset
   437
* @param aCheckType             Disktype changes.
hgs
parents:
diff changeset
   438
*/
hgs
parents:
diff changeset
   439
void CBIPController::HandleNotifyL(TMemoryPropertyCheckType aCheckType)
hgs
parents:
diff changeset
   440
    {    
hgs
parents:
diff changeset
   441
    TRACE_FUNC_ENTRY    
hgs
parents:
diff changeset
   442
    // Only interested on this notification if we are receiving something
hgs
parents:
diff changeset
   443
    if ( iBTTransferState == ETransferPut )
hgs
parents:
diff changeset
   444
        {
hgs
parents:
diff changeset
   445
       // Check the keys, what has been changed.
hgs
parents:
diff changeset
   446
       if ( aCheckType == ECheckPhoneMemory )
hgs
parents:
diff changeset
   447
           {
hgs
parents:
diff changeset
   448
           if ( SysUtil::FFSSpaceBelowCriticalLevelL( NULL, 0 ) )
hgs
parents:
diff changeset
   449
               {                
hgs
parents:
diff changeset
   450
               TRACE_INFO( _L( "[obexreceiveservicebip] CBIPController: Obex Server error diskfull:\t" ) );
hgs
parents:
diff changeset
   451
               iBTTransferState = ETransferPutDiskError;
hgs
parents:
diff changeset
   452
               }
hgs
parents:
diff changeset
   453
           }
hgs
parents:
diff changeset
   454
       else if ( aCheckType == ECheckMMCMemory )
hgs
parents:
diff changeset
   455
           {                
hgs
parents:
diff changeset
   456
           if ( SysUtil::MMCSpaceBelowCriticalLevelL( NULL, 0 ) )
hgs
parents:
diff changeset
   457
               {                    
hgs
parents:
diff changeset
   458
               TRACE_INFO( _L( "[obexreceiveservicebip] CBIPController: Obex Server error diskfull:\t" ) );
hgs
parents:
diff changeset
   459
               iBTTransferState = ETransferPutDiskError;
hgs
parents:
diff changeset
   460
               }
hgs
parents:
diff changeset
   461
           }            
hgs
parents:
diff changeset
   462
        }        
hgs
parents:
diff changeset
   463
    TRACE_FUNC_EXIT    
hgs
parents:
diff changeset
   464
    }
hgs
parents:
diff changeset
   465
    
hgs
parents:
diff changeset
   466
// ---------------------------------------------------------
hgs
parents:
diff changeset
   467
// HandleGetCapabilityRequestL()
hgs
parents:
diff changeset
   468
// ---------------------------------------------------------
hgs
parents:
diff changeset
   469
//
hgs
parents:
diff changeset
   470
void CBIPController::HandleGetCapabilityRequestL()
hgs
parents:
diff changeset
   471
    {
hgs
parents:
diff changeset
   472
    TRACE_FUNC_ENTRY    
hgs
parents:
diff changeset
   473
    CBIPCapabilityHandler* capHandler = CBIPCapabilityHandler::NewL();
hgs
parents:
diff changeset
   474
    CleanupStack::PushL(capHandler);
hgs
parents:
diff changeset
   475
    capHandler->CreateCapabilityObjectL(iCapabilityFileName);
hgs
parents:
diff changeset
   476
    delete iGetObject;
hgs
parents:
diff changeset
   477
    iGetObject = NULL; 
hgs
parents:
diff changeset
   478
    iGetObject = CObexBufObject::NewL(NULL);
hgs
parents:
diff changeset
   479
    iGetObject->SetDataBufL(iCapabilityFileName);
hgs
parents:
diff changeset
   480
    CleanupStack::PopAndDestroy(capHandler);
hgs
parents:
diff changeset
   481
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   482
    }
hgs
parents:
diff changeset
   483
hgs
parents:
diff changeset
   484
// ---------------------------------------------------------
hgs
parents:
diff changeset
   485
// HandlePutImageRequest()
hgs
parents:
diff changeset
   486
// ---------------------------------------------------------
hgs
parents:
diff changeset
   487
//
hgs
parents:
diff changeset
   488
void CBIPController::HandlePutImageRequestL()
hgs
parents:
diff changeset
   489
    {
hgs
parents:
diff changeset
   490
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   491
    
hgs
parents:
diff changeset
   492
    delete iBTObject;
hgs
parents:
diff changeset
   493
    iBTObject = NULL;
hgs
parents:
diff changeset
   494
hgs
parents:
diff changeset
   495
    if (!iFs.Handle())
hgs
parents:
diff changeset
   496
        {
hgs
parents:
diff changeset
   497
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   498
        }
hgs
parents:
diff changeset
   499
    
hgs
parents:
diff changeset
   500
    // Assign an initial value to iDrive
hgs
parents:
diff changeset
   501
    iDrive = GetDriveWithMaximumFreeSpaceL();    
hgs
parents:
diff changeset
   502
    
hgs
parents:
diff changeset
   503
    // If iDrive is at critical space level, we immediately show out_of_memory.
hgs
parents:
diff changeset
   504
    //
hgs
parents:
diff changeset
   505
    if (SysUtil::DiskSpaceBelowCriticalLevelL(&iFs, 0, iDrive))
hgs
parents:
diff changeset
   506
        {
hgs
parents:
diff changeset
   507
        TRAP_IGNORE(TObexUtilsUiLayer::ShowGlobalConfirmationQueryL(R_OUT_OF_MEMORY));
hgs
parents:
diff changeset
   508
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   509
        }
hgs
parents:
diff changeset
   510
    
hgs
parents:
diff changeset
   511
    iBTObject = CObexBufObject::NewL(NULL);    
hgs
parents:
diff changeset
   512
    
hgs
parents:
diff changeset
   513
    delete iBuf;
hgs
parents:
diff changeset
   514
    iBuf = NULL;
hgs
parents:
diff changeset
   515
    
hgs
parents:
diff changeset
   516
    TChar driveLetter;
hgs
parents:
diff changeset
   517
    iDefaultFolder.Zero();
hgs
parents:
diff changeset
   518
    iFs.DriveToChar(iDrive, driveLetter);
hgs
parents:
diff changeset
   519
    iDefaultFolder.Append(driveLetter);
hgs
parents:
diff changeset
   520
    if ( iDrive == EDriveC )
hgs
parents:
diff changeset
   521
        {
hgs
parents:
diff changeset
   522
        iDefaultFolder.Append(_L(":\\data\\"));
hgs
parents:
diff changeset
   523
        }
hgs
parents:
diff changeset
   524
    else
hgs
parents:
diff changeset
   525
        {
hgs
parents:
diff changeset
   526
        iDefaultFolder.Append(_L(":\\"));
hgs
parents:
diff changeset
   527
        }
hgs
parents:
diff changeset
   528
    
hgs
parents:
diff changeset
   529
    iDefaultFolder.Append(iCenRepFolder);
hgs
parents:
diff changeset
   530
    
hgs
parents:
diff changeset
   531
    iFile = RFile();
hgs
parents:
diff changeset
   532
    iFullPathFilename.Zero();
hgs
parents:
diff changeset
   533
    TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL(iFile, iDefaultFolder, iFullPathFilename, iBuf, KBufferSize);
hgs
parents:
diff changeset
   534
    User::LeaveIfError(iFile.Open(iFs, iFullPathFilename, EFileWrite));
hgs
parents:
diff changeset
   535
    TObexRFileBackedBuffer bufferdetails(*iBuf, iFile, CObexBufObject::EDoubleBuffering);
hgs
parents:
diff changeset
   536
    TRAPD(err, iBTObject->SetDataBufL(bufferdetails));
hgs
parents:
diff changeset
   537
    if (err != KErrNone)
hgs
parents:
diff changeset
   538
        {
hgs
parents:
diff changeset
   539
        iBTTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   540
        User::Leave(KErrGeneral); 
hgs
parents:
diff changeset
   541
        }
hgs
parents:
diff changeset
   542
        
hgs
parents:
diff changeset
   543
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   544
    }
hgs
parents:
diff changeset
   545
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
// ---------------------------------------------------------
hgs
parents:
diff changeset
   548
// HandlePutCompleteIndication()
hgs
parents:
diff changeset
   549
// ---------------------------------------------------------
hgs
parents:
diff changeset
   550
//
hgs
parents:
diff changeset
   551
TInt CBIPController::HandlePutCompleteIndication()
hgs
parents:
diff changeset
   552
	{
hgs
parents:
diff changeset
   553
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   554
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   555
hgs
parents:
diff changeset
   556
    iDefaultFolder.Zero();
hgs
parents:
diff changeset
   557
    TChar driveLetter;
hgs
parents:
diff changeset
   558
    if ( iDrive == EDriveC )
hgs
parents:
diff changeset
   559
        {
hgs
parents:
diff changeset
   560
        iFs.DriveToChar(iDrive, driveLetter);
hgs
parents:
diff changeset
   561
        iDefaultFolder.Append(driveLetter);
hgs
parents:
diff changeset
   562
        iDefaultFolder.Append(_L(":\\data\\"));
hgs
parents:
diff changeset
   563
        iDefaultFolder.Append(iCenRepFolder);
hgs
parents:
diff changeset
   564
        }
hgs
parents:
diff changeset
   565
    else
hgs
parents:
diff changeset
   566
        {
hgs
parents:
diff changeset
   567
        iFs.DriveToChar(iDrive, driveLetter);
hgs
parents:
diff changeset
   568
        iDefaultFolder.Append(driveLetter);
hgs
parents:
diff changeset
   569
        iDefaultFolder.Append(_L(":\\"));
hgs
parents:
diff changeset
   570
        iDefaultFolder.Append(iCenRepFolder);
hgs
parents:
diff changeset
   571
        }
hgs
parents:
diff changeset
   572
    
hgs
parents:
diff changeset
   573
    iFullPathFilename.Zero();
hgs
parents:
diff changeset
   574
    iFullPathFilename.Append(iDefaultFolder);
hgs
parents:
diff changeset
   575
    TRAP ( retVal, TObexUtilsMessageHandler::SaveFileToFileSystemL(iBTObject,
hgs
parents:
diff changeset
   576
                                                                   KUidMsgTypeBt,
hgs
parents:
diff changeset
   577
                                                                   iMsvIdParent,
hgs
parents:
diff changeset
   578
                                                                   iFullPathFilename,
hgs
parents:
diff changeset
   579
                                                                   iFile,
hgs
parents:
diff changeset
   580
                                                                   iRemoteDeviceName));
hgs
parents:
diff changeset
   581
    if ( retVal == KErrNone)
hgs
parents:
diff changeset
   582
        {
hgs
parents:
diff changeset
   583
        TRAP (retVal, TObexUtilsMessageHandler::AddEntryToInboxL(iMsvIdParent, iFullPathFilename));
hgs
parents:
diff changeset
   584
        }
hgs
parents:
diff changeset
   585
    
hgs
parents:
diff changeset
   586
    
hgs
parents:
diff changeset
   587
    if( retVal != KErrNone )
hgs
parents:
diff changeset
   588
        {
hgs
parents:
diff changeset
   589
        TRACE_ERROR((_L( "[obexreceiveservicebip] CBIPController: HandlePutCompleteIndication error:\t %d" ), retVal ) );              
hgs
parents:
diff changeset
   590
        TRAP( retVal, TObexUtilsMessageHandler::RemoveInboxEntriesL(iBTObject, iMsvIdParent));
hgs
parents:
diff changeset
   591
        retVal = KErrDiskFull;
hgs
parents:
diff changeset
   592
        }
hgs
parents:
diff changeset
   593
    // Even if the object saving fails we must return image handle with error code
hgs
parents:
diff changeset
   594
    TRAP_IGNORE( iBIPImageHandler->AddImageHandleHeaderL( iBTObexServer ) );            
hgs
parents:
diff changeset
   595
    TRACE_INFO( _L( "[obexreceiveservicebip] HandlePutCompleteIndication Done\t" ) );
hgs
parents:
diff changeset
   596
    delete iBTObject;
hgs
parents:
diff changeset
   597
    iBTObject = NULL;
hgs
parents:
diff changeset
   598
    delete iBuf;
hgs
parents:
diff changeset
   599
    iBuf = NULL;
hgs
parents:
diff changeset
   600
    iPreviousDefaultFolder = iDefaultFolder;  // save the last file path where file is successfully saved to file system.
hgs
parents:
diff changeset
   601
    iMsvIdParent = KMsvNullIndexEntryId;
hgs
parents:
diff changeset
   602
    TRACE_FUNC_EXIT     
hgs
parents:
diff changeset
   603
    return retVal;
hgs
parents:
diff changeset
   604
	}
hgs
parents:
diff changeset
   605
// ---------------------------------------------------------
hgs
parents:
diff changeset
   606
// RemoveCapabilityObject()
hgs
parents:
diff changeset
   607
// ---------------------------------------------------------
hgs
parents:
diff changeset
   608
//		
hgs
parents:
diff changeset
   609
TInt CBIPController::RemoveCapabilityObject()
hgs
parents:
diff changeset
   610
    {
hgs
parents:
diff changeset
   611
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   612
    if ( (iCapabilityFileName.Compare(KNullDesC)) == 0 )
hgs
parents:
diff changeset
   613
        {
hgs
parents:
diff changeset
   614
        return KErrNone; 
hgs
parents:
diff changeset
   615
        }     
hgs
parents:
diff changeset
   616
    if ( !iFs.Handle() )
hgs
parents:
diff changeset
   617
        {
hgs
parents:
diff changeset
   618
        TRACE_INFO( (_L( "[bipreceiveservice] RemoveCapabilityObject return" )) ); 
hgs
parents:
diff changeset
   619
        return KErrGeneral;
hgs
parents:
diff changeset
   620
        }               
hgs
parents:
diff changeset
   621
    iFs.Delete(iCapabilityFileName);        
hgs
parents:
diff changeset
   622
    iCapabilityFileName=KNullDesC; 
hgs
parents:
diff changeset
   623
    TRACE_FUNC_EXIT 
hgs
parents:
diff changeset
   624
    return KErrNone;    
hgs
parents:
diff changeset
   625
    }
hgs
parents:
diff changeset
   626
	 
hgs
parents:
diff changeset
   627
// ---------------------------------------------------------
hgs
parents:
diff changeset
   628
// CheckCapacity()
hgs
parents:
diff changeset
   629
// ---------------------------------------------------------
hgs
parents:
diff changeset
   630
//	    
hgs
parents:
diff changeset
   631
TBool CBIPController::CheckCapacityL()
hgs
parents:
diff changeset
   632
    {
hgs
parents:
diff changeset
   633
    TRACE_FUNC_ENTRY   
hgs
parents:
diff changeset
   634
    
hgs
parents:
diff changeset
   635
    iDrive = EDriveZ; // Intialize iDrive to Z
hgs
parents:
diff changeset
   636
    TInt filesize = iBTObject->Length();
hgs
parents:
diff changeset
   637
    
hgs
parents:
diff changeset
   638
    TInt mmcDrive = KDefaultDrive;   // External memory card  
hgs
parents:
diff changeset
   639
    TInt imsDrive = KDefaultDrive;   // Internal mass storage
hgs
parents:
diff changeset
   640
    
hgs
parents:
diff changeset
   641
    User::LeaveIfError(DriveInfo::GetDefaultDrive(DriveInfo::EDefaultMassStorage, imsDrive));
hgs
parents:
diff changeset
   642
    User::LeaveIfError(DriveInfo::GetDefaultDrive(DriveInfo::EDefaultRemovableMassStorage, mmcDrive));      
hgs
parents:
diff changeset
   643
     
hgs
parents:
diff changeset
   644
    TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL imsDrive=%d; mmcDrive=%d\t" ),imsDrive, mmcDrive ) );
hgs
parents:
diff changeset
   645
hgs
parents:
diff changeset
   646
    TVolumeInfo volumeInfo;
hgs
parents:
diff changeset
   647
    TInt err = iFs.Volume(volumeInfo, imsDrive);
hgs
parents:
diff changeset
   648
    
hgs
parents:
diff changeset
   649
    // If err != KErrNone, Drive is not available.
hgs
parents:
diff changeset
   650
    //
hgs
parents:
diff changeset
   651
    if ( !err )
hgs
parents:
diff changeset
   652
        {
hgs
parents:
diff changeset
   653
        // Check capacity on Internal mass storage            
hgs
parents:
diff changeset
   654
        TRACE_INFO( (_L( "[obexreceiveservicebip] CheckCapacityL Internal mass storage \t" )) );
hgs
parents:
diff changeset
   655
        if ( !SysUtil::DiskSpaceBelowCriticalLevelL( &iFs, filesize, imsDrive ) )
hgs
parents:
diff changeset
   656
            {
hgs
parents:
diff changeset
   657
            iDrive = imsDrive;            
hgs
parents:
diff changeset
   658
            }
hgs
parents:
diff changeset
   659
        }
hgs
parents:
diff changeset
   660
    if ( iDrive == EDriveZ )
hgs
parents:
diff changeset
   661
        {
hgs
parents:
diff changeset
   662
        err = iFs.Volume(volumeInfo, mmcDrive);
hgs
parents:
diff changeset
   663
        if ( !err )
hgs
parents:
diff changeset
   664
            {
hgs
parents:
diff changeset
   665
            // Check capacity on memory card    
hgs
parents:
diff changeset
   666
            TRACE_INFO( (_L( "[obexreceiveservicebip] CheckCapacityL Checking memory card\t" )) );
hgs
parents:
diff changeset
   667
            if ( !SysUtil::DiskSpaceBelowCriticalLevelL( &iFs, filesize, mmcDrive ) )
hgs
parents:
diff changeset
   668
                {                    
hgs
parents:
diff changeset
   669
                iDrive = mmcDrive;
hgs
parents:
diff changeset
   670
                }   
hgs
parents:
diff changeset
   671
            }
hgs
parents:
diff changeset
   672
        }           
hgs
parents:
diff changeset
   673
    if ( iDrive == EDriveZ )
hgs
parents:
diff changeset
   674
        {
hgs
parents:
diff changeset
   675
        TRACE_INFO( (_L( "[obexreceiveservicebip] CheckCapacityL Checking phone memory\t" )) );
hgs
parents:
diff changeset
   676
        // Phone memory
hgs
parents:
diff changeset
   677
        if( !SysUtil::DiskSpaceBelowCriticalLevelL( &iFs, filesize, EDriveC ))
hgs
parents:
diff changeset
   678
            {
hgs
parents:
diff changeset
   679
            iDrive = EDriveC;
hgs
parents:
diff changeset
   680
            }
hgs
parents:
diff changeset
   681
        }
hgs
parents:
diff changeset
   682
  
hgs
parents:
diff changeset
   683
    TRACE_INFO( (_L( "[obexreceiveservicebip] CheckCapacityL iDrive = %d\t" ),iDrive ) );                   
hgs
parents:
diff changeset
   684
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   685
    
hgs
parents:
diff changeset
   686
    if (iDrive == EDriveZ)
hgs
parents:
diff changeset
   687
        {
hgs
parents:
diff changeset
   688
        // If there is no free space for receiving file, we need to set iPreviousDefaultFolder back to iDefaultFolder.
hgs
parents:
diff changeset
   689
        // In order to show the file receveing dialog correctly.
hgs
parents:
diff changeset
   690
        iDefaultFolder = iPreviousDefaultFolder;
hgs
parents:
diff changeset
   691
        return EFalse;
hgs
parents:
diff changeset
   692
        }
hgs
parents:
diff changeset
   693
    return ETrue;
hgs
parents:
diff changeset
   694
    }    
hgs
parents:
diff changeset
   695
hgs
parents:
diff changeset
   696
hgs
parents:
diff changeset
   697
// ---------------------------------------------------------
hgs
parents:
diff changeset
   698
// IsOBEXActive()
hgs
parents:
diff changeset
   699
// ---------------------------------------------------------
hgs
parents:
diff changeset
   700
//
hgs
parents:
diff changeset
   701
TBool CBIPController::IsOBEXActive()
hgs
parents:
diff changeset
   702
    {    
hgs
parents:
diff changeset
   703
    TRACE_FUNC    
hgs
parents:
diff changeset
   704
    return ETrue;
hgs
parents:
diff changeset
   705
    }
hgs
parents:
diff changeset
   706
hgs
parents:
diff changeset
   707
// ---------------------------------------------------------
hgs
parents:
diff changeset
   708
// SetMediaType()
hgs
parents:
diff changeset
   709
// ---------------------------------------------------------
hgs
parents:
diff changeset
   710
//
hgs
parents:
diff changeset
   711
void CBIPController::SetMediaType( TSrcsMediaType __DEBUG_ONLY(aMediaType) ) 
hgs
parents:
diff changeset
   712
    {
hgs
parents:
diff changeset
   713
    TRACE_FUNC
hgs
parents:
diff changeset
   714
    // BIP is only for Bluetooth, so that is all we expect
hgs
parents:
diff changeset
   715
    __ASSERT_DEBUG(aMediaType == ESrcsMediaBT, User::Panic(KBipPanicCategory, EBipPanicNotBluetoothMediaType));
hgs
parents:
diff changeset
   716
    }
hgs
parents:
diff changeset
   717
hgs
parents:
diff changeset
   718
// ---------------------------------------------------------
hgs
parents:
diff changeset
   719
// SetObexServer()
hgs
parents:
diff changeset
   720
// ---------------------------------------------------------
hgs
parents:
diff changeset
   721
//
hgs
parents:
diff changeset
   722
TInt CBIPController::SetObexServer( CObexServer* aServer)
hgs
parents:
diff changeset
   723
    {
hgs
parents:
diff changeset
   724
    TInt retVal=KErrNone;
hgs
parents:
diff changeset
   725
    if (aServer)
hgs
parents:
diff changeset
   726
        {
hgs
parents:
diff changeset
   727
        iBTObexServer=aServer;
hgs
parents:
diff changeset
   728
        retVal=aServer->Start(this);
hgs
parents:
diff changeset
   729
        }
hgs
parents:
diff changeset
   730
    return retVal;
hgs
parents:
diff changeset
   731
    }    
hgs
parents:
diff changeset
   732
hgs
parents:
diff changeset
   733
void CBIPController::LaunchReceivingIndicatorL()
hgs
parents:
diff changeset
   734
    {
hgs
parents:
diff changeset
   735
    if(ReceivingIndicatorActive())
hgs
parents:
diff changeset
   736
        {
hgs
parents:
diff changeset
   737
        return;
hgs
parents:
diff changeset
   738
        }
hgs
parents:
diff changeset
   739
    
hgs
parents:
diff changeset
   740
    if(iTotalSizeByte > 0)
hgs
parents:
diff changeset
   741
        {
hgs
parents:
diff changeset
   742
        iProgressDialog = CGlobalProgressDialog::NewL(this);  
hgs
parents:
diff changeset
   743
        if(iReceivingFileName.Length() > 0)
hgs
parents:
diff changeset
   744
            {
hgs
parents:
diff changeset
   745
            iProgressDialog->ShowProgressDialogNameSizeL(iReceivingFileName, iTotalSizeByte);
hgs
parents:
diff changeset
   746
            }
hgs
parents:
diff changeset
   747
        else
hgs
parents:
diff changeset
   748
            {
hgs
parents:
diff changeset
   749
            iProgressDialog->ShowProgressDialogL(R_BT_RECEIVING_DATA);
hgs
parents:
diff changeset
   750
            }
hgs
parents:
diff changeset
   751
        }
hgs
parents:
diff changeset
   752
    else
hgs
parents:
diff changeset
   753
        {
hgs
parents:
diff changeset
   754
        iWaitDialog = CGlobalDialog::NewL(this);
hgs
parents:
diff changeset
   755
        iWaitDialog->ShowNoteDialogL(R_BT_RECEIVING_DATA, ETrue);
hgs
parents:
diff changeset
   756
        }
hgs
parents:
diff changeset
   757
    }
hgs
parents:
diff changeset
   758
hgs
parents:
diff changeset
   759
void CBIPController::UpdateReceivingIndicator()
hgs
parents:
diff changeset
   760
    {
hgs
parents:
diff changeset
   761
    if(iProgressDialog)
hgs
parents:
diff changeset
   762
        {
hgs
parents:
diff changeset
   763
        iProgressDialog->UpdateProgressDialog(iBTObject->BytesReceived(), iTotalSizeByte);
hgs
parents:
diff changeset
   764
        }
hgs
parents:
diff changeset
   765
    // else we are using a wait note, so no "need" to update
hgs
parents:
diff changeset
   766
    }
hgs
parents:
diff changeset
   767
hgs
parents:
diff changeset
   768
void CBIPController::HandleGlobalProgressDialogL( TInt aSoftkey )
hgs
parents:
diff changeset
   769
    {
hgs
parents:
diff changeset
   770
    TRACE_FUNC
hgs
parents:
diff changeset
   771
    
hgs
parents:
diff changeset
   772
    if(aSoftkey == EAknSoftkeyCancel)
hgs
parents:
diff changeset
   773
        {
hgs
parents:
diff changeset
   774
        CancelTransfer();
hgs
parents:
diff changeset
   775
        }
hgs
parents:
diff changeset
   776
    else if(aSoftkey == EAknSoftkeyHide)
hgs
parents:
diff changeset
   777
        {
hgs
parents:
diff changeset
   778
        CloseReceivingIndicator(EFalse); // Don't reset state as only hiding
hgs
parents:
diff changeset
   779
        }
hgs
parents:
diff changeset
   780
    }
hgs
parents:
diff changeset
   781
hgs
parents:
diff changeset
   782
void CBIPController::HandleGlobalNoteDialogL( TInt aSoftkey )
hgs
parents:
diff changeset
   783
    {
hgs
parents:
diff changeset
   784
    TRACE_FUNC
hgs
parents:
diff changeset
   785
    
hgs
parents:
diff changeset
   786
    if( aSoftkey == EAknSoftkeyCancel )
hgs
parents:
diff changeset
   787
        {
hgs
parents:
diff changeset
   788
        CancelTransfer();
hgs
parents:
diff changeset
   789
        }
hgs
parents:
diff changeset
   790
    else if( aSoftkey == EAknSoftkeyHide)
hgs
parents:
diff changeset
   791
        {
hgs
parents:
diff changeset
   792
        CloseReceivingIndicator(EFalse); // Don't reset state as only hiding
hgs
parents:
diff changeset
   793
        }
hgs
parents:
diff changeset
   794
    }
hgs
parents:
diff changeset
   795
hgs
parents:
diff changeset
   796
void CBIPController::CloseReceivingIndicator(TBool aResetDisplayedState)
hgs
parents:
diff changeset
   797
    {
hgs
parents:
diff changeset
   798
    TRACE_FUNC
hgs
parents:
diff changeset
   799
    if(aResetDisplayedState)
hgs
parents:
diff changeset
   800
        {
hgs
parents:
diff changeset
   801
        iNoteDisplayed = EFalse;
hgs
parents:
diff changeset
   802
        }
hgs
parents:
diff changeset
   803
    if(iProgressDialog)
hgs
parents:
diff changeset
   804
        {
hgs
parents:
diff changeset
   805
        iProgressDialog->ProcessFinished();
hgs
parents:
diff changeset
   806
        delete iProgressDialog;
hgs
parents:
diff changeset
   807
        iProgressDialog = NULL;
hgs
parents:
diff changeset
   808
        }
hgs
parents:
diff changeset
   809
    if(iWaitDialog)
hgs
parents:
diff changeset
   810
        {
hgs
parents:
diff changeset
   811
        iWaitDialog->ProcessFinished();
hgs
parents:
diff changeset
   812
        delete iWaitDialog;
hgs
parents:
diff changeset
   813
        iWaitDialog = NULL;
hgs
parents:
diff changeset
   814
        }
hgs
parents:
diff changeset
   815
    }
hgs
parents:
diff changeset
   816
 
hgs
parents:
diff changeset
   817
 // ---------------------------------------------------------
hgs
parents:
diff changeset
   818
 // GetDriveWithMaximumFreeSpace()
hgs
parents:
diff changeset
   819
 // ---------------------------------------------------------
hgs
parents:
diff changeset
   820
 // 
hgs
parents:
diff changeset
   821
 TInt CBIPController::GetDriveWithMaximumFreeSpaceL()
hgs
parents:
diff changeset
   822
     {
hgs
parents:
diff changeset
   823
     // Get drive with maximum freespace among phone memory, MMC, internal mass storage.
hgs
parents:
diff changeset
   824
     //
hgs
parents:
diff changeset
   825
      TRACE_FUNC   
hgs
parents:
diff changeset
   826
     
hgs
parents:
diff changeset
   827
     TVolumeInfo volumeInfoC;
hgs
parents:
diff changeset
   828
     TVolumeInfo volumeInfoE;
hgs
parents:
diff changeset
   829
     TVolumeInfo volumeInfoF;
hgs
parents:
diff changeset
   830
     TInt64 max = 0;
hgs
parents:
diff changeset
   831
     TInt drive = 0;
hgs
parents:
diff changeset
   832
     
hgs
parents:
diff changeset
   833
     TInt err = iFs.Volume(volumeInfoC, EDriveC);
hgs
parents:
diff changeset
   834
    
hgs
parents:
diff changeset
   835
     if ( !err )
hgs
parents:
diff changeset
   836
         {
hgs
parents:
diff changeset
   837
         // set initial values to max and drive.
hgs
parents:
diff changeset
   838
         max = volumeInfoC.iFree;
hgs
parents:
diff changeset
   839
         drive = EDriveC;
hgs
parents:
diff changeset
   840
         }
hgs
parents:
diff changeset
   841
          
hgs
parents:
diff changeset
   842
     err = iFs.Volume(volumeInfoE, EDriveE);     
hgs
parents:
diff changeset
   843
     if ( !err )
hgs
parents:
diff changeset
   844
         {
hgs
parents:
diff changeset
   845
         if (volumeInfoE.iFree >= max)
hgs
parents:
diff changeset
   846
             {
hgs
parents:
diff changeset
   847
             max = volumeInfoE.iFree;
hgs
parents:
diff changeset
   848
             drive = EDriveE;             
hgs
parents:
diff changeset
   849
             }
hgs
parents:
diff changeset
   850
         
hgs
parents:
diff changeset
   851
         }
hgs
parents:
diff changeset
   852
          
hgs
parents:
diff changeset
   853
     err = iFs.Volume(volumeInfoF, EDriveF);
hgs
parents:
diff changeset
   854
     if ( !err )
hgs
parents:
diff changeset
   855
         {
hgs
parents:
diff changeset
   856
         if (volumeInfoF.iFree >= max)
hgs
parents:
diff changeset
   857
             {
hgs
parents:
diff changeset
   858
             max = volumeInfoF.iFree;
hgs
parents:
diff changeset
   859
             drive = EDriveF;             
hgs
parents:
diff changeset
   860
             }
hgs
parents:
diff changeset
   861
         }
hgs
parents:
diff changeset
   862
     max = 0;
hgs
parents:
diff changeset
   863
     return drive;
hgs
parents:
diff changeset
   864
     }
hgs
parents:
diff changeset
   865
 
hgs
parents:
diff changeset
   866
 // ----------------------------------------------------------
hgs
parents:
diff changeset
   867
 // COPPController::HandleDevManComplete
hgs
parents:
diff changeset
   868
 // Callback from devman
hgs
parents:
diff changeset
   869
 // ----------------------------------------------------------
hgs
parents:
diff changeset
   870
 //    
hgs
parents:
diff changeset
   871
 // 
hgs
parents:
diff changeset
   872
 void CBIPController::HandleGetDevicesComplete(TInt aErr, CBTDeviceArray* /*aDeviceArray*/)
hgs
parents:
diff changeset
   873
    {
hgs
parents:
diff changeset
   874
    if ( aErr == KErrNone )
hgs
parents:
diff changeset
   875
        {
hgs
parents:
diff changeset
   876
        if ( iResultArray->Count())
hgs
parents:
diff changeset
   877
            {
hgs
parents:
diff changeset
   878
            iRemoteDeviceName.Zero();
hgs
parents:
diff changeset
   879
            if ( iResultArray->At(0)->FriendlyName().Length() > 0 )
hgs
parents:
diff changeset
   880
                {
hgs
parents:
diff changeset
   881
                TRACE_INFO( _L( "[CBIPController] HandleGetDevicesComplete: got friendly name \t" ) );
hgs
parents:
diff changeset
   882
                iRemoteDeviceName.Copy(iResultArray->At(0)->FriendlyName());
hgs
parents:
diff changeset
   883
                }
hgs
parents:
diff changeset
   884
            else
hgs
parents:
diff changeset
   885
                {
hgs
parents:
diff changeset
   886
                TRACE_INFO( _L( "[CBIPController] HandleGetDevicesComplete: got devciename name \t" ) );                
hgs
parents:
diff changeset
   887
                TRAP_IGNORE(iRemoteDeviceName.Copy(BTDeviceNameConverter::ToUnicodeL(iResultArray->At(0)->DeviceName())));
hgs
parents:
diff changeset
   888
                }
hgs
parents:
diff changeset
   889
            }
hgs
parents:
diff changeset
   890
        }
hgs
parents:
diff changeset
   891
    }
hgs
parents:
diff changeset
   892
 
hgs
parents:
diff changeset
   893
//////////////////////////// Global part ////////////////////////////
hgs
parents:
diff changeset
   894
hgs
parents:
diff changeset
   895
//  End of File