btobexprofiles/obexreceiveservices/opp/src/oppcontroller.cpp
author hgs
Tue, 19 Oct 2010 15:09:34 +0300
changeset 70 f5508c13dfe0
parent 67 16e4b9007960
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32
hgs
parents:
diff changeset
     1
/*
67
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
     2
* Copyright (c) 2004-2010 Nokia Corporation and/or its subsidiary(-ies).
32
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:  Implementation of CBtListenActive
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    "oppcontroller.h"
hgs
parents:
diff changeset
    21
#include    "btengdevman.h"
hgs
parents:
diff changeset
    22
#include    <obexutilsmessagehandler.h>
hgs
parents:
diff changeset
    23
#include    "debug.h"
hgs
parents:
diff changeset
    24
#include    <bautils.h>
hgs
parents:
diff changeset
    25
#include    <btengdomaincrkeys.h>
hgs
parents:
diff changeset
    26
#include    <sysutil.h>
hgs
parents:
diff changeset
    27
#include    <btengdomaincrkeys.h> 
hgs
parents:
diff changeset
    28
#include    <msvids.h>
42
hgs
parents: 32
diff changeset
    29
#include    <driveinfo.h>
32
hgs
parents:
diff changeset
    30
#include    <es_sock.h>
hgs
parents:
diff changeset
    31
#include    <bt_sock.h>
42
hgs
parents: 32
diff changeset
    32
#include    <bluetoothdevicedialogs.h>
67
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
    33
#include    "btconversationviewlauncher.h"
32
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
// CONSTANTS
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
const TInt    KBufferSize = 0x10000;  // 64 kB
42
hgs
parents: 32
diff changeset
    38
const TInt KFileManagerUID3 = 0x101F84EB; /// File Manager application UID3
hgs
parents: 32
diff changeset
    39
_LIT( KBTDevDialogId, "com.nokia.hb.btdevicedialog/1.0" );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    40
const TInt KMaxDisplayFileName = 20;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    41
const TInt KMinStringSize = 11;
32
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
COPPController* COPPController::NewL()
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    COPPController* self = new ( ELeave ) COPPController();
hgs
parents:
diff changeset
    49
	CleanupStack::PushL( self );
hgs
parents:
diff changeset
    50
	self->ConstructL();
hgs
parents:
diff changeset
    51
	CleanupStack::Pop( self );
hgs
parents:
diff changeset
    52
	return self;
hgs
parents:
diff changeset
    53
    }
hgs
parents:
diff changeset
    54
    
hgs
parents:
diff changeset
    55
COPPController::COPPController()
hgs
parents:
diff changeset
    56
	{
hgs
parents:
diff changeset
    57
    TRACE_FUNC
hgs
parents:
diff changeset
    58
	}
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
void COPPController::ConstructL()	
hgs
parents:
diff changeset
    61
	{
hgs
parents:
diff changeset
    62
    TRACE_FUNC
hgs
parents:
diff changeset
    63
    iObexTransferState = ETransferIdle;
hgs
parents:
diff changeset
    64
    iLowMemoryActiveCDrive = CObexUtilsPropertyNotifier::NewL(this, ECheckPhoneMemory);
hgs
parents:
diff changeset
    65
    iLowMemoryActiveMMC = CObexUtilsPropertyNotifier::NewL(this, ECheckMMCMemory);        
hgs
parents:
diff changeset
    66
    iDevMan=CBTEngDevMan::NewL(this);  
hgs
parents:
diff changeset
    67
    iResultArray = new (ELeave) CBTDeviceArray(1);
hgs
parents:
diff changeset
    68
    // Get default folder from CenRep 
hgs
parents:
diff changeset
    69
    TObexUtilsMessageHandler::GetCenRepKeyStringValueL(KCRUidBluetoothEngine, 
hgs
parents:
diff changeset
    70
                                                       KLCReceiveFolder,
hgs
parents:
diff changeset
    71
                                                       iCenRepFolder);
67
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
    72
    iBtCnvViewLauncher = CBtConversationViewLauncher::NewL();
32
hgs
parents:
diff changeset
    73
	} 
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
COPPController::~COPPController()
hgs
parents:
diff changeset
    76
    {
hgs
parents:
diff changeset
    77
    TRACE_FUNC
hgs
parents:
diff changeset
    78
    delete iObexObject;
hgs
parents:
diff changeset
    79
    delete iBuf;
hgs
parents:
diff changeset
    80
    delete iLowMemoryActiveCDrive;
hgs
parents:
diff changeset
    81
    delete iLowMemoryActiveMMC;
hgs
parents:
diff changeset
    82
    delete iDevMan;
hgs
parents:
diff changeset
    83
    if (iResultArray)
hgs
parents:
diff changeset
    84
        {
hgs
parents:
diff changeset
    85
        iResultArray->ResetAndDestroy();
hgs
parents:
diff changeset
    86
        delete iResultArray;
hgs
parents:
diff changeset
    87
        }
hgs
parents:
diff changeset
    88
    iFs.Close();
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    89
42
hgs
parents: 32
diff changeset
    90
    delete iProgressDialog;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    91
    delete iFailureDialog;
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    92
    delete iRecvDoneDialog;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    93
    delete iMemoryFullDailog;
67
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
    94
    delete iBtCnvViewLauncher;
32
hgs
parents:
diff changeset
    95
    }
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
// ---------------------------------------------------------
hgs
parents:
diff changeset
    98
// ErrorIndication()
hgs
parents:
diff changeset
    99
// ---------------------------------------------------------
hgs
parents:
diff changeset
   100
//
hgs
parents:
diff changeset
   101
void COPPController::ErrorIndication( TInt TRACE_ONLY(aError) )
hgs
parents:
diff changeset
   102
    {
hgs
parents:
diff changeset
   103
    TRACE_FUNC
hgs
parents:
diff changeset
   104
    TRACE_ERROR((_L( "[oppreceiveservice] COPPController: ErrorIndication error:\t %d" ),aError));
hgs
parents:
diff changeset
   105
    HandleError(EFalse); // false because not explicit abort
hgs
parents:
diff changeset
   106
    }
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
// ---------------------------------------------------------
hgs
parents:
diff changeset
   109
// AbortIndication() 
hgs
parents:
diff changeset
   110
// ---------------------------------------------------------
hgs
parents:
diff changeset
   111
//
hgs
parents:
diff changeset
   112
void COPPController::AbortIndication()
hgs
parents:
diff changeset
   113
	{
hgs
parents:
diff changeset
   114
	TRACE_FUNC
hgs
parents:
diff changeset
   115
	HandleError(ETrue); // true because explicit abort
hgs
parents:
diff changeset
   116
	}
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
void COPPController::HandleError(TBool aAbort)
hgs
parents:
diff changeset
   119
    {
hgs
parents:
diff changeset
   120
    TRACE_ERROR((_L( "[oppreceiveservice] COPPController:HandleError" )));
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   121
    iReceivingFailed = ETrue;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   122
    iShowRecvCompleteDialog = EFalse;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   123
    if( iObexTransferState == ETransferPut || (!aAbort && iObexTransferState == ETransferPutDiskError) )
32
hgs
parents:
diff changeset
   124
        {        
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   125
        CancelTransfer();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   126
        if(iMediaType == ESrcsMediaBT)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   127
            {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   128
            TRAP_IGNORE(
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   129
                    LaunchFailureDialogL();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   130
                    );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   131
            }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   132
        TRACE_ASSERT(iMediaType != ESrcsMediaIrDA, KErrNotSupported)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   133
32
hgs
parents:
diff changeset
   134
        if(iObexObject)
hgs
parents:
diff changeset
   135
            {
hgs
parents:
diff changeset
   136
            iObexObject->Reset();
hgs
parents:
diff changeset
   137
            }
hgs
parents:
diff changeset
   138
        }
hgs
parents:
diff changeset
   139
    delete iBuf;
hgs
parents:
diff changeset
   140
    iBuf = NULL;
hgs
parents:
diff changeset
   141
    iObexTransferState = ETransferIdle;
hgs
parents:
diff changeset
   142
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveInboxEntriesL(iObexObject, iMsvIdParent));
hgs
parents:
diff changeset
   143
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveTemporaryRFileL (iFullPathFilename));
hgs
parents:
diff changeset
   144
    }
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
// ---------------------------------------------------------
hgs
parents:
diff changeset
   147
// TransportUpIndication()
hgs
parents:
diff changeset
   148
// ---------------------------------------------------------
hgs
parents:
diff changeset
   149
//
hgs
parents:
diff changeset
   150
void COPPController::TransportUpIndication()
hgs
parents:
diff changeset
   151
	{
hgs
parents:
diff changeset
   152
	TRACE_FUNC    
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   153
	iReceivingFailed = EFalse;
32
hgs
parents:
diff changeset
   154
    iObexTransferState = ETransferIdle;	
hgs
parents:
diff changeset
   155
 
hgs
parents:
diff changeset
   156
	if ( !iFs.Handle() )
hgs
parents:
diff changeset
   157
	    {
hgs
parents:
diff changeset
   158
	    TRACE_INFO( (_L( "[oppreceiveservice] TransportUpIndication iFs.Connect()" )) ); 
hgs
parents:
diff changeset
   159
	    if ( iFs.Connect() )   // error value not preserved, iFs.Handle() checked one more time before first useage
hgs
parents:
diff changeset
   160
	        {
hgs
parents:
diff changeset
   161
	        TRACE_INFO( (_L( "[oppreceiveservice] TransportUpIndication iFs.Connect() failed" )) ); 
hgs
parents:
diff changeset
   162
	        }
hgs
parents:
diff changeset
   163
	    }
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
    iFile = RFile();
hgs
parents:
diff changeset
   166
    iFullPathFilename.Zero();
hgs
parents:
diff changeset
   167
	}
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
// ---------------------------------------------------------
hgs
parents:
diff changeset
   170
// ObexConnectIndication()
hgs
parents:
diff changeset
   171
// ---------------------------------------------------------
hgs
parents:
diff changeset
   172
//
42
hgs
parents: 32
diff changeset
   173
TInt COPPController::ObexConnectIndication( const TObexConnectInfo& aRemoteInfo,
hgs
parents: 32
diff changeset
   174
                                            const TDesC8& aInfo)
32
hgs
parents:
diff changeset
   175
    {
42
hgs
parents: 32
diff changeset
   176
    TRACE_FUNC
hgs
parents: 32
diff changeset
   177
    (void) aRemoteInfo;
hgs
parents: 32
diff changeset
   178
    (void) aInfo;
hgs
parents: 32
diff changeset
   179
    
32
hgs
parents:
diff changeset
   180
    if ( iMediaType == ESrcsMediaBT )
hgs
parents:
diff changeset
   181
        {
hgs
parents:
diff changeset
   182
        TRACE_INFO( _L( "[oppreceiveservice] ObexConnectIndication: BT media \t" ) );
hgs
parents:
diff changeset
   183
        
hgs
parents:
diff changeset
   184
        // Get remote device socket address and bluetooth name
hgs
parents:
diff changeset
   185
        // Remote bluetooth name will be displayed in the new message in inbox.
hgs
parents:
diff changeset
   186
        //
hgs
parents:
diff changeset
   187
        TSockAddr addr;
hgs
parents:
diff changeset
   188
        iObexServer->RemoteAddr(addr);
hgs
parents:
diff changeset
   189
        TBTDevAddr tBTDevAddr = static_cast<TBTSockAddr>(addr).BTAddr();
hgs
parents:
diff changeset
   190
        
hgs
parents:
diff changeset
   191
        TBTRegistrySearch nameSearch;
hgs
parents:
diff changeset
   192
        nameSearch.FindAddress(tBTDevAddr);
hgs
parents:
diff changeset
   193
        
hgs
parents:
diff changeset
   194
        iResultArray->Reset();
hgs
parents:
diff changeset
   195
        // ignore any errors here, if we don't get the name, we don't get the name
hgs
parents:
diff changeset
   196
        static_cast<void>(iDevMan->GetDevices(nameSearch, iResultArray));
hgs
parents:
diff changeset
   197
        }
hgs
parents:
diff changeset
   198
    
hgs
parents:
diff changeset
   199
    return KErrNone;
hgs
parents:
diff changeset
   200
    }
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
// ---------------------------------------------------------
hgs
parents:
diff changeset
   203
// ObexDisconnectIndication(
hgs
parents:
diff changeset
   204
// ---------------------------------------------------------
hgs
parents:
diff changeset
   205
//
42
hgs
parents: 32
diff changeset
   206
void COPPController::ObexDisconnectIndication(const TDesC8& aInfo)
32
hgs
parents:
diff changeset
   207
    {
hgs
parents:
diff changeset
   208
    TRACE_FUNC
42
hgs
parents: 32
diff changeset
   209
    (void) aInfo;
32
hgs
parents:
diff changeset
   210
    }
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
// ---------------------------------------------------------
hgs
parents:
diff changeset
   213
// TransportDownIndication()
hgs
parents:
diff changeset
   214
// ---------------------------------------------------------
hgs
parents:
diff changeset
   215
//
hgs
parents:
diff changeset
   216
void COPPController::TransportDownIndication()
hgs
parents:
diff changeset
   217
    {
hgs
parents:
diff changeset
   218
    TRACE_FUNC
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   219
    if(!iReceivingFailed && iShowRecvCompleteDialog)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   220
        {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   221
        TFileName shortname;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   222
        if ( iReceivingFileName.Length() > KMaxDisplayFileName ) 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   223
            {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   224
            // Filename is too long, 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   225
            // We make it shorter. Hiding the chars in the middle part of filename. 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   226
            shortname = iReceivingFileName.Mid(0,KMaxDisplayFileName/2);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   227
            shortname.Append(_L("..."));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   228
            shortname.Append(iReceivingFileName.Mid(iReceivingFileName.Length() - KMaxDisplayFileName/2, KMaxDisplayFileName/2));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   229
            }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   230
        else
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   231
            {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   232
            shortname.Copy(iReceivingFileName);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   233
            }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   234
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   235
        //Launch recevice completed dialog.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   236
        iRecvDoneDialog = CHbDeviceDialogSymbian::NewL();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   237
        iRecvDoneDialog->SetObserver(this);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   238
    
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   239
        CHbSymbianVariantMap* variantMap = CHbSymbianVariantMap::NewL();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   240
        CleanupStack::PushL(variantMap);
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   241
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   242
        TInt dialogIdx = TBluetoothDialogParams::EReceiveDone;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   243
        AddParamL(TBluetoothDialogParams::EDialogType, (TAny*) &dialogIdx,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   244
                CHbSymbianVariant::EInt, *variantMap);
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   245
        
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   246
        AddParamL(TBluetoothDeviceDialog::EDeviceName, (TAny*) &iRemoteDeviceName,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   247
                CHbSymbianVariant::EDes, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   248
        
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   249
        AddParamL(TBluetoothDeviceDialog::EReceivingFileName, (TAny*) &shortname,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   250
                CHbSymbianVariant::EDes, *variantMap);
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   251
        
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   252
        AddParamL(TBluetoothDeviceDialog::EReceivingFileSize, (TAny*) &iTotalSizeByte,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   253
                CHbSymbianVariant::EInt, *variantMap);
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   254
        
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   255
        AddParamL(TBluetoothDeviceDialog::EReceivedFileCount, (TAny*) &iFileCount,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   256
                CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   257
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   258
        TBuf<KMinStringSize> key(_L("OpenCnvView"));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   259
        TBool option = ETrue;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   260
        CHbSymbianVariant* value = CHbSymbianVariant::NewL( (TAny*) &option, CHbSymbianVariant::EBool );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   261
        CleanupStack::PushL(value);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   262
        variantMap->Add(key, value);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   263
        CleanupStack::Pop(value);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   264
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   265
        iRecvDoneDialog->Show( KBTDevDialogId(), *variantMap, this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   266
        CleanupStack::PopAndDestroy(variantMap);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   267
        iShowRecvCompleteDialog = EFalse;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   268
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   269
    
32
hgs
parents:
diff changeset
   270
    // Remove receiving buffer and files used during file receiving.
hgs
parents:
diff changeset
   271
    //
hgs
parents:
diff changeset
   272
    delete iObexObject;
hgs
parents:
diff changeset
   273
    iObexObject = NULL;
hgs
parents:
diff changeset
   274
    TRAP_IGNORE(TObexUtilsMessageHandler::RemoveTemporaryRFileL (iFullPathFilename)); 
hgs
parents:
diff changeset
   275
    iFs.Close();
42
hgs
parents: 32
diff changeset
   276
    iFileCount = 0;
32
hgs
parents:
diff changeset
   277
    }
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
// ---------------------------------------------------------
hgs
parents:
diff changeset
   280
// PutRequestIndication()
hgs
parents:
diff changeset
   281
// ---------------------------------------------------------
hgs
parents:
diff changeset
   282
//
hgs
parents:
diff changeset
   283
CObexBufObject* COPPController::PutRequestIndication()
hgs
parents:
diff changeset
   284
    {
hgs
parents:
diff changeset
   285
    TRACE_FUNC
hgs
parents:
diff changeset
   286
    iLengthHeaderReceived = EFalse; // New put request so clear header based state
hgs
parents:
diff changeset
   287
    iObexTransferState = ETransferPut;
hgs
parents:
diff changeset
   288
    
hgs
parents:
diff changeset
   289
    // Checking if backup is running now - if backup process is active, then we
hgs
parents:
diff changeset
   290
    // need to cancel transfer - otherwise phone will freeze during receiving
hgs
parents:
diff changeset
   291
    // data
42
hgs
parents: 32
diff changeset
   292
    if ( IsBackupRunning() )
32
hgs
parents:
diff changeset
   293
        {
hgs
parents:
diff changeset
   294
        TRACE_INFO ( _L ("Backup in progress! Canceling incoming transfer."));
hgs
parents:
diff changeset
   295
        iObexTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   296
        return NULL;
hgs
parents:
diff changeset
   297
        }
hgs
parents:
diff changeset
   298
    
hgs
parents:
diff changeset
   299
    TRAPD(err, HandlePutRequestL());
hgs
parents:
diff changeset
   300
    if(err == KErrNone)
hgs
parents:
diff changeset
   301
        {
hgs
parents:
diff changeset
   302
        return iObexObject;
hgs
parents:
diff changeset
   303
        }
hgs
parents:
diff changeset
   304
    TRACE_INFO( _L( "[oppreceiveservice] COPPController: PutRequestIndication end\t" ) );
hgs
parents:
diff changeset
   305
    if (iObexTransferState != ETransferPutInitError)
hgs
parents:
diff changeset
   306
        {
hgs
parents:
diff changeset
   307
        iObexTransferState = ETransferPutDiskError;
hgs
parents:
diff changeset
   308
        }
hgs
parents:
diff changeset
   309
    return NULL;
hgs
parents:
diff changeset
   310
    }
hgs
parents:
diff changeset
   311
hgs
parents:
diff changeset
   312
// ---------------------------------------------------------
hgs
parents:
diff changeset
   313
// PutPacketIndication()    
hgs
parents:
diff changeset
   314
// ---------------------------------------------------------
hgs
parents:
diff changeset
   315
//
hgs
parents:
diff changeset
   316
TInt COPPController::PutPacketIndication()
hgs
parents:
diff changeset
   317
    {
hgs
parents:
diff changeset
   318
    TRACE_FUNC
hgs
parents:
diff changeset
   319
    if(iObexTransferState == ETransferPutCancel)
hgs
parents:
diff changeset
   320
        {
hgs
parents:
diff changeset
   321
        // User cancelled the put request, so error the next packet to terminate the put request.
hgs
parents:
diff changeset
   322
        // BIP considers the Unauthorized error response suitable for this...
hgs
parents:
diff changeset
   323
        HandleError(ETrue); // reset state and clear up
hgs
parents:
diff changeset
   324
        return KErrIrObexRespUnauthorized;
hgs
parents:
diff changeset
   325
        }
70
hgs
parents: 67
diff changeset
   326
hgs
parents: 67
diff changeset
   327
    // For every packet received, this check is required to ensure that the case where the 
hgs
parents: 67
diff changeset
   328
    // memory card is removed while a transfer is in progress is handled in the right way.
hgs
parents: 67
diff changeset
   329
    TVolumeInfo volInfo;
hgs
parents: 67
diff changeset
   330
    TInt err = iFs.Volume(volInfo, iDrive);
hgs
parents: 67
diff changeset
   331
    if(err != KErrNone)
hgs
parents: 67
diff changeset
   332
        {
hgs
parents: 67
diff changeset
   333
        HandleError(ETrue);
hgs
parents: 67
diff changeset
   334
        return err;
hgs
parents: 67
diff changeset
   335
        }
32
hgs
parents:
diff changeset
   336
    
hgs
parents:
diff changeset
   337
    iTotalSizeByte = iObexObject->Length();     // get size of receiving file
hgs
parents:
diff changeset
   338
    iReceivingFileName = iObexObject->Name();   // get name of receiving file
hgs
parents:
diff changeset
   339
    
hgs
parents:
diff changeset
   340
    // Check that capacity is suitable as soon as possible
hgs
parents:
diff changeset
   341
    if(!iLengthHeaderReceived && iTotalSizeByte > 0)
hgs
parents:
diff changeset
   342
        {
hgs
parents:
diff changeset
   343
        iLengthHeaderReceived = ETrue; // total size value is from length header
hgs
parents:
diff changeset
   344
        TBool capacity = ETrue;
hgs
parents:
diff changeset
   345
        TRAPD(retTrap, capacity = CheckCapacityL());
hgs
parents:
diff changeset
   346
        if(retTrap != KErrNone)
hgs
parents:
diff changeset
   347
            {
hgs
parents:
diff changeset
   348
            return KErrGeneral;
hgs
parents:
diff changeset
   349
            }
hgs
parents:
diff changeset
   350
        if(!capacity)
hgs
parents:
diff changeset
   351
            {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   352
            LaunchMemoryFullDialogL(iDrive);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   353
            
32
hgs
parents:
diff changeset
   354
            return KErrDiskFull;
hgs
parents:
diff changeset
   355
            }
hgs
parents:
diff changeset
   356
        }
hgs
parents:
diff changeset
   357
    if(iObexObject->Name().Length() > KMaxFileName)
hgs
parents:
diff changeset
   358
        {
hgs
parents:
diff changeset
   359
        return KErrAccessDenied;
hgs
parents:
diff changeset
   360
        }
hgs
parents:
diff changeset
   361
    if(iObexTransferState == ETransferPutDiskError)
hgs
parents:
diff changeset
   362
        {
hgs
parents:
diff changeset
   363
        return KErrDiskFull;
hgs
parents:
diff changeset
   364
        }
hgs
parents:
diff changeset
   365
    // successfully received put packet if we reached here
hgs
parents:
diff changeset
   366
    iObexTransferState = ETransferPut;
hgs
parents:
diff changeset
   367
    
hgs
parents:
diff changeset
   368
    // Now we need to either create (in the first instance) or update the dialog on the UI.
hgs
parents:
diff changeset
   369
    if(ReceivingIndicatorActive())
hgs
parents:
diff changeset
   370
        {
42
hgs
parents: 32
diff changeset
   371
        TRAPD(err, UpdateReceivingIndicatorL());
hgs
parents: 32
diff changeset
   372
        if(err < KErrNone)
hgs
parents: 32
diff changeset
   373
            {
hgs
parents: 32
diff changeset
   374
            return err;
hgs
parents: 32
diff changeset
   375
            }
32
hgs
parents:
diff changeset
   376
        }
hgs
parents:
diff changeset
   377
    else if(!iNoteDisplayed)
hgs
parents:
diff changeset
   378
        {
hgs
parents:
diff changeset
   379
        // No note launched yet, so try to launch
hgs
parents:
diff changeset
   380
        TRAPD(err, LaunchReceivingIndicatorL());
hgs
parents:
diff changeset
   381
        iNoteDisplayed = (err == KErrNone);
hgs
parents:
diff changeset
   382
        }
hgs
parents:
diff changeset
   383
    
hgs
parents:
diff changeset
   384
    return KErrNone;
hgs
parents:
diff changeset
   385
    }
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
// ---------------------------------------------------------
hgs
parents:
diff changeset
   388
// PutCompleteIndication()
hgs
parents:
diff changeset
   389
// ---------------------------------------------------------
hgs
parents:
diff changeset
   390
//
hgs
parents:
diff changeset
   391
TInt COPPController::PutCompleteIndication()
hgs
parents:
diff changeset
   392
    {
hgs
parents:
diff changeset
   393
    TRACE_FUNC
hgs
parents:
diff changeset
   394
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   395
    if(iObexTransferState == ETransferPutCancel)
hgs
parents:
diff changeset
   396
        {
hgs
parents:
diff changeset
   397
        retVal = KErrIrObexRespUnauthorized;
hgs
parents:
diff changeset
   398
        HandleError(ETrue);
hgs
parents:
diff changeset
   399
        }
hgs
parents:
diff changeset
   400
    else
hgs
parents:
diff changeset
   401
        {
hgs
parents:
diff changeset
   402
        retVal = HandlePutCompleteIndication();
hgs
parents:
diff changeset
   403
        iObexTransferState = ETransferIdle;
hgs
parents:
diff changeset
   404
        CloseReceivingIndicator();
42
hgs
parents: 32
diff changeset
   405
        iFileCount++;
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   406
        iShowRecvCompleteDialog = ETrue;
32
hgs
parents:
diff changeset
   407
        }
hgs
parents:
diff changeset
   408
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   409
    return retVal;
hgs
parents:
diff changeset
   410
    }
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
// ---------------------------------------------------------
hgs
parents:
diff changeset
   413
// GetRequestIndication()
hgs
parents:
diff changeset
   414
// ---------------------------------------------------------
hgs
parents:
diff changeset
   415
//
42
hgs
parents: 32
diff changeset
   416
CObexBufObject* COPPController::GetRequestIndication( CObexBaseObject* aRequiredObject)
32
hgs
parents:
diff changeset
   417
    {
hgs
parents:
diff changeset
   418
    TRACE_FUNC
42
hgs
parents: 32
diff changeset
   419
    (void) aRequiredObject;
32
hgs
parents:
diff changeset
   420
    return NULL;
hgs
parents:
diff changeset
   421
    }
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
// ---------------------------------------------------------
hgs
parents:
diff changeset
   424
// GetPacketIndication()
hgs
parents:
diff changeset
   425
// ---------------------------------------------------------
hgs
parents:
diff changeset
   426
//
hgs
parents:
diff changeset
   427
TInt COPPController::GetPacketIndication()
hgs
parents:
diff changeset
   428
    {
hgs
parents:
diff changeset
   429
    TRACE_FUNC
hgs
parents:
diff changeset
   430
    return KErrNone;
hgs
parents:
diff changeset
   431
    }
hgs
parents:
diff changeset
   432
hgs
parents:
diff changeset
   433
// ---------------------------------------------------------
hgs
parents:
diff changeset
   434
// GetCompleteIndication()
hgs
parents:
diff changeset
   435
// ---------------------------------------------------------
hgs
parents:
diff changeset
   436
//
hgs
parents:
diff changeset
   437
TInt COPPController::GetCompleteIndication()
hgs
parents:
diff changeset
   438
    {
hgs
parents:
diff changeset
   439
    TRACE_FUNC
hgs
parents:
diff changeset
   440
    return KErrNone;
hgs
parents:
diff changeset
   441
    }
hgs
parents:
diff changeset
   442
hgs
parents:
diff changeset
   443
// ---------------------------------------------------------
hgs
parents:
diff changeset
   444
// SetPathIndication()
hgs
parents:
diff changeset
   445
// ---------------------------------------------------------
hgs
parents:
diff changeset
   446
//
42
hgs
parents: 32
diff changeset
   447
TInt COPPController::SetPathIndication( const CObex::TSetPathInfo& aPathInfo, 
hgs
parents: 32
diff changeset
   448
                                        const TDesC8& aInfo)
32
hgs
parents:
diff changeset
   449
    {
hgs
parents:
diff changeset
   450
    TRACE_FUNC
42
hgs
parents: 32
diff changeset
   451
    
hgs
parents: 32
diff changeset
   452
    (void) aPathInfo;
hgs
parents: 32
diff changeset
   453
    (void) aInfo;
32
hgs
parents:
diff changeset
   454
    // SetPath is not implemented in OPP - so following IrOBEX guidance, return
hgs
parents:
diff changeset
   455
    // the Forbidden response code.
hgs
parents:
diff changeset
   456
    return KErrIrObexRespForbidden;
hgs
parents:
diff changeset
   457
    }
hgs
parents:
diff changeset
   458
hgs
parents:
diff changeset
   459
hgs
parents:
diff changeset
   460
hgs
parents:
diff changeset
   461
// ---------------------------------------------------------
hgs
parents:
diff changeset
   462
// HandleNotifyL()
hgs
parents:
diff changeset
   463
// ---------------------------------------------------------
hgs
parents:
diff changeset
   464
//
hgs
parents:
diff changeset
   465
void COPPController::HandleNotifyL( TMemoryPropertyCheckType aCheckType )
hgs
parents:
diff changeset
   466
    {    
hgs
parents:
diff changeset
   467
    TRACE_FUNC        
hgs
parents:
diff changeset
   468
    
hgs
parents:
diff changeset
   469
    // Only interested on this notification if we are receiving something
hgs
parents:
diff changeset
   470
    if ( iObexTransferState == ETransferPut )
hgs
parents:
diff changeset
   471
        {
hgs
parents:
diff changeset
   472
        // Check the keys, what has been changed.
hgs
parents:
diff changeset
   473
        TRACE_INFO( _L( "[oppreceiveservice] COPPController::HandleNotifyL\t" ) );
hgs
parents:
diff changeset
   474
        if ( aCheckType == ECheckPhoneMemory )
hgs
parents:
diff changeset
   475
            {            
hgs
parents:
diff changeset
   476
            if ( SysUtil::FFSSpaceBelowCriticalLevelL( NULL, 0 ) )
hgs
parents:
diff changeset
   477
                {
hgs
parents:
diff changeset
   478
                TRACE_INFO( _L( "[oppreceiveservice] COPPController: Obex Server error diskfull\t" ) );
hgs
parents:
diff changeset
   479
                iObexTransferState = ETransferPutDiskError;                    
hgs
parents:
diff changeset
   480
                }
hgs
parents:
diff changeset
   481
            }
hgs
parents:
diff changeset
   482
        else if ( aCheckType == ECheckMMCMemory )
hgs
parents:
diff changeset
   483
            {                                
hgs
parents:
diff changeset
   484
            if ( SysUtil::MMCSpaceBelowCriticalLevelL( NULL, 0 ) )
hgs
parents:
diff changeset
   485
                {                        
hgs
parents:
diff changeset
   486
                TRACE_INFO( _L( "[oppreceiveservice] COPPController: Obex Server error diskfull\t" ) );
hgs
parents:
diff changeset
   487
                iObexTransferState = ETransferPutDiskError;
hgs
parents:
diff changeset
   488
                }
hgs
parents:
diff changeset
   489
            }            
hgs
parents:
diff changeset
   490
        }        
hgs
parents:
diff changeset
   491
    }
hgs
parents:
diff changeset
   492
// ---------------------------------------------------------
hgs
parents:
diff changeset
   493
// HandlePutRequestL()
hgs
parents:
diff changeset
   494
// ---------------------------------------------------------
hgs
parents:
diff changeset
   495
//
hgs
parents:
diff changeset
   496
void COPPController::HandlePutRequestL()
hgs
parents:
diff changeset
   497
    {
hgs
parents:
diff changeset
   498
    TRACE_FUNC
hgs
parents:
diff changeset
   499
    
hgs
parents:
diff changeset
   500
    delete iObexObject;
hgs
parents:
diff changeset
   501
    iObexObject = NULL;
hgs
parents:
diff changeset
   502
    
hgs
parents:
diff changeset
   503
    iFile = RFile();
hgs
parents:
diff changeset
   504
    
hgs
parents:
diff changeset
   505
    if ( !iFs.Handle() )
hgs
parents:
diff changeset
   506
        {
hgs
parents:
diff changeset
   507
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   508
        }
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
    // Assign an initial value to iDrive
hgs
parents:
diff changeset
   511
    iDrive = GetDriveWithMaximumFreeSpaceL();    
hgs
parents:
diff changeset
   512
     
hgs
parents:
diff changeset
   513
    // If iDrive is at critical space level, we immediately show out_of_memory.
hgs
parents:
diff changeset
   514
    //
hgs
parents:
diff changeset
   515
    if (SysUtil::DiskSpaceBelowCriticalLevelL( &iFs, 0, iDrive ))
hgs
parents:
diff changeset
   516
        {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   517
        LaunchMemoryFullDialogL(iDrive);
42
hgs
parents: 32
diff changeset
   518
    
32
hgs
parents:
diff changeset
   519
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   520
        }
hgs
parents:
diff changeset
   521
        
hgs
parents:
diff changeset
   522
    TRACE_INFO( (_L( "[oppreceiveservice] HandlePutRequestL %d\t" ),iDrive ) ); 
hgs
parents:
diff changeset
   523
    
hgs
parents:
diff changeset
   524
    iObexObject = CObexBufObject::NewL( NULL );    
hgs
parents:
diff changeset
   525
    
hgs
parents:
diff changeset
   526
    delete iBuf;
hgs
parents:
diff changeset
   527
    iBuf = NULL;
hgs
parents:
diff changeset
   528
    
hgs
parents:
diff changeset
   529
    TRACE_ASSERT(iMediaType != ESrcsMediaIrDA, KErrNotSupported);
hgs
parents:
diff changeset
   530
    if ( iMediaType == ESrcsMediaBT )
hgs
parents:
diff changeset
   531
        {
hgs
parents:
diff changeset
   532
        TChar driveLetter;
hgs
parents:
diff changeset
   533
        iDefaultFolder.Zero();
hgs
parents:
diff changeset
   534
        iFs.DriveToChar(iDrive, driveLetter);
hgs
parents:
diff changeset
   535
        iDefaultFolder.Append(driveLetter);
hgs
parents:
diff changeset
   536
        if ( iDrive == EDriveC )
hgs
parents:
diff changeset
   537
            {
hgs
parents:
diff changeset
   538
            iDefaultFolder.Append(_L(":\\data\\"));
hgs
parents:
diff changeset
   539
            }
hgs
parents:
diff changeset
   540
        else
hgs
parents:
diff changeset
   541
            {
hgs
parents:
diff changeset
   542
            iDefaultFolder.Append(_L(":\\"));
hgs
parents:
diff changeset
   543
            }
hgs
parents:
diff changeset
   544
        iDefaultFolder.Append(iCenRepFolder);
hgs
parents:
diff changeset
   545
        
hgs
parents:
diff changeset
   546
        iFile = RFile();
hgs
parents:
diff changeset
   547
        iFullPathFilename.Zero();
hgs
parents:
diff changeset
   548
        TRAPD(err, TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL(iFile,
hgs
parents:
diff changeset
   549
                                                                              iDefaultFolder,
hgs
parents:
diff changeset
   550
                                                                              iFullPathFilename,
hgs
parents:
diff changeset
   551
                                                                              iBuf,
hgs
parents:
diff changeset
   552
                                                                              KBufferSize));
hgs
parents:
diff changeset
   553
        if(err != KErrNone)
hgs
parents:
diff changeset
   554
            {
hgs
parents:
diff changeset
   555
            iObexTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   556
            User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   557
            }
hgs
parents:
diff changeset
   558
        }
hgs
parents:
diff changeset
   559
    else
hgs
parents:
diff changeset
   560
        {
hgs
parents:
diff changeset
   561
        iObexTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   562
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
   563
        }
hgs
parents:
diff changeset
   564
    
hgs
parents:
diff changeset
   565
    User::LeaveIfError(iFile.Open(iFs,iFullPathFilename,EFileWrite));   
hgs
parents:
diff changeset
   566
    TObexRFileBackedBuffer bufferdetails(*iBuf,iFile,CObexBufObject::EDoubleBuffering);    
hgs
parents:
diff changeset
   567
    
hgs
parents:
diff changeset
   568
    TRAPD(err, iObexObject->SetDataBufL( bufferdetails) );
hgs
parents:
diff changeset
   569
    if (err != KErrNone)
hgs
parents:
diff changeset
   570
        {
hgs
parents:
diff changeset
   571
        iObexTransferState = ETransferPutInitError;
hgs
parents:
diff changeset
   572
        User::Leave(KErrGeneral);  // set to != KErrNone
hgs
parents:
diff changeset
   573
        }
hgs
parents:
diff changeset
   574
    
hgs
parents:
diff changeset
   575
    TRACE_INFO( _L( "[oppreceiveservice] COPPController: HandlePutRequestL completed\t" ) );
hgs
parents:
diff changeset
   576
    }
hgs
parents:
diff changeset
   577
hgs
parents:
diff changeset
   578
hgs
parents:
diff changeset
   579
// ---------------------------------------------------------
hgs
parents:
diff changeset
   580
// HandlePutCompleteIndication()
hgs
parents:
diff changeset
   581
// ---------------------------------------------------------
hgs
parents:
diff changeset
   582
//
hgs
parents:
diff changeset
   583
TInt COPPController::HandlePutCompleteIndication()
hgs
parents:
diff changeset
   584
	{
hgs
parents:
diff changeset
   585
	TRACE_FUNC        
hgs
parents:
diff changeset
   586
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   587
70
hgs
parents: 67
diff changeset
   588
    // Before saving the file received, this check is required to ensure that the case where the 
hgs
parents: 67
diff changeset
   589
    // memory card is removed while a transfer is in progress is handled in the right way.
hgs
parents: 67
diff changeset
   590
    TVolumeInfo volInfo;
hgs
parents: 67
diff changeset
   591
    retVal = iFs.Volume(volInfo, iDrive);
hgs
parents: 67
diff changeset
   592
    if(retVal != KErrNone)
hgs
parents: 67
diff changeset
   593
        {
hgs
parents: 67
diff changeset
   594
        TRACE_INFO( (_L( "[oppreceiveservice] HandlePutCompleteIndication failed  %d \t" ),retVal ) ); 
hgs
parents: 67
diff changeset
   595
hgs
parents: 67
diff changeset
   596
        HandleError(ETrue);
hgs
parents: 67
diff changeset
   597
        delete iObexObject;
hgs
parents: 67
diff changeset
   598
        iObexObject = NULL;
hgs
parents: 67
diff changeset
   599
hgs
parents: 67
diff changeset
   600
        delete iBuf;
hgs
parents: 67
diff changeset
   601
        iBuf = NULL;
hgs
parents: 67
diff changeset
   602
        
hgs
parents: 67
diff changeset
   603
        iPreviousDefaultFolder = iDefaultFolder;  // save the last file path where file is successfully saved to file system.
hgs
parents: 67
diff changeset
   604
        iMsvIdParent = KMsvNullIndexEntryId; 
hgs
parents: 67
diff changeset
   605
        TRACE_INFO( _L( "[oppreceiveservice] HandlePutCompleteIndication Done\t" ) );    
hgs
parents: 67
diff changeset
   606
        return retVal;
hgs
parents: 67
diff changeset
   607
        }
hgs
parents: 67
diff changeset
   608
32
hgs
parents:
diff changeset
   609
	TChar driveLetter;
hgs
parents:
diff changeset
   610
	iDefaultFolder.Zero();
hgs
parents:
diff changeset
   611
	iFs.DriveToChar(iDrive, driveLetter);
hgs
parents:
diff changeset
   612
	iDefaultFolder.Append(driveLetter);
hgs
parents:
diff changeset
   613
	if ( iDrive == EDriveC )
hgs
parents:
diff changeset
   614
	    {
hgs
parents:
diff changeset
   615
	    iDefaultFolder.Append(_L(":\\data\\"));
hgs
parents:
diff changeset
   616
	    }
hgs
parents:
diff changeset
   617
	else
hgs
parents:
diff changeset
   618
	    {
hgs
parents:
diff changeset
   619
	    iDefaultFolder.Append(_L(":\\"));
hgs
parents:
diff changeset
   620
	    }
hgs
parents:
diff changeset
   621
	iDefaultFolder.Append(iCenRepFolder);
hgs
parents:
diff changeset
   622
	iFullPathFilename.Zero();
hgs
parents:
diff changeset
   623
	iFullPathFilename.Append(iDefaultFolder);
hgs
parents:
diff changeset
   624
       
hgs
parents:
diff changeset
   625
        
hgs
parents:
diff changeset
   626
	TRACE_INFO( (_L( "[oppreceiveservice] HandlePutCompleteIndication %d\t" ),iDrive ) ); 
hgs
parents:
diff changeset
   627
	
hgs
parents:
diff changeset
   628
	if (iMediaType==ESrcsMediaBT)
hgs
parents:
diff changeset
   629
	    {
hgs
parents:
diff changeset
   630
	    TRAP ( retVal, TObexUtilsMessageHandler::SaveFileToFileSystemL(iObexObject,
hgs
parents:
diff changeset
   631
	                                                                   KUidMsgTypeBt,
hgs
parents:
diff changeset
   632
	                                                                   iMsvIdParent,
hgs
parents:
diff changeset
   633
	                                                                   iFullPathFilename,
hgs
parents:
diff changeset
   634
	                                                                   iFile,
hgs
parents:
diff changeset
   635
	                                                                   iRemoteDeviceName));
hgs
parents:
diff changeset
   636
	    }
hgs
parents:
diff changeset
   637
	TRACE_ASSERT( iMediaType!=ESrcsMediaIrDA, KErrNotSupported);
hgs
parents:
diff changeset
   638
	if ( retVal == KErrNone)
hgs
parents:
diff changeset
   639
	    {
hgs
parents:
diff changeset
   640
	    TRAP (retVal, TObexUtilsMessageHandler::AddEntryToInboxL(iMsvIdParent, iFullPathFilename));		    
hgs
parents:
diff changeset
   641
                
hgs
parents:
diff changeset
   642
    if( retVal != KErrNone )
hgs
parents:
diff changeset
   643
        {
hgs
parents:
diff changeset
   644
        TRACE_INFO( (_L( "[oppreceiveservice] HandlePutCompleteIndication AddEntryToInboxL() failed  %d \t" ),retVal ) );                 	
hgs
parents:
diff changeset
   645
        TRAP_IGNORE(TObexUtilsMessageHandler::RemoveInboxEntriesL(iObexObject, iMsvIdParent));        
hgs
parents:
diff changeset
   646
        }
hgs
parents:
diff changeset
   647
        }
hgs
parents:
diff changeset
   648
	else
hgs
parents:
diff changeset
   649
	    {
hgs
parents:
diff changeset
   650
	    TRACE_INFO( (_L( "[oppreceiveservice] HandlePutCompleteIndication failed  %d \t" ),retVal ) ); 
hgs
parents:
diff changeset
   651
	    }
hgs
parents:
diff changeset
   652
	
hgs
parents:
diff changeset
   653
hgs
parents:
diff changeset
   654
    delete iObexObject;
hgs
parents:
diff changeset
   655
    iObexObject = NULL;
hgs
parents:
diff changeset
   656
hgs
parents:
diff changeset
   657
    delete iBuf;
hgs
parents:
diff changeset
   658
    iBuf = NULL;
hgs
parents:
diff changeset
   659
    
hgs
parents:
diff changeset
   660
    iPreviousDefaultFolder = iDefaultFolder;  // save the last file path where file is successfully saved to file system.
hgs
parents:
diff changeset
   661
    iMsvIdParent = KMsvNullIndexEntryId; 
hgs
parents:
diff changeset
   662
    TRACE_INFO( _L( "[oppreceiveservice] HandlePutCompleteIndication Done\t" ) );    
hgs
parents:
diff changeset
   663
    return retVal;
hgs
parents:
diff changeset
   664
	}
hgs
parents:
diff changeset
   665
hgs
parents:
diff changeset
   666
  
hgs
parents:
diff changeset
   667
// ---------------------------------------------------------
hgs
parents:
diff changeset
   668
// CheckCapacity()
hgs
parents:
diff changeset
   669
// ---------------------------------------------------------
hgs
parents:
diff changeset
   670
//	    
hgs
parents:
diff changeset
   671
TBool COPPController::CheckCapacityL()
hgs
parents:
diff changeset
   672
    {
hgs
parents:
diff changeset
   673
    TRACE_FUNC_ENTRY   
hgs
parents:
diff changeset
   674
    
hgs
parents:
diff changeset
   675
    iDrive = EDriveZ; // Intialize iDrive to Z
hgs
parents:
diff changeset
   676
    TInt filesize = iObexObject->Length();
hgs
parents:
diff changeset
   677
    
hgs
parents:
diff changeset
   678
    RFs rfs ;
hgs
parents:
diff changeset
   679
    User::LeaveIfError(rfs.Connect());
hgs
parents:
diff changeset
   680
         
hgs
parents:
diff changeset
   681
    TInt mmcDrive = KDefaultDrive;   // External memroy card  
hgs
parents:
diff changeset
   682
    TInt imsDrive = KDefaultDrive;   // Internal mass storage   
hgs
parents:
diff changeset
   683
hgs
parents:
diff changeset
   684
    User::LeaveIfError(DriveInfo::GetDefaultDrive(DriveInfo::EDefaultMassStorage, imsDrive));
hgs
parents:
diff changeset
   685
    User::LeaveIfError(DriveInfo::GetDefaultDrive(DriveInfo::EDefaultRemovableMassStorage, mmcDrive));      
hgs
parents:
diff changeset
   686
    
hgs
parents:
diff changeset
   687
    TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL imsDrive=%d; mmcDrive=%d\t" ),imsDrive, mmcDrive ) );
hgs
parents:
diff changeset
   688
    
hgs
parents:
diff changeset
   689
    TVolumeInfo volumeInfo;
hgs
parents:
diff changeset
   690
    TInt err = rfs.Volume(volumeInfo, imsDrive);
hgs
parents:
diff changeset
   691
    
hgs
parents:
diff changeset
   692
    // If err != KErrNone, Drive is not available.
hgs
parents:
diff changeset
   693
    //
hgs
parents:
diff changeset
   694
    if ( !err )
hgs
parents:
diff changeset
   695
        {
hgs
parents:
diff changeset
   696
        // Check capacity on Internal mass storage            
hgs
parents:
diff changeset
   697
        TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL Internal mass storage\t" )) );
hgs
parents:
diff changeset
   698
        if ( !SysUtil::DiskSpaceBelowCriticalLevelL( &rfs, filesize, imsDrive ) )
hgs
parents:
diff changeset
   699
            {
hgs
parents:
diff changeset
   700
            iDrive = imsDrive;            
hgs
parents:
diff changeset
   701
            }
hgs
parents:
diff changeset
   702
        }
hgs
parents:
diff changeset
   703
    
hgs
parents:
diff changeset
   704
    if ( iDrive == EDriveZ)
hgs
parents:
diff changeset
   705
        {
hgs
parents:
diff changeset
   706
        err = rfs.Volume(volumeInfo, mmcDrive);
hgs
parents:
diff changeset
   707
        if ( !err )
hgs
parents:
diff changeset
   708
            {
hgs
parents:
diff changeset
   709
            // Check capacity on Internal mass storage    
hgs
parents:
diff changeset
   710
            TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL Checking memory card\t" )) );
hgs
parents:
diff changeset
   711
            if ( !SysUtil::DiskSpaceBelowCriticalLevelL( &rfs, filesize, mmcDrive ) )
hgs
parents:
diff changeset
   712
                {                    
hgs
parents:
diff changeset
   713
                iDrive = mmcDrive;
hgs
parents:
diff changeset
   714
                }   
hgs
parents:
diff changeset
   715
            }
hgs
parents:
diff changeset
   716
        }           
hgs
parents:
diff changeset
   717
    if ( iDrive == EDriveZ )
hgs
parents:
diff changeset
   718
        {
hgs
parents:
diff changeset
   719
        TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL Checking phone memory\t" )) );
hgs
parents:
diff changeset
   720
        // Phone memory
hgs
parents:
diff changeset
   721
        if( !SysUtil::DiskSpaceBelowCriticalLevelL( &rfs, filesize, EDriveC ))
hgs
parents:
diff changeset
   722
            {
hgs
parents:
diff changeset
   723
            iDrive = EDriveC;
hgs
parents:
diff changeset
   724
            }
hgs
parents:
diff changeset
   725
        }
hgs
parents:
diff changeset
   726
    rfs.Close();
hgs
parents:
diff changeset
   727
    TRACE_INFO( (_L( "[oppreceiveservice] CheckCapacityL iDrive = %d\t" ),iDrive ) );
hgs
parents:
diff changeset
   728
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   729
    if (iDrive == EDriveZ)
hgs
parents:
diff changeset
   730
        {
hgs
parents:
diff changeset
   731
        // If there is no free space for receiving file, we need to set iPreviousDefaultFolder back to iDefaultFolder.
hgs
parents:
diff changeset
   732
        // In order to show the file receveing dialog correctly.
hgs
parents:
diff changeset
   733
        iDefaultFolder = iPreviousDefaultFolder;
hgs
parents:
diff changeset
   734
        return EFalse;
hgs
parents:
diff changeset
   735
        }
hgs
parents:
diff changeset
   736
    return ETrue;
hgs
parents:
diff changeset
   737
    }    
hgs
parents:
diff changeset
   738
hgs
parents:
diff changeset
   739
// ---------------------------------------------------------
hgs
parents:
diff changeset
   740
// IsOBEXActive()
hgs
parents:
diff changeset
   741
// ---------------------------------------------------------
hgs
parents:
diff changeset
   742
//	    
hgs
parents:
diff changeset
   743
TBool COPPController::IsOBEXActive()
hgs
parents:
diff changeset
   744
    {
hgs
parents:
diff changeset
   745
    TRACE_FUNC
hgs
parents:
diff changeset
   746
    return ETrue;
hgs
parents:
diff changeset
   747
    }
hgs
parents:
diff changeset
   748
hgs
parents:
diff changeset
   749
// ---------------------------------------------------------
hgs
parents:
diff changeset
   750
// SetMediaType()
hgs
parents:
diff changeset
   751
// ---------------------------------------------------------
hgs
parents:
diff changeset
   752
//
hgs
parents:
diff changeset
   753
void COPPController::SetMediaType( TSrcsMediaType aMediaType ) 
hgs
parents:
diff changeset
   754
    {
hgs
parents:
diff changeset
   755
    TRACE_FUNC    
hgs
parents:
diff changeset
   756
    iMediaType=aMediaType;    
hgs
parents:
diff changeset
   757
    }
hgs
parents:
diff changeset
   758
    
hgs
parents:
diff changeset
   759
// ---------------------------------------------------------
hgs
parents:
diff changeset
   760
// SetObexServer()
hgs
parents:
diff changeset
   761
// ---------------------------------------------------------
hgs
parents:
diff changeset
   762
//
hgs
parents:
diff changeset
   763
TInt COPPController::SetObexServer( CObexServer* aServer)
hgs
parents:
diff changeset
   764
	{	
hgs
parents:
diff changeset
   765
	TInt retVal=KErrNone;    
hgs
parents:
diff changeset
   766
	
hgs
parents:
diff changeset
   767
	if (aServer)
hgs
parents:
diff changeset
   768
	    {  
hgs
parents:
diff changeset
   769
	    iObexServer = aServer;
hgs
parents:
diff changeset
   770
	    retVal=aServer->Start(this);    
hgs
parents:
diff changeset
   771
	    }
hgs
parents:
diff changeset
   772
	return retVal;
hgs
parents:
diff changeset
   773
	}
hgs
parents:
diff changeset
   774
   
hgs
parents:
diff changeset
   775
// ---------------------------------------------------------
hgs
parents:
diff changeset
   776
// CancelTransfer()
hgs
parents:
diff changeset
   777
// ---------------------------------------------------------
hgs
parents:
diff changeset
   778
//
hgs
parents:
diff changeset
   779
void COPPController::CancelTransfer()
hgs
parents:
diff changeset
   780
    {
hgs
parents:
diff changeset
   781
    TRACE_FUNC
hgs
parents:
diff changeset
   782
    CloseReceivingIndicator();
hgs
parents:
diff changeset
   783
    if(iObexTransferState == ETransferPut)
hgs
parents:
diff changeset
   784
        {
hgs
parents:
diff changeset
   785
        iObexTransferState = ETransferPutCancel;
hgs
parents:
diff changeset
   786
        }
hgs
parents:
diff changeset
   787
    else // go to idle for all other states
hgs
parents:
diff changeset
   788
        {
hgs
parents:
diff changeset
   789
        iObexTransferState = ETransferIdle;
hgs
parents:
diff changeset
   790
        }
hgs
parents:
diff changeset
   791
    }
hgs
parents:
diff changeset
   792
hgs
parents:
diff changeset
   793
void COPPController::LaunchReceivingIndicatorL()
hgs
parents:
diff changeset
   794
    {
hgs
parents:
diff changeset
   795
    if(ReceivingIndicatorActive())
hgs
parents:
diff changeset
   796
        {
hgs
parents:
diff changeset
   797
        return;
hgs
parents:
diff changeset
   798
        }
hgs
parents:
diff changeset
   799
    
hgs
parents:
diff changeset
   800
    if(iTotalSizeByte > 0)
hgs
parents:
diff changeset
   801
        {
hgs
parents:
diff changeset
   802
        if(iReceivingFileName.Length() > 0)
hgs
parents:
diff changeset
   803
            {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   804
            TFileName shortname;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   805
            if ( iReceivingFileName.Length() > KMaxDisplayFileName ) 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   806
                {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   807
                // Filename is too long, 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   808
                // We make it shorter. Hiding the chars in the middle part of filename. 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   809
                shortname = iReceivingFileName.Mid(0,KMaxDisplayFileName/2);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   810
                shortname.Append(_L("..."));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   811
                shortname.Append(iReceivingFileName.Mid(iReceivingFileName.Length() - KMaxDisplayFileName/2, KMaxDisplayFileName/2));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   812
                }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   813
            else
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   814
                {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   815
                shortname.Copy(iReceivingFileName);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   816
                }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   817
42
hgs
parents: 32
diff changeset
   818
            iProgressDialog = CHbDeviceDialogSymbian::NewL();
hgs
parents: 32
diff changeset
   819
            iProgressDialog->SetObserver(this);
hgs
parents: 32
diff changeset
   820
hgs
parents: 32
diff changeset
   821
            CHbSymbianVariantMap* variantMap = CHbSymbianVariantMap::NewL();
hgs
parents: 32
diff changeset
   822
            CleanupStack::PushL(variantMap);
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   823
42
hgs
parents: 32
diff changeset
   824
            TInt dialogIdx = TBluetoothDialogParams::EReceiveProgress;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   825
            AddParamL(TBluetoothDialogParams::EDialogType, (TAny*) &dialogIdx, 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   826
                    CHbSymbianVariant::EInt, *variantMap);
42
hgs
parents: 32
diff changeset
   827
            
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   828
            AddParamL(TBluetoothDeviceDialog::EDeviceName, (TAny*) &iRemoteDeviceName,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   829
                    CHbSymbianVariant::EDes, *variantMap);
42
hgs
parents: 32
diff changeset
   830
            
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   831
            AddParamL(TBluetoothDeviceDialog::EReceivingFileName, (TAny*) &shortname,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   832
                    CHbSymbianVariant::EDes, *variantMap);
42
hgs
parents: 32
diff changeset
   833
            
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   834
            AddParamL(TBluetoothDeviceDialog::EReceivingFileSize, (TAny*) &iTotalSizeByte,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   835
                    CHbSymbianVariant::EInt, *variantMap);
42
hgs
parents: 32
diff changeset
   836
            
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   837
            AddParamL(TBluetoothDeviceDialog::EReceivedFileCount, (TAny*) &iFileCount,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   838
                    CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   839
42
hgs
parents: 32
diff changeset
   840
            iDialogActive = ETrue;
hgs
parents: 32
diff changeset
   841
            iProgressDialog->Show( KBTDevDialogId(), *variantMap, this );
hgs
parents: 32
diff changeset
   842
            CleanupStack::PopAndDestroy(variantMap);
32
hgs
parents:
diff changeset
   843
            }
hgs
parents:
diff changeset
   844
        else
hgs
parents:
diff changeset
   845
            {
hgs
parents:
diff changeset
   846
            if(iMediaType == ESrcsMediaBT)
hgs
parents:
diff changeset
   847
                {
42
hgs
parents: 32
diff changeset
   848
                //TODO - Remove the usage of the resources.
hgs
parents: 32
diff changeset
   849
                //iProgressDialog->ShowProgressDialogL(R_BT_RECEIVING_DATA);
32
hgs
parents:
diff changeset
   850
                }
hgs
parents:
diff changeset
   851
            TRACE_ASSERT(iMediaType != ESrcsMediaIrDA, KErrNotSupported);
hgs
parents:
diff changeset
   852
            }
hgs
parents:
diff changeset
   853
        }
hgs
parents:
diff changeset
   854
    else
hgs
parents:
diff changeset
   855
        {
42
hgs
parents: 32
diff changeset
   856
    
hgs
parents: 32
diff changeset
   857
        /*
hgs
parents: 32
diff changeset
   858
         * TODO - The functionality provided by CGlobalDialog will be removed
hgs
parents: 32
diff changeset
   859
         * TODO - and this will be provided by CGlobalProgressDialog.
hgs
parents: 32
diff changeset
   860
         */
