satengine/SatServer/Commands/CallControlCmd/inc/CCallControlHandler.h
changeset 0 ff3b6d0fd310
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/satengine/SatServer/Commands/CallControlCmd/inc/CCallControlHandler.h	Tue Feb 02 01:11:09 2010 +0200
@@ -0,0 +1,182 @@
+/*
+* Copyright (c) 2002-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:  CallControl command handler
+*
+*/
+
+
+
+#ifndef CCALLCONTROLHANDLER_H
+#define CCALLCONTROLHANDLER_H
+
+#include <etelsat.h>
+#include "CSatCommandHandler.h"
+#include "SatSTypes.h"
+
+class MSatUtils;
+class CCallControlRequestHandler;
+
+/**
+*  Command handler for CallControl command.
+*
+*  @lib CallControlCmd.lib
+*  @since Series 60 3.0
+*/
+class CCallControlHandler : public CSatCommandHandler
+    {
+    public:  // Constructors and destructor
+
+        /**
+        * Two-phased constructor.
+        * @param aUtils Utils inteface
+        */
+        static CCallControlHandler* NewL( MSatUtils* aUtils );
+
+        /**
+        * Destructor.
+        */
+        virtual ~CCallControlHandler();
+
+    public: // Functions from base classes
+
+        /**
+        * From MSatCommand.
+        */
+        void ClientResponse();
+        
+    public:// New Functions
+         
+        /**
+        * Processes the Cc Request Complete.
+        *
+        * @param aErrCode Result of ETelMM Api calling.
+        */
+        void DispatchCcRequestComplete( const TInt aErrCode );
+         
+        /**
+        * TCcStatus
+        * Call control status, when there is an asynchronous
+        * operation is handling by the CCallControlRequestHandler
+        * we will save some status information
+        */
+        enum TCcStatus
+            {
+            ECcIdle = 0,
+            ECcDialWaiting,
+            ECcSendSsWaiting,
+            ECcSendUssdWaiting
+            };
+            
+    protected:  // Functions from base classes
+
+        /**
+        * From CActive Cancels the usat request.
+        */
+        void DoCancel();
+
+        /**
+        * From CSatCommandHandler Requests the command notification.
+        * @param aStatus Request status to active object notification
+        */
+        void IssueUSATRequest( TRequestStatus& aStatus );
+
+        /**
+        * From CSatCommandHandler Precheck before executing the command.
+        * @return Boolean indicating is this command allowed to execute.
+        */
+        TBool CommandAllowed();
+
+        /**
+        * From CSatCommandHandler Need for ui session.
+        * @return Boolean indicating does this command need UI session.
+        */
+        TBool NeedUiSession();
+
+        /**
+        * From CSatCommandHandler Called when USAT API notifies that command.
+        */
+        void HandleCommand();
+
+        /**
+        * From CSatCommandHandler. Indicates the failure of launching ui client
+        */
+        void UiLaunchFailed();
+
+    private:
+
+        /**
+        * C++ default constructor.
+        */
+        CCallControlHandler();
+
+        /**
+        * By default Symbian 2nd phase constructor is private.
+        */
+        void ConstructL();
+        
+        
+        /**
+        * If it is needed that sat makes a no FDN check call or 
+        * send SS or send USSD we should perform these operation 
+        */
+        void CallControlClientOperation();
+        
+        /**
+        * If SAT needs to do Call Control next action, 
+        * i.e. Call Control has modified the type of request,
+        * then this method should be called
+        */
+        TInt DialNumber();
+    
+        /**
+        * Make a no FDN check Send SS
+        */
+        TInt SendSs();
+
+        /**
+        * Make a no FDN check Send USSD
+        */
+        TInt SendUssd();
+        
+        /**
+         * Notify session done, start recieve more command.
+         */
+        void CompleteCallControlCmd( TInt aErrCode );
+        
+    private:    // Data
+
+        // CallControl command data.
+        RSat::TCallControlV6 iCallControlData;
+        // CallControl command package.
+        RSat::TCallControlV6Pckg iCallControlPckg;
+        // CallControl send data
+        TSatNotificationV1 iCallControlSendData;
+        // CallControl SendData package
+        TSatNotificationV1Pckg iCallControlSendDataPckg;
+        // CallControl UI Response data
+        TSatNotificationRspV1 iCallControlUiRespData;
+        // CallControl UI Response package
+        TSatNotificationRspV1Pckg iCallControlUiRespDataPckg;
+        // Indicates is UI needed or not
+        TBool iNeedUiSession;
+        // Handing the asynchronous request
+        CCallControlRequestHandler* iRequestHandler;
+        // Current status
+        TCcStatus iCcStatus;
+
+    };
+
+#endif      // CCALLCONTROLHANDLER_H
+
+