btobexprofiles/obexserviceman/utils/src/obexutilsmessagehandler.cpp
author hgs
Fri, 06 Aug 2010 16:43:21 +0300
changeset 51 625f43ae9362
parent 47 9e2a905b887f
permissions -rw-r--r--
201031_05
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002,2010 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: 
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 "obexutilsmessagehandler.h"
hgs
parents:
diff changeset
    21
#include "obexutilsdebug.h"
hgs
parents:
diff changeset
    22
#include "obexutilsentryhandler.h"
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include <msvids.h>
hgs
parents:
diff changeset
    25
#include <msvuids.h>
hgs
parents:
diff changeset
    26
#include <apgcli.h>
hgs
parents:
diff changeset
    27
#include <txtrich.h>
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#include <biouids.h>
hgs
parents:
diff changeset
    30
#include <bautils.h>
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
#include <e32property.h>
hgs
parents:
diff changeset
    33
#include <UikonInternalPSKeys.h>
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
#include <mmsvattachmentmanagersync.h>
hgs
parents:
diff changeset
    36
#include <mmsvattachmentmanager.h>
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
#include <centralrepository.h>
hgs
parents:
diff changeset
    39
#include <btengdomaincrkeys.h>
hgs
parents:
diff changeset
    40
#include "updatemusiccollection.h"
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
#include <pathinfo.h>          // provides interface for quering system paths 
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
#ifdef __BT_SAP
hgs
parents:
diff changeset
    45
 #include "vMessageHandler.h"
hgs
parents:
diff changeset
    46
#endif // __BT_SAP
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// CONSTANT
hgs
parents:
diff changeset
    49
const TInt KFFSBelowCritical = -2;
hgs
parents:
diff changeset
    50
const TInt KRenameOffSet = 4 ;
42
hgs
parents: 32
diff changeset
    51
hgs
parents: 32
diff changeset
    52
// todo @ QT migration: take official definition from Messaging at app layer (btmsgtypeuid.h)
hgs
parents: 32
diff changeset
    53
const TUid KUidMsgTypeBt = {0x10009ED5};
hgs
parents: 32
diff changeset
    54
hgs
parents: 32
diff changeset
    55
const TInt KObexUtilsMaxCharToFromField = 256;
hgs
parents: 32
diff changeset
    56
51
625f43ae9362 201031_05
hgs
parents: 47
diff changeset
    57
const TInt32 KUidMsgTypeBtTInt32 = 0x10009ED5;
625f43ae9362 201031_05
hgs
parents: 47
diff changeset
    58
32
hgs
parents:
diff changeset
    59
// ============================= LOCAL FUNCTIONS ===============================
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
// RemoveObexBuffer  Removes Obex buffer object.
hgs
parents:
diff changeset
    63
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    64
//
hgs
parents:
diff changeset
    65
void TObexUtilsMessageHandler::RemoveObexBuffer(CObexBufObject* &aBufObject)
hgs
parents:
diff changeset
    66
    {
hgs
parents:
diff changeset
    67
    if (aBufObject)
hgs
parents:
diff changeset
    68
        {
hgs
parents:
diff changeset
    69
        delete aBufObject;
hgs
parents:
diff changeset
    70
        aBufObject = NULL;
hgs
parents:
diff changeset
    71
        }
hgs
parents:
diff changeset
    72
    }
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    75
// CreateMsvSessionLC  Creates MSV session
hgs
parents:
diff changeset
    76
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
//
hgs
parents:
diff changeset
    78
void TObexUtilsMessageHandler::CreateMsvSessionLC(
hgs
parents:
diff changeset
    79
    CDummySessionObserver* &aSessionObs,
hgs
parents:
diff changeset
    80
    CMsvSession* &aMsvSession)
hgs
parents:
diff changeset
    81
    {
hgs
parents:
diff changeset
    82
    aSessionObs = new( ELeave )CDummySessionObserver;
hgs
parents:
diff changeset
    83
    CleanupStack::PushL( aSessionObs );  //1st push
hgs
parents:
diff changeset
    84
    aMsvSession = CMsvSession::OpenSyncL( *aSessionObs );
hgs
parents:
diff changeset
    85
    CleanupStack::PushL( aMsvSession );  //2nd push
hgs
parents:
diff changeset
    86
    }
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    89
// CreateMsvSessionLC  Creates MSV session to selected destination
hgs
parents:
diff changeset
    90
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    91
//
hgs
parents:
diff changeset
    92
void TObexUtilsMessageHandler::CreateMsvSessionLC(
hgs
parents:
diff changeset
    93
    CDummySessionObserver* &aSessionObs,
hgs
parents:
diff changeset
    94
    CMsvSession* &aMsvSession,
hgs
parents:
diff changeset
    95
    CMsvEntry* &aDestination,
hgs
parents:
diff changeset
    96
    TMsvId aMsvId)
hgs
parents:
diff changeset
    97
    {
hgs
parents:
diff changeset
    98
    CreateMsvSessionLC(aSessionObs, aMsvSession);
hgs
parents:
diff changeset
    99
    aDestination = aMsvSession->GetEntryL( aMsvId );
hgs
parents:
diff changeset
   100
    CleanupStack::PushL( aDestination );  //3rd push
hgs
parents:
diff changeset
   101
    }
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   104
// GetCenRepKeyIntValueL Gets integer repository value
hgs
parents:
diff changeset
   105
// Returns: Error
hgs
parents:
diff changeset
   106
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   107
//
hgs
parents:
diff changeset
   108
EXPORT_C TInt TObexUtilsMessageHandler::GetCenRepKeyIntValueL(
hgs
parents:
diff changeset
   109
    TUid aRepositoryUid,  // aRepositoryUid Central repository's UID value
hgs
parents:
diff changeset
   110
    TUint32 aId,          // Central repository's ID value
hgs
parents:
diff changeset
   111
    TInt& aVal)           // Returned integer value