32
hgs
parents:
diff changeset
   861
        if(iMediaType == ESrcsMediaBT)
hgs
parents:
diff changeset
   862
            {
42
hgs
parents: 32
diff changeset
   863
            // TODO 
32
hgs
parents:
diff changeset
   864
            }
hgs
parents:
diff changeset
   865
        TRACE_ASSERT(iMediaType != ESrcsMediaIrDA, KErrNotSupported);
hgs
parents:
diff changeset
   866
        }
hgs
parents:
diff changeset
   867
    }
hgs
parents:
diff changeset
   868
42
hgs
parents: 32
diff changeset
   869
void COPPController::UpdateReceivingIndicatorL()
32
hgs
parents:
diff changeset
   870
    {
hgs
parents:
diff changeset
   871
    if(iProgressDialog)
hgs
parents:
diff changeset
   872
        {
42
hgs
parents: 32
diff changeset
   873
        CHbSymbianVariantMap* variantMap = CHbSymbianVariantMap::NewL();
hgs
parents: 32
diff changeset
   874
        CleanupStack::PushL(variantMap);
hgs
parents: 32
diff changeset
   875
        
hgs
parents: 32
diff changeset
   876
        TInt bytesReceived = iObexObject->BytesReceived();
hgs
parents: 32
diff changeset
   877
        CHbSymbianVariant* progress = CHbSymbianVariant::NewL( (TAny*) &bytesReceived, CHbSymbianVariant::EInt );
hgs
parents: 32
diff changeset
   878
        CleanupStack::PushL(progress);
hgs
parents: 32
diff changeset
   879
        User::LeaveIfError(variantMap->Add(_L("progress"), progress));
hgs
parents: 32
diff changeset
   880
        CleanupStack::Pop(progress);
hgs
parents: 32
diff changeset
   881
        
hgs
parents: 32
diff changeset
   882
        iProgressDialog->Update(*variantMap);
hgs
parents: 32
diff changeset
   883
        CleanupStack::PopAndDestroy(variantMap);
32
hgs
parents:
diff changeset
   884
        }
hgs
parents:
diff changeset
   885
    }
