diff -r 0efa10d348c0 -r a5a39a295112 contentcontrolsrv/ccsrv/src/ccsrv.cpp --- /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