messagingapp/msgappfw/server/src/ccsconversationmarkreadhandler.cpp
changeset 23 238255e8b033
child 25 84d9eb65b26f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingapp/msgappfw/server/src/ccsconversationmarkreadhandler.cpp	Fri Apr 16 14:56:15 2010 +0300
@@ -0,0 +1,205 @@
+/*
+* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:  CS Server Mark read Handler
+*
+*/
+// INCLUDES
+#include <ccsclientconversation.h>
+#include <ccsconversationentry.h>
+#include "ccsconversationcache.h"
+#include "ccsconversationmarkreadhandler.h"
+#include "mcsconversationmarkreadobserver.h"
+#include <mmsconst.h>
+
+// ----------------------------------------------------------------------------
+// CCsConversationMarkReadHandler::NewL
+// Two Phase Construction
+// ----------------------------------------------------------------------------
+CCsConversationMarkReadHandler* CCsConversationMarkReadHandler::
+NewL(CCsConversationCache* aCache, MCsConversationMarkReadObserver* aObserver)
+    {
+    CCsConversationMarkReadHandler* self = 
+            new (ELeave) CCsConversationMarkReadHandler();
+    CleanupStack::PushL(self);
+    self->ConstructL(aCache, aObserver);
+    CleanupStack::Pop(self); // self
+    return self;
+    }
+
+// ----------------------------------------------------------------------------
+// Constructor
+// ----------------------------------------------------------------------------
+CCsConversationMarkReadHandler::CCsConversationMarkReadHandler():
+        CActive(CActive::EPriorityLow)
+    {
+    CActiveScheduler::Add( this );
+    }
+
+// ----------------------------------------------------------------------------
+// Constructor
+// ----------------------------------------------------------------------------
+void CCsConversationMarkReadHandler::ConstructL(CCsConversationCache* aCache,
+        MCsConversationMarkReadObserver* aObserver)
+    {
+    iCache = aCache;
+    iState = EMarkReadIdle;
+    iObserver = aObserver;
+    
+    iConversationEntryList = new (ELeave)RPointerArray<CCsConversationEntry> ();  
+    iSession = CMsvSession::OpenSyncL(*this);
+    }
+
+// ----------------------------------------------------------------------------
+// Destructor
+// ----------------------------------------------------------------------------
+CCsConversationMarkReadHandler::~CCsConversationMarkReadHandler()
+    {
+    if(iSession)
+        {
+        delete iSession;
+        iSession = NULL;
+        }
+    }
+
+// ----------------------------------------------------------------------------
+// Mark set of messages as read
+// ----------------------------------------------------------------------------
+void CCsConversationMarkReadHandler::MarkReadL(TInt aConversationId)
+    {
+    // Temp client conversation object
+    CCsClientConversation* clientConversation = CCsClientConversation::NewL();
+    clientConversation->SetConversationEntryId(aConversationId);
+    CleanupStack::PushL(clientConversation);
+    
+    // Create entry list
+    iConversationEntryList = new (ELeave)RPointerArray<CCsConversationEntry> ();  
+    
+    // Get conversationlist for given client conversation
+    iCache->GetConversationsL (clientConversation, iConversationEntryList);
+    
+    iMarkReadCount = 0;
+    
+    // Cleanup  
+    CleanupStack::PopAndDestroy(clientConversation);
+        
+    iState = EMarkReadStart;
+    IssueRequest();
+    }
+
+// ----------------------------------------------------------------------------
+// Mark read a message
+// ----------------------------------------------------------------------------
+void CCsConversationMarkReadHandler::MarkReadOneMessageL()
+    {
+    CCsConversationEntry* entry = 
+            static_cast<CCsConversationEntry*>((*iConversationEntryList)[iMarkReadCount]);    
+  
+    if ( entry->IsAttributeSet(ECsAttributeNew) ||
+         entry->IsAttributeSet(ECsAttributeUnread) )
+        {    
+        TInt id = entry->EntryId();          
+        
+        CMsvEntry* cEntry = NULL;
+        TRAPD(err, cEntry = iSession->GetEntryL(id));
+        if ( err == KErrNotFound )
+           return;
+        
+        TMsvEntry entry = cEntry->Entry();
+        if ( entry.Unread() ) 
+           {
+           // Mark the entry as read
+            if(entry.iMtm != KUidMsgTypeMultimedia)
+            {
+                entry.SetUnread( EFalse );
+            }
+           cEntry->ChangeL( entry );
+           }
+        delete cEntry;
+        }
+    }
+
+// ----------------------------------------------------------------------------
+// RunL
+// ----------------------------------------------------------------------------
+void CCsConversationMarkReadHandler::RunL()
+    {
+    switch ( iState )
+        {
+        case EMarkReadStart:
+            if ( iConversationEntryList->Count() > 0 )
+                {
+                iMarkReadCount = iConversationEntryList->Count();
+                iState = EMarkReadNext;
+                IssueRequest();
+                }
+            else
+                {
+                iState = EMarkReadComplete;
+                IssueRequest();
+                }
+            break;
+        
+        case EMarkReadNext:
+            iMarkReadCount--;
+            MarkReadOneMessageL();
+            if ( iMarkReadCount > 0 )
+                {
+                iState = EMarkReadNext;
+                IssueRequest();
+                }
+            else
+                {
+                iState = EMarkReadComplete;
+                IssueRequest();
+                }
+            break;
+            
+        case EMarkReadComplete:
+            // Cleanup
+            iMarkReadCount = 0;
+            iConversationEntryList->ResetAndDestroy();
+            iConversationEntryList->Close();
+            delete iConversationEntryList;
+            iConversationEntryList = NULL;  
+            
+            // Notify observers
+            iObserver->MarkReadComplete(this);
+            break;
+        }
+    }
+
+// ----------------------------------------------------------------------------
+// DoCancel
+// ----------------------------------------------------------------------------
+void CCsConversationMarkReadHandler::DoCancel()
+    {
+    // Not supported
+    }
+
+// ---------------------------------------------------------------------------
+// Move to next state
+// ---------------------------------------------------------------------------
+//
+void CCsConversationMarkReadHandler::IssueRequest()
+    {
+    if( !IsActive() )
+        {
+        iStatus = KRequestPending;
+        TRequestStatus* status = &iStatus;
+        SetActive();
+        User::RequestComplete(status, KErrNone);
+        }
+    }
+
+// EOF