hgs
parents:
diff changeset
   886
hgs
parents:
diff changeset
   887
void COPPController::CloseReceivingIndicator(TBool aResetDisplayedState)
hgs
parents:
diff changeset
   888
    {
hgs
parents:
diff changeset
   889
    TRACE_FUNC
hgs
parents:
diff changeset
   890
    if(aResetDisplayedState)
hgs
parents:
diff changeset
   891
        {
hgs
parents:
diff changeset
   892
        iNoteDisplayed = EFalse;
hgs
parents:
diff changeset
   893
        }
42
hgs
parents: 32
diff changeset
   894
    
32
hgs
parents:
diff changeset
   895
    if(iProgressDialog)
hgs
parents:
diff changeset
   896
        {
42
hgs
parents: 32
diff changeset
   897
        iProgressDialog->Cancel();
hgs
parents: 32
diff changeset
   898
        iDialogActive = EFalse;
32
hgs
parents:
diff changeset
   899
        delete iProgressDialog;
hgs
parents:
diff changeset
   900
        iProgressDialog = NULL;
hgs
parents:
diff changeset
   901
        }
hgs
parents:
diff changeset
   902
    }
hgs
parents:
diff changeset
   903
hgs
parents:
diff changeset
   904
 // ---------------------------------------------------------
