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