hgs
parents:
diff changeset
   112
    {
hgs
parents:
diff changeset
   113
    CRepository* storage = CRepository::NewLC( aRepositoryUid );
hgs
parents:
diff changeset
   114
    TInt retval = storage->Get( aId, aVal );
hgs
parents:
diff changeset
   115
    if (retval != KErrNone)
hgs
parents:
diff changeset
   116
        {
hgs
parents:
diff changeset
   117
        FLOG(_L("[OBEXUTILS]\t GetCenRepKeyIntValueL() Get failed"));
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
    CleanupStack::PopAndDestroy( storage );
hgs
parents:
diff changeset
   120
    return retval;
hgs
parents:
diff changeset
   121
    }
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
// GetCurrentTime Gets current time
hgs
parents:
diff changeset
   125
// Returns: Current time
hgs
parents:
diff changeset
   126
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   127
//
hgs
parents:
diff changeset
   128
TTime TObexUtilsMessageHandler::GetCurrentTime()
hgs
parents:
diff changeset
   129
    {
hgs
parents:
diff changeset
   130
    TTime time;
hgs
parents:
diff changeset
   131
    time.UniversalTime();
hgs
parents:
diff changeset
   132
    return time;
hgs
parents:
diff changeset
   133
    }
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   136
// StoreAsRichTextL Change message content to Richtext
hgs
parents:
diff changeset
   137
// Returns: None.
hgs
parents:
diff changeset
   138
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   139
//
hgs
parents:
diff changeset
   140
void TObexUtilsMessageHandler::StoreAsRichTextL( 
hgs
parents:
diff changeset
   141
    CMsvEntry* aParentEntry,  // A pointer to new message server entry.
hgs
parents:
diff changeset
   142
    RFile& aFile)             // New file to store
hgs
parents:
diff changeset
   143
    {
hgs
parents:
diff changeset
   144
    FLOG(_L("[OBEXUTILS]\t StoreAsRichTextL()"));
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
    TInt fileLength = 0;
hgs
parents:
diff changeset
   147
    User::LeaveIfError( aFile.Size( fileLength ) );
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    // Calculate the number of blocks to read
hgs
parents:
diff changeset
   150
    const TInt blockSize = 128 * 1024;
hgs
parents:
diff changeset
   151
    TInt fullBlockCnt = fileLength / blockSize;
hgs
parents:
diff changeset
   152
    if (fileLength % blockSize > 0)
hgs
parents:
diff changeset
   153
        {
hgs
parents:
diff changeset
   154
        fullBlockCnt++;
hgs
parents:
diff changeset
   155
        }
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
    CRichText* richText = ConstructRichTextLC(); // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
    RBuf8 buffer8;
hgs
parents:
diff changeset
   160
    CleanupClosePushL(buffer8);  // 4th push
hgs
parents:
diff changeset
   161
    buffer8.CreateL( blockSize );
hgs
parents:
diff changeset
   162
    RBuf buffer16;
hgs
parents:
diff changeset
   163
    CleanupClosePushL(buffer16); // 5th push
hgs
parents:
diff changeset
   164
    buffer16.CreateL(blockSize);
hgs
parents:
diff changeset
   165
    
hgs
parents:
diff changeset
   166
    // Read the file into buffer in small chunks  
hgs
parents:
diff changeset
   167
    TInt readBytes = 0;
hgs
parents:
diff changeset
   168
    for (TInt i = 0; i < fullBlockCnt; ++i)
hgs
parents:
diff changeset
   169
        {
hgs
parents:
diff changeset
   170
        User::LeaveIfError( aFile.Read( buffer8 ) );
hgs
parents:
diff changeset
   171
    
hgs
parents:
diff changeset
   172
        // In order for Bio to understand 8-bit binary data, 
hgs
parents:
diff changeset
   173
        // it needs to be stored in wide rich text object
hgs
parents:
diff changeset
   174
        // in the low byte of each word with the upper byte as 0.
hgs
parents:
diff changeset
   175
        // Do not use UTF8, just convert 8-bit to 16-bit.  
hgs
parents:
diff changeset
   176
        buffer16.Copy( buffer8 );
hgs
parents:
diff changeset
   177
        
hgs
parents:
diff changeset
   178
        richText->InsertL(readBytes, buffer16);
hgs
parents:
diff changeset
   179
        readBytes += buffer8.Length();
hgs
parents:
diff changeset
   180
        }
hgs
parents:
diff changeset
   181
    CleanupStack::PopAndDestroy(2, &buffer8);
hgs
parents:
diff changeset
   182
    // -2 pop: free unused memory before StoreBodyTextL()
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    CMsvStore* parentStore = aParentEntry->EditStoreL();
hgs
parents:
diff changeset
   185
    CleanupStack::PushL(parentStore);   // 4th push
hgs
parents:
diff changeset
   186
    parentStore->StoreBodyTextL(*richText);
hgs
parents:
diff changeset
   187
    parentStore->CommitL();
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
    CleanupStack::PopAndDestroy(4);  // parentStore, richText, richParaFormatLayer,
hgs
parents:
diff changeset
   190
                                     // richCharFormatLayer
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
    FLOG(_L("[OBEXUTILS]\t StoreAsRichTextL() completed"));
hgs
parents:
diff changeset
   193
    }
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   196
// UpdateAttachmentInformationL Add the obex object as a file attachment.
hgs
parents:
diff changeset
   197
// Returns: None.
hgs
parents:
diff changeset
   198
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   199
//
hgs
parents:
diff changeset
   200
void TObexUtilsMessageHandler::UpdateAttachmentInformationL(
hgs
parents:
diff changeset
   201
    TReceivedData& aRecData,      // The obex received data
hgs
parents:
diff changeset
   202
    CMsvEntry* aAttachEntry,      // Attachment entry
hgs
parents:
diff changeset
   203
    CMsvAttachment* aAttachInfo,  // Attachment information
hgs
parents:
diff changeset
   204
    CMsvStore* aStore)            // Message store (attachment)
hgs
parents:
diff changeset
   205
    {
hgs
parents:
diff changeset
   206
    FLOG(_L("[OBEXUTILS]\t UpdateAttachmentInformationL()"));
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
    TMsvEntry attachTEntry = aAttachEntry->Entry();
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
    SetDetailsLC(attachTEntry.iDescription, aAttachInfo->MimeType());
hgs
parents:
diff changeset
   211
    attachTEntry.iSize = aRecData.bytesReceived;
hgs
parents:
diff changeset
   212
    attachTEntry.iDate = aRecData.recTime;
hgs
parents:
diff changeset
   213
    aAttachEntry->ChangeL(attachTEntry);  // Save properties.
hgs
parents:
diff changeset
   214
    CleanupStack::PopAndDestroy(); // unicode in SetDetailsLC
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
    aAttachInfo->SetSize(aRecData.bytesReceived);
hgs
parents:
diff changeset
   217
    aAttachInfo->SetAttachmentNameL(aRecData.msgName);
hgs
parents:
diff changeset
   218
    aAttachInfo->SetComplete(ETrue);
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
    aStore->AttachmentManagerExtensionsL().ModifyAttachmentInfoL(aAttachInfo);
hgs
parents:
diff changeset
   221
    
hgs
parents:
diff changeset
   222
    FLOG(_L("[OBEXUTILS]\t UpdateAttachmentInformation() completed"));
hgs
parents:
diff changeset
   223
    }
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   226
// FinaliseMessageL Save the size of all the attachments and make visible.
hgs
parents:
diff changeset
   227
// Returns: None.
hgs
parents:
diff changeset
   228
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   229
//
hgs
parents:
diff changeset
   230
void TObexUtilsMessageHandler::FinaliseMessageL(
hgs
parents:
diff changeset
   231
    CMsvEntry* aParentEntry,  // Parent entry
hgs
parents:
diff changeset
   232
    TReceivedData& aRecData,  // The obex received data
hgs
parents:
diff changeset
   233
    CMsvStore* aStore,        // Attachment's store
hgs
parents:
diff changeset
   234
    TBool aIsBioMsg)          // Is BIO message?
hgs
parents:
diff changeset
   235
    {
hgs
parents:
diff changeset
   236
    FLOG(_L("[OBEXUTILS]\t FinaliseMessageL()"));
hgs
parents:
diff changeset
   237
    // Save the size of all the attachment & make visible.   
hgs
parents:
diff changeset
   238
    TMsvEntry parentTEntry = aParentEntry->Entry();
hgs
parents:
diff changeset
   239
    parentTEntry.iDate = GetCurrentTime();
hgs
parents:
diff changeset
   240
    parentTEntry.iSize = aRecData.bytesReceived;
hgs
parents:
diff changeset
   241
    parentTEntry.SetUnread(ETrue);
hgs
parents:
diff changeset
   242
    
hgs
parents:
diff changeset
   243
    // Saved OK. Make the entry visible and flag it as complete.
hgs
parents:
diff changeset
   244
    parentTEntry.SetVisible(ETrue);                   // visible
hgs
parents:
diff changeset
   245
    parentTEntry.SetInPreparation(EFalse);            // complete
hgs
parents:
diff changeset
   246
    if (!aIsBioMsg)
hgs
parents:
diff changeset
   247
        {
hgs
parents:
diff changeset
   248
        parentTEntry.iDescription.Set(aRecData.msgName);  // "Subject"
hgs
parents:
diff changeset
   249
        }
hgs
parents:
diff changeset
   250
    aParentEntry->ChangeL(parentTEntry);              // commit changes
hgs
parents:
diff changeset
   251
hgs
parents:
diff changeset
   252
    aStore->CommitL();
hgs
parents:
diff changeset
   253
    
hgs
parents:
diff changeset
   254
    FLOG(_L("[OBEXUTILS]\t FinaliseMessageL() completed"));
hgs
parents:
diff changeset
   255
    }
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   258
// FinaliseMessageL Save the size of all the attachments and make visible.
hgs
parents:
diff changeset
   259
// for Saving file received via BT/IR directly to file system.
hgs
parents:
diff changeset
   260
// Returns: None.
hgs
parents:
diff changeset
   261
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   262
//
hgs
parents:
diff changeset
   263
void TObexUtilsMessageHandler::FinaliseMessageL(
hgs
parents:
diff changeset
   264
    CMsvEntry* aParentEntry,
hgs
parents:
diff changeset
   265
    CMsvStore* aStore,
hgs
parents:
diff changeset
   266
    TEntry& aFileEntry,
hgs
parents:
diff changeset
   267
    TParse& aFileNameParser)
hgs
parents:
diff changeset
   268
    {
hgs
parents:
diff changeset
   269
    FLOG(_L("[OBEXUTILS]\t FinaliseMessageL() new "));
hgs
parents:
diff changeset
   270
    
hgs
parents:
diff changeset
   271
    // Save the size of all the attachment & make visible.
hgs
parents:
diff changeset
   272
    TMsvEntry parentTEntry = aParentEntry->Entry();
hgs
parents:
diff changeset
   273
    parentTEntry.iDate = GetCurrentTime();
hgs
parents:
diff changeset
   274
    parentTEntry.iSize = aFileEntry.iSize;  
hgs
parents:
diff changeset
   275
    // Saved OK. Make the entry visible and flag it as complete.
hgs
parents:
diff changeset
   276
    parentTEntry.SetVisible(ETrue);                   // visible
hgs
parents:
diff changeset
   277
    parentTEntry.SetUnread(ETrue);
hgs
parents:
diff changeset
   278
    parentTEntry.SetInPreparation(EFalse);            // complete
hgs
parents:
diff changeset
   279
    parentTEntry.iDescription.Set(aFileNameParser.FullName());        // "Subject" 
hgs
parents:
diff changeset
   280
    aParentEntry->ChangeL(parentTEntry);              // commit changes
hgs
parents:
diff changeset
   281
    aStore->CommitL();
hgs
parents:
diff changeset
   282
    
hgs
parents:
diff changeset
   283
    FLOG(_L("[OBEXUTILS]\t FinaliseMessageL() new completed "));
hgs
parents:
diff changeset
   284
    }
hgs
parents:
diff changeset
   285
hgs
parents:
diff changeset
   286
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   287
// StoreAndUpdateBioMessageL Stores and updates a BIO message
hgs
parents:
diff changeset
   288
// Returns: None.
hgs
parents:
diff changeset
   289
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   290
//
hgs
parents:
diff changeset
   291
void TObexUtilsMessageHandler::StoreAndUpdateBioMessageL(
hgs
parents:
diff changeset
   292
    CBIODatabase* aBioDB,     // Bio database
hgs
parents:
diff changeset
   293
    TUid aBioMsgId,           // Bio message ID
hgs
parents:
diff changeset
   294
    CMsvEntry* parentEntry,   // Parent message entry
hgs
parents:
diff changeset
   295
    RFile& aFile)             // File to attachment
hgs
parents:
diff changeset
   296
    {
hgs
parents:
diff changeset
   297
    FLOG(_L("[OBEXUTILS]\t StoreAndUpdateBioMessageL()"));
hgs
parents:
diff changeset
   298
    
hgs
parents:
diff changeset
   299
    TInt index;
hgs
parents:
diff changeset
   300
    aBioDB->GetBioIndexWithMsgIDL(aBioMsgId, index);
hgs
parents:
diff changeset
   301
    
hgs
parents:
diff changeset
   302
    StoreAsRichTextL( parentEntry, aFile );
hgs
parents:
diff changeset
   303
    
hgs
parents:
diff changeset
   304
    TMsvEntry parentTEntry = parentEntry->Entry();
hgs
parents:
diff changeset
   305
    parentTEntry.iMtm = KUidBIOMessageTypeMtm;
hgs
parents:
diff changeset
   306
    parentTEntry.iServiceId = KMsvLocalServiceIndexEntryId;  
hgs
parents:
diff changeset
   307
    parentTEntry.iBioType = aBioMsgId.iUid;
51
625f43ae9362 201031_05
hgs
parents: 47
diff changeset
   308
    parentTEntry.iMtmData1 = KUidMsgTypeBtTInt32;
32
hgs
parents:
diff changeset
   309
    parentTEntry.iDescription.Set(aBioDB->BifReader(index).Description());
hgs
parents:
diff changeset
   310
    parentEntry->ChangeL(parentTEntry);
hgs
parents:
diff changeset
   311
    
hgs
parents:
diff changeset
   312
    FLOG(_L("[OBEXUTILS]\t StoreAndUpdateBioMessageL() completed"));
hgs
parents:
diff changeset
   313
    }
hgs
parents:
diff changeset
   314
hgs
parents:
diff changeset
   315
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   316
// RecogniseObjectsL Recognised objects if no type field has been given.
hgs
parents:
diff changeset
   317
// Returns: None.
hgs
parents:
diff changeset
   318
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   319
//
hgs
parents:
diff changeset
   320
void TObexUtilsMessageHandler::RecogniseObjectsL(
hgs
parents:
diff changeset
   321
    TFileName& aFileName,
hgs
parents:
diff changeset
   322
    CMsvAttachment* aAttachInfo)  // Attachment information
hgs
parents:
diff changeset
   323
    {
hgs
parents:
diff changeset
   324
    FLOG(_L("[OBEXUTILS]\t RecogniseObjectsL()"));
hgs
parents:
diff changeset
   325
hgs
parents:
diff changeset
   326
    TPtrC8 mimeType;
hgs
parents:
diff changeset
   327
    RApaLsSession lsSess;
hgs
parents:
diff changeset
   328
    User::LeaveIfError( lsSess.Connect() );
hgs
parents:
diff changeset
   329
    CleanupClosePushL(lsSess);
hgs
parents:
diff changeset
   330
    TDataType appDataType;
hgs
parents:
diff changeset
   331
    TUid appUid;
hgs
parents:
diff changeset
   332
    if (lsSess.AppForDocument(aFileName, appUid, appDataType) == KErrNone)
hgs
parents:
diff changeset
   333
        {
hgs
parents:
diff changeset
   334
        mimeType.Set(appDataType.Des8());
hgs
parents:
diff changeset
   335
        }
hgs
parents:
diff changeset
   336
    else
hgs
parents:
diff changeset
   337
        {
hgs
parents:
diff changeset
   338
        // Don't trust on sender's MIME type here. Just set to empty.
hgs
parents:
diff changeset
   339
        mimeType.Set(KNullDesC8);
hgs
parents:
diff changeset
   340
        FLOG(_L("[OBEXUTILS]\t RecogniseObjectsL() MIME check failed"));
hgs
parents:
diff changeset
   341
        }
hgs
parents:
diff changeset
   342
    CleanupStack::PopAndDestroy();  // lsSess
hgs
parents:
diff changeset
   343
    HBufC* buf16 = HBufC::NewLC(mimeType.Length());
hgs
parents:
diff changeset
   344
    buf16->Des().Copy(mimeType);
hgs
parents:
diff changeset
   345
    TPtrC mimeType16(buf16->Des());
hgs
parents:
diff changeset
   346
    CleanupStack::PopAndDestroy();   //   buf16
hgs
parents:
diff changeset
   347
    
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   348
    CUpdateMusicCollection* updateMusicCollection = CUpdateMusicCollection::NewL();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   349
    CleanupStack::PushL(updateMusicCollection);    
32
hgs
parents:
diff changeset
   350
    if (updateMusicCollection->isSupported(mimeType16))
hgs
parents:
diff changeset
   351
        {
hgs
parents:
diff changeset
   352
        updateMusicCollection->addToCollectionL(aFileName);
hgs
parents:
diff changeset
   353
        }
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   354
    CleanupStack::PopAndDestroy();  // updateMusicCollection
32
hgs
parents:
diff changeset
   355
    
hgs
parents:
diff changeset
   356
    aAttachInfo->SetMimeTypeL( mimeType );
hgs
parents:
diff changeset
   357
    
hgs
parents:
diff changeset
   358
    FLOG(_L("[OBEXUTILS]\t RecogniseObjectsL() completed"));
hgs
parents:
diff changeset
   359
    }
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   362
// SaveMimeAndGetBioLC Saves MIME type and gets BIO database for that MIME
hgs
parents:
diff changeset
   363
// Returns: BIO database if BIO message
hgs
parents:
diff changeset
   364
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   365
//
hgs
parents:
diff changeset
   366
CBIODatabase* TObexUtilsMessageHandler::SaveMimeAndGetBioLC(
hgs
parents:
diff changeset
   367
    TFileName& aFileName,
hgs
parents:
diff changeset
   368
    RFs& aFsSess,                 // File session
hgs
parents:
diff changeset
   369
    CMsvAttachment* aAttachInfo,  // Attachment information
hgs
parents:
diff changeset
   370
    TUid &aBioMsgId)              // BIO message ID for data
hgs
parents:
diff changeset
   371
    {
hgs
parents:
diff changeset
   372
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveMimeAndGetBioLC()"));
hgs
parents:
diff changeset
   373
    
hgs
parents:
diff changeset
   374
    RecogniseObjectsL( aFileName, aAttachInfo );
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
    // For attachments / BIO check.
hgs
parents:
diff changeset
   377
    CBIODatabase* bioDB = CBIODatabase::NewLC( aFsSess );  // 1st push
hgs
parents:
diff changeset
   378
    
hgs
parents:
diff changeset
   379
    // Run through the data objects, seeing if they can be accepted by BIO.
hgs
parents:
diff changeset
   380
    // Check if they are bio objects
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
    TBioMsgIdText bioMessageIdText;
hgs
parents:
diff changeset
   383
    SetBioDataTextL( bioMessageIdText, aAttachInfo->MimeType() );
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
    // Remove any zero termination on mime type
hgs
parents:
diff changeset
   386
    //
hgs
parents:
diff changeset
   387
    TInt zeroTermination = bioMessageIdText.Locate( TChar(0) ); 
hgs
parents:
diff changeset
   388
    
hgs
parents:
diff changeset
   389
    if ( zeroTermination != KErrNotFound )
hgs
parents:
diff changeset
   390
        {
hgs
parents:
diff changeset
   391
        bioMessageIdText.SetLength( zeroTermination );
hgs
parents:
diff changeset
   392
        }
hgs
parents:
diff changeset
   393
hgs
parents:
diff changeset
   394
    TInt bioMsgErr = bioDB->IsBioMessageL( EBioMsgIdIana, bioMessageIdText, NULL, aBioMsgId );
hgs
parents:
diff changeset
   395
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveMimeAndGetBioLC() completed"));
hgs
parents:
diff changeset
   396
    if (bioMsgErr != KErrNone)
hgs
parents:
diff changeset
   397
        {
hgs
parents:
diff changeset
   398
        return NULL;
hgs
parents:
diff changeset
   399
        }
hgs
parents:
diff changeset
   400
    return bioDB;
hgs
parents:
diff changeset
   401
    }
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
   404
hgs
parents:
diff changeset
   405
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   406
// CreateInboxAttachmentL Creates inbox entry and attachment for it
hgs
parents:
diff changeset
   407
// If this leaves, it means the entry and obex object have already been deleted.
hgs
parents:
diff changeset
   408
// In this case aMsvIdParent has been set to zero.
hgs
parents:
diff changeset
   409
// Returns: None.
hgs
parents:
diff changeset
   410
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   411
//
hgs
parents:
diff changeset
   412
EXPORT_C void TObexUtilsMessageHandler::CreateInboxAttachmentL(
hgs
parents:
diff changeset
   413
    CObexBufObject* &aBufObject,  // Obex object
hgs
parents:
diff changeset
   414
    const TUid aMtmId,            // Mtm ID of the message
hgs
parents:
diff changeset
   415
    TMsvId &aMsvIdParent,         // Message ID of the parent message entry
hgs
parents:
diff changeset
   416
    RFile &aFile)                 // File to the attachment
hgs
parents:
diff changeset
   417
    {
hgs
parents:
diff changeset
   418
    TMsvId msvId = 0;
hgs
parents:
diff changeset
   419
    TRAPD(retTrap, DoCreateInboxAttachmentL(aMtmId, msvId, aFile,KNullDesC))
hgs
parents:
diff changeset
   420
    if (retTrap != KErrNone)
hgs
parents:
diff changeset
   421
        {
hgs
parents:
diff changeset
   422
        aMsvIdParent = 0;
hgs
parents:
diff changeset
   423
        if (msvId)
hgs
parents:
diff changeset
   424
            {
hgs
parents:
diff changeset
   425
            RemoveInboxEntriesL(aBufObject, msvId);
hgs
parents:
diff changeset
   426
            }
hgs
parents:
diff changeset
   427
        User::Leave(retTrap);
hgs
parents:
diff changeset
   428
        }
hgs
parents:
diff changeset
   429
    aMsvIdParent = msvId;
hgs
parents:
diff changeset
   430
    }
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   433
// CreateInboxAttachmentL Creates inbox entry and attachment for it
hgs
parents:
diff changeset
   434
// If this leaves, it means the entry and obex object have already been deleted.
hgs
parents:
diff changeset
   435
// In this case aMsvIdParent has been set to zero.
hgs
parents:
diff changeset
   436
// Returns: None.
hgs
parents:
diff changeset
   437
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   438
//
hgs
parents:
diff changeset
   439
EXPORT_C void TObexUtilsMessageHandler::CreateInboxAttachmentL(
hgs
parents:
diff changeset
   440
    CObexBufObject* &aBufObject,  // Obex object
hgs
parents:
diff changeset
   441
    const TUid aMtmId,            // Mtm ID of the message
hgs
parents:
diff changeset
   442
    TMsvId &aMsvIdParent,         // Message ID of the parent message entry
hgs
parents:
diff changeset
   443
    RFile &aFile,                 // File to the attachment
hgs
parents:
diff changeset
   444
    const TDesC& aRemoteBluetoothName)  // bluetooth name of remote device
hgs
parents:
diff changeset
   445
    {
hgs
parents:
diff changeset
   446
    TMsvId msvId = 0;
hgs
parents:
diff changeset
   447
    TRAPD(retTrap, DoCreateInboxAttachmentL(aMtmId, msvId, aFile,aRemoteBluetoothName))
hgs
parents:
diff changeset
   448
    if (retTrap != KErrNone)
hgs
parents:
diff changeset
   449
        {
hgs
parents:
diff changeset
   450
        aMsvIdParent = 0;
hgs
parents:
diff changeset
   451
        if (msvId)
hgs
parents:
diff changeset
   452
            {
hgs
parents:
diff changeset
   453
            RemoveInboxEntriesL(aBufObject, msvId);
hgs
parents:
diff changeset
   454
            }
hgs
parents:
diff changeset
   455
        User::Leave(retTrap);
hgs
parents:
diff changeset
   456
        }
hgs
parents:
diff changeset
   457
    aMsvIdParent = msvId;
hgs
parents:
diff changeset
   458
    }
hgs
parents:
diff changeset
   459
hgs
parents:
diff changeset
   460
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   461
// DoCreateInboxAttachmentL Creates inbox entry and attachment for it (private)
hgs
parents:
diff changeset
   462
// Returns: None.
hgs
parents:
diff changeset
   463
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   464
//
hgs
parents:
diff changeset
   465
void TObexUtilsMessageHandler::DoCreateInboxAttachmentL(
hgs
parents:
diff changeset
   466
    const TUid aMtmId,     // Mtm ID of the message
hgs
parents:
diff changeset
   467
    TMsvId &aMsvIdParent,  // Message ID of the parent message entry
hgs
parents:
diff changeset
   468
    RFile &aFile,          // File to the attachment
hgs
parents:
diff changeset
   469
    const TDesC& aRemoteBluetoothName)  // bluetooth name of remote device
hgs
parents:
diff changeset
   470
    {
hgs
parents:
diff changeset
   471
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateInboxAttachmentL()"));
hgs
parents:
diff changeset
   472
    
hgs
parents:
diff changeset
   473
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
   474
    CMsvSession* msvSession;
hgs
parents:
diff changeset
   475
    CMsvEntry* inbox;
hgs
parents:
diff changeset
   476
    CreateMsvSessionLC(sessionObs, msvSession, inbox, KMsvGlobalInBoxIndexEntryId);
hgs
parents:
diff changeset
   477
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
   478
hgs
parents:
diff changeset
   479
    TBuf<KObexUtilsMaxCharToFromField> toFrom;
hgs
parents:
diff changeset
   480
42
hgs
parents: 32
diff changeset
   481
    // todo @ QT migration: load from string id for localization
32
hgs
parents:
diff changeset
   482
    if (aMtmId == KUidMsgTypeBt)
hgs
parents:
diff changeset
   483
        {
42
hgs
parents: 32
diff changeset
   484
        _LIT(KBluetoothMsg, "Bluetooth message");
hgs
parents: 32
diff changeset
   485
        toFrom.Copy(KBluetoothMsg);
32
hgs
parents:
diff changeset
   486
        }
hgs
parents:
diff changeset
   487
    else
hgs
parents:
diff changeset
   488
        {
42
hgs
parents: 32
diff changeset
   489
        _LIT(KInfraredMsg, "Infrared message");
hgs
parents: 32
diff changeset
   490
        toFrom.Copy(KInfraredMsg);    
32
hgs
parents:
diff changeset
   491
        }
hgs
parents:
diff changeset
   492
    
hgs
parents:
diff changeset
   493
    TMsvEntry parentTEntry;
hgs
parents:
diff changeset
   494
    parentTEntry.iMtm = aMtmId;
hgs
parents:
diff changeset
   495
    parentTEntry.SetVisible(EFalse); // Make invisible..
hgs
parents:
diff changeset
   496
    parentTEntry.SetUnread(ETrue);
hgs
parents:
diff changeset
   497
    
hgs
parents:
diff changeset
   498
    // ...and in preparation to make sure it gets cleaned up on errors.
hgs
parents:
diff changeset
   499
    //
hgs
parents:
diff changeset
   500
    parentTEntry.SetInPreparation(ETrue); 
hgs
parents:
diff changeset
   501
    parentTEntry.iType = KUidMsvMessageEntry;
hgs
parents:
diff changeset
   502
    parentTEntry.iServiceId = KMsvUnknownServiceIndexEntryId;
hgs
parents:
diff changeset
   503
    // iDate & iSize will be set later
hgs
parents:
diff changeset
   504
    if ( aRemoteBluetoothName.Length() > 0 )
hgs
parents:
diff changeset
   505
        {
hgs
parents:
diff changeset
   506
        parentTEntry.iDetails.Set(aRemoteBluetoothName);
hgs
parents:
diff changeset
   507
        }
hgs
parents:
diff changeset
   508
    else
hgs
parents:
diff changeset
   509
        {
hgs
parents:
diff changeset
   510
        parentTEntry.iDetails.Set(toFrom);
hgs
parents:
diff changeset
   511
        }
hgs
parents:
diff changeset
   512
    inbox->CreateL(parentTEntry);
hgs
parents:
diff changeset
   513
    
hgs
parents:
diff changeset
   514
    aMsvIdParent = parentTEntry.Id();
hgs
parents:
diff changeset
   515
    
hgs
parents:
diff changeset
   516
    // Create attachment for the inbox entry
hgs
parents:
diff changeset
   517
    
hgs
parents:
diff changeset
   518
    TMsvEntry attachTEntry;
hgs
parents:
diff changeset
   519
    attachTEntry.iType      = KUidMsvAttachmentEntry;
hgs
parents:
diff changeset
   520
    attachTEntry.iServiceId = KMsvUnknownServiceIndexEntryId;   
hgs
parents:
diff changeset
   521
    attachTEntry.iMtm       = aMtmId;
hgs
parents:
diff changeset
   522
    
hgs
parents:
diff changeset
   523
    CMsvEntry* parentEntry = msvSession->GetEntryL(aMsvIdParent);
hgs
parents:
diff changeset
   524
    CleanupStack::PushL(parentEntry);  // 4th push
hgs
parents:
diff changeset
   525
    parentEntry->CreateL(attachTEntry);  // create attachment as child of parent
hgs
parents:
diff changeset
   526
    
hgs
parents:
diff changeset
   527
    // create the v2 attachment, save RFile
hgs
parents:
diff changeset
   528
    
hgs
parents:
diff changeset
   529
    CMsvEntry* attachEntry = msvSession->GetEntryL(attachTEntry.Id());
hgs
parents:
diff changeset
   530
    CleanupStack::PushL(attachEntry);  // 5th push
hgs
parents:
diff changeset
   531
    
hgs
parents:
diff changeset
   532
    CMsvStore* store = attachEntry->EditStoreL();
hgs
parents:
diff changeset
   533
    CleanupStack::PushL(store);  // 6th push
hgs
parents:
diff changeset
   534
    CMsvAttachment* attachment = CMsvAttachment::NewL(CMsvAttachment::EMsvFile);
hgs
parents:
diff changeset
   535
    CleanupStack::PushL(attachment);  // 7th push
hgs
parents:
diff changeset
   536
     
hgs
parents:
diff changeset
   537
    store->AttachmentManagerExtensionsL().CreateAttachmentL(_L("Unnamed"), aFile, attachment);
hgs
parents:
diff changeset
   538
    CleanupStack::Pop(attachment);
hgs
parents:
diff changeset
   539
    store->CommitL();
hgs
parents:
diff changeset
   540
    // CommitL() required here otherwise EditStoreL() will fail in SaveObjToInbox()
hgs
parents:
diff changeset
   541
    
hgs
parents:
diff changeset
   542
    CleanupStack::PopAndDestroy(6);
hgs
parents:
diff changeset
   543
    // store, attachEntry, parentEntry, inbox, msvSession, sessionObs
hgs
parents:
diff changeset
   544
hgs
parents:
diff changeset
   545
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateInboxAttachmentL() completed"));
hgs
parents:
diff changeset
   546
    }
hgs
parents:
diff changeset
   547
hgs
parents:
diff changeset
   548
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   549
// CObexUtilsMessageHandler::RemoveInboxEntriesL
hgs
parents:
diff changeset
   550
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   551
EXPORT_C void TObexUtilsMessageHandler::RemoveInboxEntriesL(
hgs
parents:
diff changeset
   552
    CObexBufObject* &aBufObject, // Obex object
hgs
parents:
diff changeset
   553
    TMsvId aMsvIdParent)         // Message ID of the parent message entry
hgs
parents:
diff changeset
   554
    {
hgs
parents:
diff changeset
   555
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveInboxEntriesL()"));
hgs
parents:
diff changeset
   556
    
hgs
parents:
diff changeset
   557
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
   558
    CMsvSession* msvSession;
hgs
parents:
diff changeset
   559
    CMsvEntry* inbox;
hgs
parents:
diff changeset
   560
    CreateMsvSessionLC(sessionObs, msvSession, inbox, KMsvGlobalInBoxIndexEntryId);
hgs
parents:
diff changeset
   561
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
   562
    
hgs
parents:
diff changeset
   563
    // Close file
hgs
parents:
diff changeset
   564
    
hgs
parents:
diff changeset
   565
    RemoveObexBuffer(aBufObject);
hgs
parents:
diff changeset
   566
    
hgs
parents:
diff changeset
   567
    // Delete parent and descendants
hgs
parents:
diff changeset
   568
    if ( aMsvIdParent )
hgs
parents:
diff changeset
   569
        {
hgs
parents:
diff changeset
   570
        inbox->DeleteL(aMsvIdParent);
hgs
parents:
diff changeset
   571
        }
hgs
parents:
diff changeset
   572
    
hgs
parents:
diff changeset
   573
    CleanupStack::PopAndDestroy(3);
hgs
parents:
diff changeset
   574
    
hgs
parents:
diff changeset
   575
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveInboxEntriesL() completed"));
hgs
parents:
diff changeset
   576
    }
hgs
parents:
diff changeset
   577
hgs
parents:
diff changeset
   578
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   579
// CObexUtilsMessageHandler::SaveObjToInboxL
hgs
parents:
diff changeset
   580
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   581
//
hgs
parents:
diff changeset
   582
EXPORT_C void TObexUtilsMessageHandler::SaveObjToInboxL( 
hgs
parents:
diff changeset
   583
    CObexBufObject* /*aReceivedObject*/, const TDesC16& /*aPath*/, const TUid /*aMtmID*/ )
hgs
parents:
diff changeset
   584
    {
hgs
parents:
diff changeset
   585
    }
hgs
parents:
diff changeset
   586
hgs
parents:
diff changeset
   587
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   588
// CObexUtilsMessageHandler::SaveObjToInboxL
hgs
parents:
diff changeset
   589
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   590
//
hgs
parents:
diff changeset
   591
EXPORT_C void TObexUtilsMessageHandler::SaveObjToInboxL(
hgs
parents:
diff changeset
   592
    CObexBufObject* &aReceivedObject, // Obex object
hgs
parents:
diff changeset
   593
    RFile  &aFile,         
hgs
parents:
diff changeset
   594
    TMsvId aMsvIdParent)              // Message ID of the parent message entry
hgs
parents:
diff changeset
   595
    {
hgs
parents:
diff changeset
   596
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL()"));
hgs
parents:
diff changeset
   597
hgs
parents:
diff changeset
   598
    // Open session. 
hgs
parents:
diff changeset
   599
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
   600
    CMsvSession* msvSession;
hgs
parents:
diff changeset
   601
    CreateMsvSessionLC(sessionObs, msvSession);  // 1st, 2nd push
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
    CMsvEntry* parentEntry = msvSession->GetEntryL(aMsvIdParent);
hgs
parents:
diff changeset
   604
    CleanupStack::PushL( parentEntry );  // 3rd push
hgs
parents:
diff changeset
   605
hgs
parents:
diff changeset
   606
#ifdef __BT_SAP
hgs
parents:
diff changeset
   607
    if(CSapVMessageParser::HandleMessageL(aReceivedObject, parentEntry->Entry().iMtm,
hgs
parents:
diff changeset
   608
        aFile, msvSession, GetCurrentTime()))
hgs
parents:
diff changeset
   609
        {
hgs
parents:
diff changeset
   610
        RemoveObexBuffer(aReceivedObject);
hgs
parents:
diff changeset
   611
        CMsvEntry* inbox = msvSession->GetEntryL( KMsvGlobalInBoxIndexEntryId );
hgs
parents:
diff changeset
   612
        CleanupStack::PushL( inbox );         //4th push
hgs
parents:
diff changeset
   613
        inbox->DeleteL(aMsvIdParent);
hgs
parents:
diff changeset
   614
        // Close session etc.
hgs
parents:
diff changeset
   615
        CleanupStack::PopAndDestroy(4, sessionObs);  // inbox, parentEntry, session, sessionObs
hgs
parents:
diff changeset
   616
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() completed"));
hgs
parents:
diff changeset
   617
        return;
hgs
parents:
diff changeset
   618
        }
hgs
parents:
diff changeset
   619
#endif // __BT_SAP
hgs
parents:
diff changeset
   620
    CMsvEntry* attachEntry = msvSession->GetEntryL(((*parentEntry)[0]).Id());
hgs
parents:
diff changeset
   621
    CleanupStack::PushL(attachEntry); // 4th push
hgs
parents:
diff changeset
   622
hgs
parents:
diff changeset
   623
    CMsvStore* store = attachEntry->EditStoreL();
hgs
parents:
diff changeset
   624
    CleanupStack::PushL( store );  // 5th push
hgs
parents:
diff changeset
   625
hgs
parents:
diff changeset
   626
    // Collect obex received data before obex buffer deletion
hgs
parents:
diff changeset
   627
hgs
parents:
diff changeset
   628
    TReceivedData receivedData;
hgs
parents:
diff changeset
   629
    receivedData.bytesReceived = aReceivedObject->BytesReceived();
hgs
parents:
diff changeset
   630
    receivedData.recTime = aReceivedObject->Time();
hgs
parents:
diff changeset
   631
hgs
parents:
diff changeset
   632
    RFs& fsSess = msvSession->FileSession();
hgs
parents:
diff changeset
   633
    receivedData.msgName = aReceivedObject->Name();
hgs
parents:
diff changeset
   634
    MakeValidFileName(fsSess, receivedData.msgName);
hgs
parents:
diff changeset
   635
hgs
parents:
diff changeset
   636
    // Rename attachment for MIME type checking
hgs
parents:
diff changeset
   637
    
hgs
parents:
diff changeset
   638
    RemoveObexBuffer(aReceivedObject);
hgs
parents:
diff changeset
   639
    store->AttachmentManagerExtensionsL().RenameAttachmentL(0, receivedData.msgName);
hgs
parents:
diff changeset
   640
    RFile newFile = store->AttachmentManagerL().GetAttachmentFileL(0);
hgs
parents:
diff changeset
   641
    CleanupClosePushL(newFile);  // 6th push
hgs
parents:
diff changeset
   642
    
hgs
parents:
diff changeset
   643
    // RenameAttachmentL() modified attachment info, so read it now
hgs
parents:
diff changeset
   644
    
hgs
parents:
diff changeset
   645
    CMsvAttachment* attachInfo = store->AttachmentManagerL().GetAttachmentInfoL(0);
hgs
parents:
diff changeset
   646
    CleanupStack::PushL( attachInfo ); // 7th push
hgs
parents:
diff changeset
   647
hgs
parents:
diff changeset
   648
    TUid bioMsgId;  // SaveMimeAndGetBioLC modifies this
hgs
parents:
diff changeset
   649
    TFileName fileName;
hgs
parents:
diff changeset
   650
    newFile.FullName(fileName);
hgs
parents:
diff changeset
   651
    CBIODatabase* bioDB = SaveMimeAndGetBioLC( fileName, fsSess, attachInfo, bioMsgId );
hgs
parents:
diff changeset
   652
    // 8th push
hgs
parents:
diff changeset
   653
    if (bioDB)  // bio message
hgs
parents:
diff changeset
   654
        {
hgs
parents:
diff changeset
   655
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() BIO"));
hgs
parents:
diff changeset
   656
        StoreAndUpdateBioMessageL( bioDB, bioMsgId, parentEntry, newFile );
hgs
parents:
diff changeset
   657
        FinaliseMessageL(parentEntry, receivedData, store, ETrue);
hgs
parents:
diff changeset
   658
        TMsvId attachId = attachEntry->EntryId();
hgs
parents:
diff changeset
   659
        CleanupStack::PopAndDestroy(5);  // bioDB, attachInfo, newFile (close),
hgs
parents:
diff changeset
   660
                                         // store, attachEntry
hgs
parents:
diff changeset
   661
        // PopAndDestroying here because open store locks the entry,
hgs
parents:
diff changeset
   662
        // it can be deleted only after destroying the store pointer
hgs
parents:
diff changeset
   663
        parentEntry->DeleteL(attachId);  // invalidate unused attachment
hgs
parents:
diff changeset
   664
        CleanupStack::PopAndDestroy(3);  // parentEntry, msvSession, sessionObs
hgs
parents:
diff changeset
   665
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() BIO completed"));
hgs
parents:
diff changeset
   666
        }
hgs
parents:
diff changeset
   667
    else  // attachment message
hgs
parents:
diff changeset
   668
        {
hgs
parents:
diff changeset
   669
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() Attachment"));
hgs
parents:
diff changeset
   670
        CleanupStack::PopAndDestroy();   // bioDB
hgs
parents:
diff changeset
   671
        UpdateAttachmentInformationL(receivedData, attachEntry, attachInfo, store);
hgs
parents:
diff changeset
   672
        CleanupStack::Pop(attachInfo);   // ownership taken by ModifyAttachmentInfoL()
hgs
parents:
diff changeset
   673
        FinaliseMessageL(parentEntry, receivedData, store, EFalse);
hgs
parents:
diff changeset
   674
        CleanupStack::PopAndDestroy(6);  // newFile (close), store, attachEntry,
hgs
parents:
diff changeset
   675
                                         // parentEntry, msvSession, sessionObs
hgs
parents:
diff changeset
   676
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() Attachment completed"));
hgs
parents:
diff changeset
   677
        }
hgs
parents:
diff changeset
   678
hgs
parents:
diff changeset
   679
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveObjToInboxL() completed"));
hgs
parents:
diff changeset
   680
    }
hgs
parents:
diff changeset
   681
hgs
parents:
diff changeset
   682
hgs
parents:
diff changeset
   683
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   684
// GetCenRepKeyStringValueL Gets integer repository value
hgs
parents:
diff changeset
   685
// Returns: Error
hgs
parents:
diff changeset
   686
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   687
//
hgs
parents:
diff changeset
   688
EXPORT_C TInt TObexUtilsMessageHandler::GetCenRepKeyStringValueL(
hgs
parents:
diff changeset
   689
    TUid aRepositoryUid,  // aRepositoryUid Central repository's UID value
hgs
parents:
diff changeset
   690
    TUint32 aId,          // Central repository's ID value
hgs
parents:
diff changeset
   691
    TDes& aVal)           // Returned String
hgs
parents:
diff changeset
   692
    {
hgs
parents:
diff changeset
   693
    CRepository* storage = CRepository::NewLC( aRepositoryUid );
hgs
parents:
diff changeset
   694
    TInt retval = storage->Get( aId, aVal );
hgs
parents:
diff changeset
   695
    if (retval != KErrNone)
hgs
parents:
diff changeset
   696
        {
hgs
parents:
diff changeset
   697
        FLOG(_L("[OBEXUTILS]\t GetCenRepKeyStringValueL() Get failed"));
hgs
parents:
diff changeset
   698
        }
hgs
parents:
diff changeset
   699
    CleanupStack::PopAndDestroy( storage );
hgs
parents:
diff changeset
   700
    return retval;
hgs
parents:
diff changeset
   701
    }
hgs
parents:
diff changeset
   702
hgs
parents:
diff changeset
   703
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   704
// CreateReceiveBufferL Creates an Obex receive buffer object and RFile object.
hgs
parents:
diff changeset
   705
// Returns: Symbian error code
hgs
parents:
diff changeset
   706
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   707
//
hgs
parents:
diff changeset
   708
hgs
parents:
diff changeset
   709
EXPORT_C TInt TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL(
hgs
parents:
diff changeset
   710
    RFile& aFile,
hgs
parents:
diff changeset
   711
    const TDesC& aPath,
hgs
parents:
diff changeset
   712
    TFileName& aFullName, 
hgs
parents:
diff changeset
   713
    CBufFlat* &aReceiveObject, 
hgs
parents:
diff changeset
   714
    const TInt aBufSize )  
hgs
parents:
diff changeset
   715
    {
hgs
parents:
diff changeset
   716
    
hgs
parents:
diff changeset
   717
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL()"));
hgs
parents:
diff changeset
   718
    
hgs
parents:
diff changeset
   719
    aReceiveObject = CBufFlat::NewL(aBufSize); 
hgs
parents:
diff changeset
   720
    aReceiveObject->ResizeL(aBufSize);
hgs
parents:
diff changeset
   721
    
hgs
parents:
diff changeset
   722
    
hgs
parents:
diff changeset
   723
    RFs rfs;
hgs
parents:
diff changeset
   724
    User::LeaveIfError( rfs.Connect() );
hgs
parents:
diff changeset
   725
    if ( !BaflUtils::FolderExists( rfs, aPath ) )
hgs
parents:
diff changeset
   726
        {
hgs
parents:
diff changeset
   727
        User::LeaveIfError(rfs.MkDirAll(aPath));
hgs
parents:
diff changeset
   728
        }
hgs
parents:
diff changeset
   729
    User::LeaveIfError( aFile.Temp( rfs, aPath, aFullName, EFileWrite) );
hgs
parents:
diff changeset
   730
    // Set temp file  hidden file.
hgs
parents:
diff changeset
   731
    //
hgs
parents:
diff changeset
   732
    TUint setAttMask(0);
hgs
parents:
diff changeset
   733
    TUint clearAttMask(0);
hgs
parents:
diff changeset
   734
    aFile.SetAtt(setAttMask | KEntryAttHidden, clearAttMask);
hgs
parents:
diff changeset
   735
    aFile.Flush();
hgs
parents:
diff changeset
   736
    aFile.Close();
hgs
parents:
diff changeset
   737
    
hgs
parents:
diff changeset
   738
    RFile logFile;
hgs
parents:
diff changeset
   739
    TFileName logFilePath;
hgs
parents:
diff changeset
   740
    TFileName cenRepFolder;
hgs
parents:
diff changeset
   741
    GetCenRepKeyStringValueL(KCRUidBluetoothEngine, KLCReceiveFolder,cenRepFolder);
hgs
parents:
diff changeset
   742
    
hgs
parents:
diff changeset
   743
    logFilePath.Zero();
hgs
parents:
diff changeset
   744
    logFilePath.Append(PathInfo::PhoneMemoryRootPath());
hgs
parents:
diff changeset
   745
    logFilePath.Append(cenRepFolder);
hgs
parents:
diff changeset
   746
    
hgs
parents:
diff changeset
   747
    if ( !BaflUtils::FolderExists(rfs , logFilePath) )
hgs
parents:
diff changeset
   748
        {
hgs
parents:
diff changeset
   749
        User::LeaveIfError(rfs.MkDirAll(logFilePath));
hgs
parents:
diff changeset
   750
        }
hgs
parents:
diff changeset
   751
    logFilePath.Append(_L("log.txt"));
hgs
parents:
diff changeset
   752
    if ( !BaflUtils::FileExists( rfs, logFilePath ))
hgs
parents:
diff changeset
   753
        {
hgs
parents:
diff changeset
   754
        logFile.Create(rfs, logFilePath, EFileWrite);
hgs
parents:
diff changeset
   755
        }
hgs
parents:
diff changeset
   756
    else
hgs
parents:
diff changeset
   757
        {
hgs
parents:
diff changeset
   758
        User::LeaveIfError(logFile.Open(rfs, logFilePath, EFileWrite));
hgs
parents:
diff changeset
   759
        }
hgs
parents:
diff changeset
   760
    
hgs
parents:
diff changeset
   761
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL()    log.txt is created"));
hgs
parents:
diff changeset
   762
    TFileText ft;              
hgs
parents:
diff changeset
   763
    ft.Set(logFile);
hgs
parents:
diff changeset
   764
    ft.Write(aFullName);    // restore tempfilename in logfile
hgs
parents:
diff changeset
   765
hgs
parents:
diff changeset
   766
    // Set log file 
hgs
parents:
diff changeset
   767
    logFile.SetAtt(setAttMask | KEntryAttHidden, clearAttMask);
hgs
parents:
diff changeset
   768
    logFile.Flush();
hgs
parents:
diff changeset
   769
    logFile.Close();
hgs
parents:
diff changeset
   770
    rfs.Close();
hgs
parents:
diff changeset
   771
    
hgs
parents:
diff changeset
   772
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateReceiveBufferAndRFileL() completed"));
hgs
parents:
diff changeset
   773
    
hgs
parents:
diff changeset
   774
    return KErrNone;
hgs
parents:
diff changeset
   775
    }
hgs
parents:
diff changeset
   776
hgs
parents:
diff changeset
   777
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   778
// CObexUtilsMessageHandler::RemoveTemporaryRFileL
hgs
parents:
diff changeset
   779
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   780
//
hgs
parents:
diff changeset
   781
EXPORT_C void TObexUtilsMessageHandler::RemoveTemporaryRFileL ( const TFileName& aFullName )
hgs
parents:
diff changeset
   782
    {
hgs
parents:
diff changeset
   783
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveTemporaryRFileL()"));
hgs
parents:
diff changeset
   784
    RFs rfs;
hgs
parents:
diff changeset
   785
    User::LeaveIfError(rfs.Connect());
hgs
parents:
diff changeset
   786
    
hgs
parents:
diff changeset
   787
    TParse fileNameParser;
hgs
parents:
diff changeset
   788
    User::LeaveIfError(fileNameParser.Set(aFullName, NULL, NULL));
hgs
parents:
diff changeset
   789
    
hgs
parents:
diff changeset
   790
    TFileName logFilePath;
hgs
parents:
diff changeset
   791
    TFileName cenRepFolder;
hgs
parents:
diff changeset
   792
    GetCenRepKeyStringValueL(KCRUidBluetoothEngine, KLCReceiveFolder,cenRepFolder);
hgs
parents:
diff changeset
   793
    logFilePath.Zero();
hgs
parents:
diff changeset
   794
    logFilePath.Append(PathInfo::PhoneMemoryRootPath());
hgs
parents:
diff changeset
   795
    logFilePath.Append(cenRepFolder);
hgs
parents:
diff changeset
   796
    logFilePath.Append(_L("log.txt"));
hgs
parents:
diff changeset
   797
            
hgs
parents:
diff changeset
   798
    if ( fileNameParser.Ext().Compare(_L(".$$$")) == 0  )                                                                           
hgs
parents:
diff changeset
   799
        {
hgs
parents:
diff changeset
   800
        // aFullName is a temp file name, we need to remove it.        
hgs
parents:
diff changeset
   801
        rfs.Delete( aFullName );
hgs
parents:
diff changeset
   802
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveTemporaryRFileL() temp file is removed (bt off)"));
hgs
parents:
diff changeset
   803
        }
hgs
parents:
diff changeset
   804
    else if ( (aFullName.Length() == 0) && BaflUtils::FileExists(rfs, logFilePath))
hgs
parents:
diff changeset
   805
        {
hgs
parents:
diff changeset
   806
        RFile logFile;
hgs
parents:
diff changeset
   807
        User::LeaveIfError(logFile.Open(rfs, logFilePath, EFileRead));
hgs
parents:
diff changeset
   808
        TFileText ft;
hgs
parents:
diff changeset
   809
        ft.Set(logFile);
hgs
parents:
diff changeset
   810
        TFileName tempFileName;
hgs
parents:
diff changeset
   811
        ft.Read(tempFileName);  // read tempfile name stored in logfile.
hgs
parents:
diff changeset
   812
        
hgs
parents:
diff changeset
   813
        if ( tempFileName.Length() > 0 )
hgs
parents:
diff changeset
   814
            {
hgs
parents:
diff changeset
   815
            rfs.Delete(tempFileName);
hgs
parents:
diff changeset
   816
            }
hgs
parents:
diff changeset
   817
        logFile.Close();   
hgs
parents:
diff changeset
   818
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveTemporaryRFileL() temp files are removed (reboot)"));
hgs
parents:
diff changeset
   819
        }              
hgs
parents:
diff changeset
   820
    rfs.Delete( logFilePath );
hgs
parents:
diff changeset
   821
    rfs.Close();
hgs
parents:
diff changeset
   822
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::RemoveTemporaryRFileL() completed"));
hgs
parents:
diff changeset
   823
    }
hgs
parents:
diff changeset
   824
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   825
// CObexUtilsMessageHandler::SaveFileToFileSystemL
hgs
parents:
diff changeset
   826
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   827
//
hgs
parents:
diff changeset
   828
EXPORT_C void TObexUtilsMessageHandler::SaveFileToFileSystemL(
hgs
parents:
diff changeset
   829
    CObexBufObject* &aReceivedObject,
hgs
parents:
diff changeset
   830
    const TUid aMtmId,
hgs
parents:
diff changeset
   831
    TMsvId& aMsvIdParent,
hgs
parents:
diff changeset
   832
    TFileName& aFullName, 
hgs
parents:
diff changeset
   833
    RFile& aFile,
hgs
parents:
diff changeset
   834
    const TDesC& aSenderBluetoothName)
hgs
parents:
diff changeset
   835
    {
hgs
parents:
diff changeset
   836
   
hgs
parents:
diff changeset
   837
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveFileToFileSystemL()"));
hgs
parents:
diff changeset
   838
    // Create inbox entry ( this was done in CreateAttachment() before )
hgs
parents:
diff changeset
   839
    //
hgs
parents:
diff changeset
   840
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
   841
    CMsvSession* msvSession;
hgs
parents:
diff changeset
   842
    CMsvEntry* inbox;
hgs
parents:
diff changeset
   843
    CreateMsvSessionLC(sessionObs, msvSession, inbox, KMsvGlobalInBoxIndexEntryId);
hgs
parents:
diff changeset
   844
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
   845
hgs
parents:
diff changeset
   846
    TBuf<KObexUtilsMaxCharToFromField> toFrom;
hgs
parents:
diff changeset
   847
42
hgs
parents: 32
diff changeset
   848
    // todo @ QT migration: load from string id for localization
32
hgs
parents:
diff changeset
   849
    if (aMtmId == KUidMsgTypeBt)
hgs
parents:
diff changeset
   850
        {
42
hgs
parents: 32
diff changeset
   851
        _LIT(KBluetoothMsg, "Bluetooth message");
hgs
parents: 32
diff changeset
   852
        toFrom.Copy(KBluetoothMsg);
32
hgs
parents:
diff changeset
   853
        }
hgs
parents:
diff changeset
   854
    else
hgs
parents:
diff changeset
   855
        {
42
hgs
parents: 32
diff changeset
   856
        _LIT(KInfraredMsg, "Infrared message");
hgs
parents: 32
diff changeset
   857
        toFrom.Copy(KInfraredMsg);    
32
hgs
parents:
diff changeset
   858
        }
42
hgs
parents: 32
diff changeset
   859
    
hgs
parents: 32
diff changeset
   860
    // NOTE: toFrom will be updated to Bluetooth sender's bt name in the future.
32
hgs
parents:
diff changeset
   861
hgs
parents:
diff changeset
   862
    TMsvEntry parentTEntry;   
hgs
parents:
diff changeset
   863
    parentTEntry.iMtm = aMtmId;
hgs
parents:
diff changeset
   864
    parentTEntry.SetVisible(EFalse); // Make invisible..
hgs
parents:
diff changeset
   865
    parentTEntry.SetUnread(ETrue);  //  Set msg to Unread
hgs
parents:
diff changeset
   866
        
hgs
parents:
diff changeset
   867
    // ...and in preparation to make sure it gets cleaned up on errors.
hgs
parents:
diff changeset
   868
    //
hgs
parents:
diff changeset
   869
    parentTEntry.SetInPreparation(ETrue); 
hgs
parents:
diff changeset
   870
    parentTEntry.iType = KUidMsvMessageEntry;
hgs
parents:
diff changeset
   871
    parentTEntry.iServiceId = KMsvUnknownServiceIndexEntryId;
hgs
parents:
diff changeset
   872
    // iDate & iSize will be set later
hgs
parents:
diff changeset
   873
    if ( aSenderBluetoothName.Length() > 0 )
hgs
parents:
diff changeset
   874
        {
hgs
parents:
diff changeset
   875
        parentTEntry.iDetails.Set(aSenderBluetoothName);
hgs
parents:
diff changeset
   876
        }
hgs
parents:
diff changeset
   877
    else
hgs
parents:
diff changeset
   878
        {
hgs
parents:
diff changeset
   879
        parentTEntry.iDetails.Set(toFrom);
hgs
parents:
diff changeset
   880
        }
hgs
parents:
diff changeset
   881
    inbox->CreateL(parentTEntry);
hgs
parents:
diff changeset
   882
        
hgs
parents:
diff changeset
   883
    aMsvIdParent = parentTEntry.Id();
hgs
parents:
diff changeset
   884
        
hgs
parents:
diff changeset
   885
    // Create attachment for the inbox entry
hgs
parents:
diff changeset
   886
    
hgs
parents:
diff changeset
   887
    TMsvEntry attachTEntry;
hgs
parents:
diff changeset
   888
    attachTEntry.iType      = KUidMsvAttachmentEntry;
hgs
parents:
diff changeset
   889
    attachTEntry.iServiceId = KMsvUnknownServiceIndexEntryId;   
hgs
parents:
diff changeset
   890
    attachTEntry.iMtm       = aMtmId;
hgs
parents:
diff changeset
   891
     
hgs
parents:
diff changeset
   892
    CMsvEntry* parentEntry = msvSession->GetEntryL(aMsvIdParent);
hgs
parents:
diff changeset
   893
    CleanupStack::PushL(parentEntry);  // 4th push
hgs
parents:
diff changeset
   894
    parentEntry->CreateL(attachTEntry);  // create attachment as child of parent
hgs
parents:
diff changeset
   895
  
hgs
parents:
diff changeset
   896
    // Check if message is sap message
hgs
parents:
diff changeset
   897
    // If we delete parent entry in sap, we have to delete the RFile object ourself as well )
hgs
parents:
diff changeset
   898
    //
hgs
parents:
diff changeset
   899
    RFs& fsSess = msvSession->FileSession();
hgs
parents:
diff changeset
   900
    TFileName tempFullName;
hgs
parents:
diff changeset
   901
    aFile.FullName(tempFullName);
hgs
parents:
diff changeset
   902
    
hgs
parents:
diff changeset
   903
#ifdef __BT_SAP   
hgs
parents:
diff changeset
   904
    if(CSapVMessageParser::HandleMessageL(aReceivedObject, parentEntry->Entry().iMtm,
hgs
parents:
diff changeset
   905
            aFile, msvSession, GetCurrentTime()))
hgs
parents:
diff changeset
   906
        {
hgs
parents:
diff changeset
   907
        RemoveObexBuffer(aReceivedObject);
hgs
parents:
diff changeset
   908
        CMsvEntry* inbox = msvSession->GetEntryL( KMsvGlobalInBoxIndexEntryId );
hgs
parents:
diff changeset
   909
        CleanupStack::PushL( inbox );         //5th push
hgs
parents:
diff changeset
   910
        inbox->DeleteL(aMsvIdParent);
hgs
parents:
diff changeset
   911
        fsSess.Delete(tempFullName);  // we have to use fullname to delete the file object in file system 
hgs
parents:
diff changeset
   912
        // Close session etc.
hgs
parents:
diff changeset
   913
        CleanupStack::PopAndDestroy(5, sessionObs);  // inbox, parentEntry, session, sessionObs
hgs
parents:
diff changeset
   914
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveFileToFileSystemL() completed"));
hgs
parents:
diff changeset
   915
        return;
hgs
parents:
diff changeset
   916
        }
hgs
parents:
diff changeset
   917
#endif // __BT_SAP
hgs
parents:
diff changeset
   918
hgs
parents:
diff changeset
   919
    // Collect obex received data before obex buffer deletion
hgs
parents:
diff changeset
   920
    TReceivedData receivedData;
hgs
parents:
diff changeset
   921
    receivedData.bytesReceived = aReceivedObject->BytesReceived();
hgs
parents:
diff changeset
   922
    receivedData.recTime = aReceivedObject->Time();
hgs
parents:
diff changeset
   923
    receivedData.msgName = aReceivedObject->Name();
hgs
parents:
diff changeset
   924
    
hgs
parents:
diff changeset
   925
    TFileName filename;
hgs
parents:
diff changeset
   926
    TParse parse;
hgs
parents:
diff changeset
   927
    parse.Set(aFullName, NULL, NULL);
hgs
parents:
diff changeset
   928
    filename.Copy(receivedData.msgName);
hgs
parents:
diff changeset
   929
    FixExtremeLongFileName(filename, parse.DriveAndPath());
hgs
parents:
diff changeset
   930
    MakeValidFileName( fsSess, filename);     
hgs
parents:
diff changeset
   931
    RemoveObexBuffer(aReceivedObject);
hgs
parents:
diff changeset
   932
hgs
parents:
diff changeset
   933
    // We set file to visible before renaming 
hgs
parents:
diff changeset
   934
    // so that photo/music app can scan the media files we recevie. 
hgs
parents:
diff changeset
   935
    //
hgs
parents:
diff changeset
   936
    // Set file back to visible
hgs
parents:
diff changeset
   937
    //
hgs
parents:
diff changeset
   938
    TUint setAttMask(0);
hgs
parents:
diff changeset
   939
    TUint clearAttMask(0);
hgs
parents:
diff changeset
   940
    User::LeaveIfError(aFile.Open(fsSess,tempFullName,EFileWrite));
hgs
parents:
diff changeset
   941
    User::LeaveIfError(aFile.SetAtt(setAttMask , clearAttMask | KEntryAttHidden));
hgs
parents:
diff changeset
   942
    aFile.Close();
hgs
parents:
diff changeset
   943
    
hgs
parents:
diff changeset
   944
    
hgs
parents:
diff changeset
   945
    // Move file to the actual drive and directory
hgs
parents:
diff changeset
   946
    // as well rename the file with the correct file name instead of temporary name 
hgs
parents:
diff changeset
   947
    // tempFullName will be updated in RenameFileL()    
hgs
parents:
diff changeset
   948
    TInt error = RenameFileL(tempFullName, filename, parse.DriveAndPath(), fsSess);
hgs
parents:
diff changeset
   949
    
hgs
parents:
diff changeset
   950
    if ( error != KErrNone )
hgs
parents:
diff changeset
   951
        {
hgs
parents:
diff changeset
   952
        fsSess.Delete(tempFullName);   // If rename fails, we remove the temp RFile object.
hgs
parents:
diff changeset
   953
        }
hgs
parents:
diff changeset
   954
    aFullName = tempFullName; // assign new full Name back to aFullName,which goes back to caller
hgs
parents:
diff changeset
   955
    
hgs
parents:
diff changeset
   956
    CleanupStack::PopAndDestroy(4);         // parentEntry, inbox, msvSession, sessionObs
hgs
parents:
diff changeset
   957
     
hgs
parents:
diff changeset
   958
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::SaveFileToFileSystemL() completed"));
hgs
parents:
diff changeset
   959
    }
hgs
parents:
diff changeset
   960
hgs
parents:
diff changeset
   961
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   962
// CObexUtilsMessageHandler::AddEntryToInboxL
hgs
parents:
diff changeset
   963
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   964
//
hgs
parents:
diff changeset
   965
EXPORT_C void TObexUtilsMessageHandler::AddEntryToInboxL( 
hgs
parents:
diff changeset
   966
    TMsvId& aMsvIdParent,
hgs
parents:
diff changeset
   967
    TFileName& aFullName)
hgs
parents:
diff changeset
   968
    {
hgs
parents:
diff changeset
   969
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::AddEntryToInboxL() "));
hgs
parents:
diff changeset
   970
        
hgs
parents:
diff changeset
   971
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
   972
    CMsvSession* msvSession;
hgs
parents:
diff changeset
   973
    CreateMsvSessionLC(sessionObs, msvSession);
hgs
parents:
diff changeset
   974
    // 1st, 2nd push
hgs
parents:
diff changeset
   975
        
hgs
parents:
diff changeset
   976
    CMsvEntry* parentEntry = msvSession->GetEntryL(aMsvIdParent);
hgs
parents:
diff changeset
   977
    CleanupStack::PushL(parentEntry);  // 3th push
hgs
parents:
diff changeset
   978
    
hgs
parents:
diff changeset
   979
    CMsvEntry* attachEntry = msvSession->GetEntryL(((*parentEntry)[0]).Id());
hgs
parents:
diff changeset
   980
    CleanupStack::PushL(attachEntry); // 4th push
hgs
parents:
diff changeset
   981
            
hgs
parents:
diff changeset
   982
    CMsvStore* store = attachEntry->EditStoreL();
hgs
parents:
diff changeset
   983
    CleanupStack::PushL( store );  // 5th push
hgs
parents:
diff changeset
   984
        
hgs
parents:
diff changeset
   985
    CObexutilsEntryhandler* entryHandler = CObexutilsEntryhandler::NewL();
hgs
parents:
diff changeset
   986
    CleanupStack::PushL(entryHandler);  // 6th push  
hgs
parents:
diff changeset
   987
                
hgs
parents:
diff changeset
   988
    CMsvAttachment* attachInfo = CMsvAttachment::NewL(CMsvAttachment::EMsvLinkedFile);
hgs
parents:
diff changeset
   989
    CleanupStack::PushL(attachInfo);  // 7th push
hgs
parents:
diff changeset
   990
           
hgs
parents:
diff changeset
   991
    // Create attachment Info
hgs
parents:
diff changeset
   992
    //
hgs
parents:
diff changeset
   993
    RFs& fsSess = msvSession->FileSession();
hgs
parents:
diff changeset
   994
        
hgs
parents:
diff changeset
   995
    TParse fileNameParser;
hgs
parents:
diff changeset
   996
    User::LeaveIfError(fileNameParser.Set(aFullName, NULL, NULL));
hgs
parents:
diff changeset
   997
    attachInfo->SetAttachmentNameL( fileNameParser.FullName());
hgs
parents:
diff changeset
   998
                 
hgs
parents:
diff changeset
   999
    TEntry fileEntry;
hgs
parents:
diff changeset
  1000
    User::LeaveIfError(fsSess.Entry( fileNameParser.FullName(), fileEntry) );
hgs
parents:
diff changeset
  1001
    attachInfo->SetSize(fileEntry.iSize);
hgs
parents:
diff changeset
  1002
            
hgs
parents:
diff changeset
  1003
    // check if it's the bio message
hgs
parents:
diff changeset
  1004
           
hgs
parents:
diff changeset
  1005
    TUid bioMsgId;  // SaveMimeAndGetBioLC modifies this
hgs
parents:
diff changeset
  1006
    CBIODatabase* bioDB = SaveMimeAndGetBioLC( aFullName, fsSess, attachInfo, bioMsgId );
hgs
parents:
diff changeset
  1007
    // 8th push
hgs
parents:
diff changeset
  1008
    if (bioDB)  // bio message
hgs
parents:
diff changeset
  1009
        {
hgs
parents:
diff changeset
  1010
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::AddEntryToInboxL() BIO"));
hgs
parents:
diff changeset
  1011
    
hgs
parents:
diff changeset
  1012
        RFile file;
42
hgs
parents: 32
diff changeset
  1013
        User::LeaveIfError(file.Open(fsSess,aFullName,EFileShareReadersOnly));
32
hgs
parents:
diff changeset
  1014
        TReceivedData receivedData;
hgs
parents:
diff changeset
  1015
        receivedData.bytesReceived = fileEntry.iSize;
hgs
parents:
diff changeset
  1016
        receivedData.recTime = fileEntry.iModified;
hgs
parents:
diff changeset
  1017
        receivedData.msgName = fileNameParser.Name();     
hgs
parents:
diff changeset
  1018
                    
hgs
parents:
diff changeset
  1019
        StoreAndUpdateBioMessageL( bioDB, bioMsgId, parentEntry, file );
hgs
parents:
diff changeset
  1020
        FinaliseMessageL(parentEntry, receivedData, store, ETrue);
hgs
parents:
diff changeset
  1021
        TMsvId attachId = attachEntry->EntryId();
hgs
parents:
diff changeset
  1022
        file.Close();
hgs
parents:
diff changeset
  1023
        fsSess.Delete(aFullName);
hgs
parents:
diff changeset
  1024
        CleanupStack::PopAndDestroy(5);  // bioDB, attachInfo, linkHandler,
hgs
parents:
diff changeset
  1025
                                             // store, attachEntry
hgs
parents:
diff changeset
  1026
            
hgs
parents:
diff changeset
  1027
        // PopAndDestroying here because open store locks the entry,
hgs
parents:
diff changeset
  1028
        // it can be deleted only after destroying the store pointer
hgs
parents:
diff changeset
  1029
        parentEntry->DeleteL(attachId);  // invalidate unused attachment
hgs
parents:
diff changeset
  1030
        CleanupStack::PopAndDestroy(3);  // parentEntry, msvSession, sessionObs
hgs
parents:
diff changeset
  1031
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::AddEntryToInboxL() BIO completed"));
hgs
parents:
diff changeset
  1032
        }
hgs
parents:
diff changeset
  1033
    else
hgs
parents:
diff changeset
  1034
        {
hgs
parents:
diff changeset
  1035
hgs
parents:
diff changeset
  1036
        CleanupStack::PopAndDestroy();  // bioDB
hgs
parents:
diff changeset
  1037
        // Add entry to Inbox
hgs
parents:
diff changeset
  1038
        entryHandler->AddEntryAttachment(aFullName, attachInfo, store);
hgs
parents:
diff changeset
  1039
        CleanupStack::Pop(attachInfo);   // attachInfo, Pass ownership to store
hgs
parents:
diff changeset
  1040
        CleanupStack::PopAndDestroy(entryHandler);  // entryHandler
hgs
parents:
diff changeset
  1041
        FinaliseMessageL(parentEntry, store,fileEntry, fileNameParser);
hgs
parents:
diff changeset
  1042
        CleanupStack::PopAndDestroy(5);         // linkHandler, attachInfo, store, attachEntry,
hgs
parents:
diff changeset
  1043
                                                    // parentEntry, msvSession, sessionObs                            
hgs
parents:
diff changeset
  1044
        FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::AddEntryToInboxL() completed "));
hgs
parents:
diff changeset
  1045
        }
hgs
parents:
diff changeset
  1046
    }
hgs
parents:
diff changeset
  1047
hgs
parents:
diff changeset
  1048
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1049
// CObexUtilsMessageHandler::AddEntryToInboxL
hgs
parents:
diff changeset
  1050
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1051
//
hgs
parents:
diff changeset
  1052
EXPORT_C void TObexUtilsMessageHandler::AddEntryToInboxL( 
hgs
parents:
diff changeset
  1053
    TMsvId& aMsvIdParent,
hgs
parents:
diff changeset
  1054
    TFileName& aFullName,
hgs
parents:
diff changeset
  1055
    RArray<TMsvId>* aMsvIdArray)
hgs
parents:
diff changeset
  1056
    {
hgs
parents:
diff changeset
  1057
    AddEntryToInboxL(aMsvIdParent, aFullName);
hgs
parents:
diff changeset
  1058
    aMsvIdArray->Append(aMsvIdParent);
hgs
parents:
diff changeset
  1059
    }
hgs
parents:
diff changeset
  1060
hgs
parents:
diff changeset
  1061
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1062
// CObexUtilsMessageHandler::UpdateEntryAttachmentL
hgs
parents:
diff changeset
  1063
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1064
//
hgs
parents:
diff changeset
  1065
EXPORT_C void TObexUtilsMessageHandler::UpdateEntryAttachmentL ( 
hgs
parents:
diff changeset
  1066
    TFileName& aFullName,
hgs
parents:
diff changeset
  1067
    CMsvEntry* aParentEntry)
hgs
parents:
diff changeset
  1068
    {
hgs
parents:
diff changeset
  1069
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::UpdateEntryAttachmentL() "));
hgs
parents:
diff changeset
  1070
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
  1071
    CMsvSession* msvSession;
hgs
parents:
diff changeset
  1072
    CreateMsvSessionLC(sessionObs, msvSession);
hgs
parents:
diff changeset
  1073
    // 1st, 2nd push
hgs
parents:
diff changeset
  1074
      
hgs
parents:
diff changeset
  1075
    CMsvEntry* attachEntry = msvSession->GetEntryL(((*aParentEntry)[0]).Id());
hgs
parents:
diff changeset
  1076
    CleanupStack::PushL(attachEntry); // 3th push
hgs
parents:
diff changeset
  1077
            
hgs
parents:
diff changeset
  1078
    CMsvStore* store = attachEntry->EditStoreL();
hgs
parents:
diff changeset
  1079
    CleanupStack::PushL( store );  // 4th push
hgs
parents:
diff changeset
  1080
  
hgs
parents:
diff changeset
  1081
    CObexutilsEntryhandler* entryHandler = CObexutilsEntryhandler::NewL();
hgs
parents:
diff changeset
  1082
    CleanupStack::PushL(entryHandler);  // 5th push  
hgs
parents:
diff changeset
  1083
    
hgs
parents:
diff changeset
  1084
    // Note:
hgs
parents:
diff changeset
  1085
    // Because setFilePath() in CMsvAttachment is not implementated by Symbian yet, 
hgs
parents:
diff changeset
  1086
    // we have to delete the original attachment and add another new one to fix the broken link.
hgs
parents:
diff changeset
  1087
    //
hgs
parents:
diff changeset
  1088
    
hgs
parents:
diff changeset
  1089
    // remove the old attachment first.
hgs
parents:
diff changeset
  1090
    //
hgs
parents:
diff changeset
  1091
    store->AttachmentManagerExtensionsL().RemoveAttachmentL(0);
hgs
parents:
diff changeset
  1092
    // Create a new attachment.
hgs
parents:
diff changeset
  1093
    //
hgs
parents:
diff changeset
  1094
    CMsvAttachment* attachInfo = CMsvAttachment::NewL(CMsvAttachment::EMsvLinkedFile);
hgs
parents:
diff changeset
  1095
    CleanupStack::PushL(attachInfo);  // 6th  push
hgs
parents:
diff changeset
  1096
    
hgs
parents:
diff changeset
  1097
    // Get mime type
hgs
parents:
diff changeset
  1098
    //
hgs
parents:
diff changeset
  1099
    RecogniseObjectsL(aFullName, attachInfo);
hgs
parents:
diff changeset
  1100
    RFs& fsSess = msvSession->FileSession();
hgs
parents:
diff changeset
  1101
    
hgs
parents:
diff changeset
  1102
    TParse fileNameParser;
hgs
parents:
diff changeset
  1103
    User::LeaveIfError(fileNameParser.Set(aFullName, NULL, NULL));
hgs
parents:
diff changeset
  1104
    attachInfo->SetAttachmentNameL(fileNameParser.NameAndExt());
hgs
parents:
diff changeset
  1105
    TEntry fileEntry;
hgs
parents:
diff changeset
  1106
    User::LeaveIfError(fsSess.Entry( fileNameParser.FullName(), fileEntry) );
hgs
parents:
diff changeset
  1107
    attachInfo->SetSize(fileEntry.iSize);
hgs
parents:
diff changeset
  1108
hgs
parents:
diff changeset
  1109
    entryHandler->AddEntryAttachment(aFullName,attachInfo, store);
hgs
parents:
diff changeset
  1110
    CleanupStack::Pop(attachInfo);   // attachInfo, Pass ownership to store
hgs
parents:
diff changeset
  1111
    CleanupStack::PopAndDestroy(entryHandler);  // entryHandler
hgs
parents:
diff changeset
  1112
    FinaliseMessageL(aParentEntry, store,fileEntry, fileNameParser);
hgs
parents:
diff changeset
  1113
    CleanupStack::PopAndDestroy(4);   // store, 
hgs
parents:
diff changeset
  1114
                                      // attachEntry, msvSession, sessionObs
hgs
parents:
diff changeset
  1115
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::UpdateEntryAttachmentL() completed "));
hgs
parents:
diff changeset
  1116
    }
hgs
parents:
diff changeset
  1117
hgs
parents:
diff changeset
  1118
hgs
parents:
diff changeset
  1119
// Common methods
hgs
parents:
diff changeset
  1120
hgs
parents:
diff changeset
  1121
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1122
// ConstructRichTextLC Handles rich text initialisation.
hgs
parents:
diff changeset
  1123
// Returns: CRichText* A pointer to the rich text.
hgs
parents:
diff changeset
  1124
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1125
//
hgs
parents:
diff changeset
  1126
CRichText* TObexUtilsMessageHandler::ConstructRichTextLC()
hgs
parents:
diff changeset
  1127
    {
hgs
parents:
diff changeset
  1128
    FLOG(_L("[OBEXUTILS]\t ConstructRichTextLC()"));
hgs
parents:
diff changeset
  1129
hgs
parents:
diff changeset
  1130
    CParaFormatLayer* richParaFormatLayer = CParaFormatLayer::NewL();
hgs
parents:
diff changeset
  1131
    CleanupStack::PushL( richParaFormatLayer );
hgs
parents:
diff changeset
  1132
hgs
parents:
diff changeset
  1133
    CCharFormatLayer* richCharFormatLayer = CCharFormatLayer::NewL(); 
hgs
parents:
diff changeset
  1134
    CleanupStack::PushL( richCharFormatLayer );
hgs
parents:
diff changeset
  1135
    CRichText* richText = CRichText::NewL( richParaFormatLayer, 
hgs
parents:
diff changeset
  1136
                                           richCharFormatLayer );
hgs
parents:
diff changeset
  1137
    CleanupStack::PushL(richText);
hgs
parents:
diff changeset
  1138
hgs
parents:
diff changeset
  1139
    FLOG(_L("[OBEXUTILS]\t ConstructRichTextLC() completed"));
hgs
parents:
diff changeset
  1140
hgs
parents:
diff changeset
  1141
    return richText;
hgs
parents:
diff changeset
  1142
    }
hgs
parents:
diff changeset
  1143
hgs
parents:
diff changeset
  1144
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1145
// MakeValidFileName Rename the given filename to a valid filename.
hgs
parents:
diff changeset
  1146
// Removes invalid characters from a filename; if no characters left, filename
hgs
parents:
diff changeset
  1147
// is set to R_NAME_FOR_INVALID_FILE
hgs
parents:
diff changeset
  1148
// Returns: None.
hgs
parents:
diff changeset
  1149
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1150
//
hgs
parents:
diff changeset
  1151
void TObexUtilsMessageHandler::MakeValidFileName( 
hgs
parents:
diff changeset
  1152
    RFs& aFileSession, // A reference to file server session.
hgs
parents:
diff changeset
  1153
    TDes& aFileName )  // The filename to modify.
hgs
parents:
diff changeset
  1154
    {
hgs
parents:
diff changeset
  1155
    FLOG(_L("[OBEXUTILS]\t MakeValidFileName()"));
hgs
parents:
diff changeset
  1156
hgs
parents:
diff changeset
  1157
    TParse fileParse;
hgs
parents:
diff changeset
  1158
    fileParse.Set(aFileName, NULL, NULL);
hgs
parents:
diff changeset
  1159
    
hgs
parents:
diff changeset
  1160
    if (fileParse.NameOrExtPresent())
hgs
parents:
diff changeset
  1161
        {        
hgs
parents:
diff changeset
  1162
        aFileName = fileParse.NameAndExt();
hgs
parents:
diff changeset
  1163
        TText badChar;    
hgs
parents:
diff changeset
  1164
        TInt nameLength = aFileName.Length();
hgs
parents:
diff changeset
  1165
    
hgs
parents:
diff changeset
  1166
        while ( !aFileSession.IsValidName(aFileName, badChar) )
hgs
parents:
diff changeset
  1167
            {
hgs
parents:
diff changeset
  1168
            // Locate and delete all instances of the bad char
hgs
parents:
diff changeset
  1169
            FOREVER
hgs
parents:
diff changeset
  1170
                {
hgs
parents:
diff changeset
  1171
                TInt index = aFileName.Locate(TChar(badChar)); 
hgs
parents:
diff changeset
  1172
                nameLength--;
hgs
parents:
diff changeset
  1173
                if (index == KErrNotFound)
hgs
parents:
diff changeset
  1174
                    {
hgs
parents:
diff changeset
  1175
                    break;
hgs
parents:
diff changeset
  1176
                    }             
hgs
parents:
diff changeset
  1177
                aFileName.Delete(index,1);               
hgs
parents:
diff changeset
  1178
                }
hgs
parents:
diff changeset
  1179
                if ( nameLength <= 0 )
hgs
parents:
diff changeset
  1180
                    {
hgs
parents:
diff changeset
  1181
                    break;
hgs
parents:
diff changeset
  1182
                    }
hgs
parents:
diff changeset
  1183
            }    
hgs
parents:
diff changeset
  1184
        }    
hgs
parents:
diff changeset
  1185
    FLOG(_L("[OBEXUTILS]\t MakeValidFileName() completed"));
hgs
parents:
diff changeset
  1186
    }
hgs
parents:
diff changeset
  1187
hgs
parents:
diff changeset
  1188
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1189
// TObexUtilsMessageHandler::CreateOutboxEntryL
hgs
parents:
diff changeset
  1190
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1191
//
hgs
parents:
diff changeset
  1192
EXPORT_C TMsvId TObexUtilsMessageHandler::CreateOutboxEntryL(
hgs
parents:
diff changeset
  1193
    const TUid& aMtm,          // Message type id
42
hgs
parents: 32
diff changeset
  1194
    //todo need to check whether to use the textmap id or send as a string here
hgs
parents: 32
diff changeset
  1195
    const TInt& /*aResourceID*/ )  // Resource id for the message entry text
32
hgs
parents:
diff changeset
  1196
    {
hgs
parents:
diff changeset
  1197
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateOutboxEntryL()"));
hgs
parents:
diff changeset
  1198
hgs
parents:
diff changeset
  1199
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
  1200
    CMsvSession* msvSession;
hgs
parents:
diff changeset
  1201
    CMsvEntry* outBoxEntry;
hgs
parents:
diff changeset
  1202
    CreateMsvSessionLC(sessionObs, msvSession, outBoxEntry, KMsvGlobalOutBoxIndexEntryId);
hgs
parents:
diff changeset
  1203
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
  1204
hgs
parents:
diff changeset
  1205
    TBuf<KObexUtilsMaxCharToFromField> toFrom;
42
hgs
parents: 32
diff changeset
  1206
 //   TObexUtilsUiLayer::ReadResourceL( toFrom, aResourceID );
hgs
parents: 32
diff changeset
  1207
    //todo need to change the string constant to orbit localisation file
hgs
parents: 32
diff changeset
  1208
    toFrom.Copy(_L("Bluetooth message"));
32
hgs
parents:
diff changeset
  1209
hgs
parents:
diff changeset
  1210
    // Message entry fields
hgs
parents:
diff changeset
  1211
    TMsvEntry newTEntry;
hgs
parents:
diff changeset
  1212
    newTEntry.SetVisible( ETrue );          // Make visible
hgs
parents:
diff changeset
  1213
    newTEntry.SetInPreparation( ETrue );    // and in preparation to make sure gets cleaned up on errors.
hgs
parents:
diff changeset
  1214
    newTEntry.iDetails.Set( toFrom );       // To/From field on Outbox
hgs
parents:
diff changeset
  1215
    newTEntry.SetSendingState( KMsvSendStateSending );
hgs
parents:
diff changeset
  1216
    newTEntry.iType = KUidMsvMessageEntry;      
hgs
parents:
diff changeset
  1217
    newTEntry.iMtm = aMtm;                  // message type id 
hgs
parents:
diff changeset
  1218
    newTEntry.iServiceId = KMsvGlobalOutBoxIndexEntryId;
hgs
parents:
diff changeset
  1219
    outBoxEntry->CreateL( newTEntry );
hgs
parents:
diff changeset
  1220
    
hgs
parents:
diff changeset
  1221
    CleanupStack::PopAndDestroy(3);         //outBoxEntry, msvSession, sessionObs
hgs
parents:
diff changeset
  1222
    return newTEntry.Id();
hgs
parents:
diff changeset
  1223
    }
hgs
parents:
diff changeset
  1224
hgs
parents:
diff changeset
  1225
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1226
// TObexUtilsMessageHandler::DeleteOutboxEntryL
hgs
parents:
diff changeset
  1227
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1228
//
hgs
parents:
diff changeset
  1229
EXPORT_C void TObexUtilsMessageHandler::DeleteOutboxEntryL( const TMsvId& aMessageServerIndex )
hgs
parents:
diff changeset
  1230
    {
hgs
parents:
diff changeset
  1231
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::DeleteOutboxEntryL()"));
hgs
parents:
diff changeset
  1232
hgs
parents:
diff changeset
  1233
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
  1234
    CMsvSession* msvSession;
hgs
parents:
diff changeset
  1235
    CMsvEntry* outBoxEntry;
hgs
parents:
diff changeset
  1236
    CreateMsvSessionLC(sessionObs, msvSession, outBoxEntry, KMsvGlobalOutBoxIndexEntryId);
hgs
parents:
diff changeset
  1237
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
  1238
hgs
parents:
diff changeset
  1239
    outBoxEntry->DeleteL( aMessageServerIndex );
hgs
parents:
diff changeset
  1240
hgs
parents:
diff changeset
  1241
    CleanupStack::PopAndDestroy(3);         //outBoxEntry, msvSession, sessionObs
hgs
parents:
diff changeset
  1242
    }
hgs
parents:
diff changeset
  1243
hgs
parents:
diff changeset
  1244
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1245
// TObexUtilsMessageHandler::GetFileSystemStatus
hgs
parents:
diff changeset
  1246
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1247
//
hgs
parents:
diff changeset
  1248
EXPORT_C TInt TObexUtilsMessageHandler::GetFileSystemStatus()
hgs
parents:
diff changeset
  1249
    {
hgs
parents:
diff changeset
  1250
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetFileSystemStatus()"));
hgs
parents:
diff changeset
  1251
hgs
parents:
diff changeset
  1252
    /**
hgs
parents:
diff changeset
  1253
    *  Free space level of FFS file system (drive C:)
hgs
parents:
diff changeset
  1254
    *  The integer value may be:
hgs
parents:
diff changeset
  1255
    *       0: Free space OK
hgs
parents:
diff changeset
  1256
    *      -1: Free space at or below warning level
hgs
parents:
diff changeset
  1257
    *      -2: Free space at or below critical level
hgs
parents:
diff changeset
  1258
    */
hgs
parents:
diff changeset
  1259
    
hgs
parents:
diff changeset
  1260
    TInt status = KErrNone;
hgs
parents:
diff changeset
  1261
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
  1262
    
hgs
parents:
diff changeset
  1263
    retVal = GetPubSubKeyIntValue(KPSUidUikon, KUikFFSFreeLevel, status);
hgs
parents:
diff changeset
  1264
    if ( ( retVal == KErrNone ) && ( status == KFFSBelowCritical ) )
hgs
parents:
diff changeset
  1265
        {
hgs
parents:
diff changeset
  1266
        retVal = KErrDiskFull;
hgs
parents:
diff changeset
  1267
        }
hgs
parents:
diff changeset
  1268
     
hgs
parents:
diff changeset
  1269
    FTRACE(FPrint(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetFileSystemStatus completed with %d."), retVal));
hgs
parents:
diff changeset
  1270
    return retVal;
hgs
parents:
diff changeset
  1271
    }
hgs
parents:
diff changeset
  1272
hgs
parents:
diff changeset
  1273
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1274
// TObexUtilsMessageHandler::GetMmcFileSystemStatus
hgs
parents:
diff changeset
  1275
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1276
//
hgs
parents:
diff changeset
  1277
EXPORT_C TInt TObexUtilsMessageHandler::GetMmcFileSystemStatus()
hgs
parents:
diff changeset
  1278
    {
hgs
parents:
diff changeset
  1279
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetMmcFileSystemStatus()"));
hgs
parents:
diff changeset
  1280
hgs
parents:
diff changeset
  1281
    /**
hgs
parents:
diff changeset
  1282
    *  Free space level of FFS file system (MMC)
hgs
parents:
diff changeset
  1283
    *  The integer value may be:
hgs
parents:
diff changeset
  1284
    *       0: Free space OK
hgs
parents:
diff changeset
  1285
    *      -1: Free space at or below warning level
hgs
parents:
diff changeset
  1286
    *      -2: Free space at or below critical level
hgs
parents:
diff changeset
  1287
    */
hgs
parents:
diff changeset
  1288
   
hgs
parents:
diff changeset
  1289
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
  1290
    TInt status = KErrNone;
hgs
parents:
diff changeset
  1291
    
hgs
parents:
diff changeset
  1292
    retVal = GetPubSubKeyIntValue(KPSUidUikon, KUikMmcFFSFreeLevel, status);
hgs
parents:
diff changeset
  1293
    if ( ( retVal == KErrNone ) && ( status == KFFSBelowCritical ) )
hgs
parents:
diff changeset
  1294
        {
hgs
parents:
diff changeset
  1295
        retVal = KErrDiskFull;
hgs
parents:
diff changeset
  1296
        }
hgs
parents:
diff changeset
  1297
    
hgs
parents:
diff changeset
  1298
    FTRACE(FPrint(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetMmcFileSystemStatus completed with %d."), retVal));
hgs
parents:
diff changeset
  1299
    return retVal;
hgs
parents:
diff changeset
  1300
    }
hgs
parents:
diff changeset
  1301
hgs
parents:
diff changeset
  1302
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1303
// TObexUtilsMessageHandler::GetMessageCentreDriveL
hgs
parents:
diff changeset
  1304
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1305
//
hgs
parents:
diff changeset
  1306
EXPORT_C TInt TObexUtilsMessageHandler::GetMessageCentreDriveL()
hgs
parents:
diff changeset
  1307
    {
hgs
parents:
diff changeset
  1308
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetMessageCentreDriveL()"));
hgs
parents:
diff changeset
  1309
    
hgs
parents:
diff changeset
  1310
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
  1311
    CMsvSession* msvSession;
hgs
parents:
diff changeset
  1312
    CreateMsvSessionLC(sessionObs, msvSession);  // 1st, 2nd push
hgs
parents:
diff changeset
  1313
    
hgs
parents:
diff changeset
  1314
    TDriveUnit driveUnit = msvSession->CurrentDriveL();
hgs
parents:
diff changeset
  1315
    CleanupStack::PopAndDestroy(2);  // msvSession, sessionObs
hgs
parents:
diff changeset
  1316
    
hgs
parents:
diff changeset
  1317
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::GetMessageCentreDriveL() Completed"));
hgs
parents:
diff changeset
  1318
    return driveUnit;
hgs
parents:
diff changeset
  1319
    }
hgs
parents:
diff changeset
  1320
hgs
parents:
diff changeset
  1321
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1322
// TObexUtilsMessageHandler::CreateDefaultMtmServiceL
hgs
parents:
diff changeset
  1323
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1324
//
hgs
parents:
diff changeset
  1325
EXPORT_C void TObexUtilsMessageHandler::CreateDefaultMtmServiceL(TUid aMtm)
hgs
parents:
diff changeset
  1326
    {
hgs
parents:
diff changeset
  1327
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateDefaultMtmServiceL()"));
hgs
parents:
diff changeset
  1328
    
hgs
parents:
diff changeset
  1329
    CDummySessionObserver* sessionObs;
hgs
parents:
diff changeset
  1330
    CMsvSession* msvSession;
hgs
parents:
diff changeset
  1331
    CMsvEntry* root;
hgs
parents:
diff changeset
  1332
    CreateMsvSessionLC(sessionObs, msvSession, root, KMsvRootIndexEntryId);
hgs
parents:
diff changeset
  1333
    // 1st, 2nd, 3rd push
hgs
parents:
diff changeset
  1334
    
hgs
parents:
diff changeset
  1335
    TMsvSelectionOrdering msvSelectionOrdering = root->SortType();
hgs
parents:
diff changeset
  1336
    msvSelectionOrdering.SetShowInvisibleEntries( ETrue );
hgs
parents:
diff changeset
  1337
    root->SetSortTypeL( msvSelectionOrdering );
hgs
parents:
diff changeset
  1338
    
hgs
parents:
diff changeset
  1339
    CMsvEntrySelection* sel = root->ChildrenWithMtmL( aMtm );
hgs
parents:
diff changeset
  1340
    CleanupStack::PushL( sel );  // 4th push
hgs
parents:
diff changeset
  1341
    if (sel->Count() == 0)
hgs
parents:
diff changeset
  1342
        {
hgs
parents:
diff changeset
  1343
        TMsvEntry serviceEntry;
hgs
parents:
diff changeset
  1344
        serviceEntry.iMtm = aMtm;
hgs
parents:
diff changeset
  1345
        serviceEntry.iType = KUidMsvServiceEntry;
hgs
parents:
diff changeset
  1346
        serviceEntry.SetVisible(EFalse);
hgs
parents:
diff changeset
  1347
        serviceEntry.SetReadOnly(ETrue);
hgs
parents:
diff changeset
  1348
        serviceEntry.SetInPreparation(EFalse);
hgs
parents:
diff changeset
  1349
        root->CreateL(serviceEntry);
hgs
parents:
diff changeset
  1350
        }
hgs
parents:
diff changeset
  1351
    CleanupStack::PopAndDestroy(4);  // sel, root, msvSession, sessionObs
hgs
parents:
diff changeset
  1352
    
hgs
parents:
diff changeset
  1353
    FLOG(_L("[OBEXUTILS]\t TObexUtilsMessageHandler::CreateDefaultMtmServiceL() Completed"));
hgs
parents:
diff changeset
  1354
    }
hgs
parents:
diff changeset
  1355
hgs
parents:
diff changeset
  1356
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1357
// GetCenRepKeyIntValue Gets integer value for a specified CenRep key
hgs
parents:
diff changeset
  1358
// Returns: CenRep key's value
hgs
parents:
diff changeset
  1359
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1360
//
hgs
parents:
diff changeset
  1361
EXPORT_C TInt TObexUtilsMessageHandler::GetPubSubKeyIntValue(
hgs
parents:
diff changeset
  1362
    TUid aCategory,  // Category of the key
hgs
parents:
diff changeset
  1363
    TUint aKey,      // PUBSUB key
hgs
parents:
diff changeset
  1364
    TInt& value)     // Returned value
hgs
parents:
diff changeset
  1365
    {
hgs
parents:
diff changeset
  1366
    TInt retVal;
hgs
parents:
diff changeset
  1367
    RProperty property;
hgs
parents:
diff changeset
  1368
    retVal = property.Attach(aCategory, aKey);
hgs
parents:
diff changeset
  1369
    if ( retVal == KErrNone )
hgs
parents:
diff changeset
  1370
        {
hgs
parents:
diff changeset
  1371
        retVal = property.Get(value);
hgs
parents:
diff changeset
  1372
        if (retVal != KErrNone)
hgs
parents:
diff changeset
  1373
            {
hgs
parents:
diff changeset
  1374
            FLOG(_L("[OBEXUTILS]\t GetPubSubKeyIntValue() Get failed for CenRep key"));
hgs
parents:
diff changeset
  1375
            }
hgs
parents:
diff changeset
  1376
        }
hgs
parents:
diff changeset
  1377
    else
hgs
parents:
diff changeset
  1378
        {
hgs
parents:
diff changeset
  1379
        FLOG(_L("[OBEXUTILS]\t GetPubSubKeyIntValue() Attach failed for CenRep key"));
hgs
parents:
diff changeset
  1380
        }
hgs
parents:
diff changeset
  1381
    property.Close();
hgs
parents:
diff changeset
  1382
    return retVal;
hgs
parents:
diff changeset
  1383
    }
hgs
parents:
diff changeset
  1384
hgs
parents:
diff changeset
  1385
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1386
// SetBioDataTextL Converts message type to bio message id.
hgs
parents:
diff changeset
  1387
// Returns: None.
hgs
parents:
diff changeset
  1388
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1389
//
hgs
parents:
diff changeset
  1390
void TObexUtilsMessageHandler::SetBioDataTextL(
hgs
parents:
diff changeset
  1391
    TBioMsgIdText& aText, // A bio message id text.
hgs
parents:
diff changeset
  1392
    const TDesC8& aType ) // The type of the content. 
hgs
parents:
diff changeset
  1393
    {
hgs
parents:
diff changeset
  1394
    FLOG(_L("[OBEXUTILS]\t SetBioDataTextL()"));
hgs
parents:
diff changeset
  1395
hgs
parents:
diff changeset
  1396
    HBufC16* unicode = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aType );
hgs
parents:
diff changeset
  1397
    CleanupStack::PushL( unicode );
hgs
parents:
diff changeset
  1398
    
hgs
parents:
diff changeset
  1399
    if (unicode->Length() > KMaxBioIdText )
hgs
parents:
diff changeset
  1400
        {
hgs
parents:
diff changeset
  1401
        User::Leave( KErrOverflow );
hgs
parents:
diff changeset
  1402
        }
hgs
parents:
diff changeset
  1403
    
hgs
parents:
diff changeset
  1404
    aText = unicode->Des();
hgs
parents:
diff changeset
  1405
    CleanupStack::PopAndDestroy( unicode );
hgs
parents:
diff changeset
  1406
    
hgs
parents:
diff changeset
  1407
    FLOG(_L("[OBEXUTILS]\t SetBioDataTextL() completed"));
hgs
parents:
diff changeset
  1408
    }
hgs
parents:
diff changeset
  1409
hgs
parents:
diff changeset
  1410
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1411
// SetDetailsLC Converts message type to unicode.
hgs
parents:
diff changeset
  1412
// Returns: None.
hgs
parents:
diff changeset
  1413
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1414
//
hgs
parents:
diff changeset
  1415
void TObexUtilsMessageHandler::SetDetailsLC(
hgs
parents:
diff changeset
  1416
    TPtrC& aDetails,      // A message text.
hgs
parents:
diff changeset
  1417
    const TDesC8& aType ) // The type of the content.
hgs
parents:
diff changeset
  1418
    {
hgs
parents:
diff changeset
  1419
    FLOG(_L("[OBEXUTILS]\t SetDetailsLC()"));
hgs
parents:
diff changeset
  1420
hgs
parents:
diff changeset
  1421
    HBufC16* unicode = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aType );
hgs
parents:
diff changeset
  1422
    CleanupStack::PushL( unicode );
hgs
parents:
diff changeset
  1423
    aDetails.Set(unicode->Des());
hgs
parents:
diff changeset
  1424
hgs
parents:
diff changeset
  1425
    FLOG(_L("[OBEXUTILS]\t SetDetailsLC() completed"));
hgs
parents:
diff changeset
  1426
    }
hgs
parents:
diff changeset
  1427
hgs
parents:
diff changeset
  1428
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1429
// Rename a file and move file if needed 
hgs
parents:
diff changeset
  1430
// Return: None.
hgs
parents:
diff changeset
  1431
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1432
//
hgs
parents:
diff changeset
  1433
TInt TObexUtilsMessageHandler::RenameFileL(
hgs
parents:
diff changeset
  1434
    TFileName& aFileName, 
hgs
parents:
diff changeset
  1435
    TFileName& aNewFileName,
hgs
parents:
diff changeset
  1436
    const TDesC& aNewPath, 
hgs
parents:
diff changeset
  1437
    RFs& aFileSession)
hgs
parents:
diff changeset
  1438
    {
hgs
parents:
diff changeset
  1439
    
hgs
parents:
diff changeset
  1440
    // We move the file to the final location
hgs
parents:
diff changeset
  1441
    //
hgs
parents:
diff changeset
  1442
    CFileMan* fileMan= CFileMan::NewL(aFileSession);
hgs
parents:
diff changeset
  1443
    CleanupStack::PushL(fileMan);       
hgs
parents:
diff changeset
  1444
    TPtrC tmpNewPath;
hgs
parents:
diff changeset
  1445
    TParse fileParse;
hgs
parents:
diff changeset
  1446
    fileParse.Set(aFileName, NULL, NULL);
hgs
parents:
diff changeset
  1447
    
hgs
parents:
diff changeset
  1448
    TInt error = fileMan->Move(aFileName,aNewPath,CFileMan::ERecurse );
hgs
parents:
diff changeset
  1449
    
hgs
parents:
diff changeset
  1450
    // if error while moving to new location, keep file in old location and change file name
hgs
parents:
diff changeset
  1451
    if (error != KErrNone)
hgs
parents:
diff changeset
  1452
        {
hgs
parents:
diff changeset
  1453
        tmpNewPath.Set (fileParse.DriveAndPath()); 
hgs
parents:
diff changeset
  1454
        }
hgs
parents:
diff changeset
  1455
    else
hgs
parents:
diff changeset
  1456
        {
hgs
parents:
diff changeset
  1457
        tmpNewPath.Set (aNewPath);
hgs
parents:
diff changeset
  1458
        }
hgs
parents:
diff changeset
  1459
    
hgs
parents:
diff changeset
  1460
    CleanupStack::PopAndDestroy(fileMan);
hgs
parents:
diff changeset
  1461
hgs
parents:
diff changeset
  1462
    TFileName tempFile;
hgs
parents:
diff changeset
  1463
    tempFile.Append(tmpNewPath);
hgs
parents:
diff changeset
  1464
    tempFile.Append(fileParse.NameAndExt());
hgs
parents:
diff changeset
  1465
    aFileName = tempFile;
hgs
parents:
diff changeset
  1466
    
hgs
parents:
diff changeset
  1467
    // check the duplicated file name. if so, we renamed in a different way. 
hgs
parents:
diff changeset
  1468
    TInt segmentNum = 0;
hgs
parents:
diff changeset
  1469
    TBuf<64> segmentString;
hgs
parents:
diff changeset
  1470
    
hgs
parents:
diff changeset
  1471
    TFileName newFullName;
hgs
parents:
diff changeset
  1472
    newFullName.Zero();
hgs
parents:
diff changeset
  1473
    newFullName.Append(tmpNewPath);
hgs
parents:
diff changeset
  1474
    newFullName.Append(aNewFileName);
hgs
parents:
diff changeset
  1475
    
hgs
parents:
diff changeset
  1476
    aFileSession.SetSessionPath(tmpNewPath);
hgs
parents:
diff changeset
  1477
    
hgs
parents:
diff changeset
  1478
    while ( BaflUtils::FileExists(aFileSession, newFullName) )    
hgs
parents:
diff changeset
  1479
        {
hgs
parents:
diff changeset
  1480
        segmentNum++;
hgs
parents:
diff changeset
  1481
        User::LeaveIfError( RenameFileWithSegmentNumL(aNewFileName, segmentNum, segmentString) );
hgs
parents:
diff changeset
  1482
        newFullName.Zero();
hgs
parents:
diff changeset
  1483
        newFullName.Append(tmpNewPath);
hgs
parents:
diff changeset
  1484
        newFullName.Append(aNewFileName);
hgs
parents:
diff changeset
  1485
        }
hgs
parents:
diff changeset
  1486
    // rename the file.
hgs
parents:
diff changeset
  1487
    //
hgs
parents:
diff changeset
  1488
    error = aFileSession.Rename(aFileName, newFullName);
hgs
parents:
diff changeset
  1489
hgs
parents:
diff changeset
  1490
    aFileName = newFullName;
hgs
parents:
diff changeset
  1491
    
hgs
parents:
diff changeset
  1492
    return error;
hgs
parents:
diff changeset
  1493
    }
hgs
parents:
diff changeset
  1494
hgs
parents:
diff changeset
  1495
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1496
// Rename a file by adding a additional segment string
hgs
parents:
diff changeset
  1497
// Return: None.
hgs
parents:
diff changeset
  1498
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1499
//
hgs
parents:
diff changeset
  1500
TInt TObexUtilsMessageHandler::RenameFileWithSegmentNumL(
hgs
parents:
diff changeset
  1501
    TDes &aFileName,        // name for the file 
hgs
parents:
diff changeset
  1502
    TInt aSegmentNum,       // segment number
hgs
parents:
diff changeset
  1503
    TDes &aSegmentString)   // segment String with parenthesis
hgs
parents:
diff changeset
  1504
    {
hgs
parents:
diff changeset
  1505
    
hgs
parents:
diff changeset
  1506
    FLOG(_L("[OBEXUTILS]\t RenameFileWithSegmentNumL()"));
hgs
parents:
diff changeset
  1507
hgs
parents:
diff changeset
  1508
    const char KDot = '.';
hgs
parents:
diff changeset
  1509
    const char KLeftParenthesis = '(';
hgs
parents:
diff changeset
  1510
    const char KRightParenthesis = ')';
hgs
parents:
diff changeset
  1511
    
hgs
parents:
diff changeset
  1512
    // Convert Integer to String
hgs
parents:
diff changeset
  1513
    // 
hgs
parents:
diff changeset
  1514
    TBuf<64> buf;
hgs
parents:
diff changeset
  1515
    buf.Zero();
hgs
parents:
diff changeset
  1516
    _LIT(KNum, "%d" );
hgs
parents:
diff changeset
  1517
    buf.AppendFormat(KNum, aSegmentNum);
hgs
parents:
diff changeset
  1518
    
hgs
parents:
diff changeset
  1519
    // Rules to modify the duplicated filenames.
hgs
parents:
diff changeset
  1520
    // case 1: No extention in filename,  we append aSegmentString directly.
hgs
parents:
diff changeset
  1521
    // case 2: Filename with extention, we insert aSegmentString right before dot (.)
hgs
parents:
diff changeset
  1522
    // case 3: Filename with aSegmentString is still duplicated, 
hgs
parents:
diff changeset
  1523
    //         we remove the old aSegmentString from aFileName and add a new one and add a new aSegmentString.
hgs
parents:
diff changeset
  1524
    
hgs
parents:
diff changeset
  1525
    TInt posOfDot = aFileName.LocateReverse(KDot);
hgs
parents:
diff changeset
  1526
    
hgs
parents:
diff changeset
  1527
    if ( aSegmentNum > 1 )   // filename with aSegementString is still duplicated
hgs
parents:
diff changeset
  1528
        {
hgs
parents:
diff changeset
  1529
        // In case the original file name contains the same string as our aSegmentString
hgs
parents:
diff changeset
  1530
        // eg 1 with ext. original filename is file(1).txt, after renaming, it is changed to file(1)(1).txt.
hgs
parents:
diff changeset
  1531
        // eg 2 without ext. original filename is file(1), after renaming, it is changed to file(1)(1).
hgs
parents:
diff changeset
  1532
        TInt posDeleteStarts = posOfDot == KErrNotFound ? 
hgs
parents:
diff changeset
  1533
                                aFileName.Length() - aSegmentString.Length() :
hgs
parents:
diff changeset
  1534
                                posOfDot - aSegmentString.Length();
hgs
parents:
diff changeset
  1535
                                
hgs
parents:
diff changeset
  1536
        aFileName.Delete(posDeleteStarts, aSegmentString.Length());
hgs
parents:
diff changeset
  1537
        }
hgs
parents:
diff changeset
  1538
    
hgs
parents:
diff changeset
  1539
    // Construct (New) aSegmentString
hgs
parents:
diff changeset
  1540
    aSegmentString.Zero();
hgs
parents:
diff changeset
  1541
    aSegmentString.Append(KLeftParenthesis);
hgs
parents:
diff changeset
  1542
    aSegmentString.Append(buf);
hgs
parents:
diff changeset
  1543
    aSegmentString.Append(KRightParenthesis);
hgs
parents:
diff changeset
  1544
    
hgs
parents:
diff changeset
  1545
    // 
hgs
parents:
diff changeset
  1546
    // If the length of new filename will be larger than KMaxFileName, we remove few chars from the end of aFilename 
hgs
parents:
diff changeset
  1547
    // in order to add aSegmentString without panic.
hgs
parents:
diff changeset
  1548
    // 
hgs
parents:
diff changeset
  1549
    if ( KMaxFileName < (aFileName.Length() + aSegmentString.Length()))
hgs
parents:
diff changeset
  1550
        {
hgs
parents:
diff changeset
  1551
        aFileName.Delete(KMaxFileName - aSegmentString.Length(), KMaxFileName - aFileName.Length());
hgs
parents:
diff changeset
  1552
        }
hgs
parents:
diff changeset
  1553
    
hgs
parents:
diff changeset
  1554
    posOfDot = aFileName.LocateReverse(KDot);
hgs
parents:
diff changeset
  1555
    if ( posOfDot == KErrNotFound )   
hgs
parents:
diff changeset
  1556
        {
hgs
parents:
diff changeset
  1557
        // aFileName has no extension
hgs
parents:
diff changeset
  1558
        // we append the modification to aFileName
hgs
parents:
diff changeset
  1559
        //
hgs
parents:
diff changeset
  1560
        aFileName.Append(aSegmentString);
hgs
parents:
diff changeset
  1561
        }
hgs
parents:
diff changeset
  1562
    else
hgs
parents:
diff changeset
  1563
        {
hgs
parents:
diff changeset
  1564
        // Dot (.) is found, we insert the modifications before dot.
hgs
parents:
diff changeset
  1565
        //
hgs
parents:
diff changeset
  1566
        aFileName.Insert(posOfDot,aSegmentString);
hgs
parents:
diff changeset
  1567
        
hgs
parents:
diff changeset
  1568
        }
hgs
parents:
diff changeset
  1569
    
hgs
parents:
diff changeset
  1570
    FLOG(_L("[OBEXUTILS]\t RenameFileWithSegmentNumL() completed"));
hgs
parents:
diff changeset
  1571
    return KErrNone;
hgs
parents:
diff changeset
  1572
    }
hgs
parents:
diff changeset
  1573
hgs
parents:
diff changeset
  1574
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1575
// Shorten an extreme long file name
hgs
parents:
diff changeset
  1576
// Return: None.
hgs
parents:
diff changeset
  1577
//-------------------------------------------------------------------------------
hgs
parents:
diff changeset
  1578
//
hgs
parents:
diff changeset
  1579
void TObexUtilsMessageHandler::FixExtremeLongFileName(TFileName& aExtremeLongFileName, const TDesC& aDriveAndPath)
hgs
parents:
diff changeset
  1580
     {
hgs
parents:
diff changeset
  1581
     FLOG( _L( "[OBEXUTILS]\t FixExtremeLongFileName() ") );
hgs
parents:
diff changeset
  1582
     const char KDot = '.';
hgs
parents:
diff changeset
  1583
     TInt combinedLength = aExtremeLongFileName.Length() + aDriveAndPath.Length();
hgs
parents:
diff changeset
  1584
     
hgs
parents:
diff changeset
  1585
     if ( combinedLength > aExtremeLongFileName.MaxLength() )
hgs
parents:
diff changeset
  1586
        {
hgs
parents:
diff changeset
  1587
        FLOG( _L( "[OBEXUTILS]\t FixExtremeLongFileName: combinedLenght > aExtremeLongFileName.MaxLength()\t") );
hgs
parents:
diff changeset
  1588
         //KDefaultFileExtensionSeparator
hgs
parents:
diff changeset
  1589
         TFileName tempFileName;
hgs
parents:
diff changeset
  1590
         TInt dotPos = aExtremeLongFileName.LocateReverse( KDot );    
hgs
parents:
diff changeset
  1591
         TInt overLap = combinedLength - aExtremeLongFileName.MaxLength() + KRenameOffSet;  
hgs
parents:
diff changeset
  1592
 
hgs
parents:
diff changeset
  1593
         if ( dotPos > 0 )
hgs
parents:
diff changeset
  1594
             {
hgs
parents:
diff changeset
  1595
             tempFileName.Copy( aExtremeLongFileName.Left( dotPos - overLap ) );
hgs
parents:
diff changeset
  1596
             tempFileName.Append( aExtremeLongFileName.Right( aExtremeLongFileName.Length() - dotPos ) );  
hgs
parents:
diff changeset
  1597
             }
hgs
parents:
diff changeset
  1598
         else
hgs
parents:
diff changeset
  1599
             {
hgs
parents:
diff changeset
  1600
             tempFileName.Copy( aExtremeLongFileName.Left(aExtremeLongFileName.Length() - overLap ) );
hgs
parents:
diff changeset
  1601
             }
hgs
parents:
diff changeset
  1602
         aExtremeLongFileName.Copy( tempFileName );
hgs
parents:
diff changeset
  1603
         }
hgs
parents:
diff changeset
  1604
     FLOG( _L( "[OBEXUTILS]\t FixExtremeLongFileName() completed") );
hgs
parents:
diff changeset
  1605
     }
hgs
parents:
diff changeset
  1606
hgs
parents:
diff changeset
  1607
//  End of File  
hgs
parents:
diff changeset
  1608