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