hgs
parents:
diff changeset
   905
  // GetDriveWithMaximumFreeSpace()
hgs
parents:
diff changeset
   906
  // ---------------------------------------------------------
hgs
parents:
diff changeset
   907
  // 
hgs
parents:
diff changeset
   908
  TInt COPPController::GetDriveWithMaximumFreeSpaceL()
hgs
parents:
diff changeset
   909
      {
hgs
parents:
diff changeset
   910
      // Get drive with maximum freespace among phone memory, MMC, internal mass storage.
hgs
parents:
diff changeset
   911
      //
hgs
parents:
diff changeset
   912
      TRACE_FUNC   
hgs
parents:
diff changeset
   913
      TVolumeInfo volumeInfoC;
hgs
parents:
diff changeset
   914
      TVolumeInfo volumeInfoE;
hgs
parents:
diff changeset
   915
      TVolumeInfo volumeInfoF;
hgs
parents:
diff changeset
   916
      TInt64 max = 0;
hgs
parents:
diff changeset
   917
      TInt drive = 0;
hgs
parents:
diff changeset
   918
      
hgs
parents:
diff changeset
   919
      TInt err = iFs.Volume(volumeInfoC, EDriveC);
hgs
parents:
diff changeset
   920
     
hgs
parents:
diff changeset
   921
      if ( !err )
hgs
parents:
diff changeset
   922
          {
hgs
parents:
diff changeset
   923
          // set initial values to max and drive.
hgs
parents:
diff changeset
   924
          max = volumeInfoC.iFree;
hgs
parents:
diff changeset
   925
          drive = EDriveC;
hgs
parents:
diff changeset
   926
          }
hgs
parents:
diff changeset
   927
           
hgs
parents:
diff changeset
   928
      err = iFs.Volume(volumeInfoE, EDriveE);     
hgs
parents:
diff changeset
   929
      if ( !err )
hgs
parents:
diff changeset
   930
          {
hgs
parents:
diff changeset
   931
          if (volumeInfoE.iFree >= max)
hgs
parents:
diff changeset
   932
              {
hgs
parents:
diff changeset
   933
              max = volumeInfoE.iFree;
hgs
parents:
diff changeset
   934
              drive = EDriveE;             
hgs
parents:
diff changeset
   935
              }
hgs
parents:
diff changeset
   936
          
hgs
parents:
diff changeset
   937
          }
hgs
parents:
diff changeset
   938
           
hgs
parents:
diff changeset
   939
      err = iFs.Volume(volumeInfoF, EDriveF);
hgs
parents:
diff changeset
   940
      if ( !err )
hgs
parents:
diff changeset
   941
          {
hgs
parents:
diff changeset
   942
          if (volumeInfoF.iFree >= max)
hgs
parents:
diff changeset
   943
              {
hgs
parents:
diff changeset
   944
              max = volumeInfoF.iFree;
hgs
parents:
diff changeset
   945
              drive = EDriveF;             
hgs
parents:
diff changeset
   946
              }
hgs
parents:
diff changeset
   947
          }
hgs
parents:
diff changeset
   948
      
hgs
parents:
diff changeset
   949
      max = 0;
hgs
parents:
diff changeset
   950
      return drive;
hgs
parents:
diff changeset
   951
      }
