--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/securitydialogs/secuidialognotifier/src/secuidialognotifiersrv.cpp Tue Sep 28 14:03:54 2010 +0300
@@ -0,0 +1,148 @@
+/*
+* Copyright (c) 2010 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: Secui dialog notifier server, client-side API.
+*
+*/
+
+#include "secuidialognotifiersrv.h" // RSecuiDialogNotifierSrv
+#include "../../secuidialognotifiersrv/inc/secuidialognotifierservername.h"
+#include "secuidialogstrace.h" // TRACE macro
+
+
+// ======== MEMBER FUNCTIONS ========
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::RSecuiDialogNotifierSrv()
+// ---------------------------------------------------------------------------
+//
+RSecuiDialogNotifierSrv::RSecuiDialogNotifierSrv()
+ {
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::~RSecuiDialogNotifierSrv()
+// ---------------------------------------------------------------------------
+//
+RSecuiDialogNotifierSrv::~RSecuiDialogNotifierSrv()
+ {
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::Connect()
+// ---------------------------------------------------------------------------
+//
+TInt RSecuiDialogNotifierSrv::Connect()
+ {
+ TRACE( "RSecuiDialogNotifierSrv::Connect" );
+ const TInt KMaxCreateSessionAttepmts = 2;
+ TInt retry = KMaxCreateSessionAttepmts;
+ FOREVER
+ {
+ TInt err = CreateSession( KSecuiDialogNotifierServerName, Version() );
+ TRACE( "RSecuiDialogNotifierSrv::Connect, create session err=%d", err );
+ if( err != KErrNotFound && err != KErrServerTerminated )
+ {
+ return err;
+ }
+
+ if( --retry == 0 )
+ {
+ return err;
+ }
+
+ err = StartServer();
+ if( err != KErrNone && err != KErrAlreadyExists )
+ {
+ return err;
+ }
+ }
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::Version()
+// ---------------------------------------------------------------------------
+//
+TVersion RSecuiDialogNotifierSrv::Version() const
+ {
+ return TVersion( KSecuiDialogNotifierServerMajorVersionNumber,
+ KSecuiDialogNotifierServerMinorVersionNumber,
+ KSecuiDialogNotifierServerBuildVersionNumber );
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::SecuiDialogOperationL()
+// ---------------------------------------------------------------------------
+//
+void RSecuiDialogNotifierSrv::SecuiDialogOperation(
+ TSecurityDialogOperation aOperation,
+ const TDesC8& aInputBuffer, TDes8& aOutputBuffer,
+ TRequestStatus& aStatus )
+ {
+ TRACE( "RSecuiDialogNotifierSrv::SecuiDialogOperation" );
+ iArgs = TIpcArgs( &aInputBuffer, &aOutputBuffer );
+ SendReceive( aOperation, iArgs, aStatus );
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::CancelOperation()
+// ---------------------------------------------------------------------------
+//
+void RSecuiDialogNotifierSrv::CancelOperation()
+ {
+ TRACE( "RSecuiDialogNotifierSrv::CancelOperation" );
+ SendReceive( KSecuiDialogCancelOperation );
+ }
+
+// ---------------------------------------------------------------------------
+// RSecuiDialogNotifierSrv::StartServer()
+// ---------------------------------------------------------------------------
+//
+TInt RSecuiDialogNotifierSrv::StartServer()
+{
+ TRACE( "RSecuiDialogNotifierSrv::StartServer, begin" );
+ RProcess server;
+ TInt err = server.Create( KSecuiDialogNotifierServerName, KNullDesC );
+ if( err )
+ {
+ TRACE( "RSecuiDialogNotifierSrv::StartServer, create failed, err=%d", err );
+ return err;
+ }
+
+ TRequestStatus status;
+ server.Rendezvous( status );
+ if( status == KRequestPending )
+ {
+ server.Resume();
+ }
+ else
+ {
+ server.Kill( KErrNone );
+ }
+
+ TRACE( "RSecuiDialogNotifierSrv::StartServer, waiting rendezvous" );
+ User::WaitForRequest( status );
+ if( server.ExitType() == EExitPanic )
+ {
+ err = KErrGeneral;
+ }
+ else
+ {
+ err = status.Int();
+ }
+ server.Close();
+
+ TRACE( "RSecuiDialogNotifierSrv::StartServer, end err=%d", err );
+ return err;
+}
+