pushmtm/Plugins/PushContentHandler/PushMtmAutoFetchOperation.cpp
branchRCL_3
changeset 65 8e6fa1719340
parent 0 84ad3b177aa3
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/pushmtm/Plugins/PushContentHandler/PushMtmAutoFetchOperation.cpp	Wed Sep 01 12:31:04 2010 +0100
@@ -0,0 +1,235 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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:  Implementation of CPushMtmAutoFetchOperation.
+*
+*/
+
+
+
+// INCLUDE FILES
+
+#include "PushMtmAutoFetchOperation.h"
+#include "PushMtmFetchOperation.h"
+#include "PushContentHandlerPanic.h"
+#include "PushMtmLog.h"
+
+// CONSTANTS
+
+/// Max retry.
+LOCAL_D const TInt KMaxTry = 2;
+
+// ================= MEMBER FUNCTIONS =======================
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::NewL
+// ---------------------------------------------------------
+//
+CPushMtmAutoFetchOperation* CPushMtmAutoFetchOperation::NewL
+            (
+                const TDesC& aRequestedUrl, 
+                TInt aTimeDelayInSec, 
+                TRequestStatus& aObserverRequestStatus 
+            )
+    {
+    CPushMtmAutoFetchOperation* op = 
+        new (ELeave) CPushMtmAutoFetchOperation
+            ( aTimeDelayInSec, aObserverRequestStatus );
+    CleanupStack::PushL( op );
+    op->ConstructL( aRequestedUrl );
+    CleanupStack::Pop(); // op
+    return op;
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::~CPushMtmAutoFetchOperation
+// ---------------------------------------------------------
+//
+CPushMtmAutoFetchOperation::~CPushMtmAutoFetchOperation()
+    {
+    Cancel();
+    delete iFetchOp;
+    delete iRequestedUrl;
+	iTimer.Close();
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::StartL
+// ---------------------------------------------------------
+//
+void CPushMtmAutoFetchOperation::StartL()
+    {
+    PUSHLOG_ENTERFN("CPushMtmAutoFetchOperation::StartL")
+
+    Cancel();
+
+    iTry = 0;
+    iState = EFetch;
+
+	SetActive();
+    TRequestStatus* status = &iStatus;
+    User::RequestComplete( status, KErrNone );
+
+    PUSHLOG_LEAVEFN("CPushMtmAutoFetchOperation::StartL")
+	}
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::CPushMtmAutoFetchOperation
+// ---------------------------------------------------------
+//
+CPushMtmAutoFetchOperation::CPushMtmAutoFetchOperation
+                            
+        ( 
+            TInt aTimeDelayInSec, 
+            TRequestStatus& aObserverRequestStatus 
+        )
+:   CActive( EPriorityStandard ), 
+    iObserver( aObserverRequestStatus ),
+    iState( EInit ), 
+    iTimeDelayInSec( aTimeDelayInSec )
+    {
+    CActiveScheduler::Add( this );
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::ConstructL
+// ---------------------------------------------------------
+//
+void CPushMtmAutoFetchOperation::ConstructL( const TDesC& aRequestedUrl )
+    {
+    PUSHLOG_ENTERFN("CPushMtmAutoFetchOperation::ConstructL")
+
+    iRequestedUrl = HBufC::NewMaxL( aRequestedUrl.Length() );
+    iRequestedUrl->Des().Copy( aRequestedUrl );
+
+    User::LeaveIfError( iTimer.CreateLocal() );
+
+    PUSHLOG_LEAVEFN("CPushMtmAutoFetchOperation::ConstructL")
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::FetchL
+// ---------------------------------------------------------
+//
+void CPushMtmAutoFetchOperation::FetchL()
+    {
+    PUSHLOG_ENTERFN("CPushMtmAutoFetchOperation::FetchL")
+
+    delete iFetchOp;
+    iFetchOp = NULL;
+    iStatus = KRequestPending;
+    SetActive();
+    iFetchOp = CPushMtmFetchOperation::NewL( *iRequestedUrl, iStatus );
+    PUSHLOG_WRITE(" Fetch op created")
+
+    ++iTry; // Increase indicator.
+    PUSHLOG_WRITE_FORMAT(" Try: %d",iTry)
+    iFetchOp->StartL();
+    iState = ECheck; // Next state.
+    PUSHLOG_WRITE(" Fetch op started")
+
+    PUSHLOG_LEAVEFN("CPushMtmAutoFetchOperation::FetchL")
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::DoCancel
+// ---------------------------------------------------------
+//
+void CPushMtmAutoFetchOperation::DoCancel()
+    {
+    if ( iFetchOp )
+        {
+        iFetchOp->Cancel();
+        }
+
+    iTimer.Cancel();
+
+    TRequestStatus* status = &iObserver;
+    User::RequestComplete( status, KErrCancel );
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::RunL
+// ---------------------------------------------------------
+//
+void CPushMtmAutoFetchOperation::RunL()
+    {
+    PUSHLOG_ENTERFN("CPushMtmAutoFetchOperation::RunL")
+
+    __ASSERT_DEBUG( iState != EInit && iState != EDone, 
+                    ContHandPanic( EPushContHandPanAutBadState ) );
+
+    switch ( iState )
+        {
+        case EFetch:
+            {
+            PUSHLOG_WRITE(" EFetch")
+            FetchL();
+            break;
+            }
+
+        case ECheck:
+            {
+            PUSHLOG_WRITE_FORMAT2(" ECheck: %d,%d",iStatus.Int(),iTry)
+            if ( iStatus.Int() != KErrNone && iTry < KMaxTry )
+                {
+                // Wait and Retry.
+                iTimer.Cancel();
+                iStatus = KRequestPending;
+                SetActive();
+                TTimeIntervalMicroSeconds32 delayInMSec = 
+                                            iTimeDelayInSec * 1000000;
+                iTimer.After( iStatus, delayInMSec );
+                iState = EFetch;
+                }
+            else
+                {
+                // No error or no more trial allowed.
+                iState = EDone;
+                PUSHLOG_WRITE_FORMAT(" SignalObs: %d",iStatus.Int());
+                TRequestStatus* status = &iObserver;
+                User::RequestComplete( status, iStatus.Int() );
+                }
+            break;
+            }
+
+        default:
+            {
+            PUSHLOG_WRITE(" default")
+            // JIC.
+            iState = EDone;
+            TRequestStatus* status = &iObserver;
+            User::RequestComplete( status, KErrNone );
+            break;
+            }
+        }
+
+    PUSHLOG_LEAVEFN("CPushMtmAutoFetchOperation::RunL")
+    }
+
+// ---------------------------------------------------------
+// CPushMtmAutoFetchOperation::RunError
+// ---------------------------------------------------------
+//
+TInt CPushMtmAutoFetchOperation::RunError( TInt aError )
+    {
+    PUSHLOG_WRITE_FORMAT("CPushMtmAutoFetchOperation::RunError <%d>",aError);
+
+    // Signal the observer that a leave has occured.
+    TRequestStatus* status = &iObserver;
+    User::RequestComplete( status, aError );
+
+    return KErrNone;
+    }
+
+// End of file.