hgs
parents:
diff changeset
   952
 
hgs
parents:
diff changeset
   953
 
hgs
parents:
diff changeset
   954
 // ----------------------------------------------------------
hgs
parents:
diff changeset
   955
 // COPPController::HandleGetDevicesComplete
hgs
parents:
diff changeset
   956
 // Callback from devman
hgs
parents:
diff changeset
   957
 // ----------------------------------------------------------
hgs
parents:
diff changeset
   958
 //
42
hgs
parents: 32
diff changeset
   959
 void COPPController::HandleGetDevicesComplete(TInt aErr, CBTDeviceArray* aDeviceArray)
32
hgs
parents:
diff changeset
   960
    {
hgs
parents:
diff changeset
   961
    TRACE_INFO( _L( "[oppreceiveservice] HandleGetDevicesComplete: enter \t" ) );
42
hgs
parents: 32
diff changeset
   962
    
hgs
parents: 32
diff changeset
   963
    (void) aDeviceArray;
hgs
parents: 32
diff changeset
   964
    
32
hgs
parents:
diff changeset
   965
    if ( aErr == KErrNone )
hgs
parents:
diff changeset
   966
        {
hgs
parents:
diff changeset
   967
        if ( iResultArray->Count())
hgs
parents:
diff changeset
   968
            {             
hgs
parents:
diff changeset
   969
            iRemoteDeviceName.Zero();
hgs
parents:
diff changeset
   970
            if ( iResultArray->At(0)->FriendlyName().Length() > 0 )
hgs
parents:
diff changeset
   971
                {
hgs
parents:
diff changeset
   972
                TRACE_INFO( _L( "[oppreceiveservice] HandleGetDevicesComplete: got friendly name \t" ) );
hgs
parents:
diff changeset
   973
                iRemoteDeviceName.Copy(iResultArray->At(0)->FriendlyName());
hgs
parents:
diff changeset
   974
                }
hgs
parents:
diff changeset
   975
            else
hgs
parents:
diff changeset
   976
                {
hgs
parents:
diff changeset
   977
                TRACE_INFO( _L( "[oppreceiveservice] HandleGetDevicesComplete: got devciename name \t" ));
hgs
parents:
diff changeset
   978
                TRAP_IGNORE(iRemoteDeviceName.Copy( BTDeviceNameConverter::ToUnicodeL(iResultArray->At(0)->DeviceName())));
hgs
parents:
diff changeset
   979
                }
hgs
parents:
diff changeset
   980
            }
hgs
parents:
diff changeset
   981
        }
hgs
parents:
diff changeset
   982
    }
