ximpfw/presence/srcpresencecache/presencecacheserver/presencecachebuddystore.cpp
changeset 0 e6b17d312c8b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ximpfw/presence/srcpresencecache/presencecacheserver/presencecachebuddystore.cpp	Thu Dec 17 08:54:49 2009 +0200
@@ -0,0 +1,269 @@
+/*
+* Copyright (c) 2008 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:  Store object for single buddy in a service
+*
+*/
+
+
+#include "presencecachebuddystore.h"
+#include "presencecacheservicestore.h"
+#include "presencecachesession.h"
+#include "presencetypehelpers.h"
+#include "ximpidentityimp.h"
+#include "presencebuddyinfoimp.h"
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::NewLC()
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CPresenceCacheBuddyStore* CPresenceCacheBuddyStore::NewLC(
+                                    CPresenceCacheServiceStore* aServiceStore,
+                                    MXIMPIdentity* aIdentity)
+    {
+    CPresenceCacheBuddyStore* self = new( ELeave ) CPresenceCacheBuddyStore(
+                                            aServiceStore);
+    CleanupStack::PushL( self );
+    self->ConstructL(aIdentity);
+    return self;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::NewL()
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CPresenceCacheBuddyStore* CPresenceCacheBuddyStore::NewL(
+                                    CPresenceCacheServiceStore* aServiceStore,
+                                    MXIMPIdentity* aIdentity)
+    {
+    CPresenceCacheBuddyStore* self = NewLC(aServiceStore,aIdentity);
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::~CPresenceCacheBuddyStore()
+// ---------------------------------------------------------------------------
+//
+CPresenceCacheBuddyStore::~CPresenceCacheBuddyStore()
+    {
+    if (iPresenceBuddyInfo)
+        delete iPresenceBuddyInfo;
+    if(iIdentity)
+        delete iIdentity;
+    iSubscribedSessions.Close();
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::CPresenceCacheBuddyStore()
+// ---------------------------------------------------------------------------
+//
+CPresenceCacheBuddyStore::CPresenceCacheBuddyStore(
+          CPresenceCacheServiceStore* aServiceStore):iPresenceBuddyInfo(NULL),
+                                                    iServiceStore(aServiceStore)
+    {
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::ConstructL()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::ConstructL(MXIMPIdentity* aIdentity)
+    {
+    if(aIdentity)
+        iIdentity = TXIMPGetImpClassOrPanic< CXIMPIdentityImp >::From( *aIdentity );
+    else
+        iIdentity = CXIMPIdentityImp::NewL();
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::SetPresenceBuddyInfo()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::SetPresenceBuddyInfo(MPresenceBuddyInfo* aPresBuddyInfo)
+    {
+    if(aPresBuddyInfo)
+        {
+        if (iPresenceBuddyInfo)
+            delete iPresenceBuddyInfo;
+        iPresenceBuddyInfo = aPresBuddyInfo;
+        }
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::RemovePresenceBuddyInfo()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::RemovePresenceBuddyInfo()
+    {
+    if (iPresenceBuddyInfo)
+        delete iPresenceBuddyInfo;
+    iPresenceBuddyInfo = NULL;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::GetSubscribedSessions()
+// ---------------------------------------------------------------------------
+//
+RPointerArray<CPresenceCacheSession>& CPresenceCacheBuddyStore::GetSubscribedSessions()
+    {
+    return iSubscribedSessions;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::AddSubscribedSession()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::AddSubscribedSession(CPresenceCacheSession* aSession)
+    {
+    if(iSubscribedSessions.Find(aSession)<0)
+        iSubscribedSessions.Append(aSession);
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::RemoveSubscribedSession()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::RemoveSubscribedSession(CPresenceCacheSession* aSession)
+    {
+    TInt index = iSubscribedSessions.Find(aSession);
+    if(index>-1)
+        iSubscribedSessions.Remove(index);
+    
+    // delete this object if it doesnt have any presence or subscribers
+    if(!(iPresenceBuddyInfo || HasSubscribers()))
+        {
+        if(iServiceStore)
+            {
+            iServiceStore->RemoveBlind(this);
+            }
+        }
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::SetBuddyId()
+// ---------------------------------------------------------------------------
+//
+void CPresenceCacheBuddyStore::SetBuddyId(MXIMPIdentity* aIdentity)
+    {
+    if(aIdentity)
+        {
+        delete iIdentity;
+            iIdentity = TXIMPGetImpClassOrPanic< CXIMPIdentityImp >::From( *aIdentity );
+        }
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::ServiceName()
+// ---------------------------------------------------------------------------
+//
+TPtrC CPresenceCacheBuddyStore::ServiceName() const
+    {
+    _LIT(KColon, ":");
+    TInt pos = iIdentity->Identity().Find(KColon);
+    TPtrC serviceName;
+    if(pos>0) // if colon found and there is something before colon, i.e. xsp id
+        {
+        serviceName.Set(iIdentity->Identity().Left(pos));
+        }
+    else
+        serviceName.Set(TPtrC());
+    return serviceName;
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::PresenceBuddyInfo()
+// ---------------------------------------------------------------------------
+//
+MPresenceBuddyInfo* CPresenceCacheBuddyStore::PresenceBuddyInfo() const
+    {
+    return iPresenceBuddyInfo;
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::BuddyId()
+// ---------------------------------------------------------------------------
+//
+const MXIMPIdentity* CPresenceCacheBuddyStore::BuddyId() const
+    {
+    return iIdentity;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::EqualsIdentity()
+// ---------------------------------------------------------------------------
+//
+TBool CPresenceCacheBuddyStore::EqualsIdentity(
+                    const CPresenceCacheBuddyStore* aOtherInstance ) const
+    {
+    TBool ret(EFalse);
+    if(aOtherInstance)
+        {
+        const CXIMPIdentityImp* tmp = 
+            TXIMPGetImpClassOrPanic< const CXIMPIdentityImp >::From( *(aOtherInstance->BuddyId()));
+        ret = iIdentity->EqualsContent( *tmp);
+        }
+    return ret;
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::EqualsIdentity()
+// ---------------------------------------------------------------------------
+//
+TBool CPresenceCacheBuddyStore::EqualsIdentity(
+                    const MPresenceBuddyInfo* aOtherInstance ) const
+    {
+    TBool ret(EFalse);
+    if(aOtherInstance)
+        {
+        const CXIMPIdentityImp* tmp = 
+            TXIMPGetImpClassOrPanic< const CXIMPIdentityImp >::From( *(aOtherInstance->BuddyId()));
+        ret = iIdentity->EqualsContent( *tmp);
+        }
+    return ret;
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::EqualsIdentity()
+// ---------------------------------------------------------------------------
+//
+TBool CPresenceCacheBuddyStore::EqualsIdentity(
+                    const MXIMPIdentity& aOtherIdentity ) const
+    {
+    const CXIMPIdentityImp* tmp = 
+            TXIMPGetImpClassOrPanic< const CXIMPIdentityImp >::From(aOtherIdentity);
+    return iIdentity->EqualsContent( *tmp);
+    }
+    
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::HasPresence()
+// ---------------------------------------------------------------------------
+//
+TBool CPresenceCacheBuddyStore::HasPresence() const
+    {
+    if(iPresenceBuddyInfo)
+        return ETrue;
+    return EFalse;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceCacheBuddyStore::HasSubscribers()
+// ---------------------------------------------------------------------------
+//
+TBool CPresenceCacheBuddyStore::HasSubscribers() const
+    {
+    if(iSubscribedSessions.Count())
+        return ETrue;
+    return EFalse;
+    }
+