contentcontrolsrv/ccsrv/src/ccsrv.cpp
branchRCL_3
changeset 114 a5a39a295112
child 118 8baec10861af
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/contentcontrolsrv/ccsrv/src/ccsrv.cpp	Wed Sep 01 12:22:09 2010 +0100
@@ -0,0 +1,344 @@
+/*
+ * 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:  
+ *
+ */
+
+// System include files
+
+// User include files
+#include "ccsrv.h"
+#include "ccsrvsession.h"
+#include "ccresource.h"
+#include "ccsrvapi.h"
+
+
+// Local constants
+
+// Home screen content control server name
+_LIT( KCcSrvName,"ccserver" );
+
+// Home screen content control server policy
+//Total number of ranges
+const TUint KCcRangeCount = 2;
+
+//Definition of the ranges of IPC numbers
+const TInt KCcRanges[KCcRangeCount] = 
+        {
+        ECcIPCFunctionBase,
+        ECcNotSupported 
+        }; 
+
+// Policy actions for each of the above ranges
+const TUint8 KCcPolicyAction[KCcRangeCount] = 
+        {
+        0,
+        CPolicyServer::ENotSupported
+        };
+
+// Requested capabilities
+const CPolicyServer::TPolicyElement KCcCapability[] = 
+        {
+        {_INIT_SECURITY_POLICY_C2( ECapabilityReadDeviceData, ECapabilityWriteDeviceData ), CPolicyServer::EFailClient}
+        };
+
+const CPolicyServer::TPolicy KCcPolicy =
+        {
+        0,
+        KCcRangeCount,                                 
+        KCcRanges,
+        KCcPolicyAction,
+        KCcCapability
+        };
+
+// -----------------------------------------------------------------------------
+// RunServerL()
+// -----------------------------------------------------------------------------
+//
+static void RunServerL()
+    {
+    User::LeaveIfError(User::RenameThread(KCcSrvName));
+    CActiveScheduler* s=new(ELeave) CActiveScheduler;
+    CleanupStack::PushL(s);
+    CActiveScheduler::Install(s);
+    CCcSrv::NewLC();
+    RProcess::Rendezvous(KErrNone);
+    CActiveScheduler::Start();
+    CleanupStack::PopAndDestroy( 2, s );
+    }
+
+// -----------------------------------------------------------------------------
+// E32Main
+// Server process entry-point
+// -----------------------------------------------------------------------------
+//
+TInt E32Main()
+    {
+    __UHEAP_MARK;
+    CTrapCleanup* cleanup=CTrapCleanup::New();
+    TInt r=KErrNoMemory;
+    if (cleanup)
+        {
+        TRAP(r,RunServerL());
+        delete cleanup;
+        }
+    __UHEAP_MARKEND;
+    return r;
+    }
+
+// ======== MEMBER FUNCTIONS ========
+
+// -----------------------------------------------------------------------------
+// CCcSrv::NewLC
+// -----------------------------------------------------------------------------
+//
+CServer2* CCcSrv::NewLC()
+    {
+    CCcSrv* self=new ( ELeave ) CCcSrv;
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    return self;
+    }
+
+// -----------------------------------------------------------------------
+// CCcSrv::ConstructL()
+// -----------------------------------------------------------------------
+//
+void CCcSrv::ConstructL()
+    {
+    StartL( KCcSrvName );
+    }
+
+// -----------------------------------------------------------------------
+// CCcSrv::CCcSrv()
+// -----------------------------------------------------------------------
+//
+CCcSrv::CCcSrv()
+    :CPolicyServer( 0,KCcPolicy,ESharableSessions )
+    ,iLastSessionId( 0 )
+    {
+    }
+
+// -----------------------------------------------------------------------
+// CCcSrv::~CCcSrv()
+// -----------------------------------------------------------------------
+//
+CCcSrv::~CCcSrv()
+    {
+    iSessions.Close();
+    iProviders.Close();
+    iObservers.Close();
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::NewSessionL
+// -----------------------------------------------------------------------------
+//
+CSession2* CCcSrv::NewSessionL(
+    const TVersion&,
+    const RMessage2& /* aMessage */ ) const
+    {
+    return new ( ELeave ) CCcSrvSession();
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::AddSessionL
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::AddSessionL( CCcSrvSession* aSession )
+    {
+    // Find next available session id
+    while( ETrue )
+        {
+        iLastSessionId = iLastSessionId + 1;
+        TBool found( EFalse );
+        for ( TUint32 i = 0; i < iSessions.Count() && !found; i++ )
+            {
+            if ( iSessions[ i ]->Id() == iLastSessionId )
+                {
+                found = ETrue;
+                }
+            }
+        if ( !found )
+            {
+            break;
+            }
+        }
+    
+    aSession->SetId( iLastSessionId );
+    iSessions.AppendL( aSession );
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::DropSession
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::DropSession( CCcSrvSession* aSession )
+    {
+    // Remove possible provider
+    for ( TUint32 i = 0; i < iProviders.Count(); i++ )
+        {
+        if ( iProviders[ i ].iSession->Id() == aSession->Id() )
+            {
+            iProviders.Remove( i );
+            break;
+            }
+        }
+    // Unregister possible observations and remove observer
+    for ( TUint32 i = 0; i < iObservers.Count(); )
+        {
+        if ( iObservers[ i ].iObserver == aSession->Id() )
+            {
+            for ( TUint32 j = 0; j < iProviders.Count(); j++ )
+                {
+                if ( iObservers[ i ].iProviderId == iProviders[ j ].iId )
+                    {
+                    TRAP_IGNORE( iProviders[ j ].iSession->
+                        UnregisterObserverSessionL( aSession->Id() ) );
+                    }
+                }
+            iObservers.Remove( i );
+            }
+        else
+            {
+            // Get next observer
+            i++;
+            }
+        }
+    // Remove session
+    for ( TUint32 i = 0; i < iSessions.Count(); i++ )
+        {
+        if ( iSessions[ i ]->Id() == aSession->Id() )
+            {
+            iSessions.Remove( i );
+            break;
+            }
+        }
+    
+    if ( iSessions.Count() == 0 )
+        {
+        // Last session dropped -> stop server
+        CActiveScheduler::Stop();
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::RegisterProviderSessionL
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::RegisterProviderL( 
+    TUint32 aProvider,
+    CCcSrvSession* aSession )
+    {
+    for ( TUint32 i = 0; i < iProviders.Count(); i++ )
+        {
+        if ( iProviders[ i ].iId == aProvider )
+            {
+            User::Leave( KErrAlreadyExists );
+            }
+        }
+    CCcSrv::TCcProvider provider;
+    provider.iId = aProvider;
+    provider.iSession = aSession;
+    iProviders.Append( provider );
+    
+    // Register possible active observers
+    for ( TUint32 i = 0; i < iObservers.Count(); i++ )
+        {
+        if ( iObservers[ i ].iProviderId == aProvider )
+            {
+            provider.iSession->RegisterObserverSessionL( iObservers[ i ].iObserver );
+            }
+        }
+    
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::RegisterObserverL
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::RegisterObserverL( 
+    TUint32 aProvider,
+    CCcSrvSession* aSession )
+    {
+    for ( TUint32 i = 0; i < iProviders.Count(); i++ )
+        {
+        if ( iProviders[ i ].iId == aProvider )
+            {
+            iProviders[ i ].iSession->RegisterObserverSessionL( aSession->Id() );
+            break;
+            }
+        }
+    CCcSrv::TCcObserver observer;
+    observer.iProviderId = aProvider;
+    observer.iObserver = aSession->Id();
+    iObservers.Append( observer );
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::ResolveProviderAddressL
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::ResolveProviderAddressL( 
+    TUint32 aProvider,
+    TUint32& aAddress )
+    {
+    TBool found( EFalse );
+    for ( TUint32 i = 0; i < iProviders.Count() && !found; i++ )
+        {
+        if ( iProviders[ i ].iId == aProvider )
+            {
+            aAddress = iProviders[ i ].iSession->Id();
+            found = ETrue;
+            }
+        }
+    if ( !found )
+        {
+        User::Leave( KErrNotFound );
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::GetTrId
+// -----------------------------------------------------------------------------
+//
+TUint32 CCcSrv::GetTrId()
+    {
+    iLastTrId++;
+    return iLastTrId;
+    }
+
+// -----------------------------------------------------------------------------
+// CCcSrv::SendMsgL
+// -----------------------------------------------------------------------------
+//
+void CCcSrv::SendMsgL( 
+    CCcSrvMsg& aMessage )
+    {
+    TBool found( EFalse );
+    for ( TUint32 i = 0; i < iSessions.Count() && !found; i++ )
+        {
+        if ( iSessions[ i ]->Id() == aMessage.Receiver() )
+            {
+            iSessions[ i ]->ReceiveMsgL( aMessage );
+            found = ETrue;
+            }
+        }
+    if ( !found )
+        {
+        User::Leave( KErrNotFound );
+        }
+    }
+
+// End of file