42
hgs
parents: 32
diff changeset
   983
 TBool COPPController::IsBackupRunning()
hgs
parents: 32
diff changeset
   984
    {
hgs
parents: 32
diff changeset
   985
    const TUint32 KFileManagerBkupStatus = 0x00000001;
hgs
parents: 32
diff changeset
   986
    
hgs
parents: 32
diff changeset
   987
    TInt status = EFileManagerBkupStatusUnset;
hgs
parents: 32
diff changeset
   988
    TBool retValue = EFalse;
hgs
parents: 32
diff changeset
   989
    TInt err = RProperty::Get( TUid::Uid(KFileManagerUID3), KFileManagerBkupStatus,
hgs
parents: 32
diff changeset
   990
                              status );
hgs
parents: 32
diff changeset
   991
    if ( err == KErrNone )
hgs
parents: 32
diff changeset
   992
        {
hgs
parents: 32
diff changeset
   993
        if ( status == EFileManagerBkupStatusBackup || 
hgs
parents: 32
diff changeset
   994
             status == EFileManagerBkupStatusRestore )
hgs
parents: 32
diff changeset
   995
            {
hgs
parents: 32
diff changeset
   996
            TSecureId fileManagerSecureId( KFileManagerUID3 );
hgs
parents: 32
diff changeset
   997
            //only returning ETrue if backup process is still active
hgs
parents: 32
diff changeset
   998
            retValue = ProcessExists( fileManagerSecureId );
hgs
parents: 32
diff changeset
   999
            }
hgs
parents: 32
diff changeset
  1000
        }
hgs
parents: 32
diff changeset
  1001
   
hgs
parents: 32
diff changeset
  1002
    return retValue;
hgs
parents: 32
diff changeset
  1003
    }
