javaextensions/midppush/pushregistryplugin/src/pushconncompletedtimercontainer.cpp
changeset 21 2a9601315dfc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javaextensions/midppush/pushregistryplugin/src/pushconncompletedtimercontainer.cpp	Mon May 03 12:27:20 2010 +0300
@@ -0,0 +1,143 @@
+/*
+* Copyright (c) 2009 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:
+*
+*/
+
+#include "pushconncompletedtimercontainer.h"
+#include "pushconstant.h"
+#include "logger.h"
+
+using namespace java::push;
+using namespace java::captain;
+using namespace java::comms;
+
+/**
+ *
+ */
+PushConnCompletedTimer::PushConnCompletedTimer(int aTimerId,const std::wstring& aUri,
+        const java::comms::CommsMessage& aCommsMsg)
+        : mTimerId(aTimerId),mUri(aUri),mCommsMsg(aCommsMsg)
+{
+}
+
+/**
+ *
+ */
+PushConnCompletedTimer::~PushConnCompletedTimer()
+{
+}
+
+/**
+ *
+ */
+PushConnCompletedTimer::PushConnCompletedTimer(const PushConnCompletedTimer& aData)
+{
+    *this = aData;
+}
+
+/**
+ *
+ */
+PushConnCompletedTimer& PushConnCompletedTimer::operator=(const PushConnCompletedTimer& x)
+{
+    mTimerId = x.mTimerId;
+    mUri = x.mUri;
+    mCommsMsg = x.mCommsMsg;
+    return *this;
+}
+
+/**
+ *
+ */
+PushConnCompletedTimerContainer::PushConnCompletedTimerContainer(TimerServerInterface& aTimerServer,
+        PushConnCompletedTimerListener& aListener)
+        : mTimerServer(aTimerServer),mListener(aListener)
+{
+    JELOG2(EJavaPush);
+}
+
+/**
+ *
+ */
+PushConnCompletedTimerContainer::~PushConnCompletedTimerContainer()
+{
+    JELOG2(EJavaPush);
+
+    //It is enough to clear content of timer list container without cancelling pending
+    //timers because this object is deleted only when JavaCaptain process is closed.
+    mTimerList.clear();
+}
+
+/**
+ *
+ */
+void PushConnCompletedTimerContainer::setTimer(const std::wstring& aUri,const CommsMessage& aMsg)
+{
+    JELOG2(EJavaPush);
+
+    int timerId = mTimerServer.timerCreateSeconds(TIMEOUT_VALUE_FOR_UNREG_RESPONSE,this);
+    if (0 == timerId)
+    {
+        ELOG(EJavaPush,"ERROR!!! PushConnCompletedTimerContainer::setTimer() creation of the timer failed");
+        return;
+    }
+    PushConnCompletedTimer dataObj(timerId,aUri,aMsg);
+    mTimerList.push_back(dataObj);
+}
+
+/**
+ *
+ */
+void PushConnCompletedTimerContainer::cancelTimer(const std::wstring& aUri)
+{
+    JELOG2(EJavaPush);
+
+    for (TimerListIter_t iter = mTimerList.begin(); iter != mTimerList.end(); ++iter)
+    {
+        if (iter->mUri == aUri)
+        {
+            mTimerServer.timerCancel(iter->mTimerId);
+            mListener.connCompletedTimerExpired(iter->mCommsMsg);
+            mTimerList.erase(iter);
+            break;
+        }
+    }//end for
+}
+
+/**
+ *
+ */
+void PushConnCompletedTimerContainer::timerTimeout(const int& aTimerId)
+{
+    JELOG2(EJavaPush);
+
+    ELOG(EJavaPush,
+         "ERROR!!! PushConnCompletedTimerContainer::timerTimeout Timeout occurs");
+
+    for (TimerListIter_t iter = mTimerList.begin(); iter != mTimerList.end(); ++iter)
+    {
+        if (iter->mTimerId == aTimerId)
+        {
+            mListener.connCompletedTimerExpired(iter->mCommsMsg);
+            mTimerList.erase(iter);
+            break;
+        }
+    }//end for
+}
+
+
+
+
+