phonesrv_plat/phone_settings_api/inc/PsetCallBarring.h
changeset 0 ff3b6d0fd310
child 12 ae8abd0db65c
child 43 7d48bed6ce0c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/phonesrv_plat/phone_settings_api/inc/PsetCallBarring.h	Tue Feb 02 01:11:09 2010 +0200
@@ -0,0 +1,226 @@
+/*
+* Copyright (c) 2002 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:  Call barring class. Sets and gets call barring setting.
+*
+*
+*/
+
+
+#ifndef     PSETCALLBARRING_H
+#define     PSETCALLBARRING_H
+
+// INCLUDES
+#include "MPsetBarringObs.h"    
+#include "MPsetCallBarring.h"   
+#include "MSSSettingsObserver.h"
+#include "nwdefs.h"             
+#include <mmretrieve.h>
+#include <etelmm.h>
+
+// FORWARD DECLARATIONS
+class MPsetRequestObserver;
+class RSSSettings;
+
+// CLASS DEFINITIONS
+/**
+*  CPsetCallBarring class is call barring SS handler. 
+*  @lib phonesettings.lib
+*  @since 1.0
+*/
+class CPsetCallBarring : public CActive,
+						 public MPsetCallBarring,
+						 public MSSSettingsObserver
+    {
+    public:
+
+        // The type of request.
+        enum TPSetBarringRequest
+            {
+            EPSetRequestNone,
+            EPSetRequestChangeBarring,
+            EPSetRequestGetStatus,
+            EPSetRequestChangeBarringPwd,
+            EPSetRequestChangeCommonPwd
+            };
+
+        /**
+        * Symbian OS 2-phase Constructor.
+        *
+        * @param aObserver Observer for call barring.
+        * @param aPhone Provides client access to mobile phone 
+        *               functionality provided by TSY.
+        * @return Created CPsetCallBarring object.
+        */
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        static CPsetCallBarring* NewL( MPsetBarringObserver& aObserver, 
+            RMobilePhone& aPhone );
+
+        /**
+        * Destructor.
+        */
+        IMPORT_C ~CPsetCallBarring();
+
+    public: //methods from base classes
+
+        /**
+        * @see MPsetCallBarring::SetBarringL().
+        */
+        IMPORT_C void SetBarringL( const TCallBarringSetting& aBarring, 
+            TBasicServiceGroups aBsc );
+
+        /**
+        * @see MPsetCallBarring::GetBarringStatusL().
+        */      
+        IMPORT_C void GetBarringStatusL( const TServiceGroup aGroup, 
+            const TBarringProgram aMode ); 
+
+        /**
+        * @see MPsetCallBarring::CancelCurrentRequest().
+        */
+        IMPORT_C TInt CancelCurrentRequest();
+        
+        /**
+        * @see MSSSettingsObserver::PhoneSettingChanged().
+        */
+        void PhoneSettingChanged( TSSSettingsSetting aSetting, TInt aNewValue );     
+
+    public: //new
+
+        /**
+        * DEPRECATED - calls the method below.
+        */
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        IMPORT_C void ChangePasswordL(
+            RMobilePhone::TMobilePhonePasswordChangeV2& aPwds,
+            TBool aIsBarringPassword );
+
+        /**
+        * Request to change ss password.
+        * @param aPwds Passwords (old, new, verified new) 
+        *              needed for the operation.
+        * @since 2.0
+        */
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        IMPORT_C void ChangePasswordL( 
+            RMobilePhone::TMobilePhonePasswordChangeV2& aPwds );
+        
+        /** 
+        * Sets request observer.
+        *
+        * @param aObs Where the request completion should be informed to.
+        */        
+        IMPORT_C void SetRequestObserver( MPsetRequestObserver* aObs );
+
+    private:    // constructors
+
+        void ConstructL( MPsetBarringObserver& aObserver );
+
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        CPsetCallBarring( RMobilePhone& aPhone );
+
+    private:
+    
+    	void ValidateBsc( TBasicServiceGroups& aBsc );
+
+        void SetObserver( MPsetBarringObserver& aObserver );
+
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        RMobilePhone::TMobilePhoneCBCondition SetBarringProgram ( 
+            TBarringProgram aMode );
+
+        static void DoHandleLeave( TAny* aAny );
+
+        void CleanupLeavePushL();
+
+        void HandleLeave();
+
+        void StartRequestingL( const TInt& aRequest );
+
+        TBool GetPlurality();
+
+        void RequestCompleted( const TInt& aError );
+
+        //Empties member variables.
+        void ClearParams();
+
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        RMobilePhone::TMobilePhoneServiceAction SetBarringAction( 
+            const TBarringSetting& aSetting );
+
+
+        void HandleInquiryResultL();
+
+        void SetRequestStatus( TPSetBarringRequest aStatus );
+
+    private: //from base class CActive
+
+        void DoCancel();
+
+        void RunL(); 
+
+    private:
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        // Provides client access to mobile line functionality provided by TSY.
+        RMobileLine* iLine;
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/
+        // Provides client access to mobile phone functionality provided by TSY.
+        RMobilePhone& iPhone;
+        // Barring observer, handles results.
+        MPsetBarringObserver* iObserver;
+        // Currently active request
+        TPSetBarringRequest iCurrentReq;
+        // Barring settings
+        TCallBarringSetting iChangeSetting;
+        // Request handler
+        MPsetRequestObserver* iReqObserver;
+        // Retrieves the Call Barring status list from the phone.
+        CRetrieveMobilePhoneCBList* iCbStatusInterrogator;
+        //Barring parameters
+        /*****************************************************
+        *    Series 60 Customer / ETel
+        *    Series 60  ETel API
+        *****************************************************/    
+        RMobilePhone::TMobilePhoneCBChangeV1 iBarringParameters;
+        // Value of Alternative Line Selection setting
+        TSSSettingsAlsValue iAls;
+        // SsSettings pointer, accesses supplementary services on SIM
+        RSSSettings* iSsSettings;
+    };
+#endif      
+//  PSETCALLBARRING_H      
+// End of File