32
hgs
parents:
diff changeset
  1004
 
42
hgs
parents: 32
diff changeset
  1005
 TBool COPPController::ProcessExists( const TSecureId& aSecureId )
hgs
parents: 32
diff changeset
  1006
     {
hgs
parents: 32
diff changeset
  1007
     _LIT( KFindPattern, "*" );
hgs
parents: 32
diff changeset
  1008
     TFindProcess finder(KFindPattern);
hgs
parents: 32
diff changeset
  1009
     TFullName processName;
hgs
parents: 32
diff changeset
  1010
     while( finder.Next( processName ) == KErrNone )
hgs
parents: 32
diff changeset
  1011
         {
hgs
parents: 32
diff changeset
  1012
         RProcess process;
hgs
parents: 32
diff changeset
  1013
         if ( process.Open( processName ) == KErrNone )
hgs
parents: 32
diff changeset
  1014
             {
hgs
parents: 32
diff changeset
  1015
             TSecureId processId( process.SecureId() );
hgs
parents: 32
diff changeset
  1016
             process.Close();
hgs
parents: 32
diff changeset
  1017
             if( processId == aSecureId )
hgs
parents: 32
diff changeset
  1018
                 {
hgs
parents: 32
diff changeset
  1019
                 return ETrue;
hgs
parents: 32
diff changeset
  1020
                 }
hgs
parents: 32
diff changeset
  1021
             }
hgs
parents: 32
diff changeset
  1022
         }
hgs
parents: 32
diff changeset
  1023
     return EFalse;
hgs
parents: 32
diff changeset
  1024
     }
hgs
parents: 32
diff changeset
  1025
 
hgs
parents: 32
diff changeset
  1026
 void COPPController::DataReceived(CHbSymbianVariantMap& aData)
hgs
parents: 32
diff changeset
  1027
     {
hgs
parents: 32
diff changeset
  1028
     if(aData.Keys().MdcaPoint(0).Compare(_L("actionResult")) == 0)
hgs
parents: 32
diff changeset
  1029
         {
hgs
parents: 32
diff changeset
  1030
         TInt val = *(static_cast<TInt*>(aData.Get(_L("actionResult"))->Data()));
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1031
         switch(val)
42
hgs
parents: 32
diff changeset
  1032
             {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1033
             case TBluetoothDialogParams::ECancelReceive:
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1034
                 {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1035
                 //User choose to cancel receiving.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1036
                 CancelTransfer();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1037
                 }break;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1038
                 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1039
             case TBluetoothDialogParams::EHide:
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1040
                 {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1041
                 //Use choose to hide the progress dialog.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1042
                 CloseReceivingIndicator(EFalse);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1043
                 }break;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1044
                 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1045
             case TBluetoothDialogParams::EShow:
67
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
  1046
                 {
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
  1047
                 TRAP_IGNORE(iBtCnvViewLauncher->LaunchConversationViewL());
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
  1048
                 }
16e4b9007960 201039_4
hgs
parents: 57
diff changeset
  1049
             //No break statement after the preview case since the receive dialog must be closed anyway    
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1050
             case TBluetoothDialogParams::ECancelShow:
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1051
                 {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1052
                 //In case of Show, the device dialog will handle the opening of conversation view.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1053
                 iRecvDoneDialog->Cancel();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1054
                 delete iRecvDoneDialog;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1055
                 iRecvDoneDialog = NULL;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
  1056
                 }break;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1057
             default:
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1058
                 break;
42
hgs
parents: 32
diff changeset
  1059
             }
hgs
parents: 32
diff changeset
  1060
         }
hgs
parents: 32
diff changeset
  1061
     }
hgs
parents: 32
diff changeset
  1062
 
hgs
parents: 32
diff changeset
  1063
 void COPPController::DeviceDialogClosed(TInt aCompletionCode)
hgs
parents: 32
diff changeset
  1064
     {
hgs
parents: 32
diff changeset
  1065
     (void) aCompletionCode;
hgs
parents: 32
diff changeset
  1066
     }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1067
 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1068
 void COPPController::LaunchFailureDialogL()
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1069
     {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1070
     if(iFailureDialog)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1071
         {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1072
         iFailureDialog->Cancel();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1073
         delete iFailureDialog;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1074
         iFailureDialog = NULL;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1075
         }
42
hgs
parents: 32
diff changeset
  1076
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1077
     iFailureDialog = CHbDeviceDialogSymbian::NewL();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1078
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1079
     CHbSymbianVariantMap* variantMap = CHbSymbianVariantMap::NewL();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1080
     CleanupStack::PushL(variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1081
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1082
     TInt dialogIdx = TBluetoothDialogParams::EInformationDialog;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1083
     AddParamL(TBluetoothDialogParams::EDialogType, (TAny*) &dialogIdx,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1084
             CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1085
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1086
     AddParamL(TBluetoothDeviceDialog::EDeviceName, (TAny*) &iRemoteDeviceName,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1087
             CHbSymbianVariant::EDes, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1088
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1089
     TInt dialogTitleIdx = TBluetoothDialogParams::ERecvFailed;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1090
     AddParamL(TBluetoothDialogParams::EDialogTitle, (TAny*) &dialogTitleIdx,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1091
             CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1092
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1093
     TUint32 deviceClass = iResultArray->At(0)->DeviceClass().DeviceClass();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1094
     AddParamL(TBluetoothDeviceDialog::EDeviceClass, (TAny*) &deviceClass,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1095
             CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1096
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1097
     iFailureDialog->Show( KBTDevDialogId(), *variantMap );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1098
     CleanupStack::PopAndDestroy(variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1099
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1100
     iReceivingFailed = EFalse;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1101
     }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1102
 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1103
 void COPPController::LaunchMemoryFullDialogL(TInt aDrive)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1104
     {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1105
     if(iMemoryFullDailog)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1106
         {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1107
         iMemoryFullDailog->Cancel();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1108
         delete iMemoryFullDailog;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1109
         iMemoryFullDailog = NULL;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1110
         }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1111
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1112
     iMemoryFullDailog = CHbDeviceDialogSymbian::NewL();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1113
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1114
     CHbSymbianVariantMap* variantMap = CHbSymbianVariantMap::NewL();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1115
     CleanupStack::PushL(variantMap);
32
hgs
parents:
diff changeset
  1116
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1117
     TInt dialogIdx = TBluetoothDialogParams::EInformationDialog;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1118
     AddParamL(TBluetoothDialogParams::EDialogType, (TAny*) &dialogIdx,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1119
             CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1120
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1121
     TInt dialogTitleIdx = TBluetoothDialogParams::EMemoryFull;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1122
     AddParamL(TBluetoothDialogParams::EDialogTitle, (TAny*) &dialogTitleIdx,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1123
             CHbSymbianVariant::EInt, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1124
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1125
     TChar driveLetter;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1126
     iFs.DriveToChar(aDrive, driveLetter);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1127
     AddParamL(TBluetoothDeviceDialog::EDriveLetter, (TAny*) &driveLetter,
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1128
             CHbSymbianVariant::EChar, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1129
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1130
     TVolumeInfo volumeInfo;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1131
     iFs.Volume(volumeInfo, aDrive);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1132
     AddParamL(TBluetoothDeviceDialog::EDriveName, (TAny*) &(volumeInfo.iName),
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1133
             CHbSymbianVariant::EDes, *variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1134
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1135
     iMemoryFullDailog->Show( KBTDevDialogId(), *variantMap );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1136
     CleanupStack::PopAndDestroy(variantMap);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1137
     }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1138
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1139
 void COPPController::AddParamL(const TInt aKey, const TAny* aValue, 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1140
         CHbSymbianVariant::TType aValueType,  CHbSymbianVariantMap& aVariantMap)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1141
     {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1142
     //Prepare the key
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1143
     TBuf<KMinStringSize> key;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1144
     key.Num(aKey);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1145
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1146
     //Prepare the value
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1147
     CHbSymbianVariant* value = CHbSymbianVariant::NewL( aValue, aValueType );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1148
     CleanupStack::PushL(value);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1149
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1150
     //add the key-value pair to the variant map
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1151
     User::LeaveIfError(aVariantMap.Add(key, value));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1152
     
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1153
     CleanupStack::Pop(value);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1154
     }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1155
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1156
 //////////////////////////// Global part ////////////////////////////
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
  1157
 
32
hgs
parents:
diff changeset
  1158
//  End of File