FreeCalypso > hg > fc-tourmaline
diff src/ui/bmi/mmiPins.c @ 3:67bfe9f274f6
src/ui: import of src/ui3 from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:33:10 +0000 |
parents | |
children | c0052fe355d3 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/ui/bmi/mmiPins.c Fri Oct 16 06:33:10 2020 +0000 @@ -0,0 +1,12017 @@ + +/******************************************************************************* + + CONDAT (UK) + +******************************************************************************** + + This software product is the property of Condat (UK) Ltd and may not be + disclosed to any third party without the express permission of the owner. + +******************************************************************************** + + $Project name: Basic MMI + $Project code: BMI (6349) + $Module: MMI + $File: MmiPins.c + $Revision: 1.0 + + $Author: Condat(UK) + $Date: 25/10/00 + +******************************************************************************** + + Description: + + MMI PIN / PUK entry handling + +******************************************************************************** + + $History: MmiPins.c + + May 24, 2007 DR: OMAPS00132483 x0pleela + Description: MM: While playing an AAC, unplug USB freezes the audio + Solution: If any Audio file is playing, then stopping them before enabling/disabling phone lock, + auto phone lock and changing unlock password. + Changed the name of fucntions for setting and restting the headset/usb bit in + ph_lock status variable + + May 23, 2007 DR: OMAPS00127483 x0pleela + Description: Phonelock - Unable to unlock the phone during incoming call with ringer... + Solution: When ringer for either incoming call or alarm is playing in phone locked state, Audio + usues the DMA channels which will be active. The DMA channels will be available only + after the audio file is fully played. This will cause that process to be blocked until the + DMA channel becomes in-active and in turn if we try to query or access secure driver + we are blocked until the audio file is completely played. Since this is a hardware + constraint, we found a workaround for this issue and are stopping the ringer + either for incoming call or alarm before accessing secure driver for enabling or + disbaling the phone lock. + + May 09, 2007 DR: OMAPS00129014 + Description: COMBO: unable to send SMS during midi playing + Solution: Setting the auto phone lock flag to TRUE / FALSE when automatic phonelock is + on / off respectively + + Apr 03, 2007 ER: OMAPS00122561 x0pleela + Description: [ACI] Phone lock feature has to be supported by ACI + Solution: Phone Lock ER implementation + + Feb 19, 2006 ER:OMAPS00115179 a0393213 + Description : support SIM insertion without powering down + Solution : Unnecessary windows cleared during SIM insertion + + Nov 13, 2006 DR: OMAPS00103356 x0pleela + Description: SIMP:Master unlock failed through MMI + Solution: 1) In function pins_editor_cb() for INPUT_MASTER_KEY_REQ, + - An event SMLK_SHOW_WRONG_PWD is sent for wrong Master unlock password + - An event SMLK_SHOW_DEP_CATS_UNLOCKED is sent which says all the dependent + categories are unlocked + 2) In function pin_messages(): + - An event SMLK_SHOW_WRONG_PWD is handled to display a dialog saying Master + Unblock Password is wrong + - An event SMLK_SHOW_DEP_CATS_UNLOCKED to display a dialog saying Master + unlocking operation is successful + + Sep 26, 2006 DR: OMAPS00095524 x0pleela + Description:Implement 2 missing SIM Lock types + Solution: Made the following changes + 1) sim_event_cb_main() + - Handling the event MFW_SIM_PBLOCK_REQ for requesting unlocking password + of "Blocked Network" category + 2) simp_busy_cb() + - Added a check for CME class and Ext class and handled all CME errors + and EXT errors separately + 3) pin_main() + - Handling the event INPUT_PBLOCK_PIN_REQ to prompt the user to enter the + Blocked Network Password (PIN or PUK) + 4) pin_info_cb() + - Added a check for CME class and Ext class and handled all CME errors and EXT + errors separately for event SMLK_MASTERKEY and SMLK_PUK + 5) simlock_check_PBCatLock() + - Added new function which gets the lock status of Blocked Network category + and accordingly display the menu item + 6) simp_unlock_Category() + - Handling "Blocked Network" category and send INPUT_PBLOCK_PIN_REQ event + 7) setLockTypePb() + - Added new function which sets the global flag to the Personalisation lock + 8) set_pin_messages() + - Updating the variable which prompts the user to enter Blocked Network password + 9) pins_editor_cb() + - Handling the event INPUT_PBLOCK_PIN_REQ fr Blocked Network category + - Added a check for CME class and Ext class and handled all CME errors and EXT + errors separately + + Sep 26, 2006 DR: OMAPS00096565 x0pleela + Description: After blocking PIN, when ISAMPLE is reset, instead of prompting for PUK, master + unlock key is asked + Solution: Added a check for C_KEY_REQ in functions sim_event_cb_main(), pin_info_cb() . + If this variable is set the SIMP menu will be isplayed + else user wil be prompted to enter PUK + + + xashmic 21 Sep 2006, OMAPS00095831 + Description: USB enumeration does not happen in PIN/PUK/Insert SIM scenarios + Solution: When booting up without SIM card, or prompting for PIN/PUK/SIMP entry, + enumerate all the USB ports automatically + + Sep 11, 2006 DR: OMAPS00094215 x0pleela + Description: MMI compilation failed as CME_ErrBusy undefined + Solution: Handling new Ext_ERR_Busy sent by ACI + + Sep 08, 2006 DR: OMAPS00091250 x0pleela + Description:The phone resets if no MEPD data is presented + Solution: - Handling MFW_MEPD_INVALID event in function sim_event_cb_main() + - Handling NO_MEPD event in functions pin_main(), pin_edt_kbd_cb(), check_pins(), + pin_editor(), pin_messages(), check_set_pins(), pins_editor_cb(), show_confirmation_cb() + + July 31, 2006 ER: OMAPS00087586, OMAPS00087587 x0pleela + Description: OMAPS00087586: MasterKey funtion in TCS3.2 SW + OMAPS00087587: Time Penaly feature extend handset security + Solution:Made the following changes + 1) Added new element mk_pin to store Master Unlock key to T_Pin structure + 2) pin_main(), pin_messages(), setting_pin_main(),set_pin_messages(): Added new event SIM_LOCK_BUSY_UNBLOCK + to display a dialog "Busy" when wrong unlock password is entered after 1st attempt if timer is running + 3) pin_info_cb(): Handling CME_ERR_Busy + 4) mmi_simlock_reset_fc_value(), pins_editor_cb(): Handling CME_ERR_Busy error and sending new event + SIM_LOCK_BUSY_UNBLOCK to display a dialog "Busy" when wrong unlock password + is entered after 1st attempt if timer is running + + July 21, 2006 ER: OMAPS00087586, OMAPS00087587 x0pleela + Description: OMAPS00087586: MasterKey funtion in TCS3.2 SW + OMAPS00087587: Time Penaly feature extend handset security + + Solution:Made the following changes + 1) sim_event_cb_main(): check for Master Unlock option enabled. If so, then display the menu + with options Unblock ME and Master Unlock. Similar for all the categories also. + 2) pin_main(): + a) Handling SIM_LOCK_BUSY_BOOTUP event which displays a dialog "Busy" for the user + if timer is enabled and ACI returns Busy error when user had entered wrong unlocking + password + b) Handling events SMLK_SHOW_MK_FAIL for wrong master unlock key, + SMLK_SHOW_MK_SUCC for correct master unlock key + + 3) pin_messages(): + a) Handling event SMLK_SHOW_MK_FAIL to show a dialog saying "Master Unlock Failed" + b) Handling event SMLK_SHOW_MK_SUCC to show a dialog saying "Master Unlock Success" + c) For event SMLK_SHOW_FC_SUCC, changed the event from PIN_OK to SMLK_PUK bcoz + after unblocking ME, for event PIN_OK it would go to idle screen without displaying + menu for unlocking any categories if any + d) Delete the simp_list window handler after displaying the dialog immaterial of whether + the unlock/unblock passwords are correct or not + + 4) pin_info_cb(): + a) Handling PUK1_REQ separately as a menu should be displayed for Unblocking ME and + Master Unlock + b) Handling SMLK_MASTERKEYto display menu for Unblocking ME or unlocking categories + if any and Master Unlock + c) Made changes in the code for event SMLK_PUK to display menu Unblocking ME or + unlocking categories if any and Master Unlock + + 5) setting_pin_main(): + a) Handling event SIM_LOCK_REQ_MKPWD for Master unlock ket request + b) Handling event SIM_LOCK_MKPWD_FAIL for Master unlocking failed + c) Handling event SIM_LOCK_MKPWDSUCC for Master unlocking success + d) Handling new event SIM_LOCK_BUSY to display a dialog Busy for wrong entry of + unlocking pwd and timer been enable + + 6) mmi_display_result(): Handling CME error busy while unlocking a locked category and send + SIM_LOCK_BUSY event + + 7) mmi_simlock_en_dis_verify(): Handling CME error busy while unlocking a locked category + and send SIM_LOCK_BUSY event + + 8) set_pin_editor(): Handling event INPUT_SIM_MKPWD + + 9) set_pin_kbd_cb(): Handling event INPUT_SIM_MKPWD + + 10) set_pin_messages(): Handling events SIM_LOCK_MKPWD_FAIL for Master unlock failed, + SIM_LOCK_MKPWDSUCC for Master unlock success, SIM_LOCK_BUSY for category unlock + return with Busy error from ACI + + 11) pins_editor_cb(): + a) Update mmi_simlock_aciErrDesc with the latest CME error + b) Event INPUT_MASTER_KEY_REQ performs master unlock and sends corresponding + events during bootup + c) Delete the simp list window handler immaterial of whether the unlock/unblock + passwords are correct or not + d) Get the busy state "Simp_Busy_State" and send event to display a dialog Busy + for the user + e) Check for Master Unlock option enabled. If so, then display the menu with options + <Category> unlock and Master Unlock + + 12) Added following new functions: + a) simp_busy_cb: This function checks for the ACI CME error and display menu for + unlocking categories or unblocking ME + b) mmi_simlock_category_menus: Starts the simlock category list menu + c) SIMLock_unblock_ME: This function sends an event to display an editor for the user to + enter unblocking code + d) SIMLock_MasterKeyUnlock_bootup: This functioh gets called to unlock category /unblock + ME during bootup sequence + e) SIMLock_MasterKeyUnlock: This functioh gets called to unlock category /unblock ME + through SIMP menu + f) simlock_check_masterkey: If there is no support for Master Unlocking the item "Master unlock" + will not appear on the menulist + g) simlock_get_masterkey_status: This function gets the master key status + h) simlock_check_NWCatLock: This function gets the lock status of Network category and + accordingly display the menu item + i) simlock_check_NSCatLock: This function gets the lock status of Network subset category and + accordingly display the menu item + j) simlock_check_SPCatLock: This function gets the lock status of Service Provider category and + accordingly display the menu item + k) simlock_check_CPCatLock: This function gets the lock status of Corporate category and + accordingly display the menu item + l) simlock_check_SIMCatLock: This function gets the lock status of SIM category and accordingly + display the menu item + m) simlock_check_CatBlock: This function gets the ME status and accordingly display the menu item + n) mmi_simlock_master_unlock: This function unlocks category/unblocks ME and sends event + accordingly through SIMP menu + o) simp_unlock_Category: This function sends corresponding event to unlock a locked category + through dynamic menu + + July 11, 2006 DR: OMAPS00084081 x0039928 + Descripton: CT-GCF-LL[27.22.4.7.2]-No IMSI attched request after SIM reset + Solution: Network registration is initiated on sim reset. + + July 05, 2006 DR: OMAPS00084642 x0pleela + Descripton: SIMP: we can unlock category with invalid password (more than 16 digit) + Solution: Changed the size of simlock password enty from MAX_DIG to MAX_PIN+1 + + xreddymn 4, Jul, 2006 OMAPS00083495 + Resolved issues reported in PIN and PUK input through BPM. + + June 07, 2006 DR: OMAPS00080701 x0021334 + Descripton: Phone hangs while unblocking SIMP during bootup. + Solution: The assignment of 'SIMP_BOOTUP' to 'sim_unlock_in_prog' to indicate that + the operation is happeneing during boot-up sequence was not taking place since the + respective function was not being called when SIMP was blocked and re-boot was done. + This has now been corrected. + + xrashmic 6 Jul, 2006 OMAPS00080708 + The pin window is necessary for displaying the error message for MFW_SS_FAIL + + xrashmic 1 Jul, 2006 OMAPS00075784 + Fixed the blue screen issue in pin, pin2 and simp scenarios + + May 15, 2006 DR:OMAPS00067919 x0pleela + Description: SIMP:On repeat Depersonalisation with invalid password MEPD unblock key should + be asked not Puk1. + Solution: Made the following changes + Function: pin_main() + 1. Change the text display based on the PUK1 or Unblock code request + 2. Added code to close the editor on PIN_OK_END event + Function: pins_editor_cb() + 1. Modified the code to check SIMP during bootup sequence + + Apr 19, 2006 DR:OMAPS00067912 x0pleela + Description: SIMP:On repeat Depersonalisation with invalid password MEPD unblock key should + be asked not Puk1. + Solution: Made changes in the functions sim_event_cb_main(), pin_main(), pin_messages(), + pin_info_cb(), setting_pin_main(), pins_editor_cb()to handle SIMP unblocking code + + Nov 24, 2005 DR: OMAPS00045909 - Shashi Shekar B.S. + Description: Improve IMEI control mechanism + Solution : When MMI calls sAT_PLUSCFUN, if an IMEI invalid error is returned, + we will block on that screen & will not allow the user to browse menus further, + since the PS will not be booted at all!!! + + Nov 17, 2005 DR: OMAPS00050447 - nekkareb + Description: Even after removing the SIM , Hutch or Airtel network is seen + Solution : Sim removal event is now being handled and appropriate display shown. + Nov 15,2005 DR : OMAPS00057280 - x0034700 + Description: Compilation Errors in Neptune build while integrating latest MMI Changes + Solution: Included the compilation FLAG "NEPTUNE_BOARD" for un wanted code for Neptune build + + + Nov 03, 2005 DR: OMAPS00050595 - xpradipg + Description: SIMP: If the SIM is blocked (by entering invalid PIN1), the user is + not able to unblock it even after entering the valid PUK1 + Solution : The global flag for SIM Personlaization PUK request was set even + for the SIM PUK request. This setting is removed. Also the condition + check has been done first for the global flag and then the rest of the + checks. + + Nov 03, 2005 DR: OMAPS00052032 - xpradipg + Description : Locosto: SIMP - integration of issues submitted by solDel on + ME Personalization - changes as per the new interfaces + Solution : The return value of sAT_PlusCLCK of AT_EXCT is handled and + a please wait screen is displayed until the response is recieved + + Sept 24, 2005 REF: LOCOSTO-ENH-34438, xpradipg + Description: Integration changes required with new aci labe + Solution: changes to adopt to the new ACI label + + July 19, 2005 REF: CRR LOCOSTO-ENH-28173 xpradipg + Description: To provide MMI Support to enable/disable/change password and + query all the Personalization locks + Solution: Integration of the changes for the same provided by the soldel + team + + June 16, 2005 REF: CRR 31267 x0021334 + Description: Handset ignore the initializtion of the PIN1/PIN2 + Fix: Cheking is done to ascertain if PIN1/PIN2 are initialised. If not, appropriate + message is displayed to the user. + +// May 31, 2004 REF: CRR 17291 xvilliva +// Bug: After power cycle the setting of the used line which have been made +// from the BMI is lost. +// Fix: The Pin2 which is entered in the editor and sent for verification is +// stored in a global variable for re-use in sAT_PlusCLCK(). + +// May 13, 2004 REF: CRR 13632 xvilliva +// The PUK1 screen is not brought up even if user enters wrong Pin1 thrice +// from Idle screen -"**04*OLD_CHV1*NEW_CHV1*NEW_CHV1#". +// If the Pin1 fails for 2 times - "Not accepted" screen is displayed. +// but if the Pin1 fails 3rd consecutive time - "Pin Blocked" screen is displayed +// and the user is taken to PUK1 screen. +// May 13, 2004 REF: CRR 13623 xvilliva +// The PUK1 screen can be exited by pressing HangUP or Back key. +// The PUK1 screen if contains less than 1 character then back key is disabled. +// Hangup key is disabled permenantly to avoid exiting the screen. + + + 25/10/00 Original Condat(UK) BMI version. + + $End + + // Issue Number : SPR#15692 on 25/03/04 by Rashmi.C.N. + +*******************************************************************************/ + + + +/******************************************************************************* + + Include Files + +*******************************************************************************/ +#define ENTITY_MFW + +/* includes */ +#include <string.h> +#include <stdio.h> +#include <stdlib.h> + +#if defined (NEW_FRAME) + +#include "typedefs.h" +#include "vsi.h" +#include "pei.h" +#include "custom.h" +#include "gsm.h" + +#else + +#include "STDDEFS.H" +#include "custom.h" +#include "gsm.h" +#include "vsi.h" + +#endif +#include "mfw_sys.h" + +#include "prim.h" + + +#include "mfw_mfw.h" +#include "mfw_win.h" +#include "mfw_kbd.h" +/* SPR#1428 - SH - New Editor changes */ +#ifndef NEW_EDITOR +#include "mfw_edt.h" +#endif +#include "mfw_lng.h" +#include "mfw_cm.h" +#include "mfw_icn.h" +#include "mfw_phb.h" +#include "ksd.h" +#include "psa.h" +#include "mfw_ss.h" +#include "mfw_sim.h" +#include "mfw_nm.h" +#include "mfw_sat.h" +#include "mfw_tim.h" +#include "mfw_mnu.h" +#include "mfw_sms.h" + +//x0pleela 15 May, 2007 DR: OMAPS00127483 +#ifdef FF_PHONE_LOCK +#ifdef FF_MIDI_RINGER +#include "mfw_midi.h" +#endif //FF_MIDI_RINGER +#endif /* FF_PHONE_LOCK */ + +#include "dspl.h" + + +#include "MmiMmi.h" +#include "MmiDummy.h" +#include "MmiDialogs.h" +#include "MmiLists.h" + +/* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR +#include "ATBCommon.h" +#include "ATBDisplay.h" +#include "ATBEditor.h" +#include "AUIEditor.h" +#include "AUIPinEditor.h" +#else +#include "MmiEditor.h" +#endif + +#include "MmiMain.h" +#include "MmiStart.h" +#include "MmiMenu.h" +#include "MmiSoftKeys.h" +#include "MmiIdle.h" +#include "mmiCall.h" +#include "MmiNetwork.h" +#include "MmiSounds.h" +#include "MmiSettings.h" +#include "MmiServices.h" +#include "Mmiicons.h" +#include "MmiDialogs.h" +#include "MmiPins.h" +#include "MmiCPHS.h" +#include "cus_aci.h" +#ifndef NEPTUNE_BOARD +#include "p_sim.h" +#endif +#include "prim.h" +#ifndef PCM_2_FFS +#include "pcm.h" +#endif + + +#include "mmiColours.h" +#include "mmiSmsIdle.h" //GW SPR#1035 - For smsidle_unset_ready_state(void) definition. +#ifdef SIM_PERS +#include "aci_cmh.h" +#include "cmh.h" +#endif +//#define CLEAR_PIN_EDIT_AREA dspl_Clear(0,30,LCD_X,LCD_Y); + + +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK +#include "usb/usb_api.h" +#include "mfw_mme.h" +//x0pleela 15 May, 2007 DR: OMAPS00127483 +#include "MmiSounds.h" +#endif /* FF_PHONE_LOCK */ + +#ifdef SIM_PERS +//x0pleela 25 Apr, 2006 DR: OMAPS00067919 +//Global variable to store the code result of qAT_PlusCPIN() result +extern T_ACI_CPIN_RSLT simp_cpin_code; +extern UBYTE simp_cpin_flag; +#endif + + +/* PROTOTYPS */ + +static int pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static int pin_edt_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static int pin_edt_kbd_cb (T_MFW_EVENT event, T_MFW_KBD * kc); +static void check_pins (T_MFW_HND win,void * edt_pin); +static void gsm_sec_execute(T_MFW_HND win,void *string); +static void pin_edt_tim_out_cb (T_MFW_EVENT event,T_MFW_TIM * t); +static int pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static void pin_icons(void); +static void clear_edit_array (void * parameter); +static void emerg_pin(void * string); +static int sim_rem_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static void pin_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static int gsm_test(T_MFW_HND win,void * edt_pin); +static void pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static void sim_rem_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static int pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc); +static void main_call_edit(T_MFW_HND win, USHORT event); +static void main_call_mess(T_MFW_HND win,USHORT event); +static int setting_pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static int set_pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +static void sett_pin_mess(T_MFW_HND win,USHORT event); +static void check_set_pins (T_MFW_HND win,void * edt_pin); +static int set_pin_kbd_cb (T_MFW_EVENT event,T_MFW_KBD * kc); +static void set_pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static int set_pin_win_cb (T_MFW_EVENT event,T_MFW_WIN * win); +static void sett_pin_edit(T_MFW_HND win,USHORT event); +static int gsm_set_test(T_MFW_HND win,void * edt_pin); +static void set_mode_fdn_adn(T_MFW_HND win,void * string); +static void check_plock_to_clock(T_MFW_HND win,USHORT event); +static void check_nlock_to_clock(T_MFW_HND win,USHORT event); +static void check_splock_to_clock(T_MFW_HND win,USHORT event); +static void check_nslock_to_clock(T_MFW_HND win,USHORT event); +static void check_sim_clock(T_MFW_HND win,USHORT event); +static void pin_ch_end_or_abort (T_MFW_HND win); +static void pin_verif_or_check2_end(T_MFW_HND win); +static void pin1_en_dis_verify(T_MFW_HND win); +static int set_pin_edt_win_cb (T_MFW_EVENT event,T_MFW_WIN * win); +static int set_pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc); +static void gsm_sec_execute_set(T_MFW_HND win,void *string); +void pin2_not_available_screen(void); /* Warning Correction */ +static void not_avail_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason); +static void pins_editor_cb (T_MFW_HND win, USHORT Identifier, SHORT reason); +void pin1_not_enabled_screen(void); /* Warning Correction */ + +// June 16, 2005 REF: CRR 31267 x0021334 +// Call back function for handling uninitialised PIN1 condition +void pin1_cb_function (T_MFW_HND win, UBYTE identifier, UBYTE reason); + +static void pins_editor_cb (T_MFW_HND win, USHORT Identifier, SHORT reason); +/* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR +void pins_loadEditDefault (T_AUI_EDITOR_DATA *editor_data, USHORT TitleId, USHORT Idenfitier); +#else /* NEW_EDITOR */ +void pins_loadEditDefault (T_EDITOR_DATA *editor_data); +#endif /* NEW_EDITOR */ +/* SPR#1746 - SH - Add identifier parameter */ +void show_confirmation (T_MFW_HND win, USHORT Identifier); +static int show_confirmation_cb(T_MFW_HND win, USHORT identifier, UBYTE reason); + +void pin_skClear( void ); +void pin_rectClear( MfwRect *win ); + + +#ifdef SIM_PERS +//this global variable is used to track which lock was selected +S16 mmi_simlock_locktype =0xFF; +// Nov 03, 2005 DR: OMAPS00052032 - xpradip +// holds the info display handle +static T_MFW_HND info_disp = NULL; +//this global variable is used to track the action to be performed on the selected category +S16 mmi_simlock_lockaction = 0xFF; +static T_ACI_ERR_DESC mmi_simlock_aciErrDesc = 0; +// Sept 24, 2005 REF: LOCOSTO-ENH-34438, xpradipg +// added prototypes require for new compiler 2.54 +static void mmi_simlock_reset_fc_value(T_MFW_HND win); +static void mmi_simlock_en_dis_verify(T_MFW_HND win); +#endif + +extern T_MFW_SS_RETURN mfw_simlock_enable_lock(U8 *pin, S16 lcktyp); +extern T_MFW_SS_RETURN mfw_simlock_disable_lock(U8 *pin, S16 lcktyp); + +#define NUM_OF_PLOCK 6 +// the coordinate of the TxtId +//moved info text defines to MmiResources.h +#define PIN_ENTRY_MAX 3 +#define STAR 0x2a +#define HASH 0x23 +#define FIRST_DIGIT 1 +//#define NUM_OF_PLOCK 6 +#define IDENT_GSM_1 5 +#define IDENT_GSM_2 6 +#define TIM_LOCK 0x01 +#define TIM_LOCK_JUMP 1000 +typedef struct +{ + T_MMI_CONTROL mmi_control; + T_MFW_HND parent_win; + T_MFW_HND pin_win; + T_MFW_HND sim_handle; +#ifdef SIM_PERS +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +//New window handler for the new menu "menuBootupCatList" + T_MFW_HND simp_list_win; + UBYTE mk_pin[MAX_PIN+1]; /* Master Unlock Key*/ +#endif + int pin_retries; /* number of pin attempts */ + UBYTE puk_request; + USHORT display_id1; + USHORT display_id2; + UBYTE gsm_state; /* status gsm in security */ + SET_CASE set_state; /* setting state */ + UBYTE pin[MAX_DIG+1]; /* number string pin */ + UBYTE puk[MAX_PIN+1]; /* number string puk */ + UBYTE new_pin[MAX_PIN+1]; /* store new pin */ + UBYTE old_pin[MAX_PIN+1]; /* store old pin */ + PIN_CASE pin_case; /* editor state */ + char edtbuf[MAX_DIG]; +} T_pin; +typedef struct +{ + T_MMI_CONTROL mmi_control; + T_MFW_HND parent_win; + T_MFW_HND pin_mess_win; + USHORT display_id1; + USHORT display_id2; + PIN_CASE pin_case; +}T_pin_mess; + +typedef struct +{ + T_MMI_CONTROL mmi_control; + T_MFW_HND parent_win; + T_MFW_HND pin_edt_win; + T_MFW_HND kbd_handle; + T_MFW_HND kbd_long_handle; +#ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes */ + T_ED_DATA * editor; +#else /* NEW_EDITOR */ + T_MFW_HND editor_handle; +#endif /* NEW_EDITOR */ + T_MFW_HND tim_out_handle; + UBYTE pin[MAX_PIN+1]; /* number string pin */ + UBYTE puk[MAX_PIN+1]; /* number string puk */ + UBYTE new_pin[MAX_PIN+1]; /* store new pin */ + UBYTE old_pin[MAX_PIN+1]; /* store old pin */ + UBYTE editor_index; + PIN_CASE pin_case_edit; + UBYTE gsm_state; /* status gsm in security */ + UBYTE emergency_call; + char edtbuf[MAX_DIG]; +#ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes */ + T_ED_ATTR editorPinAttr; +#else /* NEW_EDITOR */ + MfwEdtAttr editpinAttr; +#endif /* NEW_EDITOR */ +}T_pin_edt; + +typedef struct +{ + T_MMI_CONTROL mmi_control; + T_MFW_HND parent_win; + T_MFW_HND sim_rem_win; + T_MFW_HND sim_handle; + PIN_CASE pin_case; + USHORT display_id1; +} T_sim_rem; + +LOCAL T_sim_rem sim_rem_data; + +static T_MFW_HND pin_windows; +static T_MFW_HND pin_edit_windows; +static T_MFW_HND pin_editor_window; +static T_MFW_HND pin_mess_windows; +static T_MFW_HND set_pin_windows; +/* static T_MFW_HND sim_rem_handle; x0039928-Lint warning removal */ + +//API define for a flag for PIN Emergency Entry +UBYTE pin_emergency_call; +char pin_emerg_call[MIN_PIN]; + +#ifdef SIM_PERS +UBYTE FCUnlock_flag; +UBYTE perm_blocked; +UBYTE gsim_status; +/*a0393213 warnings removal-sim_unlock_in_prog made to be of type T_MFW_SIMP_CLCK_FLAG*/ +EXTERN T_MFW_SIMP_CLCK_FLAG sim_unlock_in_prog; // June 07, 2006 DR: OMAPS00080701 x0021334 +#endif +//June 16, 2005 REF: CRR 31267 x0021334 +BOOL pin1Flag = FALSE; + +// June 16, 2005 REF: CRR 31267 x0021334 +extern BOOL pin2Flag; // This variable will be needed here + +//xashmic 21 Sep 2006, OMAPS00095831 +//To track the various stages during bootup +T_BOOTUP_STATE BootUpState = BOOTUP_STATE_NONE; + +//x0pleela 08 ep, 2006 DR: OMAPS00091250 +//Adding the prototype +void mfw_flash_write(char *LogMsg,...); + +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK +EXTERN T_call call_data; +static int autoPhLock_menu; +T_MFW_HND phlock_win_handle; /* to hold the win handle of phone unlock editor window */ +T_MFW_HND phlock_kbd_handle; /* to hold the kbd handle of phone unlock editor window */ +T_MFW_HND phlock_alarm_win_handle; /* to hold the win handle of alarm window */ +T_MFW_HND phlock_mtc_win_handle; /* to hold the win handle of MT call window */ +T_MFW_HND phlock_dialog_mtc_win_handle;/* to hold the win handle of MT call dialog window */ +int phlock_alarm; /* flag to check whether alarm event has occured or not */ +//x0pleela 09 Mar, 2007 DR: OMAPS00129014 +EXTERN UBYTE phlock_auto; /* flag to check whether auo phone lock is enabled or not */ + +//x0pleela 15 May, 2007 DR: OMAPS00127483 +#ifdef FF_MMI_AUDIO_PROFILE +extern UBYTE mfwAudPlay;//flag for audio +#endif + +void mmi_phlock_change_pin(T_MFW_HND win,int type,char* oldpsw,char* newpsw); +static void mmi_phlock_en_dis_verify(T_MFW_HND win); + +//x0pleela 19 Mar, 2007 ER: OMAPS00122561 +EXTERN void mmi_set_usbms_enum( int usb_enum); +EXTERN int mmi_get_usbms_enum(void); +EXTERN void mmi_set_Headset_Reg( int headset_reg); +EXTERN int mmi_get_Headset_Reg(void); +static MfwHnd mmi_phlock_show_info(T_MFW_HND parent, int str1, int str2, T_VOID_FUNC callback); +T_MFW_HND phlock_setting_pin_create (T_MFW_HND parent_window); +static int phlock_setting_pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +void phlock_setting_pin_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static void phlock_sett_pin_mess(T_MFW_HND win,USHORT event); +T_MFW_HND phlock_set_pin_mess_create(T_MFW_HND parent_window); +void phlock_set_pin_mess_destroy (T_MFW_HND own_window); +static int phlock_set_pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); +void phlock_set_pin_messages(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +void phlock_set_pin_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reasons); +static void phlock_sett_pin_edit(T_MFW_HND win, USHORT event); +T_MFW_HND phlock_set_pin_edt_create (T_MFW_HND parent_window); +static int phlock_set_pin_edt_win_cb (T_MFW_EVENT event,T_MFW_WIN * win); +static void phlock_set_pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter); +static int phlock_set_pin_kbd_cb (T_MFW_EVENT event,T_MFW_KBD * kc); +static int phlock_set_pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc); +static void phlock_pin_edt_tim_out_cb (T_MFW_EVENT event,T_MFW_TIM * t); +void phlock_setting_pin_destroy (T_MFW_HND own_window); +void phlock_set_pin_edt_destroy (T_MFW_HND own_window); +T_MFW_SS_RETURN mfw_phlock_enable_lock(U8 *pin, S16 lcktyp); +T_MFW_SS_RETURN mfw_phlock_disable_lock(U8 *pin, S16 lcktyp); + +//x0pleela 29 May, 2007 DR: OMAPS00132483 +EXTERN int mfw_get_Phlock_status(void); +EXTERN void mfw_set_Phlock_status( int phlock_status); +EXTERN int mfw_get_Auto_Phlock_status(void); +EXTERN void mfw_set_Auto_Phlock_status( int phlock_status); +#endif /* FF_PHONE_LOCK */ + +/******************************************************************************* + + $Function: pin_init + + $Description: This is the start-up time initialisation routine. + call from init routine in the idle + + $Returns: None + + $Arguments: parent window + +*******************************************************************************/ +void pin_init (T_MFW_HND parent_window) +{ + pin_create (parent_window); + BootUpState = BOOTUP_STATE_NONE;//xashmic 21 Sep 2006, OMAPS00095831 +} + + +/******************************************************************************* + + $Function: pin_exit + + $Description: power down in security screen + $Returns: None + + $Arguments: None + +*******************************************************************************/ +void pin_exit (void) +{ + if(pin_mess_windows) + pin_mess_destroy(pin_mess_windows); + + if (pin_editor_window) + { +#ifdef NEW_EDITOR + AUI_pin_Destroy(pin_editor_window); +#else + editor_destroy(pin_editor_window); +#endif + pin_editor_window = NULL; + } + + if (pin_edit_windows) + pin_edt_destroy(pin_edit_windows); + + if(pin_windows) + { + TRACE_FUNCTION("pin_destroy 1"); + pin_destroy (pin_windows); + + } +} + + +/******************************************************************************* + + $Function: pin_create + + $Description: Creation of an instance for the PIN dialog (sim activation) + + Type of dialog : SINGLE_DYNAMIC + $Returns: Window + + $Arguments: Parent window + +*******************************************************************************/ +T_MFW_HND pin_create (T_MFW_HND parent_window) +{ + + T_MFW_WIN * win; + T_pin * data = (T_pin *)ALLOC_MEMORY (sizeof (T_pin)); + + data->pin_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)pin_win_cb); + + pin_windows = data->pin_win; + pin_edit_windows = NULL; + pin_editor_window = NULL; + pin_mess_windows = NULL; + + TRACE_FUNCTION("MmiPins:pin_create"); + + if (data->pin_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)pin_main;/* dialog main function */ + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_win)->data; + win->user = (void *) data; + + + /* + * Create any other handler + */ + + data->sim_handle = sim_create(data->pin_win,E_SIM_ALL_SERVICES,(MfwCb)sim_event_cb_main); + + /* + * return window handle + */ + + mfwSetSignallingMethod(1);//mfw focus handling + winShow(data->pin_win); + + + return data->pin_win; +} + + +/******************************************************************************* + + $Function: pin_destroy + + $Description: Destroy the pin dialog. + $Returns: None + + $Arguments: window + +*******************************************************************************/ +void pin_destroy (T_MFW_HND own_window) +{ + + T_pin * data; + T_MFW_WIN * win; + + TRACE_FUNCTION("MmiPins:pin_destroy"); + + if (own_window) + { + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin *)win->user; + + if(data) + { + /* + * Exit SIM and Delete SIM Handler + */ + sim_delete (data->sim_handle); + + /* + * Delete WIN Handler + */ + win_delete (data->pin_win); + pin_windows = 0; + FREE_MEMORY((void *)data,(sizeof(T_pin))); + } + } +} + + +/******************************************************************************* + + $Function: pin_win_cb + + $Description: Callback function for windows + $Returns: Status int + $Arguments: window handler event, window + +*******************************************************************************/ +static int pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + TRACE_EVENT_P1("pin_win_cb: %d", event); + + if (event EQ MfwWinVisible) + { + dspl_ClearAll(); + return 1; + } + return 0; +} + + + + + +/******************************************************************************* + + $Function: sim_event_cb_main + + $Description: PURPOSE : SIM event handler for Pins + $Returns: Status int + $Arguments: window handler event, sim status + +*******************************************************************************/ +int sim_event_cb_main (T_MFW_EVENT event, T_MFW_HND para) +{ +/**********************/ +// #define NO_ACTION 0 /* Warning Correction */ + +// BYTE reconf_handling = NO_ACTION; /* Warning Correction */ +// BYTE reconf_defreeze_display = 1; /* Warning Correction */ +/*********************/ + + T_MFW_SIM_STATUS * status; + UBYTE limited; + + T_MFW_HND win = mfw_parent(mfw_header()); + +#ifdef SIM_PERS + int status1, max1, curr1; +#endif + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + + T_pin * pin_data = (T_pin *)win_data->user; + + status = (T_MFW_SIM_STATUS *)para; + + limited = TRUE; /* initial limited mode */ + + TRACE_EVENT_P3("sim event handler,event:%d, status:%d, proc:%d",event, status->sim_status, status->sim_procedure); +// June 16, 2005 REF: CRR 31267 x0021334 +// If PIN1 and PUK1 are uninitialised, post SIM_LOCKED event + if ((sim_pin_count(MFW_SIM_PIN1) EQ 0) AND (sim_pin_count(MFW_SIM_PUK1) EQ 0)) + { + SEND_EVENT(pin_data->pin_win, SIM_LOCKED, 0, pin_data); + } + else // June 16, 2005 REF: CRR 31267 x0021334 + { + switch(event) + { + case E_SIM_INSERTED: /* there not handled */ + + BootUpState = BOOTUP_STATE_COMPLETED;//xashmic 21 Sep 2006, OMAPS00095831 + + /* 14-Mar-2006, Monika.B.J., x0045876, START (Bug OMAPS00071413) */ +#ifdef FF_MMI_SAT_ICON + addSatMessage(NULL, 0, 0, NULL, FALSE, SAT_ICON_IDLEMODE_TEXT); + +#else + addSatMessage(NULL); +#endif +// July 11, 2006 DR: OMAPS00084081 x0039928 +// Fix: Registers to network on sim reset + nm_registration (NM_AUTOMATIC, 0, FALSE); + /*OMAPS00115179 - support SIM insertion without powering down - a0393213(R.Prabakar) + If pin_editor_window for the removed SIM("Insert SIM" window or "PIN" entry window) is present + destroy it when a new SIM is inserted. + If "PIN" entry window is necessary even for the newly inserted SIM, it + would be created once again at a different point. */ + if(pin_editor_window) + { + AUI_pin_Destroy(pin_editor_window); + pin_editor_window=NULL; + } + smsidle_unset_ready_state (); + + /* 14-Mar-2006, Monika.B.J., x0045876, END */ + return 0; /* (handled in sim_rem dialog, commented out currently */ + + + //GW-SPR#1035-Added STK Changes + case E_SIM_RESET: + TRACE_FUNCTION("E_SIM_RESET"); + /*NM, 110702 + the MM-entity initated the de-registration already (MMI dont have to do it); + after this event we should avoid any cases to access the SIM + (e.g. reading phonebook, reading sms....) + + - how to do it ??? + -> unset the "sms_initialised" flag to FALSE + + - when does it set back to TRUE ??? + -> the flag will be set after the event "E_SMS_READY" + */ + smsidle_unset_ready_state (); + info_screen(0, TxtSimNot, TxtReady, NULL); + /*NM, 110702 END*/ + return 0; + + + case E_SIM_STATUS: + /* + * check whether decoded message is available + */ + if( para EQ (T_MFW_SIM_STATUS *)NULL ) + return MFW_RES_ILL_HND; + + status = (T_MFW_SIM_STATUS *)para; + + TRACE_FUNCTION_P1("sim_status: %d", status->sim_status); + +/********************************/ +#ifdef SIM_PERS + + //x0pleela 18 Oct, 2006 DR: OMAPS00099660 + //Added the following code (MFW_MEPD_INVALID)inside the SIM_PERS flag + //x0pleela 08 Sep, 2006 DR: OMAPS00091250 + //Write No MEPD, NO SIM string into a file + if( status->sim_procedure == MFW_SIM_ACTIVATION ) + { + if(status->sim_status == MFW_MEPD_INVALID) + mfw_flash_write("No MEPD"); + if(status->sim_status == MFW_SIM_NO_SIM_CARD) + mfw_flash_write("No SIM"); + } + + + //x0pleela 29 Aug, 2006 DR: OMAPS00091250 + //Added this check so that MMI doesn't hang at boot up as + //MEPD data is not present + if( ( status->sim_procedure == MFW_SIM_ACTIVATION )AND + ( ( status->sim_status != MFW_MEPD_INVALID) OR + (status->sim_status != MFW_SIM_NO_SIM_CARD) ) ) + { + + status1 =mfw_simlock_check_status(0,&max1, &curr1); + if(status1== MFW_SIM_PERM_BLOCKED) + { + perm_blocked = 1; + status->sim_status=MFW_SIM_PUK_REQ; + } + } + +#endif + BootUpState = BOOTUP_STATE_INPROGRESS;//xashmic 21 Sep 2006, OMAPS00095831 + + switch (status->sim_procedure) + { + /* + * Initial activation of the SIM card + */ + case MFW_SIM_ACTIVATION: + /* + * check the result of activation + */ + switch (status->sim_status) + { + //x0pleela 18 Oct, 2006 DR: OMAPS00099660 + //Added the following code (MFW_MEPD_INVALID)inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 29 aug, 2006 DR: OMAPS00091250 + //Send event No MEPD data + case MFW_MEPD_INVALID: + //limited = TRUE; + TRACE_FUNCTION("sim_event_cb_main:no MEPD data"); + SEND_EVENT(pin_data->pin_win,NO_MEPD, 0, pin_data); + break; +#endif + /* + * PIN 1 must be entered + */ + case MFW_SIM_PIN_REQ: + if(status->sim_pin_retries < PIN_ENTRY_MAX) + { + TRACE_FUNCTION("sim_event_cb_main:PIN1 req-retr"); + pin_data->pin_retries = status->sim_pin_retries;/* number of retries */ + SEND_EVENT(pin_data->pin_win,PIN1_REQ_ATT,0,pin_data); + } + else + { + +/********************************/ + + TRACE_FUNCTION("sim_event_cb_main:PIN1 req"); + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,pin_data); + } + break; + + /* + * SIM card is blocked, PUK 1 is needed + */ + case MFW_SIM_PUK_REQ: + { +#ifdef SIM_PERS + int smlk_status, max, curr; //x0pleela 19 Apr, 2006 DR:OMAPS00067912 changed the name from stastus to smlk_status +#endif + TRACE_FUNCTION("sim_event_cb_main:PUK1 req"); +#ifdef SIM_PERS + //x0pleela 19 Apr, 2006 DR:OMAPS00067912 + //changed the name from stastus to smlk_status + smlk_status =mfw_simlock_check_status(0,&max, &curr); + if( (smlk_status== MFW_SIM_BLOCKED) OR (smlk_status == MFW_SIM_NOT_BLOCKED) ) + { + TRACE_EVENT("BMI: MFW_SIM_BLOCKED"); + perm_blocked = 0; + TRACE_EVENT("BMI: MFW_SIM_PUK1"); + //x0pleela 26 Sep, 2006 DR: OMAPS00096565 + //Adding a check for C_KEY_REQ. If set, display SIMP menu + //Else prompt the user for PUK entry + if( C_KEY_REQ ) + { + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options Unblock ME and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + } + else +#endif + SEND_EVENT(pin_data->pin_win,PUK1_REQ_ACT_INFO,0,pin_data); + +#ifdef SIM_PERS + } + //x0pleela 19 Apr, 2006 DR:OMAPS00067912 + //changed the name from stastus to smlk_status + else if (smlk_status == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } +#endif + } + break; + + /* + * no PIN is needed + */ + case MFW_SIM_NO_PIN: + + BootUpState = BOOTUP_STATE_COMPLETED;//xashmic 21 Sep 2006, OMAPS00095831 + + limited = FALSE; + TRACE_FUNCTION("sim_event_cb_main:no Pin"); + mmi_cphs_refresh(); + SEND_EVENT(pin_data->pin_win,PIN_OK, 0, NULL);//back to idle + break; + + /* + * SIM card is broken + */ + case MFW_SIM_INVALID_CARD: + TRACE_FUNCTION("sim_event_cb_main: invalid card"); + SEND_EVENT(pin_data->pin_win,INVALID_CARD, 0, pin_data); + break; + + /* + * No SIM card is inserted + */ + case MFW_SIM_NO_SIM_CARD: + + TRACE_FUNCTION("sim_event_cb_main: no SIM Card"); + SEND_EVENT(pin_data->pin_win,NO_SIM_CARD, 0, pin_data); + break; + +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + case MFW_IMEI_NOT_VALID: + limited = FALSE; + TRACE_FUNCTION("sim_event_cb_main: IMEI is not valid"); + SEND_EVENT(pin_data->pin_win,INVALID_IMEI, 0, pin_data); + break; + +#ifdef SIM_PERS + + case MFW_SIM_PLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_PLOCK_REQ"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options SIM unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SIM_PIN_REQ, 0, pin_data); + break; + + case MFW_SIM_NLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_NLOCK_REQ"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options Network unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NLOCK_PIN_REQ, 0, pin_data); + break; + + case MFW_SIM_NSLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_NSLOCK_REQ"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options Network subset unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NSLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NSLOCK_PIN_REQ, 0, pin_data); + break; + + case MFW_SIM_SPLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_SPLOCK_REQ"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options Service Provider unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_SPLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SPLOCK_PIN_REQ, 0, pin_data); + break; + + case MFW_SIM_CLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_CLOCK_REQ"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //check for Master Unlock option enabled. + //If so, then display the menu with options Corporate unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_CLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_CLOCK_PIN_REQ, 0, pin_data); + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //Request unlocking password of "Blocked Network" category + case MFW_SIM_PBLOCK_REQ: + TRACE_FUNCTION("sim_event_cb_main: MFW_SIM_PBLOCK_REQ"); + //check for Master Unlock option enabled. + //If so, then display the menu with options Network unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PBLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_PBLOCK_PIN_REQ, 0, pin_data); + break; +#endif + default: + return 0; + } + /* + * start limited or full service */ + + if (limited) + { + /* + * limited shall be the requested service + * if no service is reached, the limited + * service is requested*/ + TRACE_FUNCTION("DEBUG"); + + if (nm_reg_status() EQ NOT_PRESENT_8BIT + AND + status->sim_procedure EQ MFW_SIM_ACTIVATION) + { + TRACE_FUNCTION("registration in limited mode "); + nm_registration (NM_AUTOMATIC, 0, TRUE); + } + } + break; + case MFW_SIM_VERIFY: + /* + * check the result of verify + */ + switch (status->sim_status) + { + /* + * PIN 1 must be entered + */ + case MFW_SIM_PIN_REQ: + if(status->sim_pin_retries < PIN_ENTRY_MAX) + { + TRACE_FUNCTION("sim_event_cb_main:Ver:PIN1 req-retr"); + pin_data->pin_retries = status->sim_pin_retries; + SEND_EVENT(pin_data->pin_win,PIN1_REQ_ATT,0,pin_data); + } + else + { + TRACE_FUNCTION("SimEventPins:V:PIN1 req"); + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,pin_data); + } + break; + /* + * SIM card is blocked, PUK 1 is needed + */ + case MFW_SIM_PUK_REQ: + TRACE_FUNCTION("SimEventPins:V:PUK1 req"); + SEND_EVENT(pin_data->pin_win,PUK1_REQ_VER_INFO,0,pin_data); + break; + + /* + * PIN entering successfull + */ + case MFW_SIM_NO_PIN: + TRACE_FUNCTION("sim_event_cb_main:PIN ok without sim unlock"); + mmi_cphs_refresh(); + pin_data->pin_case = PIN_OK_INFO; + if (pin_data->set_state == PIN2_CHECK) + { + set_mode_fdn_adn(win,pin_data); + } + SEND_EVENT(pin_data->pin_win,PIN_OK_INFO,0,pin_data); + break; + /* + * SIM card is broken + */ + case MFW_SIM_INVALID_CARD: + TRACE_FUNCTION("sim_event_cb_main: invalid card"); + SEND_EVENT(pin_data->pin_win,INVALID_CARD, 0, pin_data); + break; + + /* + * No SIM card is inserted + */ + case MFW_SIM_NO_SIM_CARD: + TRACE_FUNCTION("sim_event_cb_main: no SIM Card"); + SEND_EVENT(pin_data->pin_win,NO_SIM_CARD, 0, pin_data); + break; + default: + return 0; + } + break; + /* + * response to PUK entering + */ + case MFW_SIM_UNBLOCK: + switch (status->sim_status) + { + case MFW_SIM_PUK_REQ: + TRACE_FUNCTION("sim_event_cb_main:unblock failure"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_FAIL_INFO,0,pin_data); + break; + case MFW_SIM_SUCCESS: + TRACE_FUNCTION("sim_event_cb_main:unblock success"); + mmi_cphs_refresh(); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_SUCC,0,pin_data); + break; + case MFW_SIM_FAILURE: + TRACE_FUNCTION("sim_event_cb_main:unblock fatal error"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_FATAL_ERROR,0,pin_data); + break; + case MFW_SIM_INVALID_CARD: + TRACE_FUNCTION("sim_event_cb_main:unblock failed, no more retries"); + SEND_EVENT(pin_data->pin_win,INVALID_CARD,0,pin_data); + break; + default: + return 0; + } + break; + + case MFW_SIM_REMOVED:/* Handle the removal of SIM card */ + /* OMAPS00050447: a0393130, handle removal of sim card */ + switch (status->sim_status) + { + case MFW_SIM_NO_SIM_CARD: + TRACE_FUNCTION("sim_event_cb_main: SIM Card removed"); + /*OMAPS00115179 - support SIM insertion without powering down - a0393213 + SMS state should be unset immediately after removing the SIM card. This ensures + icons/display related to messages are NOT shown in the idle screen after the removal of SIM card*/ + smsidle_unset_ready_state (); + SEND_EVENT(idle_get_window(),NETWORK_NO_SERVICE, 0, 0); + break; + + default: + return 0; + } + break; + /* OMAPS00050447: a0393130, handle removal of sim card */ + + default: + return 0; + } + + return 1; + #ifdef BMI_TEST_MC_SIM_EVENT + break; + case BMI_TEST_MC_SIM_EVENT: + { + T_MFW_READ_CALLBACK* sim_read_data; + + sim_read_data = (T_MFW_READ_CALLBACK*)para; + + TRACE_EVENT_P3("SIM READ Error: %d, %x%x", sim_read_data->error_code, + sim_read_data->read_buffer[0], sim_read_data->read_buffer[1]); + } + break; + #endif + } + } // June 16, 2005 REF: CRR 31267 x0021334 + + /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function ) */ + return 0; +} +#ifdef SIM_PERS +/******************************************************************************* + + $Function: simp_busy_cb + + $Description: This function checks for the ACI CME error and display menu for unlocking + categories or unblocking ME + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +void simp_busy_cb(T_MFW_HND win, USHORT identifier, UBYTE reasons) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; + + T_pin * pin_data = (T_pin *)win_data->user;//pin main data + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for CME class and handle all CME errors + if( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Cme) + { + switch(aciErrDesc & 0x0000FFFF) + { + case CME_ERR_NetworkPersPinReq: + TRACE_EVENT("CME_ERR_NetworkPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_NetworkSubsetPersPinReq: + TRACE_EVENT("CME_ERR_NetworkSubsetPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NSLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NSLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_ProviderPersPinReq: + TRACE_EVENT("CME_ERR_ProviderPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_SPLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SPLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_CorporatePersPinReq: + TRACE_EVENT("CME_ERR_CorporatePersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_CLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_CLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhSimPinReq: + TRACE_EVENT("CME_ERR_PhSimPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SIM_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhoneFail: + case CME_ERR_NetworkPersPukReq: + case CME_ERR_NetworkSubsetPersPukReq: + case CME_ERR_ProviderPersPukReq: + case CME_ERR_CorporatePersPukReq: + { + int status,curr_fail_reset, curr_succ_reset; + TRACE_EVENT("PUK Req"); + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if( status == MFW_SIM_BLOCKED) + { + C_KEY_REQ = 1; + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else if (status == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + break; + + case CME_ERR_WrongPasswd: + TRACE_EVENT("CME_ERR_WrongPasswd"); + SEND_EVENT(pin_data->pin_win,identifier,0,pin_data); + break; + + default: + TRACE_EVENT("Undefined error"); + } +} + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for Ext class and handle all Extension errors + else if( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) + { + switch(aciErrDesc & 0x0000FFFF) + { + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //Request for Blocked Network Password + case EXT_ERR_BlockedNetworkPersPinReq: + TRACE_EVENT("CME_ERR_NetworkPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PBLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_PBLOCK_PIN_REQ,0,pin_data); + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //Request for Blocked Network Unblock code + case EXT_ERR_BlockedNetworkPersPukReq: + { + int status,curr_fail_reset, curr_succ_reset; + TRACE_EVENT("PUK Req"); + + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if( status==MFW_SIM_BLOCKED) + { + C_KEY_REQ = 1; + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else if (status == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + break; + + default: + break; + } + } + +} + +#endif + +/******************************************************************************* + + $Function: pin_main + + $Description: PIN MAIN Dialog Handling function + $Returns: void + $Arguments: window, window handler event, value, parameters + +*******************************************************************************/ +static void pin_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user;//pin main data +// T_pin_mess * mess_data = (T_pin_mess *) parameter;//pin message data /* Warning Correction */ +// T_pin_edt * edt_data = (T_pin_edt *) parameter;//pin editor data /* Warning Correction */ + + // June 16, 2005 REF: CRR 31267 x0021334 + // Added the following two variables + static int pin1_info_count = 0; + T_DISPLAY_DATA display_info; + +#ifdef NEW_EDITOR + T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */ +#else + T_EDITOR_DATA editor_data; +#endif + + TRACE_EVENT_P1("MmiPins:pin_main: %d", event); + + switch(event) + { +#ifdef SIM_PERS + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //This event displays a dialog "Busy" for the user if timer is enabled and + //ACI returns Busy error when user had entered wrong unlocking password + case SIM_LOCK_BUSY_BOOTUP: + mfw_simlock_set_busy_state(FALSE); + dlg_initDisplayData_TextId(&display_info, NULL, NULL, TxtBusy, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)simp_busy_cb, THREE_SECS, KEY_LEFT | KEY_RIGHT); + info_dialog (pin_data->pin_win, &display_info); + break; +#endif + + // June 16, 2005 REF: CRR 31267 x0021334 + // This case is added to handle PIN1 and PUK1 EQ 0 condition + case SIM_LOCKED: + if(pin1_info_count EQ 0) // To avoid getting the sim blocked dialog during emergency call set up + { + pin1Flag = TRUE; // set this flag to TRUE to indicate that PIN1 and PUK1 are 0 + // Display info dialog that the sim is blocked for 3 seconds, after which call back function is called. + dlg_initDisplayData_TextId(&display_info, NULL, NULL, TxtSimBlocked, TxtDealer, COLOUR_STATUS); + dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)pin1_cb_function, THREE_SECS, KEY_LEFT | KEY_RIGHT); + info_dialog (pin_data->pin_win, &display_info); + pin1_info_count++; + } + else // post SIM_LOCKED_EMR_EDITOR event to create the editor for entering emergency numbers + { + SEND_EVENT(pin_data->pin_win, SIM_LOCKED_EMR_EDITOR, 0, 0); + } + break; + + // June 16, 2005 REF: CRR 31267 x0021334 + // This case is added to handle response from call back function 'pin1_cb_function' + case SIM_LOCKED_EMR_EDITOR: + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + pins_loadEditDefault (&editor_data, TxtSimBlocked, SIM_LOCKED_EMR_EDITOR); + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_DIG); + pin_editor_window = AUI_pin_Start(win, &editor_data); // start the editor + break; + + case PIN1_STATUS: //Text "Pin disabled" or "enabled" + case PIN1_REQ_ATT: //info screen "xx attempts " + case PUK1_REQ_ACT_INFO: //info screen "SIM blocked " + + case GSM_FAIL: // gsm not allowed + case NEW_PIN_FAIL: // new pin failed + case PUK1_REQ_VER_INFO: // Text "Pin blocked " + case PUK1_UNBL_FAIL_INFO: // unblock error - new puk requ + case PUK1_UNBL_FATAL_ERROR: + + + case SIM_UNLOCK_OK: //Text "Unlock ok " + case SIM_LOCK_ERR: +#ifdef SIM_PERS + case SIM_LOCK_PERS_CHK_OK: + case SMLK_SHOW_FC_FAIL: + case SMLK_SHOW_FC_SUCC: +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SMLK_SHOW_MK_FAIL: //wrong master unlock key + case SMLK_SHOW_MK_SUCC: //correct master unlock key + case SIM_LOCK_BUSY_UNBLOCK: //wrong unblock code +#endif + main_call_mess(win,event); + break; + + case PUK1_REQ: //Text "Enter Puk " +#ifdef SIM_PERS + case INPUT_SIM_PIN_REQ: + case INPUT_NLOCK_PIN_REQ: + case INPUT_NSLOCK_PIN_REQ: + case INPUT_SPLOCK_PIN_REQ: + case INPUT_CLOCK_PIN_REQ: + case PERM_BLK: +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case INPUT_MASTER_KEY_REQ: //Master Unlock Key request + case INPUT_PBLOCK_PIN_REQ: //x0pleela 25 Sep, 2006 ER: OMAPS00095524 +#endif + //clear the editor-buffer + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR +#ifdef SIM_PERS + switch(event) + { + case PERM_BLK: + pins_loadEditDefault (&editor_data, TxtPhoneBlocked, PERM_BLK); + break; + + case PUK1_REQ: + if( C_KEY_REQ ) + pins_loadEditDefault (&editor_data, TxtUnblockCode, PUK1_REQ); + else + pins_loadEditDefault (&editor_data, TxtEnterPuk1, PUK1_REQ); + break; + + case INPUT_NLOCK_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterNLock, INPUT_NLOCK_PIN_REQ); + break; + + case INPUT_NSLOCK_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterNsLock, INPUT_NSLOCK_PIN_REQ); + break; + + case INPUT_SPLOCK_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterSpLock, INPUT_SPLOCK_PIN_REQ); + break; + + case INPUT_CLOCK_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterCLock, INPUT_CLOCK_PIN_REQ); + break; + + case INPUT_SIM_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterPsLock, INPUT_SIM_PIN_REQ); + break; + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case INPUT_MASTER_KEY_REQ: + pins_loadEditDefault (&editor_data, TxtMasterUnlock, INPUT_MASTER_KEY_REQ); + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + case INPUT_PBLOCK_PIN_REQ: + pins_loadEditDefault (&editor_data, TxtEnterPbLock, INPUT_PBLOCK_PIN_REQ); + break; + + } + TRACE_FUNCTION_P1("sim_status: %d", gsim_status); +#else + pins_loadEditDefault (&editor_data, TxtEnterPuk1, PUK1_REQ); +#endif + //x0pleela 05 Jul, 2006 DR: OMAPS00084642 + //Changed the size of simlock password enty from MAX_DIG to MAX_PIN+1 + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_PIN+1); + pin_editor_window = AUI_pin_Start(win, &editor_data); +#else /*NEW_EDITOR */ + pins_loadEditDefault (&editor_data); + + editor_data.editor_attr.text = pin_data->edtbuf; /* buffer to be edited */ + editor_data.editor_attr.size = MAX_PIN + 1; /* limit to 8 digits */ + editor_data.LeftSoftKey = TxtSoftOK; + editor_data.RightSoftKey = TxtDelete; + editor_data.TextId = TxtEnterPuk1; + editor_data.Identifier = PUK1_REQ; + editor_data.min_enter = 4; + editor_data.hide = TRUE; +#ifdef SIM_PERS + switch(event) + { + case PERM_BLK: + editor_data.TextId = TxtPhoneBlocked; + editor_data.Identifier = PERM_BLK; + break; + + case PUK1_REQ: + if( C_KEY_REQ ) + editor_data.TextId = TxtUnblockCode; + else + editor_data.TextId = TxtEnterPuk1; + editor_data.Identifier = PUK1_REQ; + break; + + case INPUT_NLOCK_PIN_REQ: + editor_data.TextId =TxtEnterNLock; + editor_data.Identifier = INPUT_NLOCK_PIN_REQ; + break; + + case INPUT_NSLOCK_PIN_REQ: + editor_data.TextId =TxtEnterNsLock; + editor_data.Identifier = INPUT_NSLOCK_PIN_REQ; + break; + + case INPUT_SPLOCK_PIN_REQ: + editor_data.TextId =TxtEnterSpLock; + editor_data.Identifier = INPUT_SPLOCK_PIN_REQ; + break; + + case INPUT_CLOCK_PIN_REQ: + editor_data.TextId =TxtEnterCLock; + editor_data.Identifier = INPUT_CLOCK_PIN_REQ; + break; + + case INPUT_SIM_PIN_REQ: + editor_data.TextId =TxtEnterPsLock; + editor_data.Identifier = INPUT_SIM_PIN_REQ; + break; + + //x0pleela 20 july, 2006 ER: OMAPS00087586, OMAPS00087587 + case INPUT_MASTER_KEY_REQ: + editor_data.TextId =TxtMasterUnlock; + editor_data.Identifier = INPUT_MASTER_KEY_REQ; + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + case INPUT_PBLOCK_PIN_REQ: + editor_data.TextId =TxtEnterPbLock; + editor_data.Identifier = INPUT_PBLOCK_PIN_REQ; + break; + } +#endif + /* create the dialog handler */ + pin_editor_window = editor_start(win, &editor_data); /* start the editor */ +#endif /*NEW_EDITOR */ + break; + + case INPUT_NEW_PIN: + //clear the editor-buffer + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + pins_loadEditDefault (&editor_data, TxtEnterNewPin, INPUT_NEW_PIN); + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_PIN+1); + pin_editor_window = AUI_pin_Start(win, &editor_data); +#else /*NEW_EDITOR */ + pins_loadEditDefault (&editor_data); + + editor_data.editor_attr.text = pin_data->edtbuf; /* buffer to be edited */ + editor_data.editor_attr.size = MAX_PIN + 1; /* limit to 8 digits */ + editor_data.LeftSoftKey = TxtSoftOK; + editor_data.RightSoftKey = TxtDelete; + editor_data.TextId = TxtEnterNewPin; + editor_data.Identifier = INPUT_NEW_PIN; + editor_data.min_enter = 4; + editor_data.hide = TRUE; + + /* create the dialog handler */ + pin_editor_window = editor_start(win, &editor_data); /* start the editor */ +#endif /*NEW_EDITOR */ + break; + + case INPUT_NEW_PIN_AGAIN: + //clear the editor-buffer + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + pins_loadEditDefault (&editor_data, TxtConfPin, INPUT_NEW_PIN_AGAIN); + + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_PIN+1); + pin_editor_window = AUI_pin_Start(win, &editor_data); +#else /*NEW_EDITOR */ + pins_loadEditDefault (&editor_data); + + editor_data.editor_attr.text = pin_data->edtbuf; /* buffer to be edited */ + editor_data.editor_attr.size = MAX_PIN + 1; /* limit to 8 digits */ + editor_data.LeftSoftKey = TxtSoftOK; + editor_data.RightSoftKey = TxtDelete; + editor_data.TextId = TxtConfPin; + editor_data.Identifier = INPUT_NEW_PIN_AGAIN; + editor_data.min_enter = 4; + editor_data.hide = TRUE; + + /* create the dialog handler */ + pin_editor_window = editor_start(win, &editor_data); /* start the editor */ +#endif /* NEW_EDITOR */ + break; + + case PIN1_REQ: //Text "Enter Pin " + TRACE_FUNCTION("PIN1_REQ"); + //clear the editor-buffer + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + pins_loadEditDefault (&editor_data, TxtEnterPin1, PIN1_REQ); + + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_DIG); + pin_editor_window = AUI_pin_Start(win, &editor_data); +#else /*NEW_EDITOR */ + pins_loadEditDefault (&editor_data); + + editor_data.editor_attr.text = pin_data->edtbuf; /* buffer to be edited */ + editor_data.editor_attr.size = MAX_PIN + 1; /* limit to 8 digits */ + editor_data.LeftSoftKey = TxtSoftOK; + editor_data.RightSoftKey = TxtDelete; + editor_data.TextId = TxtEnterPin1; + editor_data.Identifier = PIN1_REQ; + editor_data.min_enter = 4; + editor_data.hide = TRUE; + + /* create the dialog handler */ + pin_editor_window = editor_start(win, &editor_data); /* start the editor */ +#endif /* NEW_EDITOR */ + break; + + case NO_SIM_CARD: //Text "No Sim Card " + case INVALID_CARD: //Text "Invalid SIM card " +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + case INVALID_IMEI: //Text "Invalid IMEI " +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + case NO_MEPD: //x0pleela 30 Aug, 2006 DR: OMAPS00091250 +#endif + + TRACE_EVENT("NO_SIM OR INVALID_SIM OR INVALID IMEI"); + +// May 15, 2006 DR: OMAPS00077825 - x0039928 +// Fix : TTY is initialized. +#ifdef MMI_TTY_ENABLED + call_tty_init(); +#endif + + /* API - Created the one call to generate the editor as there were two duplicate calls */ + //clear the editor-buffer + memset(pin_data->edtbuf,'\0',sizeof(pin_data->edtbuf)); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + pins_loadEditDefault (&editor_data, TxtNull, 0); + + if(event == NO_SIM_CARD) + { + AUI_edit_SetTextStr(&editor_data, TxtNull, TxtDelete, TxtNoCard, NULL); + AUI_edit_SetEvents(&editor_data, INSERT_CARD, FALSE, FOREVER, (T_AUI_EDIT_CB)pins_editor_cb); + } + else if (event == INVALID_IMEI) // Nov 24, 2005, a0876501, DR: OMAPS00045909 + { + AUI_edit_SetTextStr(&editor_data, TxtNull, TxtDelete, TxtInvalidIMEI, NULL); + AUI_edit_SetEvents(&editor_data, SHOW_IMEI_INVALID, FALSE, FOREVER, (T_AUI_EDIT_CB)pins_editor_cb); + + } +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + else if ( event == NO_MEPD ) + { + AUI_edit_SetTextStr(&editor_data, TxtNull, TxtDelete, TxtNoMEPD, NULL); + AUI_edit_SetEvents(&editor_data, NO_MEPD_DATA, FALSE, FOREVER, (T_AUI_EDIT_CB)pins_editor_cb); + + } +#endif + else + { + AUI_edit_SetTextStr(&editor_data, TxtNull, TxtDelete, TxtInvalidCard, NULL); + AUI_edit_SetEvents(&editor_data, CARD_REJECTED, FALSE, FOREVER, (T_AUI_EDIT_CB)pins_editor_cb); + + } + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)pin_data->edtbuf, MAX_DIG); + AUI_edit_SetAltTextStr(&editor_data, 3, TxtNull, TRUE, TxtNull); + + /*SPR#2235 - DS - Overwrite default 'hidden' PIN entry mode */ + AUI_edit_SetMode(&editor_data, 0 /*Numeric Mode */, ED_CURSOR_UNDERLINE); + + pin_editor_window = AUI_pin_Start(win, &editor_data); +#else /*NEW_EDITOR */ + pins_loadEditDefault (&editor_data); + + if(event == NO_SIM_CARD) + { + editor_data.TextId = TxtNoCard; + editor_data.Identifier = INSERT_CARD; + } + else if(event == INVALID_IMEI) // Nov 24, 2005, a0876501, DR: OMAPS00045909 + { + editor_data.TextId = TxtInvalidIMEI; + editor_data.Identifier = SHOW_IMEI_INVALID; + } +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + else if (event == NO_MEPD ) + { + editor_data.TextId = TxtNoMEPD; + editor_data.Identifier = NO_MEPD_DATA; + } +#endif + else + { + editor_data.TextId = TxtInvalidCard; + editor_data.Identifier = CARD_REJECTED; + } + + editor_data.editor_attr.text = pin_data->edtbuf; /* buffer to be edited */ + editor_data.editor_attr.size = MAX_DIG; /* Don't limit to 3 digits (as that prevents "*#06#") */ + editor_data.LeftSoftKey = TxtNull; + editor_data.RightSoftKey = TxtDelete; + editor_data.min_enter = 3; + editor_data.destroyEditor = FALSE; + + /* create the dialog handler */ + pin_editor_window = editor_start(win, &editor_data); /* start the editor */ +#endif /* NEW_EDITOR */ + + break; + + case TXT_SIM_PLOCK: + pin_data->pin_case = SIM_PLOCK; + main_call_edit(win,SIM_PLOCK); // Start: enter P unlock + break; + case TXT_SIM_SPLOCK: + pin_data->pin_case = SIM_SPLOCK; + main_call_edit(win,SIM_SPLOCK); // Start: enter SP unlock + break; + case TXT_SIM_NLOCK: + pin_data->pin_case = SIM_NLOCK; + main_call_edit(win,SIM_NLOCK); // Start: enter N unlock + break; + case TXT_SIM_CLOCK: + pin_data->pin_case = SIM_CLOCK; + main_call_edit(win,SIM_CLOCK); // Start: enter C unlock + break; + case TXT_SIM_NSLOCK: + pin_data->pin_case = SIM_NSLOCK; + main_call_edit(win,SIM_NSLOCK); // Start: enter NS unlock + break; + + + + } + + switch(event) + { + case PIN_OK_INFO: // PIN was needed + case PIN_OK: // PIN wasn't needed + check_plock_to_clock(win,event);/* start sim lock procedure */ + break; + case PIN_OK_END: + { + BootUpState = BOOTUP_STATE_COMPLETED;//xashmic 21 Sep 2006, OMAPS00095831 + +// U8 uMode; /* Warning Correction */ + /* + *** registration in full service mode case: PIN was necessary + */ + /* SH - show welcome screen */ + showwelcome(idle_get_window()); + + network_start_full_service (); +//GW-SPR#1035-Added STK Changes + TRACE_FUNCTION("pin_destroy 2"); + } + break; +//nm insert new one + case PIN1_STATUS_END: + pin_destroy(pin_data->pin_win);// finish main pin dialog + TRACE_FUNCTION("pin_destroy 3"); + break; +//nm + case TXT_SIM_LOCK_ALL: + ShowMessage(idle_get_window(), pin_data->display_id1, pin_data->display_id2); + pin_destroy(pin_data->pin_win);// finish main pin dialog + TRACE_FUNCTION("pin_destroy 4"); + break; + case PUK1_UNBL_SUCC: + if((pin_data->pin_case EQ PUK1_END) || (pin_data->gsm_state && (pin_data->pin_case EQ INPUT_PUK1))) + /* sim lock check only after power on and puk verified */ + /* by PUK (normal way) or by gsm unblock string */ + { + check_plock_to_clock(win,event); + } + else + { + + main_call_mess(win,event); + + } + break; + } + + switch(event) + { + + + case SIM_NLOCK_REQ: + case SIM_NSLOCK_REQ: + case SIM_SPLOCK_REQ: + case SIM_CLOCK_REQ: + main_call_mess(win,event); + break; + case SIM_PLOCK: + check_nlock_to_clock(win,event); + break; + case SIM_NLOCK: + check_splock_to_clock(win,event); + break; + case SIM_SPLOCK: + check_nslock_to_clock(win,event); + break; + case SIM_NSLOCK: + check_sim_clock(win,event); + break; + case SIM_CLOCK: + if(sim_unlock_sim_lock(MFW_SIM_CLOCK,(UBYTE *)pin_data->pin)EQ MFW_SIM_CLOCK)/* unlock code */ + { + main_call_mess(win,SIM_UNLOCK_OK); /* finish sim unlock procedure */ + } + else if(sim_unlock_sim_lock(MFW_SIM_CLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_UNLOCK_ERR) + { + main_call_mess(win,SIM_LOCK_ERR); + } + break; + default: + break; + } +} + + +/******************************************************************************* + + $Function: check_plock_to_clock + + $Description: sim lock check from PLOCK to CLOCK + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void check_plock_to_clock(T_MFW_HND win,USHORT event) +{ + /* x0045876, 14-Aug-2006 (WR - "win_data" was declared but never referenced) */ + /* T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; */ + +// T_pin * pin_data = (T_pin *)win_data->user; // pin main data /* Warning Correction */ + + TRACE_FUNCTION("MmiPins:check_plock_to_clock"); + /*MC SPR 1351 check all locks other than Plock for being blocked as well as locked. User can + then attempt to enter overall PUK to disable lock if need be*/ + if(sim_check_sim_Plock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_LOCK_ALL); + } + else if(sim_check_sim_Plock() EQ MFW_SIM_LOCKED) + { + main_call_mess(win,SIM_PLOCK_REQ); + } + else if(sim_check_sim_Nlock() EQ MFW_SIM_LOCKED ||sim_check_sim_Nlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NLOCK_REQ); + } + else if(sim_check_sim_SPlock() EQ MFW_SIM_LOCKED||sim_check_sim_SPlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_SPLOCK_REQ); + } + else if(sim_check_sim_NSlock() EQ MFW_SIM_LOCKED ||sim_check_sim_NSlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NSLOCK_REQ); + } + else if(sim_check_sim_Clock() EQ MFW_SIM_LOCKED|| sim_check_sim_Clock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_CLOCK_REQ); + } + else + { + switch(event) + { + case PIN_OK: + + /* + *** registration in full service mode case: PIN was not necessary + */ + /* SH - show welcome screen*/ + showwelcome(idle_get_window()); + /*SPR 1431*/ + network_start_full_service(); +//GW-SPR#1035-Added STK Changes +/* NM, 110702 + this destroy the only ONE SIM-handler which we have + after switching on !! + It should be at least one SIM-handler activ all the time +*/ + TRACE_FUNCTION("pin_destroy 5"); + break; + case PIN_OK_INFO: + main_call_mess(win,PIN_OK_INFO); + break; + case PUK1_UNBL_SUCC: + main_call_mess(win,event); + break; + default: + break; + } + } +} + + +/******************************************************************************* + + $Function: check_nlock_to_clock + $Description: sim lock check from NLOCK to CLOCK + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void check_nlock_to_clock(T_MFW_HND win,USHORT event) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins:check_nlock_to_clock"); + + if(sim_unlock_sim_lock(MFW_SIM_PLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_PLOCK)/* P unlock code ok */ + { /*MC SPR 1351 check locks for being blocked as well as locked. User can + then attempt to enter overall PUK to disable lock*/ + if(sim_check_sim_Nlock() EQ MFW_SIM_LOCKED || sim_check_sim_Nlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NLOCK_REQ); //check N unlock code + } + else if(sim_check_sim_SPlock() EQ MFW_SIM_LOCKED || sim_check_sim_SPlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_SPLOCK_REQ); //check SP unlock code + } + else if(sim_check_sim_NSlock() EQ MFW_SIM_LOCKED || sim_check_sim_NSlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NSLOCK_REQ); //check NS unlock code + } + else if(sim_check_sim_Clock() EQ MFW_SIM_LOCKED || sim_check_sim_Clock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_CLOCK_REQ); //check C unlock code + } + else /* finish sim unlock procedure */ + { + main_call_mess(win,SIM_UNLOCK_OK); + } + } + else if(sim_unlock_sim_lock(MFW_SIM_PLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_UNLOCK_ERR) + { + main_call_mess(win,SIM_LOCK_ERR); + } +} + + +/******************************************************************************* + + $Function: check_splock_to_clock + $Description: sim lock check from SPLOCK to CLOCK + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void check_splock_to_clock(T_MFW_HND win,USHORT event) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins:check_splock_to_clock"); + + if(sim_unlock_sim_lock(MFW_SIM_NLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_NLOCK) + {/*MC SPR 1351 check locks for being blocked as well as locked. User can + then attempt to enter overall PUK to disable lock*/ + if(sim_check_sim_SPlock() EQ MFW_SIM_LOCKED || sim_check_sim_SPlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_SPLOCK_REQ); //check SP unlock code + } + else if(sim_check_sim_NSlock() EQ MFW_SIM_LOCKED|| sim_check_sim_NSlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NSLOCK_REQ); //check NS unlock code + } + else if(sim_check_sim_Clock() EQ MFW_SIM_LOCKED || sim_check_sim_Clock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_CLOCK_REQ); //check C unlock code + } + else /* finish sim unlock procedure */ + { + main_call_mess(win,SIM_UNLOCK_OK); /* finish sim unlock procedure */ + } + } + else if(sim_unlock_sim_lock(MFW_SIM_NLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_UNLOCK_ERR) + { + main_call_mess(win,SIM_LOCK_ERR); + } +} + + +/******************************************************************************* + + $Function: check_nslock_to_clock + $Description: sim lock check from NSLOCK to CLOCK + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void check_nslock_to_clock(T_MFW_HND win,USHORT event) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins:check_nslock_to_clock"); + + if(sim_unlock_sim_lock(MFW_SIM_SPLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_SPLOCK)/* unlock code ok */ + {/*MC SPR 1351 check locks for being blocked as well as locked. User can + then attempt to enter overall PUK to disable lock*/ + if(sim_check_sim_NSlock() EQ MFW_SIM_LOCKED || sim_check_sim_NSlock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_NSLOCK_REQ); //check NS unlock code + } + else if(sim_check_sim_Clock() EQ MFW_SIM_LOCKED || sim_check_sim_Clock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_CLOCK_REQ); //check C unlock code + } + else /* finish sim unlock procedure */ + { + main_call_mess(win,SIM_UNLOCK_OK); /* finish sim unlock procedure */ + } + } + else if(sim_unlock_sim_lock(MFW_SIM_SPLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_UNLOCK_ERR) + { + main_call_mess(win,SIM_LOCK_ERR); + } +} + + +/******************************************************************************* + + $Function: check_sim_clock + $Description: sim lock check CLOCK + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void check_sim_clock(T_MFW_HND win,USHORT event) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins:check_sim_lock"); + + if(sim_unlock_sim_lock(MFW_SIM_NSLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_NSLOCK)/* unlock code ok */ + {/*MC SPR 1351 check locks for being blocked as well as locked. User can + then attempt to enter overall PUK to disable lock*/ + if(sim_check_sim_Clock() EQ MFW_SIM_LOCKED || sim_check_sim_Clock() EQ MFW_SIM_BLOCKED) + { + main_call_mess(win,SIM_CLOCK_REQ); //check C unlock code + } + else /* finish sim unlock procedure */ + { + main_call_mess(win,SIM_UNLOCK_OK); /* finish sim unlock procedure */ + } + } + else if(sim_unlock_sim_lock(MFW_SIM_NSLOCK,(UBYTE *)pin_data->pin) EQ MFW_SIM_UNLOCK_ERR) + { + main_call_mess(win,SIM_LOCK_ERR); + } +} + +/******************************************************************************* + + $Function: main_call_mess + $Description: help function for message dialog + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void main_call_mess(T_MFW_HND win, USHORT event) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_mess_win; + TRACE_FUNCTION("MmiPins: main_call_mess"); + + pin_mess_win = pin_mess_create(pin_data->pin_win); + + if(pin_mess_win) + { + SEND_EVENT(pin_mess_win,event,0,pin_data); + } +} + + +/******************************************************************************* + + $Function: main_call_edit + $Description: help function for editor dialog + $Returns: void + $Arguments: window, window handler event + +*******************************************************************************/ +static void main_call_edit(T_MFW_HND win,USHORT event) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_edt_win; + + + + + pin_edt_win = pin_edt_create(pin_data->pin_win); + + if(pin_edt_win) + { + SEND_EVENT(pin_edt_win,event,0,pin_data); + } +} + + +/******************************************************************************* + + $Function: pin_edt_create + $Description: Creation of an instance for the PIN Editor dialog. + Type of dialog : SINGLE_DYNAMIC + $Returns: void + $Arguments: parent window + +*******************************************************************************/ +T_MFW_HND pin_edt_create (T_MFW_HND parent_window) +{ + T_pin_edt * data = (T_pin_edt *)ALLOC_MEMORY (sizeof (T_pin_edt)); + + T_MFW_WIN * win; + + data->pin_edt_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)pin_edt_win_cb); + TRACE_FUNCTION("pin_edt_create"); + + if (data->pin_edt_win EQ 0) + return 0; + + /* + * Create window handler + */ + pin_edit_windows = data->pin_edt_win; + data->mmi_control.dialog = (T_DIALOG_FUNC)pin_editor; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_edt_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->tim_out_handle = tim_create(data->pin_edt_win,TIMEOUT,(T_MFW_CB)pin_edt_tim_out_cb); + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + data->editor = ATB_edit_Create(&data->editorPinAttr,0); +#else /* NEW_EDITOR */ + data->editor_handle = edt_create(data->pin_edt_win,&data->editpinAttr,0,0); +#endif /* NEW_EDITOR */ + + data->kbd_handle = kbd_create(data->pin_edt_win,KEY_ALL,(T_MFW_CB)pin_edt_kbd_cb); + data->kbd_long_handle = kbd_create(data->pin_edt_win,KEY_ALL | KEY_LONG,(T_MFW_CB)pin_edt_kbd_long_cb); + /* + * return window handle + */ + return data->pin_edt_win; +} + + +/******************************************************************************* + + $Function: pin_edt_destroy + $Description: Destroy the pin editor dialog. + $Returns: void + $Arguments: window + +*******************************************************************************/ +void pin_edt_destroy (T_MFW_HND own_window) +{ + T_pin_edt * data ; + T_MFW_WIN * win; + + + if (own_window) + { + TRACE_FUNCTION("pin_edt_destroy"); + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_edt *)win->user; + + if(data) + { + /* + * Delete WIN Handler and children handler + */ + pin_edit_windows = 0; + win_delete (data->pin_edt_win); + FREE_MEMORY((void *)data,(sizeof(T_pin_edt)));; + } + } +} + + +/******************************************************************************* + + $Function: pin_edt_win_cb + $Description: Callback function for editor windows + $Returns: Status int + $Arguments: window handle event, window + +*******************************************************************************/ +static int pin_edt_win_cb (T_MFW_EVENT event,T_MFW_WIN * win) +{ + T_pin_edt *edt_data = (T_pin_edt *)win->user;//pin edt data + T_MFW_WIN *win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin *pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_EVENT_P1("pin_edt_win_cb: %d", event); + + if (event EQ MfwWinVisible) + { + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Show(edt_data->editor); + + /* ED_UPDATE_TRIVIAL only updates text, not title */ + if (edt_data->editor->update!=ED_UPDATE_TRIVIAL) + { + /* Set the colour for drawing title */ + + resources_setTitleColour(COLOUR_EDITOR); + PROMPT(0,0,0,pin_data->display_id1); + + dspl_Clear(0,0, SCREEN_SIZE_X-1, edt_data->editor->attr->win_size.py-1); + } + + edt_data->editor->update = ED_UPDATE_DEFAULT; + +#else /* NEW_EDITOR */ + pin_icons(); + PROMPT(INFO_TEXT_X,INFO_TEXT_Y,0,pin_data->display_id1); +#endif /* NEW_EDITOR */ + + return 1; + } + return 0; +} + + +/******************************************************************************* + + $Function: pin_edt_kbd_cb + $Description: Callback function for keyboard + $Returns: Status int + $Arguments: window handle event, keyborad control block + +*******************************************************************************/ +static int pin_edt_kbd_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data +// T_sim_rem * sim_rem_data = (T_sim_rem *)win_pin->user; //sim_rem data possible too /* Warning Correction */ + + char timer = TRUE; + timStop(edt_data->tim_out_handle);/* stop entering timer */ + + TRACE_FUNCTION("MmiPins:pin_edt_kbd_cb"); + switch(kc->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_3: + case KCD_4: + case KCD_5: + case KCD_6: + case KCD_7: + case KCD_8: + case KCD_9: + case KCD_STAR: + if(edt_data->editor_index < MAX_DIG) + { + if(kc->code EQ KCD_STAR) + edt_data->pin[edt_data->editor_index] = STAR; + else + edt_data->pin[edt_data->editor_index] = '0' + kc->code; +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if((edt_data->pin_case_edit NEQ CARD_REJECTED) AND (edt_data->pin_case_edit NEQ INSERT_CARD) + AND (edt_data->pin_case_edit NEQ SHOW_IMEI_INVALID) +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + AND (edt_data->pin_case_edit NEQ NO_MEPD_DATA) +#endif + ) + { + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, '*', TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,'*'); /* hide security code */ +#endif /* NEW_EDITOR */ + } + else + { + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, edt_data->pin[edt_data->editor_index], TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,edt_data->pin[edt_data->editor_index]); /* not hide emergency call */ +#endif /* NEW_EDITOR */ + } + + edt_data->editor_index++; + check_pins(win, edt_data); /* digits check depends on status pin_case */ + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + + } + break; + case KCD_HASH: + case KCD_LEFT: + switch(edt_data->pin_case_edit) + { + + case INSERT_CARD: + case CARD_REJECTED: + case SHOW_IMEI_INVALID: // Nov 24, 2005, a0876501, DR: OMAPS00045909 +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + case NO_MEPD_DATA: +#endif + if(edt_data->emergency_call) + { + emerg_pin(edt_data); /* start emergency call */ + timer = FALSE; + } + else + { + clear_edit_array (edt_data); + memset(edt_data->pin,'\0', sizeof(edt_data->pin));/* initial string */ + edt_data->editor_index = 0; + } + break; + case SIM_PLOCK: + timer = FALSE; + strncpy((char*)pin_data->pin,(char*)edt_data->pin,MAX_PIN); + pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SIM_PLOCK,0,pin_data);//check P unlock code + break; + case SIM_NLOCK: + strncpy((char*)pin_data->pin,(char*)edt_data->pin,MAX_PIN); + pin_edt_destroy(edt_data->pin_edt_win); + timer = FALSE; + SEND_EVENT(pin_data->pin_win,SIM_NLOCK,0,pin_data); + break; + case SIM_SPLOCK: + strncpy((char*)pin_data->pin,(char*)edt_data->pin,MAX_PIN); + pin_edt_destroy(edt_data->pin_edt_win); + timer = FALSE; + SEND_EVENT(pin_data->pin_win,SIM_SPLOCK,0,pin_data); + break; + case SIM_NSLOCK: + strncpy((char*)pin_data->pin,(char*)edt_data->pin,MAX_PIN); + pin_edt_destroy(edt_data->pin_edt_win); + timer = FALSE; + SEND_EVENT(pin_data->pin_win,SIM_NSLOCK,0,pin_data); + break; + case SIM_CLOCK: + strncpy((char*)pin_data->pin,(char*)edt_data->pin,MAX_PIN); + pin_edt_destroy(edt_data->pin_edt_win); + timer = FALSE; + SEND_EVENT(pin_data->pin_win,SIM_CLOCK,0,pin_data); + break; + default: + break; + } + break; + case KCD_HUP: + case KCD_RIGHT: + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ + + if(strlen((char*)edt_data->pin) < MIN_PIN) + { + TRACE_FUNCTION("clear softknr 4"); + pin_rectClear( &edt_data->editpinAttr.win ); + } +#endif /* NEW_EDITOR */ + edt_data->emergency_call = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PUK1) /* special case ?? */ + winShow(edt_data->pin_edt_win); + else + check_pins(win,edt_data); /* check remain for emergency call */ + break; + default: + break; + } + if (timer) + tim_start(edt_data->tim_out_handle);/* start timer for entering */ + return MFW_EVENT_CONSUMED; +} + + +/******************************************************************************* + + $Function: check_pins + $Description: check pins input string + $Returns: none + $Arguments: window, pin editor attributes + +*******************************************************************************/ +static void check_pins (T_MFW_HND win, void * edt_pin) +{ + T_pin_edt * edt_data = (T_pin_edt *)edt_pin; + + TRACE_FUNCTION("MmiPins:check_pins"); + + if(strlen((char*)edt_data->pin)NEQ 0) + { + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + if (strlen((char*)edt_data->pin) > FIRST_DIGIT) /* for every character */ + { + if(strlen((char*)edt_data->pin) >= 3) + { + + TRACE_FUNCTION("Softkeys:nr 1"); + softKeys_displayId(TxtSoftOK,TxtDelete,0, COLOUR_EDITOR_XX); + } + else + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + + gsm_test(win,edt_data); /* test if GSM string or not*/ + } + + TRACE_FUNCTION("Check Length of PIN"); + if (strlen((char*)edt_data->pin) EQ (MIN_PIN - 1) || strlen((char*)edt_data->pin) EQ (MIN_PIN -2)) + { + TRACE_FUNCTION("cm_check_emergency() TRACE PINS 2"); + if(cm_check_emergency((U8*)edt_data->pin))/* test emergency call*/ + { + TRACE_FUNCTION("MmiPins:check_pins:emercall"); + edt_data->emergency_call = TRUE; + softKeys_displayId(TxtSoftCall,TxtNull,0, COLOUR_EDITOR_XX); + } + else + { +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if((edt_data->pin_case_edit EQ CARD_REJECTED) OR (edt_data->pin_case_edit EQ INSERT_CARD) + OR (edt_data->pin_case_edit EQ SHOW_IMEI_INVALID) +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + OR (edt_data->pin_case_edit EQ NO_MEPD_DATA) +#endif + ) + { /* delete all digits */ + clear_edit_array (edt_data); /* clear editor array */ + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + edt_data->editor_index = 0; + } + edt_data->emergency_call = FALSE; + } + } + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && (strlen((char*)edt_data->pin) < (MAX_PIN + 1))) + { +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if(((edt_data->pin_case_edit EQ CARD_REJECTED) OR (edt_data->pin_case_edit EQ INSERT_CARD) + OR (edt_data->pin_case_edit EQ SHOW_IMEI_INVALID) +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + OR (edt_data->pin_case_edit EQ NO_MEPD_DATA) +#endif + ) && !(edt_data->gsm_state)) + { + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; /* only emergency calls, 3 digits */ + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack); +#endif /* NEW_EDITOR */ + + } + else + { + TRACE_FUNCTION("clear softknr 5"); + + if(((edt_data->pin_case_edit EQ INPUT_PUK1) ||(edt_data->pin_case_edit EQ INPUT_PUK2)) && !(edt_data->gsm_state)) + { /* PUK 1/2 (not by gsm string) max. 8 digits */ + if(strlen((char*)edt_data->pin) >= MAX_PIN) + { + TRACE_FUNCTION("Softkeys:nr 2"); + } + } + else if((edt_data->pin_case_edit EQ SIM_CLOCK) || + (edt_data->pin_case_edit EQ SIM_NLOCK) || + (edt_data->pin_case_edit EQ SIM_NSLOCK) || + (edt_data->pin_case_edit EQ SIM_SPLOCK)) + { /* sim lock code max. 8 digits exept PLOCK */ + if(strlen((char*)edt_data->pin) >= MAX_PIN) + { + TRACE_FUNCTION("Softkeys:nr 3"); + } + } + else if (edt_data->pin_case_edit EQ SIM_PLOCK) + { /* sim lock PLOCK code max. 6 digits */ + if(strlen((char*)edt_data->pin) >= NUM_OF_PLOCK) + { + TRACE_FUNCTION("Softkeys:nr 4"); + } + } + else + { + if(!(edt_data->gsm_state)) /* usual way for PIN 4 digits */ + { + TRACE_FUNCTION("softkey 5"); + + } + else + { + TRACE_FUNCTION("clear softkey 6"); + pin_skClear( ); +// dspl_Clear( PIN_EDIT_2 ); /* clear button */ + } + } + edt_data->emergency_call = FALSE; + } + } + if((strlen((char*)edt_data->pin) > MAX_PIN) && !(edt_data->gsm_state)) /* >8 digits not allowed */ + { + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack); +#endif /* NEW_EDITOR */ + } + } +} + + +/******************************************************************************* + + $Function: gsm_test + $Description: test if gsm string + $Returns: Status int + $Arguments: window, pin editor attributes + +*******************************************************************************/ +static int gsm_test(T_MFW_HND win,void * edt_pin) +{ + int status; + T_pin_edt * edt_data = (T_pin_edt *)edt_pin; + + //T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; /* Warning Correction */ + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("MmiPins:gsm_test"); + + status = ss_check_ss_string((UBYTE*)edt_data->pin);/* check GSM-String */ + switch(status) + { + case MFW_SS_SIM_UNBLCK_PIN: + if(!(edt_data->gsm_state)) + { + switch(edt_data->pin_case_edit) + { + case INPUT_PUK1:/* replace * with string id */ + if(!(strncmp((char*)edt_data->pin,"**05*",IDENT_GSM_1))) + { + edt_data->gsm_state = TRUE; + strncpy((char*)edt_data->edtbuf,(char*)edt_data->pin,edt_data->editor_index-1); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Show(edt_data->editor); +#else /* NEW_EDITOR */ + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + } + else + { + edt_data->gsm_state = FALSE; + TRACE_EVENT("dsplClearAll 2"); + dspl_ClearAll(); + clear_edit_array (edt_data); + pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + } + break; + default: + edt_data->gsm_state = FALSE; + TRACE_EVENT("dsplClearAll 3"); + dspl_ClearAll(); + clear_edit_array (edt_data); + pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + break; + } + } + return status; + case MFW_SS_DIAL: /* string not yet detected */ + case MFW_SS_USSD: /*JVJ SPR 1040- The short USSD strings should also be + considered in this case, since they can be confused with dialled numbers + */ + edt_data->gsm_state = FALSE; + return status; + default: + TRACE_FUNCTION("MmiPins:default in gsm_test"); + edt_data->gsm_state = FALSE; + TRACE_FUNCTION("dsplClearAll 4"); + dspl_ClearAll(); + clear_edit_array (edt_data); + pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + return status; + } +} + + +#if(0) /* x0039928 - Lint warning fix */ +/******************************************************************************* + + $Function: gsm_sec_execute + $Description: GSM-String will be executed + $Returns: None + $Arguments: window, string + +*******************************************************************************/ +static void gsm_sec_execute(T_MFW_HND win,void *string) +{ + + T_pin_edt * edt_data = (T_pin_edt *)string; + +// T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; /* Warning Correction */ + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + int result; + + TRACE_FUNCTION("MmiPins:gsm_sec_execute"); + + result = ss_execute_transaction((UBYTE*)edt_data->pin,0);/* ussd_man = 0 while SSD */ + + TRACE_FUNCTION("dsplClearAll 5"); + dspl_ClearAll(); + clear_edit_array (edt_data); + pin_edt_destroy(edt_data->pin_edt_win); + + switch(result) + { + case MFW_SS_SIM_REG_PW: /* change PIN1/2 */ + TRACE_FUNCTION("MmiPins:gsm_sec_execute:MFW_SS_SIM_REG_PW"); + break; + case MFW_SS_SIM_UNBLCK_PIN: /* unblock PIN1/2 */ + TRACE_FUNCTION("MmiPins:gsm_sec_execute:MFW_SS_SIM_UNBLCK_PIN"); + break; + case MFW_SS_FAIL: + TRACE_FUNCTION("MmiPins:gsm_sec_execute:MFW_SS_FAIL"); + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/* new PIN and new PIN again are not the same */ + break; + default: + break; + } +} + +#endif + +/******************************************************************************* + + $Function: pin_edt_kbd_long_cb + $Description: Callback function for keyboard long + $Returns: Status int + $Arguments: window handler event, keyboard control block + +*******************************************************************************/ +static int pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + TRACE_FUNCTION("MmiPins:pin_edt_kbd_long_cb"); + + if ((event & KEY_CLEAR) && (event & KEY_LONG)) + { + timStop(edt_data->tim_out_handle); /* stop entering timer */ + clear_edit_array(edt_data); + memset(edt_data->pin,'\0',sizeof(edt_data->pin));/* initial string */ + edt_data->editor_index = 0; + edt_data->emergency_call = FALSE; + winShow(edt_data->pin_edt_win); + return MFW_EVENT_CONSUMED; + } + return MFW_EVENT_CONSUMED; +} + + + + +/******************************************************************************* + + $Function: pin_edt_tim_out_cb + $Description: Callback function for timer (watchdog entering) + $Returns: void + $Arguments: window handler event, timer control block + +*******************************************************************************/ +static void pin_edt_tim_out_cb (T_MFW_EVENT event,T_MFW_TIM * t) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user; + + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("MmiPins:pin_edt_tim_out_cb"); + + + TRACE_FUNCTION("clear softkey 7"); + + // clear the softkeys + pin_skClear(); + clear_edit_array(edt_data); + // clear the input + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_ClearAll(edt_data->editor); +#else /* NEW_EDITOR */ + pin_rectClear( &edt_data->editpinAttr.win ); + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index = 0; + edt_data->gsm_state = FALSE; + pin_data->gsm_state = FALSE; + + winShow(edt_data->pin_edt_win); +} + + + +/******************************************************************************* + + $Function: pin_editor + $Description: Pin editor Dialog Signal Handling function + $Returns: void + $Arguments: window, window handler event, value, parameter + +*******************************************************************************/ +static void pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user; + + + T_pin * pin_data = (T_pin *)parameter;//pin main data + + edt_data->pin_case_edit = pin_data->pin_case; + + TRACE_FUNCTION("MmiPins:pin_editor"); + + /* + * depending on event + */ + switch (event) + { + case INPUT_PIN1: + case INPUT_PUK1: + case INPUT_NEW_PIN: + case INPUT_NEW_PIN_AGAIN: + case CARD_REJECTED: + case INSERT_CARD: + case SHOW_IMEI_INVALID: // Nov 24, 2005, a0876501, DR: OMAPS00045909 + case SIM_PLOCK: + case SIM_NLOCK: + case SIM_NSLOCK: + case SIM_SPLOCK: + case SIM_CLOCK: +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + case NO_MEPD_DATA: //x0pleela 30 Aug, 2006 DR: OMAPS00091250 +#endif + + //SPR#717 - GW - Wrong structures being cleared + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + memset(edt_data->puk, '\0', sizeof(edt_data->puk)); + memset(edt_data->new_pin, '\0', sizeof(edt_data->new_pin)); + memset(edt_data->old_pin, '\0', sizeof(edt_data->old_pin)); + + // the coordinate of the editor (enter the pin) + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + AUI_edit_SetAttr( &edt_data->editorPinAttr, PIN_EDIT_RESET, COLOUR_EDITOR_XX, EDITOR_FONT, 0, ED_CURSOR_UNDERLINE, ATB_DCS_ASCII, (UBYTE *)edt_data->edtbuf, MAX_DIG); + clear_edit_array(edt_data); /* clear editor buffer */ + ATB_edit_Init(edt_data->editor); +#else /* NEW_EDITOR */ + editor_attr_init( &edt_data->editpinAttr, PIN_EDIT_RESET, edtCurBar1,0,(char*)edt_data->edtbuf,MAX_DIG,COLOUR_EDITOR_XX); + clear_edit_array(edt_data); /* clear editor buffer */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index = 0; + winShow(edt_data->pin_edt_win); + break; + default: + break; + } +} + + +/******************************************************************************* + + $Function: pin_mess_create + $Description: Creation of an instance for the PIN Message dialog. + Type of dialog : SINGLE_DYNAMIC + $Returns: window + $Arguments: parent win + +*******************************************************************************/ +T_MFW_HND pin_mess_create (T_MFW_HND parent_window) +{ + T_pin_mess * data = (T_pin_mess *)ALLOC_MEMORY (sizeof (T_pin_mess)); + + T_MFW_WIN * win; + + data->pin_mess_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)pin_mess_win_cb); + + TRACE_FUNCTION("MmiPins:pin_mess_create"); + + if (data->pin_mess_win EQ 0) + return 0; + + /* + * Create window handler + */ + pin_mess_windows = data->pin_mess_win; + data->mmi_control.dialog = (T_DIALOG_FUNC)pin_messages; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_mess_win)->data; + win->user = (void *) data; + + /* + * return window handle + */ + return data->pin_mess_win; +} + + +/******************************************************************************* + + $Function: pin_mess_destroy + $Description: Destroy the pin message dialog. + $Returns: none + $Arguments: win + +*******************************************************************************/ +void pin_mess_destroy (T_MFW_HND own_window) +{ + T_pin_mess * data; + T_MFW_WIN * win; + + if (own_window) + { + TRACE_FUNCTION("MmiPins:pin_mess_destroy "); + + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_mess *)win->user; + + if(data) + { + + /* + * Delete WIN Handler + */ + + pin_mess_windows = 0; + win_delete (data->pin_mess_win); + FREE_MEMORY((void *)data,(sizeof(T_pin_mess))); + } + } +} + +/******************************************************************************* + + $Function: pin_mess_win_cb + $Description: Callback function for message windows + $Returns: Status int + $Arguments: event, window + +*******************************************************************************/ +static int pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + /* + * Top Window has no output + */ + return 1; +} + + + + +/******************************************************************************* + + $Function: pin_messages + $Description: Pin message Dialog Handling function + $Returns: none + $Arguments: window, event, value, parameter + +*******************************************************************************/ +void pin_messages(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_mess * mess_data = (T_pin_mess *)win_data->user; + + T_DISPLAY_DATA display_info; + +// T_MFW_SIM_PIN_STATUS status; //need to check the Pin 1 status /* Warning Correction */ + //EF_SIMLCK simlck;MC, not needed SPR 1351 +// ULONG timcount = TIM_LOCK; /* Warning Correction */ +// UBYTE i; /* Warning Correction */ + + T_pin * pin_data = (T_pin *)parameter; + T_sim_rem * sim_rem_data = (T_sim_rem *)parameter;// sim_rem_data possible too + + TRACE_FUNCTION("Mmi.Pins:pin_messages"); + TRACE_EVENT_P1("Event: %d", event); + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNull, TxtNull, COLOUR_STATUS_PINS); + + /* + * depending on signal + */ + switch (event) + { + case PIN1_REQ_ATT: + case PUK1_REQ_ACT_INFO: + case PUK1_REQ_VER_INFO: + case GSM_FAIL: + case NEW_PIN_FAIL: + case PIN_OK_INFO: + case PUK1_UNBL_FAIL_INFO: + case PUK1_UNBL_SUCC: + case PUK1_UNBL_FATAL_ERROR: + case SIM_UNLOCK_OK: +#ifdef SIM_PERS + case SIM_LOCK_PERS_CHK_OK: + case SMLK_SHOW_FC_FAIL: + case SMLK_SHOW_FC_SUCC: + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SMLK_SHOW_MK_FAIL: //Event to show a dialog saying "Master Unlock Failed" + case SMLK_SHOW_MK_SUCC: //Event to show a dialog saying "Master Unlock Success" + case SIM_LOCK_BUSY_UNBLOCK: //wrong unblock code +#endif + case PIN1_STATUS: + + + + switch(event) + { + case PIN1_REQ_ATT: + pin_data->pin_case = PIN1_REQ; + display_info.TextId = TxtPINFail; + display_info.TextId2 = 0; + if(pin_data->pin_retries EQ 1) + display_info.TextId2 = TxtOneAttemptLeft; + else + display_info.TextId2 = TxtTwoAttemptsLeft; + break; + + case PUK1_REQ_ACT_INFO: + pin_data->pin_case = PUK1_REQ; +#ifdef SIM_PERS + if( C_KEY_REQ ) + display_info.TextId = TxtPhoneBlocked; + else +#endif /*SIM_PERS */ + display_info.TextId = TxtSimBlocked; + + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + + case PUK1_REQ_VER_INFO: + pin_data->pin_case = PUK1_REQ; + display_info.TextId =TxtPINBlock; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + case GSM_FAIL: + display_info.TextId = TxtNotAcc; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + case PUK1_UNBL_FATAL_ERROR: + pin_data->pin_case = PUK1_REQ; + display_info.TextId = TxtNotAcc; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + case NEW_PIN_FAIL: + pin_data->pin_case = INPUT_NEW_PIN; + display_info.TextId = TxtNewPIN; + display_info.TextId2 = TxtCodeInc; + display_info.TextString2 = 0; + break; + case PIN_OK_INFO: + pin_data->pin_case = PIN_OK; + display_info.TextId = TxtPINOK; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + case PUK1_UNBL_FAIL_INFO: + pin_data->pin_case = PUK1_REQ; + display_info.TextId = TxtCodeInc; + display_info.TextId2 = TxtNull; + display_info.TextString2 = 0; + break; + case PUK1_UNBL_SUCC: + pin_data->pin_case = PIN_OK; + display_info.TextId = TxtNewPIN; + display_info.TextId2 = TxtChanged; + display_info.TextString2 = 0; + break; + case SIM_UNLOCK_OK: + pin_data->pin_case = PIN_OK; + display_info.TextId = TxtUnlockOK; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; +#ifdef SIM_PERS + case SIM_LOCK_PERS_CHK_OK: + pin_data->pin_case = PIN_OK; + display_info.TextId = TxtPhoneUnblocked; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + + case SMLK_SHOW_FC_FAIL: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); +// if( curr_fail_reset ) + pin_data->pin_case = SMLK_PUK; +// else +// pin_data->pin_case = PERM_BLK; + switch(mmi_simlock_aciErrDesc ) + { + case CME_ERR_NetworkPersPinReq: + case CME_ERR_NetworkSubsetPersPinReq: + case CME_ERR_ProviderPersPinReq: + case CME_ERR_CorporatePersPinReq: + case CME_ERR_PhSimPinReq: + sprintf((char*)buf1,"%d attempts left",curr_succ_reset); + sprintf((char*)buf2,"%s", "FC Reset-Success"); + break; + + default: + sprintf((char*)buf1,"%d attempts left",curr_fail_reset); + sprintf((char*)buf2,"%s", "FC Reset-Failure"); + break; + } + display_info.TextString= buf1; + display_info.TextString2 = buf2; + break; + } + + case SMLK_SHOW_FC_SUCC: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + //if( curr_succ_reset ) + // leela: for simp: pin_data->pin_case = PIN_OK; + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Changed the event from PIN_OK to SMLK_PUK bcoz after unblocking ME, + //for event PIN_OK it would go to idle screen without displaying menu for + //unlocking any categories if any + pin_data->pin_case = SMLK_PUK; + //else + //pin_data->pin_case = PERM_BLK; + sprintf((char*)buf1,"%d attempts left",curr_succ_reset); + sprintf((char*)buf2,"%s", "FC Reset-Success"); + display_info.TextString= buf1; + display_info.TextString2 = buf2; + break; + } + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Event to display a dialog saying Master Unblock Failed + case SMLK_SHOW_MK_FAIL: + { + char buf[25]; + pin_data->pin_case = SMLK_MASTERKEY; + sprintf((char*)buf,"%s", "Master Unlock Failed"); + display_info.TextString= buf; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + } + break; + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Event to display a dialog saying Master Unblock Success + case SMLK_SHOW_MK_SUCC: + { + char buf[25]; + pin_data->pin_case = PIN_OK; + sprintf((char*)buf,"%s", "Master Unlock Success"); + display_info.TextString= buf; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + } + break; + + //x0pleela 13 Nov, 2006 DR: OMAPS00103356 + //Event to display a dialog saying Master Unblock Password is wrong + case SMLK_SHOW_WRONG_PWD: + { + char buf[25]; + pin_data->pin_case = SMLK_MASTERKEY; + sprintf((char*)buf,"%s", "Incorrect Password"); + display_info.TextString= buf; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + } + + //x0pleela 13 Nov, 2006 DR: OMAPS00103356 + //Event to display a dialog saying Master unlocking operation is successful + case SMLK_SHOW_DEP_CATS_UNLOCKED: + { + char buf[25]; + pin_data->pin_case = SMLK_MASTERKEY; + sprintf((char*)buf,"%s", "Master Unlock Success"); + display_info.TextString= buf; + display_info.TextId2 = 0; + display_info.TextString2 = 0; + } + break; + + //x0pleela 26 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Event to display a dialog saying Busy for wrong entry of unblocking password + case SIM_LOCK_BUSY_UNBLOCK: //wrong unblock code + { + pin_data->pin_case = SMLK_PUK; + display_info.TextId = TxtBusy; + } + break; +#endif +//nm insert new one + case PIN1_STATUS: + pin_data->pin_case = PIN1_STATUS; + + if(pin_data->set_state EQ ENABLE) + { + display_info.TextId = TxtEnabled; + } + else + { + display_info.TextId = TxtDisabled; + } + + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; +//NM + + } + + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)pin_info_cb, THREE_SECS, 0 ); + display_info.Identifier = pin_data->pin_case; + info_dialog(pin_data->pin_win,&display_info); //information screen + pin_mess_destroy(mess_data->pin_mess_win); +#ifdef SIM_PERS + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Delete the simp_list window handler after displaying the dialog + if(pin_data->simp_list_win) + win_delete(pin_data->simp_list_win); +#endif + break; + case SIM_LOCK_ERR: + display_info.TextId = TxtCodeInc; + display_info.TextId2 = TxtPleaseWait; + display_info.Identifier = pin_data->pin_case;//last pin_case + + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)pin_info_cb, 5*TIM_LOCK_JUMP, 0 ); + pin_mess_destroy(mess_data->pin_mess_win); + info_dialog(pin_data->pin_win,&display_info); //information screen + break; + + case SIM_REMOVED: + pin_data->display_id1 = TxtNoCard; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(sim_rem_data->sim_rem_win,TXT_INSERT_CARD,0,pin_data); + break; + case INVALID_CARD: + pin_data->display_id1 = TxtInvalidCard; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_INVALID_CARD,0,pin_data); + break; +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS +//x0pleela 30 Aug, 2006 DR: OMAPS00091250 + case NO_MEPD: + pin_data->display_id1 = TxtNoMEPD; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_NO_MEPD,0,pin_data); + break; +#endif + case NO_SIM_CARD: + pin_data->display_id1 = TxtNoCard; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_NO_CARD,0,pin_data); + break; +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + case INVALID_IMEI: + pin_data->display_id1 = TxtInvalidIMEI; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_INVALID_IMEI,0,pin_data); + break; + case SIM_LOCK_ALL: + pin_data->display_id1 = TxtBlckPerm; + pin_data->display_id2 = TxtDealer; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_LOCK_ALL,0,pin_data); + break; + case SIM_PLOCK_REQ: + pin_data->display_id1 = TxtEnterPCK; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_PLOCK,0,pin_data); + break; + case SIM_NLOCK_REQ: + pin_data->display_id1 = TxtEnterNCK; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_NLOCK,0,pin_data); + break; + case SIM_CLOCK_REQ: + pin_data->display_id1 = TxtEnterCCK; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_CLOCK,0,pin_data); + break; + case SIM_NSLOCK_REQ: + pin_data->display_id1 = TxtEnterNSCK; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_NSLOCK,0,pin_data); + break; + case SIM_SPLOCK_REQ: + pin_data->display_id1 = TxtEnterSPCK; + pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_SIM_SPLOCK,0,pin_data); + break; + default: + break; + } +} + + +#ifndef NEW_EDITOR +/******************************************************************************* + + $Function: pin_icons + $Description: display back from pins + $Returns: none + $Arguments: none + +*******************************************************************************/ +static void pin_icons(void) +{ + + TRACE_FUNCTION("pin_icons"); + + + // clear the softkeys + TRACE_FUNCTION("clear softkey 8"); + pin_skClear(); + + TRACE_FUNCTION("dsplClearAll 6"); + dspl_ClearAll(); + + GlobalIconStatus = GlobalSignalIconFlag | GlobalBatteryIconFlag | + GlobalVoiceMailIconFlag + | GlobalCallForwardingIconFlag| GlobalKeyplockIconFlag + | GlobalRingerIconFlag | GlobalRingVibrIconFlag + | GlobalVibratorIconFlag | GlobalAlarmIconFlag + | GlobalSilentRingerIconFlag + #ifdef FF_MMI_CPHS + | GlobalRoamingIndFlag + #endif + +/* x0045876, 14-Aug-2006 (WR - nested comment is not allowed) */ +/* SH 18/01/02. Flag for GPRS icon. */ + +/* SH 18/01/02. Flag for GPRS icon. + Note: SPR877 - Homezone icon not displayed in PIN screen. */ + #ifdef MMI_GPRS_ENABLED + | GlobalGPRSOnIconFlag + #endif + ; + iconsShow(); /* representation of the desired icons */ +} + +#endif + +/******************************************************************************* + + $Function: clearEditArray + $Description: clear EditArray + $Returns: none + $Arguments: pin editor attributes +*******************************************************************************/ +static void clear_edit_array (void * parameter) +{ +// U8 i; /* Warning Correction */ + T_pin_edt * edt_data = (T_pin_edt *)parameter; + + TRACE_FUNCTION("MmiPins:clearEditArray"); + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + memset(edt_data->edtbuf,'\0',sizeof(edt_data->edtbuf)); + ATB_edit_Reset(edt_data->editor); + ATB_edit_Unhide(edt_data->editor); +#else /* NEW_EDITOR */ + memset(edt_data->edtbuf,'\0',sizeof(edt_data->edtbuf)); + edtReset(edt_data->editor_handle); + edtUnhide(edt_data->editor_handle); +#endif + +} + + +/******************************************************************************* + + $Function: pinsIsFocussed + $Description: check MmiPins windows focussed + $Returns: Status int + $Arguments: none +*******************************************************************************/ + +int pinsIsFocussed(void) +{ + int status; + + if (winIsFocussed(pin_windows) || winIsFocussed(pin_edit_windows) || + winIsFocussed(pin_editor_window) ||winIsFocussed(pin_mess_windows)) + status = FOCUSSED_PINS; + else + status = NOT_FOCUSSED_PINS; + + return status; +} + + +/******************************************************************************* + + $Function: pinsSetIsFocussed + $Description: check MmiPins in settings windows focussed + $Returns: Status int + $Arguments: none +*******************************************************************************/ +int pinsSetIsFocussed(void) +{ + int status; + + if (winIsFocussed(set_pin_windows)) + status = FOCUSSED_PINS; + else + status = NOT_FOCUSSED_PINS; + + return status; +} + + +/******************************************************************************* + + $Function: emerg_pin + $Description: emergency call + $Returns: none + $Arguments: pin editor attributes +*******************************************************************************/ +static void emerg_pin(void * string) +{ + T_pin_edt * edt_data = (T_pin_edt *)string; + + edt_data->emergency_call = FALSE; + clear_edit_array(edt_data); /* clear editor array */ + callNumber((UBYTE*)edt_data->pin); /* emergency call */ + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/*initial string*/ + edt_data->editor_index = 0; +TRACE_FUNCTION("clear softkey 9"); + pin_skClear(); +} + + + +/******************************************************************************* + + $Function: pin_info_cb + $Description: pin information screen call back + $Returns: none + $Arguments: win, identifier, reason for callback (not used) +*******************************************************************************/ +int pin_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reasons) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + TRACE_EVENT_P1 ("pin_info_cb() %d", identifier); + + switch(identifier) + { + case PIN_OK: + { +#ifdef SIM_PERS + int curr_fail_reset1, curr_succ_reset1; +#endif + TRACE_FUNCTION("pin_info_cb: PIN_OK"); + +#ifdef SIM_PERS + mfw_simlock_check_status(0, &curr_fail_reset1, &curr_succ_reset1); + + if (curr_succ_reset1 == 0) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + else +#endif + SEND_EVENT(pin_data->pin_win,PIN_OK_END,0,NULL);//PIN was needed + } + break; + + case PIN1_REQ: + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //case PUK1_REQ: //Handling PUK1_REQ separately as a menu should be displayed for Unblocking ME and Master Unlock + case INPUT_NEW_PIN: + + SEND_EVENT(pin_data->pin_win,identifier,0,NULL);//pin_main data !! + break; + + + case PUK1_REQ: +#ifdef SIM_PERS + //x0pleela 26 Sep, 2006 DR: OMAPS00096565 + //Adding a check for C_KEY_REQ. If set, displaySIMP menu + //Else prompt the user for PUK entry + if( C_KEY_REQ ) + { + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Handling PUK1_REQ separately as a menu should be displayed for Unblocking ME and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + } + else +#endif + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,NULL);//pin_main data !! + break; +#ifdef SIM_PERS + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Handling SMLK_MASTERKEYto display menu for Unblocking ME or unlocking categories if any and Master Unlock + case SMLK_MASTERKEY: + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for CME class and handle all CME errors + if( ((mmi_simlock_aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Cme) + { + switch(mmi_simlock_aciErrDesc & 0x0000FFFF) + { + case CME_ERR_NetworkPersPinReq: + TRACE_EVENT("CME_ERR_NetworkPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_NetworkSubsetPersPinReq: + TRACE_EVENT("CME_ERR_NetworkSubsetPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NSLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NSLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_ProviderPersPinReq: + TRACE_EVENT("CME_ERR_ProviderPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_SPLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SPLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_CorporatePersPinReq: + TRACE_EVENT("CME_ERR_CorporatePersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_CLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_CLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhSimPinReq: + TRACE_EVENT("CME_ERR_PhSimPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SIM_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhoneFail: + case CME_ERR_NetworkPersPukReq: + case CME_ERR_NetworkSubsetPersPukReq: + case CME_ERR_ProviderPersPukReq: + case CME_ERR_CorporatePersPukReq: + case CME_ERR_WrongPasswd: + + TRACE_FUNCTION("PUK Req"); + C_KEY_REQ = 1; + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + { + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + break; + + default: + TRACE_EVENT("Undefined error"); + break; + } + } + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for Ext class and handle all Extension errors + else if( ((mmi_simlock_aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) + { + switch(mmi_simlock_aciErrDesc & 0x0000FFFF) + { + //Request for Blocked Network Password + case EXT_ERR_BlockedNetworkPersPinReq: + TRACE_EVENT("EXT_ERR_BlockedNetworkPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PBLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_PBLOCK_PIN_REQ,0,pin_data); + break; + + //Request for Blocked Network Unblock code + case EXT_ERR_BlockedNetworkPersPukReq: + TRACE_EVENT("PUK Req"); + C_KEY_REQ = 1; + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + { + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + break; + + default: + break; + } + } + break; + + case SMLK_PUK: + { + int status1,curr_fail_reset1, curr_succ_reset1; + + status1 = mfw_simlock_check_status(0, &curr_fail_reset1, &curr_succ_reset1); + + if (status1 == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + else + { + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //checking for Class type and the ext busy error + if( ( ((mmi_simlock_aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (mmi_simlock_aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + { + C_KEY_REQ = 1; + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + { + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + } + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for Cme class and handle all CME errors + else if( ((mmi_simlock_aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Cme) + { + //end of x0pleela 11 Sep, 2006 DR: OMASP00094215 + switch(mmi_simlock_aciErrDesc & 0x0000FFFF) + { + case CME_ERR_NetworkPersPinReq: + TRACE_EVENT("CME_ERR_NetworkPersPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_NetworkSubsetPersPinReq: + TRACE_EVENT("CME_ERR_NetworkSubsetPersPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NSLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NSLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_ProviderPersPinReq: + TRACE_EVENT("CME_ERR_ProviderPersPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_SPLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SPLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_CorporatePersPinReq: + TRACE_EVENT("CME_ERR_CorporatePersPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_CLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_CLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhSimPinReq: + TRACE_EVENT("CME_ERR_PhSimPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SIM_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhoneFail: + case CME_ERR_NetworkPersPukReq: + case CME_ERR_NetworkSubsetPersPukReq: + case CME_ERR_ProviderPersPukReq: + case CME_ERR_CorporatePersPukReq: + case CME_ERR_WrongPasswd: + + TRACE_FUNCTION("PUK Req"); + C_KEY_REQ = 1; + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + break; + + default: + TRACE_EVENT("Undefined error"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //If no CME error, which implies none of the categories are locked + //so send PIN_OK_END event for camping on to the network + SEND_EVENT(pin_data->pin_win,PIN_OK_END,0,NULL);//PIN was needed + break; + } + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + } + //end of x0pleela 11 Sep, 2006 DR: OMASP00094215 + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for Ext class and handle all Extension errors + else if( ((mmi_simlock_aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) + { + switch(mmi_simlock_aciErrDesc & 0x0000FFFF) + { + //Request for Blocked Network Password + case EXT_ERR_BlockedNetworkPersPinReq: + TRACE_EVENT("EXT_ERR_BlockedNetworkPersPinReq"); + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PBLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_PBLOCK_PIN_REQ,0,pin_data); + break; + + //Request for Blocked Network Unblock code + case EXT_ERR_BlockedNetworkPersPukReq: + TRACE_EVENT("PUK Req"); + C_KEY_REQ = 1; + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays menu for Unblocking ME or unlocking categories if any and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + { + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + break; + + default: + break; + } + } + } + } + break; +#endif + + case INPUT_PIN1: + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,NULL);//pin_main data !! + break; + case INPUT_PUK1: + TRACE_FUNCTION("INPUT_PUK1"); + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,NULL);//pin_main data !! + break; + /*mc SPR 1351, check if simlocks blocked before requesting them again*/ + case SIM_PLOCK: + if (sim_check_sim_Plock() != MFW_SIM_BLOCKED) + SEND_EVENT(pin_data->pin_win,SIM_PLOCK_REQ,0,NULL);//pin_main data !! + else + { ShowMessage(idle_get_window(), TxtBlckPerm, TxtDealer); + pin_destroy(pin_data->pin_win); + } + break; + case SIM_NLOCK: + if (sim_check_sim_Nlock() != MFW_SIM_BLOCKED) + SEND_EVENT(pin_data->pin_win,SIM_NLOCK_REQ,0,NULL);//pin_main data !! + else + { ShowMessage(idle_get_window(), TxtBlckPerm, TxtDealer); + pin_destroy(pin_data->pin_win); + } + break; + case SIM_SPLOCK: + if (sim_check_sim_SPlock() != MFW_SIM_BLOCKED) + SEND_EVENT(pin_data->pin_win,SIM_SPLOCK_REQ,0,NULL);//pin_main data !! + else + { ShowMessage(idle_get_window(), TxtBlckPerm, TxtDealer); + pin_destroy(pin_data->pin_win); + } + break; + case SIM_NSLOCK: + if (sim_check_sim_NSlock() != MFW_SIM_BLOCKED) + SEND_EVENT(pin_data->pin_win,SIM_NSLOCK_REQ,0,NULL);//pin_main data !! + else + { ShowMessage(idle_get_window(), TxtBlckPerm, TxtDealer); + pin_destroy(pin_data->pin_win); + } + break; + case SIM_CLOCK: + if (sim_check_sim_Clock() != MFW_SIM_BLOCKED) + SEND_EVENT(pin_data->pin_win,SIM_CLOCK_REQ,0,NULL);//pin_main data !! + else + { ShowMessage(idle_get_window(), TxtBlckPerm, TxtDealer); + pin_destroy(pin_data->pin_win); + } + break; + /*MC end*/ + case PIN1_STATUS: + SEND_EVENT(pin_data->pin_win,PIN1_STATUS_END,0,NULL);//pin_main data !! + break; + default: + break; + } + return 1; +} + +/******************************************************************************* + + $Function: sim_rem_init + $Description: This is the start-up time initialisation routine. + For compatibility reasons the functions is still there. + $Returns: none + $Arguments: parent window +*******************************************************************************/ +void sim_rem_init (T_MFW_HND parent_window) +{ + sim_rem_create (parent_window); +} + + + + +/******************************************************************************* + + $Function: sim_rem_exit + $Description: his is the shutdown time clean-up routine. + $Returns: none + $Arguments: parent window +*******************************************************************************/ +void sim_rem_exit(T_MFW_HND parentWindow) +{ + sim_rem_destroy (sim_rem_data.sim_rem_win); +} + + + +/******************************************************************************* + + $Function: sim_rem_create + $Description: Creation of an instance for the SIM remove dialog. + Type of dialog : SINGLE_STATIC + Top Window must be available at any time, only one instance. + $Returns: window + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND sim_rem_create (T_MFW_HND parent_window) +{ + + T_sim_rem * data = &sim_rem_data; + T_MFW_WIN * win; + + data->sim_rem_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)sim_rem_win_cb); + + if (data->sim_rem_win EQ 0) + return 0; + else + { + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)sim_rem_main; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->sim_rem_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->sim_handle = sim_create(0,E_SIM_ALL_SERVICES,(MfwCb)sim_rem_cb_main); + winShow(data->sim_rem_win); + /* + * return window handle + */ + return data->sim_rem_win; + } +} + + + +/******************************************************************************* + + $Function: sim_rem_destroy + $Description: Destroy the sim remove dialog. + $Returns: none + $Arguments: window +*******************************************************************************/ +void sim_rem_destroy (T_MFW_HND own_window) +{ + T_sim_rem * data; + T_MFW_WIN * win; + + if (own_window) + { + win = ((T_MFW_HDR *)own_window)->data; + data = (T_sim_rem *)win->user; + + if(data) + { + /* + * Exit SIM and Delete SIM Handler + */ + sim_delete (data->sim_handle); + + /* + * Delete WIN Handler + */ + win_delete (data->sim_rem_win); + } + } +} + + +/******************************************************************************* + + $Function: sim_rem_win_cb + $Description: Callback function for windows + $Returns: Status int + $Arguments: event, window +*******************************************************************************/ +static int sim_rem_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + if (event EQ MfwWinVisible) + { + /* + * Top Window has no output + */ + TRACE_FUNCTION("dsplClearAll 7"); + dspl_ClearAll(); + return 1; + } + return 0; +} + + + +/******************************************************************************* + + $Function: sim_rem_cb_main + $Description: SIM remove handler + $Returns: Status int + $Arguments: event, sim status +*******************************************************************************/ +int sim_rem_cb_main (T_MFW_EVENT event, T_MFW_HND para) +{ + + T_MFW_SIM_STATUS * status; + + T_MFW_HND sim_rem_win; + + status = (T_MFW_SIM_STATUS *)para; + TRACE_FUNCTION("MmiPins:sim_rem_cb_main"); + + switch(event) + { + case E_SIM_STATUS: + /* + * check whether decoded message is available + */ + if( para EQ (T_MFW_SIM_STATUS *)NULL ) + return MFW_RES_ILL_HND; + + status = (T_MFW_SIM_STATUS *)para; + switch (status->sim_procedure) + { + case MFW_SIM_REMOVED: + switch (status->sim_status) + { + /* + * SIM card is removed + */ + case MFW_SIM_NO_SIM_CARD: + TRACE_FUNCTION("sim_rem_cb_main:SIM removed"); + sim_rem_win = sim_rem_create(0); + if(sim_rem_win) + { + SEND_EVENT(sim_rem_win,SIM_REMOVED,0,NULL); + } + /* + * limited shall be the requested service + * if no service is reached, the limited + * service is requested*/ + nm_registration (NM_AUTOMATIC, 0, TRUE); + break; + default: + return 0; + } + break; + default: + return 0; + } + return 1; + } + + /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function ) */ + return 0; +} + + + +/******************************************************************************* + + $Function: sim_rem_main + $Description: SIM remove main Dialog Handling function + $Returns: None + $Arguments: window, event, value, parameter +*******************************************************************************/ +static void sim_rem_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_sim_rem * sim_rem_data = (T_sim_rem *)win_data->user;//sim remove main data +// T_pin_mess * mess_data = (T_pin_mess *) parameter;//pin message data /* Warning Correction */ + + T_MFW_HND pin_mess_win; + T_MFW_HND pin_edt_win; + + TRACE_FUNCTION("MmiPins:sim_rem_main"); + + switch(event) + { + case SIM_REMOVED: //Text "Insert Card " + pin_mess_win = pin_mess_create(sim_rem_data->sim_rem_win); + if(pin_mess_win) + { + SEND_EVENT(pin_mess_win,event,0,sim_rem_data); + } + break; + case TXT_INSERT_CARD: + sim_rem_data->pin_case = INSERT_CARD; + pin_edt_win = pin_edt_create(sim_rem_data->sim_rem_win);// Start: enter only emerg call + if(pin_edt_win) + { + SEND_EVENT(pin_edt_win,INSERT_CARD,0,sim_rem_data); + } + break; + default: + break; + } + +} + + + + +/******************************************************************************* + + $Function: setting_pin_init + $Description: This is the start-up time initialisation routine. + Start in the Menu + $Returns: None + $Arguments: parent window +*******************************************************************************/ +void setting_pin_init (T_MFW_HND parent_window) +{ + setting_pin_create (parent_window); +} + + + +/******************************************************************************* + + $Function: setting_pin_create + $Description: Creation of an instance for the Settings PIN main dialog. + Type of dialog : SINGLE_DYNAMIC + Top Window must be available at any time, only one instance. + $Returns: window + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND setting_pin_create (T_MFW_HND parent_window) +{ + + T_pin * data = (T_pin *)ALLOC_MEMORY (sizeof (T_pin)); + T_MFW_WIN * win; + + data->pin_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)setting_pin_win_cb); + + TRACE_FUNCTION("MmiPins:setting_pin_create"); + + set_pin_windows = data->pin_win; + + if (data->pin_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)setting_pin_main; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->sim_handle = sim_create(data->pin_win,E_SIM_ALL_SERVICES,(MfwCb)sim_event_cb_setting); + + /* + * Initialise + */ + data->set_state = DEFAULT; + data->puk_request = FALSE; + + + mfwSetSignallingMethod(1);//mfw focus handling + winShow(data->pin_win);//focus on settings:PIN/PIN2 Change/act/Deac + + + /* + * return window handle + */ + return data->pin_win; +} + + +/******************************************************************************* + + $Function: setting_pin_destroy + $Description: Destroy the settings pin main dialog. + $Returns: none + $Arguments: window +*******************************************************************************/ +void setting_pin_destroy (T_MFW_HND own_window) +{ + T_pin * data; + T_MFW_WIN * win; + + if (own_window) + { + TRACE_FUNCTION("MmiPins:setting_pin_destroy"); + + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin *)win->user; + + if(data) + { + /* + * Exit SIM and Delete SIM Handler + */ + sim_delete (data->sim_handle); + + /* + * Delete WIN Handler + */ + set_pin_windows = 0; + win_delete (data->pin_win); + data->pin_win=0; + if(data) + FREE_MEMORY((void *)data,(sizeof(T_pin))); + } + } +} + + +/******************************************************************************* + + $Function: setting_pin_win_cb + $Description: Callback function for main windows in settings + $Returns: Status int + $Arguments: event, window +*******************************************************************************/ +static int setting_pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + TRACE_FUNCTION("setting_pin_win_cb"); + if (event EQ MfwWinVisible) + { + /* + * Top Window has no output + */ + /* NDH : Removed to prevent Blue Screen on Pin Entry */ + return 1; + } + return 0; + +} + + +/******************************************************************************* + + $Function: sim_event_cb_setting + $Description: SIM event handler for Setttings Pins + $Returns: Status int + $Arguments: event, sim status +*******************************************************************************/ +int sim_event_cb_setting (T_MFW_EVENT event, T_MFW_HND para) +{ + + T_MFW_SIM_STATUS * status; + + T_MFW_HND win = mfw_parent(mfw_header()); + + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + status = (T_MFW_SIM_STATUS *)para; + + TRACE_FUNCTION("Sim Event Handler of Settings Pin"); + switch(event) + { + case E_SIM_INSERTED://handle in sim_rem_cb_main + return 0; + case E_SIM_STATUS: + /* + * check whether decoded message is available + */ + if( para EQ (T_MFW_SIM_STATUS *)NULL ) + return MFW_RES_ILL_HND; + + status = (T_MFW_SIM_STATUS *)para; + switch (status->sim_procedure) + { + /* + * Initial activation of the SIM card + */ + case MFW_SIM_VERIFY: + //xrashmic 1 Jul, 2006 OMAPS00075784 + //When pin is blocked, the user is immediatly prompted with puk + // entry screen or else the blue screen is displayed + case MFW_SIM_ACTIVATION: + /* + * check the result of verify + */ + switch (status->sim_status) + { + /* + * PIN 1 must be entered + */ + case MFW_SIM_PIN_REQ: + if(status->sim_pin_retries < PIN_ENTRY_MAX) + { + TRACE_FUNCTION("sim_event_cb_settings V:PIN1 req-retr"); + pin_data->pin_retries = status->sim_pin_retries; + SEND_EVENT(pin_data->pin_win,PIN1_REQ_ATT,0,pin_data); + } + else + { + TRACE_FUNCTION("sim_event_cb_setting V:PIN1 req"); + SEND_EVENT(pin_data->pin_win,PIN1_REQ_OLD,0,pin_data); + } + break; + /* + * PIN 2 must be entered + */ + case MFW_SIM_PIN2_REQ: + if(status->sim_pin_retries < PIN_ENTRY_MAX) + { + TRACE_FUNCTION("sim_event_cb_settings V:PIN2 req-retr"); + pin_data->pin_retries = status->sim_pin_retries; + SEND_EVENT(pin_data->pin_win,PIN2_REQ_ATT,0,pin_data); + } + else + { + TRACE_FUNCTION("sim_event_cb_setting V:PIN2 req"); + SEND_EVENT(pin_data->pin_win,PIN2_REQ,0,pin_data); + } + break; + /* + * SIM card is blocked, PUK 1 is needed + */ + case MFW_SIM_PUK_REQ: + pin_data->puk_request = TRUE; + TRACE_FUNCTION("sim_event_cb_setting V:PUK1 req"); + SEND_EVENT(pin_data->pin_win,PUK1_REQ_VER_INFO,0,pin_data); + break; + /* + * SIM card is blocked, PUK 2 is needed + */ + case MFW_SIM_PUK2_REQ: + pin_data->puk_request = TRUE; + TRACE_FUNCTION("sim_event_cb_setting V:PUK2 req"); + SEND_EVENT(pin_data->pin_win,PUK1_REQ_VER_INFO,0,pin_data); + break; + + /* + * PIN entering successfull + */ + case MFW_SIM_NO_PIN: + TRACE_FUNCTION("sim_event_cb_setting V:PIN ok "); + pin_data->pin_case = PIN_OK_INFO; + SEND_EVENT(pin_data->pin_win,PIN_OK_INFO,0,pin_data); + break; + + /* Marcus: Issue 1609: 23/01/2003: Start */ + case MFW_SIM_FAILURE: + /* An attempt to verify a PIN has failed */ + if (status->sim_status_type == MFW_SIM_PIN2) + { + /* PIN2 verification not supported by this SIM */ + SEND_EVENT(pin_data->pin_win,PIN2_SIM_FAILURE,0,pin_data); + } + else /* Not verifying PIN2, presumably verifying PIN1 */ + return 0; + break; + /* Marcus: Issue 1609: 23/01/2003: End */ + + default: + return 0; + } + break; + /* + * response to PUK entering + */ + case MFW_SIM_UNBLOCK: + switch (status->sim_status) + { + case MFW_SIM_PUK_REQ: + TRACE_FUNCTION("sim_event_cb_setting:unblock failure"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_FAIL_INFO,0,pin_data); + break; + case MFW_SIM_PUK2_REQ: + TRACE_FUNCTION("sim_event_cb_setting:unblock failure"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_FAIL_INFO,0,pin_data); + break; + case MFW_SIM_SUCCESS: + TRACE_FUNCTION("sim_event_cb_setting:unblock success"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_SUCC,0,pin_data); + break; + case MFW_SIM_FAILURE: + TRACE_FUNCTION("sim_event_cb_setting:unblock fatal error"); + SEND_EVENT(pin_data->pin_win,PUK1_UNBL_FATAL_ERROR,0,pin_data); + break; + case MFW_SIM_INVALID_CARD: + TRACE_FUNCTION("sim_event_cb_main:unblock failed, no more retries"); + SEND_EVENT(pin_data->pin_win,INVALID_CARD,0,pin_data); + break; + default: + return 0; + } + break; + + case MFW_SIM_REMOVED: + return 0;/* there not handled */ + case MFW_SIM_CHANGE: + switch (status->sim_status) + { + case MFW_SIM_SUCCESS: + TRACE_FUNCTION("sim_event_cb_setting: succ/CH"); + if(pin_data->set_state EQ IDLE_GSM) + { + SEND_EVENT(pin_data->pin_win,PIN1_CH_SUCC,0,pin_data);/* change PIN by gsm string in idle */ + } + else if(pin_data->pin_case EQ INPUT_NEW_PIN_AGAIN OR (status->sim_status_type EQ MFW_SIM_PIN1)) + { + SEND_EVENT(pin_data->pin_win,PIN1_CH_SUCC,0,pin_data);/* change PIN, also by gsm string */ + } + else + { + SEND_EVENT(pin_data->pin_win,PIN2_CH_SUCC,0,pin_data);/* change PIN2, also by gsm string */ + } + break; + case MFW_SIM_FAILURE: + TRACE_FUNCTION("sim_event_cb_setting: fail/CH"); + if(!pin_data->puk_request) + { + if(pin_data->pin_case EQ INPUT_NEW_PIN_AGAIN) + { + SEND_EVENT(pin_data->pin_win,NEW_PIN_FAIL,0,pin_data);/* new Pin failed */ + } + else if(pin_data->pin_case EQ INPUT_NEW_PIN2_AGAIN) + { + SEND_EVENT(pin_data->pin_win,NEW_PIN2_FAIL,0,pin_data);/* new Pin2 failed */ + } + else if(pin_data->gsm_state) + { + if(sim_pin_count(MFW_SIM_PIN1) <= 0 )// May 13, 2004 REF: CRR 13632 xvilliva + { + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK1_REQ_VER_INFO,0,pin_data); + } + else + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,pin_data); + } + } + else + { + if(pin_data->pin_case EQ INPUT_NEW_PIN_AGAIN) + { + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else + { + SEND_EVENT(pin_data->pin_win,PUK2_REQ,0,pin_data); + } + + } + break; + default: + return 0; + } + break; + case MFW_SIM_DISABLE: + case MFW_SIM_ENABLE: + switch (status->sim_status) + { + case MFW_SIM_SUCCESS: + TRACE_FUNCTION("sim_event_cb_setting: succ/DIS/E"); + + if (status->sim_procedure EQ MFW_SIM_ENABLE) + { + SEND_EVENT(pin_data->pin_win,PIN1_ENAB_END,0,pin_data); + } + else + { + SEND_EVENT(pin_data->pin_win,PIN1_DISAB_END,0,pin_data); + } + break; + case MFW_SIM_FAILURE: + TRACE_FUNCTION("sim_event_cb_setting: fail/DIS/E"); + pin_data->pin_retries = sim_pin_count(MFW_SIM_PIN1); + SEND_EVENT(pin_data->pin_win,PIN1_ENDIS_FAIL,0,pin_data); + break; + default: + return 0; + } + break; + default: + return 0; + } + return 1; + } + /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function) */ + return 0; +} + + + +/******************************************************************************* + + $Function: set_pin_ch_item_flag + $Description: decision about show entry "PIN change" + $Returns: Status int; 0 if PIN enabled, 1 if disabled + $Arguments: menu tag, menu attribute tag, menu item tag +*******************************************************************************/ +U16 set_pin_ch_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + T_MFW_SIM_PIN_STATUS status; + + TRACE_FUNCTION("MmiPins:set_pin_item_flag_state:pinChange"); + + status.type = MFW_SIM_PIN1; + sim_pin_status(&status); + if(status.set EQ MFW_SIM_DISABLE) /*if PIN disabled no change PIN */ + return MNU_ITEM_HIDE; + else + return 0; /* PIN enabled, change PIN possible */ +} + + +/******************************************************************************* + + $Function: set_pin_en_item_flag + $Description: decision about show entry "PIN enable" + $Returns: Status int; 0 if show, 1 if don't show + $Arguments: menu tag, menu attribute tag, menu item tag +*******************************************************************************/ +U16 set_pin_en_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + T_MFW_SIM_PIN_STATUS status; + + TRACE_FUNCTION("MmiPins:set_pin_en_item_flag:pinEnable"); + + status.type = MFW_SIM_PIN1; + sim_pin_status(&status); + if(status.set EQ MFW_SIM_ENABLE) /*if PIN enabled no show menu entry */ + return MNU_ITEM_HIDE; + else + return 0; /* PIN disabled show menu entry */ +} + + +/******************************************************************************* + + $Function: set_pin_dis_item_flag + $Description: decision about show entry "PIN enable" + $Returns: Status int; 0 if show, 1 if don't show + $Arguments: menu tag, menu attribute tag, menu item tag +*******************************************************************************/ +U16 set_pin_dis_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + T_MFW_SIM_PIN_STATUS status; + + TRACE_FUNCTION("MmiPins:set_pin_en_item_flag:pinDisable"); + + status.type = MFW_SIM_PIN1; + sim_pin_status(&status); + if(status.set EQ MFW_SIM_DISABLE) /*if PIN disabled no show menu entry */ + return MNU_ITEM_HIDE; + else + return 0; /* PIN enabled show menu entry */ +} + + +/******************************************************************************* + + $Function: set_pin2_ch_item_flag + $Description: decision about show entry "PIN2 change" + $Returns: Status int; 0 if show, 1 if don't show + $Arguments: menu tag, menu attribute tag, menu item tag +*******************************************************************************/ +//change back to old version +U16 set_pin2_ch_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + T_MFW_SIM_PIN_STATUS status; + + TRACE_FUNCTION("MmiPins:set_pin2_ch_item_flag:pin2Change"); + + status.type = MFW_SIM_PIN2; + sim_pin_status(&status); + /*if(status.set EQ MFW_SIM_DISABLE)*/ /*if PIN disabled no change PIN */ + if(status.set EQ MFW_SIM_UNKNOWN) + return MNU_ITEM_HIDE; + else + return 0; /* PIN enabled, change PIN possible */ +} + +#ifdef SIM_PERS +/******************************************************************************* + $Function: mmi_simlock_change_pin + $Description: Performs the change password for a given lock type + $Returns: success or failure + $Arguments: lock type, oldpassword, new password +*******************************************************************************/ + +void mmi_simlock_change_pin(T_MFW_HND win,int type,char* oldpsw,char* newpsw) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + TRACE_EVENT_P2(" old paswwrd%s new password%s ",oldpsw,newpsw); + if(mfw_simlock_change_lock_code(type,oldpsw,newpsw) !=MFW_SS_OK) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_NEW_ENDISFAIL,0,pin_data); + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_NEW_ENDSUCC,0,pin_data); +} +#endif + +/******************************************************************************* + + $Function: setting_pin_main + $Description: PIN Settings Dialog Handling function + $Returns: none + $Arguments: win, event, value, parameters +*******************************************************************************/ +void setting_pin_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user;//pin main data +// T_pin_mess * mess_data = (T_pin_mess *) parameter;//pin message data /* Warning Correction */ +// T_pin_edt * edt_data = (T_pin_edt *) parameter;//pin editor data /* Warning Correction */ + T_MFW_WIN * par_window; + + + switch(event) + { + case PIN1_REQ_OLD: // Text "Enter Old Pin " + case PIN2_REQ_OLD: // Text "Enter Old Pin2 " + case PIN1_REQ_ATT: // info screen "xx attempts " + case PIN2_REQ_ATT: // info screen "xx attempts " + case PUK1_REQ: // Text "Enter Puk " + case PIN1_REQ: // Text "Enter Pin " + case PUK2_REQ: // Text "Enter Puk2 " + case PIN2_REQ: // Text "Enter Pin2 " + case PIN1_STATUS: // Text "Pin enabled"or disabled + case INPUT_NEW_PIN: // Text "Enter New PIN " + case INPUT_NEW_PIN2: // Text "Enter New PIN2 " + case INPUT_NEW_PIN_AGAIN: // Text "Enter New PIN again " + case INPUT_NEW_PIN2_AGAIN: // Text "Enter New PIN2 again " + case GSM_FAIL: // gsm not allowed + case NEW_PIN_FAIL: // new pin2 failed + case NEW_PIN2_FAIL: // new pin failed + case PUK1_REQ_VER_INFO: // Text "Pin blocked " + case PUK1_UNBL_FAIL_INFO: // unblock error - new puk requ + case PUK1_UNBL_FATAL_ERROR: + case PIN1_CH_SUCC: + case PIN2_CH_SUCC: + case PIN1_ENAB_END: + case PIN1_DISAB_END: + case PIN2_SIM_FAILURE: // Marcus: Issue 1609: 23/01/2003 - failure to verify PIN2 + + case FDN_ACTIVATED: + case ADN_ACTIVATED: + case FDN_FAIL: + case FDN_ACT_END: + case FDN_DEACT_END: +#ifdef SIM_PERS +//The different cases of enabling/disabling/quering and changing password +//scenarios are handled +case SIM_LOCK_NEW_ENDSUCC_CKEY: + case INPUT_NEW_SIM_PLOCK_AGAIN: + case SIM_LOCK_REQ_NEW: + case TXT_SIM_LOCK_ALL: + case SIM_LOCK_ENDSUCC: + case SIM_LOCK_ALREADY_ENDIS: + case SIM_LOCK_REQ_FCPWD: + case SIM_LOCK_FCPWD_FAIL: + case SIM_LOCK_FCPWDSUCC: + case SIM_LOCK_REQ_OLD: + case SIM_LOCK_STATUS: + case NEW_SIM_PLOCK_FAIL: + case SIM_LOCK_NEW_ENDSUCC: + case SIM_LOCK_NEW_ENDISFAIL: + case SIM_LOCK_SIM_REM: + case PERM_BLK: + case SMLK_SHOW_FC_FAIL1: +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SIM_LOCK_REQ_MKPWD: //Master unlock ket request + case SIM_LOCK_MKPWD_FAIL: //Master unlocking failed + case SIM_LOCK_MKPWDSUCC: //Master unlocking success +#endif + sett_pin_mess(win,event); + break; + case PUK1_UNBL_SUCC: + sett_pin_mess(win,event); + break; + + } + + switch(event) + { + case TXT_ENTER_PIN1: + pin_data->pin_case = INPUT_PIN1;//enter PIN1 start + sett_pin_edit(win,INPUT_PIN1); + break; + #ifdef SIM_PERS +//events to handle input of new password, password and new password again + case TXT_ENTER_PLOCK: + pin_data->pin_case = INPUT_SIM_PLOCK;//enter PIN1 start + sett_pin_edit(win,INPUT_SIM_PLOCK); + break; + + case TXT_ENTER_FCPWD: + pin_data->pin_case = INPUT_SIM_FCPWD;//enter FC pwd start + sett_pin_edit(win,INPUT_SIM_FCPWD); + break; +//x0pleel 20 July, 2006 + case TXT_ENTER_MKPWD: + pin_data->pin_case = INPUT_SIM_MKPWD;//enter FC pwd start + sett_pin_edit(win,INPUT_SIM_MKPWD); + break; + + case TXT_ENTER_NEW_SIMLOCK: + pin_data->pin_case = INPUT_NEW_SIM_PLOCK;//enter PIN1 start + sett_pin_edit(win,INPUT_NEW_SIM_PLOCK); + break; + + case TXT_ENTER_NEW_SIMLOCK_AGAIN: + pin_data->pin_case = INPUT_NEW_SIM_PLOCK_AGAIN;//enter new PIN2 start + sett_pin_edit(win,INPUT_NEW_SIM_PLOCK_AGAIN); + break; + case NEW_SIM_PLOCK_END: + if(!pin_data->puk_request) + { + mmi_simlock_change_pin(win,mmi_simlock_locktype,(char*)pin_data->old_pin,(char*)pin_data->new_pin); + } + break; + +#endif + case TXT_ENTER_PIN2: + pin_data->pin_case = INPUT_PIN2;//enter PIN2 start + sett_pin_edit(win,INPUT_PIN2); + break; +#ifdef SIM_PERS + case ME_PERM_BLK: + TRACE_FUNCTION("ME_PERM_BLK"); + pin_data->pin_case = PERM_BLK1;//enter PUK1 start + sett_pin_edit(win,PERM_BLK1); + break; +#endif + case TXT_ENTER_PUK1: + TRACE_FUNCTION("TXT_ENTER_PUK1"); + pin_data->pin_case = INPUT_PUK1;//enter PUK1 start + sett_pin_edit(win,INPUT_PUK1); + break; + case TXT_ENTER_PUK2: + pin_data->pin_case = INPUT_PUK2;//enter PUK2 start + sett_pin_edit(win,INPUT_PUK2); + break; + case TXT_ENTER_NEW_PIN: + pin_data->pin_case = INPUT_NEW_PIN;//enter new PIN start + sett_pin_edit(win,INPUT_NEW_PIN); + break; + case TXT_ENTER_NEW_PIN2: + pin_data->pin_case = INPUT_NEW_PIN2;//enter new PIN2 start + sett_pin_edit(win,INPUT_NEW_PIN2); + break; + case TXT_ENTER_NEW_PIN_AGAIN: + pin_data->pin_case = INPUT_NEW_PIN_AGAIN; + sett_pin_edit(win,INPUT_NEW_PIN_AGAIN);// Start: enter New PIN1 again + break; + case TXT_ENTER_NEW_PIN_AGAIN2: + pin_data->pin_case = INPUT_NEW_PIN2_AGAIN; + sett_pin_edit(win,INPUT_NEW_PIN2_AGAIN);// Start: enter New PIN2 again + break; + case PIN1_END: + pin1_en_dis_verify(win); + break; + +#ifdef SIM_PERS +//Events that indicate the input of the lock code and new lock code + case SIM_PLOCK_END: + mmi_simlock_en_dis_verify(win); + break; + + case SIM_FCPWD_END: + mmi_simlock_reset_fc_value(win); + break; + + //x0pleela 20 july, 2006 ER: OMAPS00087586, OMAPS00087587 + case SIM_MKPWD_END: + //Master unlocking through SIMP menu + mmi_simlock_master_unlock(win, MFW_SIM_MKEYM); + break; +#endif + case PIN2_END: + sim_verify_pin(MFW_SIM_PIN2,(char*)pin_data->old_pin);/* verification pin2 */ + break; + case NEW_PIN_END: + if(!pin_data->puk_request) + sim_change_pin(MFW_SIM_PIN1,(U8*)pin_data->old_pin,(U8*)pin_data->new_pin);/* change PIN1 */ + else + { + sim_unblock_pin(MFW_SIM_PUK1, (char*)pin_data->puk, (char*)pin_data->new_pin);/* unblock pin1 */ + } + break; + case NEW_PIN2_END: + if(!pin_data->puk_request) + sim_change_pin(MFW_SIM_PIN2,(U8*)pin_data->old_pin,(U8*)pin_data->new_pin);/* change PIN2 */ + else + sim_unblock_pin(MFW_SIM_PUK2, (char*)pin_data->puk, (char*)pin_data->new_pin);/* unblock pin2 */ + break; + case PIN_OK_INFO: // PIN was need + if((pin_data->set_state NEQ FDN_ACTIV) AND (pin_data->set_state NEQ FDN_DEACTIV)) + { + sett_pin_mess(win,PIN_OK_INFO);// for pin2 change and pin2 check from serv/phoneb + + } + else + { + set_mode_fdn_adn(win,pin_data); + } + break; + } + + switch(event) + { + case PIN_OK_END: + pin_verif_or_check2_end(win); + break; + case PIN1_CH_END: + case PIN2_CH_END: + case UNBL_OK: + pin_ch_end_or_abort(win); + break; + + case PIN1_STATUS_END: + case IDLE_GSM_FAIL: + pin_ch_end_or_abort(win); + break; + case SETT_ABORT: + TRACE_FUNCTION("clear softkey 10"); + // June 16, 2005 REF: CRR 31267 x0021334 + if (pin2Flag NEQ TRUE) // To ensure that the screen does not blank out + { + dspl_ClearAll(); + } + if(pin_data->set_state EQ PIN1_CHECK) + { + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + } + else if(pin_data->set_state EQ PIN2_CHECK) + { + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + // June 16, 2005 REF: CRR 31267 x0021334 + if (pin2Flag EQ TRUE) // To ensure that failed dialog is not given + { + pin2Flag = FALSE; + winDelete(par_window); + } + else + SEND_EVENT(par_window, PIN2_ABORT, 0, NULL); + } + else + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + break; + case FDN_UNBL_OK: + TRACE_FUNCTION("clear softkey 11"); + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + break; + case PIN1_ENDIS_FAIL: + if(sim_pin_count(MFW_SIM_PIN1) EQ 0) + { + pin_data->puk_request = TRUE; + sett_pin_mess(win,PUK1_REQ_VER_INFO); + } + else + { + sett_pin_mess(win,PIN1_ENDIS_FAIL); + } + break; + case FDN_WAIT: + pin_data->pin_case = FDN_WAIT; + winShow(pin_data->pin_win); + break; // waiting for call back from phonebook handler +#ifdef SIM_PERS + +//event to handle lock/unlock failure + case SIM_LOCK_ENDIS_FAIL: + sett_pin_mess(win,SIM_LOCK_ENDIS_FAIL); + break; + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //New event to display a dialog Busy for wrong entry of unlocking pwd and timer been enabled + case SIM_LOCK_BUSY: + sett_pin_mess(win,SIM_LOCK_BUSY); + break; + + //x0pleela 26 July,2006 ER: OMAPS00087586, OMAPS00087587 + //new event to display a dialog Busy for wrong entry of unblocking pwd and timer been enabled + case SIM_LOCK_BUSY_UNBLOCK: + sett_pin_mess(win, SIM_LOCK_BUSY_UNBLOCK); + break; + +#endif + default: + break; + } +} + + + +/******************************************************************************* + + $Function: pin_ch_end_or_abort + $Description: PIN change finished or abort (settings) + $Returns: none + $Arguments: win +*******************************************************************************/ +static void pin_ch_end_or_abort (T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + T_MFW_WIN * par_window; + + TRACE_FUNCTION("MmiPins:pin_ch_end_or_abort"); + + if(pin_data->set_state NEQ PIN2_CHECK) + { + if((pin_data->set_state EQ FDN_ACTIV) ||(pin_data->set_state EQ FDN_DEACTIV)) + { + set_mode_fdn_adn(win,pin_data); + } + else if(pin_data->set_state EQ PIN1_CHECK) + { + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + SEND_EVENT(par_window,PIN1_OK,0,NULL);// pin1 check over PUK1 + } + else + { + TRACE_FUNCTION("clear softkey 12"); + pin_skClear(); + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog,also idle gsm + } /* back to menu tree */ + } + else + { + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + SEND_EVENT(par_window,PIN2_OK,0,NULL);// pin2 check over PUK2 + } + +} + +#ifdef SIM_PERS +// Nov 03, 2005 DR: OMAPS00052032 - xpradip +/******************************************************************************* + $Function: mmi_display_result + $Description: Displays appropriate info dialog for the sAT_PlusCLCK operation + $Returns: none + $Arguments: state for displaying enabled or failed +*******************************************************************************/ +void mmi_display_result(U8 state) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)info_disp)->data; + T_dialog_info * display_info = (T_dialog_info *)win_data->user; + T_MFW_HND parent = display_info->parent_win; + T_MFW_WIN * win_data1 = ((T_MFW_HDR *)parent)->data; + T_pin * pin_data = (T_pin *)win_data1->user; + + if( info_disp) + dialog_info_destroy(info_disp); + info_disp = NULL; + + if( state) + { + SEND_EVENT(parent,SIM_LOCK_ENDSUCC,0,pin_data); + } + else + { + if((aciErrDesc & 0x0000FFFF) EQ CME_ERR_SimNotIns) + SEND_EVENT(parent,SIM_LOCK_SIM_REM,0,pin_data); + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //checking for Class type and the ext busy error while unlocking a locked category + else if( ( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY,0,pin_data); + else + SEND_EVENT(parent,SIM_LOCK_ENDIS_FAIL,0,pin_data); + } +} + +static void mmi_simlock_reset_fc_value(T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + int status,curr_fail_reset, curr_succ_reset; + + TRACE_FUNCTION("mmi_simlock_reset_fc_value()"); + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + if( curr_succ_reset ) + { + status = mfw_simlock_reset_fc_value((U8*)pin_data->old_pin,MFW_SIM_FCM); + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if (status == MFW_SS_FAIL) + { + if((aciErrDesc & 0x0000FFFF) EQ CME_ERR_SimNotIns) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_SIM_REM,0,pin_data); + + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //checking for Class type and the ext busy error while unlocking a locked category + else if( ( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + { + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY_UNBLOCK,0,pin_data); + } + + else + { + if( curr_fail_reset ) + { + SEND_EVENT(pin_data->pin_win,SIM_LOCK_FCPWD_FAIL,0,pin_data); + } + else + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + } + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_FCPWDSUCC,0,pin_data); + } + else + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + + } +/******************************************************************************* + $Function: mmi_simlock_en_dis_verify + $Description: performs the operation of enabling/disabling and verifying a given + lock type after the input of the password + $Returns: none + $Arguments: none +*******************************************************************************/ + +static void mmi_simlock_en_dis_verify(T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + T_MFW_SS_RETURN ret; + T_DISPLAY_DATA display_info; + + TRACE_FUNCTION("mmi_simlock_en_dis_verify()"); + if((pin_data->set_state != ENABLE) && (pin_data->set_state != DISABLE)) + { + + TRACE_FUNCTION("We're verifying SIMLock"); + + SEND_EVENT(pin_data->pin_win,SIM_LOCK_REQ_NEW,0,pin_data); + + } + else if(pin_data->set_state EQ ENABLE) + { + TRACE_FUNCTION("MmiPins:Enable Lock now"); + //TRACE_FUNCTION_P1("Vidya: SimLock_MMI_Enable Password=%s",pin_data->old_pin); + ret = mfw_simlock_enable_lock((U8*)pin_data->old_pin, mmi_simlock_locktype); + if ( ret == MFW_SS_FAIL) + { + if((aciErrDesc & 0x0000FFFF) EQ CME_ERR_SimNotIns) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_SIM_REM,0,pin_data); + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ENDIS_FAIL,0,pin_data); + } +// Nov 03, 2005 DR: OMAPS00052032 - xpradip +// handle the execute state for enabling the lock + else if( ret == MFW_EXCT) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull,TxtPleaseWait,TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, FOREVER, KEY_CLEAR | KEY_LEFT ); + info_disp = info_dialog (pin_data->pin_win, &display_info); + } + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ENDSUCC,0,pin_data); + } + else if(pin_data->set_state EQ DISABLE) + { + ret = mfw_simlock_disable_lock((U8*)pin_data->old_pin,mmi_simlock_locktype); + if (ret == MFW_SS_FAIL) + { + if((aciErrDesc & 0x0000FFFF) EQ CME_ERR_SimNotIns) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_SIM_REM,0,pin_data); + + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //checking for Class type and the ext busy error while unlocking a locked category + else if( ( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY,0,pin_data); + else + { + pin_data->pin_retries = sim_pin_count(MFW_SIM_PIN1); + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ENDIS_FAIL,0,pin_data); + } + } + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ENDSUCC,0,pin_data); + } + +} + + +/******************************************************************************* + $Function: simLock_enable + $Description: Initiates the password input screen for enabling a lock none + $Arguments: none +*******************************************************************************/ +void SIMLock_enable () +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + UBYTE slock_status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 -Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + + pin_data = (T_pin *)win_data->user; + + /*a0393213 warnings removal-status variable set but not used*/ + /*T_MFW_SIM_PIN_STATUS status; + + status.type = MFW_SIM_PLOCK;*/ + slock_status= mfw_simlock_get_lock_status(mmi_simlock_locktype); + pin_data->set_state = ENABLE; + + if(slock_status EQ MFW_SIM_DISABLE) /*if PIN disabled*/ + { + SEND_EVENT(pin_data->pin_win,TXT_SIM_LOCK_ALL,0,pin_data); + } + else if (slock_status EQ MFW_SIM_BLOCKED) + { + pin_data->pin_case = SIM_LOCK_ALL; + SEND_EVENT(pin_data->pin_win, SIM_LOCK_ENDIS_FAIL,0,pin_data); + } + else + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ALREADY_ENDIS,0,pin_data); + } +} + +/******************************************************************************* + + $Function: SIMLock_disable + $Description: Initiates the password input screen for the disabling of a lock + $Returns: + $Arguments: +*******************************************************************************/ +void SIMLock_disable () +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + UBYTE slock_status; + T_MFW_WIN * win_data = NULL; + // T_DISPLAY_DATA display_info; + T_pin * pin_data = NULL; + /*T_MFW_SIM_PIN_STATUS status;*//*a0393213 warnings removal-status variable set but not used*/ + + TRACE_FUNCTION("SIMLock_disable()"); + + if(win != NULL) /* x0039928 - Lint warning removal */ + { win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + /*status.type = MFW_SIM_PLOCK;*/ /*a0393213 warnings removal-status variable set but not used*/ + slock_status= mfw_simlock_get_lock_status(mmi_simlock_locktype); + pin_data->set_state = DISABLE; + if(slock_status EQ MFW_SIM_ENABLE) /*if PIN disabled*/ + { + SEND_EVENT(pin_data->pin_win,TXT_SIM_LOCK_ALL,0,pin_data); + } + else if (slock_status EQ MFW_SIM_BLOCKED) + { + pin_data->pin_case = SIM_LOCK_ALL; + SEND_EVENT(pin_data->pin_win, SIM_LOCK_ENDIS_FAIL,0,pin_data); + } + else //PIN already enabled + /*{ + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtLockDisabled, TxtNull, COLOUR_STATUS_PINS); + //display_info.TextId = TxtLockEnabled; + dlg_initDisplayData_events( &display_info, NULL, THREE_SECS, 0 ); + info_dialog(0,&display_info); + }*/ + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ALREADY_ENDIS,0,pin_data); + } + return ; +} + + +/******************************************************************************* + $Function: SIMLock_change + $Description: Initiates the password input screen for change password + $Arguments: none +*******************************************************************************/ + + void SIMLock_change () +{ + T_MFW_HND idle_win = mfwParent( mfw_header()); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + int status; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + pin_data->set_state = CHANGE_PIN; + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + + TRACE_FUNCTION("MmiPins:SIMLock_change"); + + if(status == MFW_SIM_BLOCKED) + { + pin_data->pin_case = SIM_LOCK_ALL; + SEND_EVENT(pin_data->pin_win,SIM_LOCK_ENDIS_FAIL,0,pin_data); + } + else if( status == MFW_SIM_ENABLE){ + SEND_EVENT(pin_data->pin_win,SIM_LOCK_STATUS,0,pin_data); + } + else + { + /*a0393213 warnings removal - enumerated typed mixed with other type - the statement is not necessary*/ + /*pin_data->pin_case = DISABLE;*/ + SEND_EVENT(pin_data->pin_win,SIM_LOCK_REQ_OLD,0,pin_data); + } + } +} + +/******************************************************************************* + + $Function: SIMLock_status + $Description: Initiates the query for the lock status. + $Returns: + $Arguments:none +*******************************************************************************/ +void SIMLock_status () +{ + + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + + TRACE_FUNCTION("SIMLock_status"); + + SEND_EVENT(pin_data->pin_win,SIM_LOCK_STATUS,0,pin_data); + } +} + + +/******************************************************************************* + + $Function: simlock_doAction + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + +void simlock_doAction() +{ +TRACE_FUNCTION("simlock_doAction()"); + switch(mmi_simlock_lockaction) + { + case MFW_SIM_ENABLE: + SIMLock_enable(); + break; + + case MFW_SIM_DISABLE: + SIMLock_disable(); + break; + + case MFW_SIM_CHANGE: + SIMLock_change(); + break; + case MFW_SIM_VERIFY: + SIMLock_status(); + break; + + default: + break; + } +} + +int SIMLock_resetFC (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 -Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + TRACE_FUNCTION("SIMLock_resetFC()"); + + SEND_EVENT(pin_data->pin_win, SIM_LOCK_REQ_FCPWD,0,pin_data); + } + return 1; +} + +/******************************************************************************* + + $Function: mmi_simlock_category_menus() + + $Description: starts the simlock category list menu + + $Returns: None + + $Arguments: parent window + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +T_MFW_HND mmi_simlock_category_menus(T_MFW_HND parent) +{ + T_MFW_HND simp_cat_list_win; + TRACE_FUNCTION("mmi_simlock_category_menus"); + + simp_cat_list_win = bookMenuStart(parent, SIMPCategoryListAttributes(), NULL); + return simp_cat_list_win; + +} + +/******************************************************************************* + $Function: SIMLock_unblock_ME + $Description: This function sends an event to display an editor for the user to enter + unblocking code + $Returns: none + $Arguments: none +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +int SIMLock_unblock_ME(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND pin_win = pin_windows; + T_MFW_WIN * win_data = ((T_MFW_HDR *)pin_win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("SIMLock_unblock_ME()"); + + pin_data->puk_request = TRUE; + C_KEY_REQ=1; + FCUnlock_flag=1; + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + return 1; +} + +/******************************************************************************* + $Function: SIMLock_MasterKeyUnlock_bootup + $Description: This functioh gets called to unlock category /unblock ME during bootup sequence + $Returns: none + $Arguments: none +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +int SIMLock_MasterKeyUnlock_bootup (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND pin_win = pin_windows; + T_MFW_WIN * win_data = ((T_MFW_HDR *)pin_win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("SIMLock_MasterKeyUnlock_bootup()"); + + SEND_EVENT(pin_data->pin_win, INPUT_MASTER_KEY_REQ,0,pin_data); + + return 1; +} + +/******************************************************************************* + $Function: SIMLock_MasterKeyUnlock + $Description: This functioh gets called to unlock category /unblock ME through SIMP menu + $Returns: none + $Arguments: none +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +int SIMLock_MasterKeyUnlock (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + TRACE_FUNCTION("SIMLock_MasterKeyUnlock()"); + SEND_EVENT(pin_data->pin_win, SIM_LOCK_REQ_MKPWD,0,pin_data); + } + return 1; +} + +/******************************************************************************* + + $Function: simlock_check_masterkey + + $Description: If there is no support for Master Unlocking the item "Master unlock" will not + appear on the menulist + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_masterkey(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + UBYTE status; + TRACE_FUNCTION("simlock_check_masterkey"); + + status = mfw_simlock_check_masterkey(MFW_SIM_MKEYM); + if( status EQ MFW_MASTER_UNLOCK_ACTIVE) + return 0; + else + return 1; +} + +/******************************************************************************* + + $Function: simlock_get_masterkey_status + + $Description: Get the master key status + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +UBYTE simlock_get_masterkey_status(void) + +{ + UBYTE status; + TRACE_FUNCTION("simlock_get_masterkey_status"); + + status = mfw_simlock_check_masterkey(MFW_SIM_MKEYM); + return status; +} + +/******************************************************************************* + + $Function: simlock_check_NWCatLock + + $Description: Get the lock status of Network category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_NWCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_NWCatLock"); + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_NLOCK ) && ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; + +} + +/******************************************************************************* + + $Function: simlock_check_NSCatLock + + $Description: Get the lock status of Network subset category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_NSCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_NSCatLock"); + + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_NSLOCK )&& ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; +} + +/******************************************************************************* + + $Function: simlock_check_SPCatLock + + $Description: Get the lock status of Service Provider category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_SPCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_SPCatLock"); + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_SPLOCK )&& ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; +} + +/******************************************************************************* + + $Function: simlock_check_CPCatLock + + $Description: Get the lock status of Corporate category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_CPCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_CPCatLock"); + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_CLOCK )&& ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; +} + +/******************************************************************************* + + $Function: simlock_check_SIMCatLock + + $Description: Get the lock status of SIM category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_SIMCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_SIMCatLock"); + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_PLOCK )&& ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; +} + +/******************************************************************************* + + $Function: simlock_check_CatBlock + + $Description: Get the ME status and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +USHORT simlock_check_CatBlock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) +{ + T_SUP_INFO_TYPE FLAG; + int curr_fc; + + TRACE_FUNCTION("simlock_check_CatBlock"); + + FLAG=FCATTEMPTSLEFT; /* set flag to current */ + curr_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + if((curr_fc == 0)) //ME blocked + return 0; + else + return 1; +} +/******************************************************************************* + + $Function: mmi_simlock_master_unlock + + $Description: This function unlocks category/unblocks ME and sends event accordingly through SIMP menu + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +static void mmi_simlock_master_unlock(T_MFW_HND win, UBYTE MK_Unblock_flag) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + int status; + + TRACE_FUNCTION("mmi_simlock_master_unlock()"); + + status = mfw_simlock_master_unlock((U8*)pin_data->old_pin, MK_Unblock_flag); + if (status == MFW_SS_FAIL) + { + SEND_EVENT(pin_data->pin_win,SIM_LOCK_MKPWD_FAIL,0,pin_data); + } + else + { + SEND_EVENT(pin_data->pin_win,SIM_LOCK_MKPWDSUCC,0,pin_data); + } +} + +/******************************************************************************* + + $Function: simlock_check_PBCatLock + + $Description: Get the lock status of Blocked Network category and accordingly display the menu item + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 25 Sep, 2006 ER: OMAPS00095524 +USHORT simlock_check_PBCatLock(struct MfwMnuTag *m, + struct MfwMnuAttrTag *ma, + struct MfwMnuItemTag *mi) + +{ + int status; + + TRACE_FUNCTION("simlock_check_PBCatLock"); + + status = mfw_simlock_get_lock_status(mmi_simlock_locktype); + if( (mmi_simlock_locktype EQ MFW_SIM_PBLOCK ) && ( status NEQ MFW_SIM_BLOCKED) ) + return 0; + else + return 1; + +} + +/******************************************************************************* + + $Function: simp_unlock_Category + + $Description: This function sends corresponding event to unlock a locked category through dynamic menu + + $Returns: + + $Arguments: + +*******************************************************************************/ +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 +int simp_unlock_Category(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND pin_win = pin_windows; + T_MFW_WIN * win_data = ((T_MFW_HDR *)pin_win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("simp_unlock_Category()"); + switch((int)i->str) + { + case TxtNetwork: + SEND_EVENT(pin_win,INPUT_NLOCK_PIN_REQ, 0, pin_data); + break; + case TxtNetworkSubset: + SEND_EVENT(pin_win,INPUT_NSLOCK_PIN_REQ, 0, pin_data); + break; + case TxtServiceProvider: + SEND_EVENT(pin_win,INPUT_SPLOCK_PIN_REQ, 0, pin_data); + break; + case TxtCorporate: + SEND_EVENT(pin_win,INPUT_CLOCK_PIN_REQ, 0, pin_data); + break; + case TxtSIM: + SEND_EVENT(pin_win,INPUT_SIM_PIN_REQ, 0, pin_data); + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //Handling "Blocked Network" category + case TxtBlkNetwork: + SEND_EVENT(pin_win,INPUT_PBLOCK_PIN_REQ, 0, pin_data); + break; + } + return MFW_EVENT_CONSUMED; +} + +/******************************************************************************* + $Function: get_fc_max_value + $Description: gets the maximum value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_fc_max_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=FCMAX; /* set flag to current */ + + TRACE_FUNCTION("get_fc_max_value"); + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + sprintf(buf, "MAX %d tries", max_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + +/******************************************************************************* + $Function: get_fc_attempts_left + $Description: gets the current value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_fc_attempts_left (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int curr_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; +// Sept 24, 2005 REF: LOCOSTO-ENH-34438, xpradipg +// new ENUM used to adopt to the aci label + FLAG = FCATTEMPTSLEFT; /* set flag to current */ + + curr_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(curr_fc != MFW_FAILURE) + { + sprintf(buf, "%d tries left", curr_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + + + +/******************************************************************************* + $Function: get_fail_reset_fc_max_value + $Description: gets the maximum value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_fail_reset_fc_max_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=FCRESETFAILMAX; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + sprintf(buf, "MAX %d tries", max_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + +/******************************************************************************* + $Function: get_succ_reset_fc_max_value + $Description: gets the maximum value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_succ_reset_fc_max_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=FCRESETSUCCESSMAX; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + sprintf(buf, "MAX %d tries", max_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} +/******************************************************************************* + $Function: get_fail_reset_fc_attempts_left + $Description: gets the maximum value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_fail_reset_fc_attempts_left (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; +// Sept 24, 2005 REF: LOCOSTO-ENH-34438, xpradipg +// new ENUM used to adopt to the aci label + FLAG = FCRESETFAILATTEMPTSLEFT; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + sprintf(buf, "%d tries left", max_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} +/******************************************************************************* + $Function: get_succ_reset_fc_attempts_left + $Description: gets the maximum value of FC + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_succ_reset_fc_attempts_left (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; +// Sept 24, 2005 REF: LOCOSTO-ENH-34438, xpradipg +// new ENUM used to adopt to the aci label + FLAG=FCRESETSUCCESSATTEMPTSLEFT; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + sprintf(buf, "%d tries left", max_fc); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} +/******************************************************************************* + $Function: get_timer_flag_value + $Description: gets the value of timer for successive unlock attempts + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_timer_flag_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=TIMERFLAG; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + if( max_fc ) + sprintf(buf, "Flag Enabled"); + else + sprintf(buf,"Flag Disabled"); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + +/******************************************************************************* + $Function: get_airtel_ind_flag_value + $Description: gets the value of airtel indication flag + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_airtel_ind_flag_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=AIRTELINDFLAG; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + if( max_fc ) + sprintf(buf, "Flag Enabled"); + else + sprintf(buf,"Flag Disabled"); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + +/******************************************************************************* + $Function: get_etsi_flag_value + $Description: gets the value of ETSI flag + $Returns: none + $Arguments: none +*******************************************************************************/ +int get_etsi_flag_value (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_SUP_INFO_TYPE FLAG; + int max_fc; + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + char buf[30]; + FLAG=ETSIFLAG; /* set flag to current */ + + max_fc=mfw_simlock_get_sup_info(FLAG); /* get the value of the corresponding flag*/ + + if(max_fc != MFW_FAILURE) + { + if( max_fc ) + sprintf(buf, "Flag Enabled"); + else + sprintf(buf,"Flag Disabled"); + dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, (char *)buf, (char *)NULL, COLOUR_STATUS); + } + else + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); + + dlg_initDisplayData_events( &display_info, NULL, TWO_SECS, KEY_OK ); + // display_info.TextString2 = NULL; + display_info.Identifier = NULL; + info_dialog(win,&display_info); //information screen + + return 1; + +} + +/******************************************************************************* + $Function: setLockTypeNw + $Description: sets the global flag to the network lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int setLockTypeNw (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypeNw"); + mmi_simlock_locktype=MFW_SIM_NLOCK; + simlock_doAction(); + return 1; +} +/******************************************************************************* + $Function: setLockTypeSp + $Description: sets the global flag to the Service provider lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int setLockTypeSp (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypeNw"); + mmi_simlock_locktype=MFW_SIM_SPLOCK; + simlock_doAction(); + return 1; +} +/******************************************************************************* + $Function: setLockTypeNs + $Description: sets the global flag to the network subset lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int setLockTypeNs (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypeNs"); + mmi_simlock_locktype=MFW_SIM_NSLOCK; + simlock_doAction(); + return 1; +} +/******************************************************************************* + $Function: setLockTypeCp + $Description: sets the global flag to the Corprate lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int setLockTypeCp (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypeCp"); + mmi_simlock_locktype=MFW_SIM_CLOCK; + simlock_doAction(); + return 1; +} +/******************************************************************************* + $Function: setLockTypePs + $Description: sets the global flag to the Personalisation lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int setLockTypePs(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypePs"); + mmi_simlock_locktype=MFW_SIM_PLOCK; + simlock_doAction(); + return 1; +} + + +/******************************************************************************* + $Function: setLockTypePb + $Description: sets the global flag to the Personalisation lock + $Returns: none + $Arguments: none +*******************************************************************************/ +//x0pleela 25 Sep, 2006 ER: OMAPS00095524 +int setLockTypePb(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("setLockTypePb"); + mmi_simlock_locktype=MFW_SIM_PBLOCK; + simlock_doAction(); + return 1; +} +/******************************************************************************* + + $Function: setLockActionLock + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + + +void setLockActionLock(void) +{ + TRACE_FUNCTION("setLockActionLock"); + mmi_simlock_lockaction= MFW_SIM_ENABLE; +} + + +/******************************************************************************* + + $Function: setLockActionUnlock + + $Description: sets the global flag to the action unlock + + $Returns: none + + $Arguments: none + +*******************************************************************************/ + + +void setLockActionUnlock(void) +{ + TRACE_FUNCTION("setLockActionUnlock"); + mmi_simlock_lockaction= MFW_SIM_DISABLE; +} +/******************************************************************************* + + $Function: setLockActionChPwd + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + + +void setLockActionChPwd(void) +{ + TRACE_FUNCTION("setLockActionChPwd"); + mmi_simlock_lockaction= MFW_SIM_CHANGE; +} + +/******************************************************************************* + + $Function: setLockActionChkStat + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + + +void setLockActionChkStat(void) +{ + TRACE_FUNCTION("setLockActionChkStat"); + mmi_simlock_lockaction= MFW_SIM_VERIFY; +} + +#endif + + + +/******************************************************************************* + + $Function: pin_verif_or_check2_end + $Description: PIN change finished or abort (settings) + $Returns: none + $Arguments: win +****************************************************************************/ +static void pin_verif_or_check2_end(T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + T_MFW_WIN * par_window; + + TRACE_FUNCTION("MmiPins:pin_verif_or_check2_end"); + + if(pin_data->set_state NEQ PIN2_CHECK) + { + if(pin_data->set_state NEQ CHANGE_PIN2) + { + TRACE_FUNCTION("MmiPins:changing PIN 2"); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN,0,pin_data);//pin change + } + else if(pin_data->set_state EQ PIN1_CHECK) + { + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + SEND_EVENT(par_window,PIN1_OK,0,NULL);// pin1 check (not over PUK1) + } + else + { + TRACE_FUNCTION("MmiPins:changing PIN 2"); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN2,0,pin_data);// pin2 change + } + + } + else + { TRACE_FUNCTION("MmiPins:checking PIN 2"); + par_window = pin_data->parent_win; + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + SEND_EVENT(par_window,PIN2_OK,0,NULL);// pin2 check (not over PUK2) + } + +} + + + + +/******************************************************************************* + + $Function: pin1_en_dis_verify + $Description: PIN enab/disab/verify start + $Returns: none + $Arguments: win +****************************************************************************/ +static void pin1_en_dis_verify(T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins:pin1_en_dis_verify"); + + if((pin_data->set_state NEQ ENABLE) AND (pin_data->set_state NEQ DISABLE)) + { TRACE_FUNCTION("We're verifying pin 1"); + sim_verify_pin(MFW_SIM_PIN1,(char*)pin_data->old_pin);/* verification pin1 */ + } + else if(pin_data->set_state EQ ENABLE) + { /* start enabling PIN1 */ + TRACE_FUNCTION("MmiPins:Pin1 now enabled"); + if (sim_enable_pin((U8*)pin_data->old_pin) == MFW_SS_FAIL) + { /*SPR 2145, if attempt fails then behave as though a "Pin incorrect" + event has been sent to MMI*/ + pin_data->pin_retries = sim_pin_count(MFW_SIM_PIN1); + SEND_EVENT(pin_data->pin_win,PIN1_ENDIS_FAIL,0,pin_data); + } + + } + else + { /* start disabling PIN1 */ + TRACE_FUNCTION("MmiPins:Pin1 now disabled"); + if (sim_disable_pin((U8*)pin_data->old_pin) == MFW_SS_FAIL) + { /*SPR 2145, if attempt fails then behave as though a "Pin incorrect" + event has been sent to MMI*/ + pin_data->pin_retries = sim_pin_count(MFW_SIM_PIN1); + SEND_EVENT(pin_data->pin_win,PIN1_ENDIS_FAIL,0,pin_data); + } + } + +} + +/******************************************************************************* + + $Function: pin_change + $Description: PIN change : call from menu Settings + $Returns: Status int + $Arguments: menu, item +*******************************************************************************/ + +int pin_change (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = idle_get_window(); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + T_MFW_SIM_PIN_STATUS status; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + pin_data->set_state = CHANGE_PIN; + + TRACE_FUNCTION("MmiPins:pin_change"); + + status.type = MFW_SIM_PIN1; + sim_pin_status(&status); + if(status.set EQ MFW_SIM_ENABLE) /*if PIN enabled no show menu entry */ + { if(sim_pin_count(MFW_SIM_PIN1) > 0) + SEND_EVENT(pin_data->pin_win,PIN1_REQ_OLD,0,pin_data); + else + { /* not included the state of the puk counter ! */ + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + } + else + { + setting_pin_destroy(win); + pin1_not_enabled_screen(); + } + } + return 1; +} + + +/******************************************************************************* + + $Function: pin2_change + $Description: PIN2 change : call from menu Settings + $Returns: Status int + $Arguments: menu, item +*******************************************************************************/ +int pin2_change (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = idle_get_window(); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + pin_data->set_state = CHANGE_PIN2; + + TRACE_FUNCTION("MmiPins:pin2_change"); + // June 16, 2005 REF: CRR 31267 x0021334 + // Check if PIN2 and PUK2 are initialised + if((sim_pin_count(MFW_SIM_PIN2) > 0) AND (sim_pin_count(MFW_SIM_PUK2) NEQ 0)) + SEND_EVENT(pin_data->pin_win,PIN2_REQ_OLD,0,pin_data); + // If PIN2 is not initialised, ask for PUK 2 + else if ((sim_pin_count(MFW_SIM_PIN2) EQ 0) AND (sim_pin_count(MFW_SIM_PUK2) > 0)) + { + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK2_REQ,0,pin_data); + } + // Else display that PIN2 is not available + else + { + SEND_EVENT(pin_data->pin_win,PIN2_SIM_FAILURE,0,pin_data); + } + } + return 1; +} + + +/******************************************************************************* + + $Function: pin_enable + $Description: PIN1 enable : call from menu Settings + $Returns: Status int + $Arguments: menu, item +*******************************************************************************/ +int pin_enable (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_SIM_PIN_STATUS status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + status.type = MFW_SIM_PIN1;//get pin1 status + sim_pin_status(&status); + if(status.set EQ MFW_SIM_DISABLE) /*if PIN disabled*/ + { pin_data->set_state = ENABLE; + if(sim_pin_count(MFW_SIM_PIN1) > 0) //if PIN1 not blocked + { //ask for PIN1 + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,pin_data); + } + else + { //ask for PUK1 + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + } + else //PIN already enabled + SEND_EVENT(pin_data->pin_win,PIN1_ENAB_END,0,pin_data); + } + return 1; +} + + + +/******************************************************************************* + + $Function: pin_disable + $Description: PIN1 disable : call from menu Settings + $Returns: Status int + $Arguments: menu, item +*******************************************************************************/ +int pin_disable (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win =mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_SIM_PIN_STATUS status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + + TRACE_FUNCTION("MmiPins:pin_disable"); + status.type = MFW_SIM_PIN1; //get pin1 status + sim_pin_status(&status); + /*MC CONQ 5578, 27/05/02, if pin disabling NOT available*/ + if(status.stat EQ MFW_SIM_NO_DISABLE) + { /*tell user and destroy PIN window*/ + ShowMessage(win, TxtNotAllowed, TxtNull); + setting_pin_destroy(win); + } + else + { + /*if PIN enabled */ + if(status.set EQ MFW_SIM_ENABLE ) + { + pin_data->set_state = DISABLE; + if(sim_pin_count(MFW_SIM_PIN1) > 0) //if PIN not blocked + {//ask for PIN + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,pin_data); + } + else + { //ask for PUK1 + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + } + else //if PIN already disabled no need to ask for PIN + SEND_EVENT(pin_data->pin_win,PIN1_DISAB_END,0,pin_data); + } + } + return 1; +} + + +/******************************************************************************* + + $Function: pin_status + $Description: how if pin request is on or off + $Returns: Status int + $Arguments: menu, item +*******************************************************************************/ +int pin_status (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + T_MFW_HND idle_win = idle_get_window(); + T_MFW_HND win = setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + + TRACE_FUNCTION("MmiPins:pin_status"); + + SEND_EVENT(pin_data->pin_win,PIN1_STATUS,0,pin_data); + } + return 1; + +} + + + +/******************************************************************************* + + $Function: pin2_fdn_activate + $Description: PIN2 activate fdn call from menu Settings + $Returns: Status int + $Arguments: none +*******************************************************************************/ +int pin2_fdn_activate (void) +{ T_MFW_HND parent_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(parent_win); + T_MFW_SIM_PIN_STATUS status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + + pin_data->set_state = FDN_ACTIV; + + TRACE_FUNCTION("MmiPins:pin2_check"); + + status.type = MFW_SIM_PIN2; + sim_pin_status(&status); + SimHasPin(MFW_SIM_PIN2); + + TRACE_EVENT_P1("PIN2 status is: %d",status.stat); + // June 16, 2005 REF: CRR 31267 x0021334 + // Check if PIN2 and PUK2 are initialised + if ((sim_pin_count(MFW_SIM_PIN2) > 0) AND (sim_pin_count(MFW_SIM_PUK2) NEQ 0)) + { + SEND_EVENT(pin_data->pin_win,PIN2_REQ,0,pin_data); + } + // If PIN2 is not initialised, ask for PUK 2 + else if ((sim_pin_count(MFW_SIM_PIN2) EQ 0) AND (sim_pin_count(MFW_SIM_PUK2) > 0)) + { + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK2_REQ,0,pin_data); + } + // Else display that PIN2 is not available + else + { + SEND_EVENT(pin_data->pin_win,PIN2_SIM_FAILURE,0,pin_data); + } + } + return 1; +} +void pin1_not_enabled_screen( void ) +{ + T_MFW_HND parent_window = mfwParent( mfw_header() ); + T_DISPLAY_DATA display_info; + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtEnablePIN, TxtNull , COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)not_avail_cb, THREE_SECS, KEY_RIGHT|KEY_LEFT ); + + info_dialog( parent_window, &display_info ); +} + +void pin2_not_available_screen( void ) +{ + T_MFW_HND parent_window = mfwParent( mfw_header() ); + T_DISPLAY_DATA display_info; + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtPin2Code, TxtNotAvailable , COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)not_avail_cb, THREE_SECS, KEY_RIGHT|KEY_LEFT ); + + info_dialog( parent_window, &display_info ); +} + +static void not_avail_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason) +{ + + switch (reason) + { + case INFO_KCD_LEFT: + case INFO_KCD_RIGHT: + + case INFO_TIMEOUT: + winShow(win); + break; + } + +} +/******************************************************************************* + + $Function: pin2_fdn_deactivate + $Description: PIN2 deactivate fdn call from menu Settings + $Returns: Status int + $Arguments: none +*******************************************************************************/ +int pin2_fdn_deactivate (void) +{ + T_MFW_HND parent_win = mfwParent( mfw_header() ); + T_MFW_HND win = setting_pin_create(parent_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; +//test if sim card has a PIN2 + pin_data->set_state = FDN_DEACTIV; + + TRACE_FUNCTION("MmiPins:pin2_fdn_deactivate"); + // June 16, 2005 REF: CRR 31267 x0021334 + // Check if PIN2 and PUK2 are initialised + if ((sim_pin_count(MFW_SIM_PIN2) > 0) AND (sim_pin_count(MFW_SIM_PUK2) NEQ 0)) //if there is a sim pin2 count + { + SEND_EVENT(pin_data->pin_win,PIN2_REQ,0,pin_data); + } + // If PIN2 is not initialised, ask for PUK 2 + else if ((sim_pin_count(MFW_SIM_PIN2) EQ 0) AND (sim_pin_count(MFW_SIM_PUK2) > 0)) + { + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK2_REQ,0,pin_data); + } + // Else display that PIN2 is not available + else + { + SEND_EVENT(pin_data->pin_win,PIN2_SIM_FAILURE,0,pin_data); + } + } + return 1; +} + + + + +/******************************************************************************* + + $Function: sett_pin_edit + $Description: help function for editor dialog + $Returns: none + $Arguments: window, event +*******************************************************************************/ +static void sett_pin_edit(T_MFW_HND win, USHORT event) +{ + +//open the editor for entering the pin + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_edt_win; + + + + pin_edt_win = set_pin_edt_create(pin_data->pin_win); + + + + if(pin_edt_win) + { + SEND_EVENT(pin_edt_win,event,0,pin_data); + } + + + +} + + + +/******************************************************************************* + + $Function: set_pin_edt_create + $Description: Creation of an instance for the PIN Editor dialog settings + Type of dialog : SINGLE_DYNAMIC + $Returns: window + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND set_pin_edt_create (T_MFW_HND parent_window) +{ + T_pin_edt * data = (T_pin_edt *)ALLOC_MEMORY (sizeof (T_pin_edt)); + T_MFW_WIN * win; + + data->pin_edt_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)set_pin_edt_win_cb); + + TRACE_FUNCTION("MmiPins:set_pin_edt_create"); + + if (data->pin_edt_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)set_pin_editor; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_edt_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->tim_out_handle = tim_create(data->pin_edt_win,TIMEOUT,(T_MFW_CB)pin_edt_tim_out_cb); + +/* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + data->editor = ATB_edit_Create(&data->editorPinAttr,0); +#else /* NEW_EDITOR */ + data->editor_handle = edt_create(data->pin_edt_win,&data->editpinAttr,0,0); +#endif /* NEW_EDITOR */ + data->kbd_handle = kbd_create(data->pin_edt_win,KEY_ALL,(T_MFW_CB)set_pin_kbd_cb); + data->kbd_long_handle = kbd_create(data->pin_edt_win,KEY_ALL | KEY_LONG,(T_MFW_CB)set_pin_edt_kbd_long_cb); + /* + * return window handle + */ + return data->pin_edt_win; +} + + +/******************************************************************************* + + $Function: set_pin_edt_destroy + $Description: Destroy the pin editor dialog + $Returns: none + $Arguments: window +*******************************************************************************/ +void set_pin_edt_destroy (T_MFW_HND own_window) +{ + T_pin_edt * data ; + T_MFW_WIN * win; + + if (own_window) + { + TRACE_FUNCTION("MmiPins:set_pin_edt_destroy"); + + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_edt *)win->user; + + if(data) + { + /* + * Delete WIN Handler + */ + win_delete (data->pin_edt_win); + FREE_MEMORY((void *)data,(sizeof(T_pin_edt))); + } + } +} + +#if(0) /* x0039928 - Lint warning removal */ +/******************************************************************************* + + $Function: set_pin_win_cb + $Description: Callback function for editor windows + $Returns: status int + $Arguments: event, window +*******************************************************************************/ +static int set_pin_win_cb (T_MFW_EVENT event,T_MFW_WIN * win) +{ + + TRACE_FUNCTION("set_pin_win_cb"); + if (event EQ MfwWinVisible) + { + + dspl_ClearAll(); + return 1; + } + return 0; +} +#endif + +/******************************************************************************* + + $Function: set_pin_edt_win_cb + $Description: Callback function for editor windows + $Returns: status int + $Arguments: event, window +*******************************************************************************/ +static int set_pin_edt_win_cb (T_MFW_EVENT event,T_MFW_WIN * win) +{ + T_pin_edt * edt_data = (T_pin_edt *)win->user;//pin edt data + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("set_pin_edt_win_cb"); + + if (event EQ MfwWinVisible) + { + /* SPR#1428 - SH - New Editor changes */ + #ifdef NEW_EDITOR + ATB_edit_Show(edt_data->editor); + + if (edt_data->editor->update!=ED_UPDATE_TRIVIAL) + { + /* Set the colour for drawing title */ + + resources_setTitleColour(COLOUR_EDITOR); + + dspl_Clear(0,0, SCREEN_SIZE_X-1, edt_data->editor->attr->win_size.py-1); + + /* Title */ + + if(pin_emergency_call == TRUE) + { + PROMPT(0,0,0,TxtEmergency); + } + else + { + PROMPT(0,0,0,pin_data->display_id1); +#ifdef SIM_PERS + if( pin_data->display_id2) + PROMPT(0,20,0,pin_data->display_id2); +#endif + } + + /* Soft keys */ + + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && (strlen((char*)edt_data->pin) < (MAX_PIN + 1))) + { + if(!(edt_data->gsm_state)) /* usual way for PIN 4 digits */ + { +#ifdef SIM_PERS + if(pin_data->display_id1 == TxtPhoneBlocked) + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + else +#endif + softKeys_displayId(TxtSoftOK,TxtDelete,0, COLOUR_EDITOR_XX); + } + } + //xvilliva - Added the below "if" and moved the existing "if" in to "else". "if" avoids "delete" key display. + if((strlen((char*)edt_data->pin) == 0))// May 13, 2004 REF: CRR 13623 xvilliva + { + TRACE_EVENT("clear softkey 16 - zero length"); + softKeys_displayId(TxtNull,TxtNull,0, COLOUR_EDITOR_XX); + } + else if((strlen((char*)edt_data->pin) < MIN_PIN) && (edt_data->emergency_call != TRUE)) + { + TRACE_EVENT("clear softkey 16"); + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + } +#ifdef SIM_PERS + else if((strlen((char*)edt_data->pin) < MIN_PIN) && (edt_data->emergency_call == TRUE)) + { + TRACE_EVENT("clear softkey 16"); + if(pin_emergency_call == TRUE) + softKeys_displayId(TxtSoftCall,TxtDelete,0, COLOUR_EDITOR_XX); + else + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + } +#endif + } + + edt_data->editor->update = ED_UPDATE_DEFAULT; + +#else /* NEW_EDITOR */ + pin_icons(); + PROMPT(INFO_TEXT_X,INFO_TEXT_Y,0,pin_data->display_id1); + + TRACE_FUNCTION("softkey 6"); + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); +#endif /* NEW_EDITOR */ + return 1; + } + return 0; +} + + + +/******************************************************************************* + + $Function: set_pin_editor + $Description: Pin editor Dialog Signal Handling function + $Returns: void + $Arguments: window, event, value, parameters +*******************************************************************************/ +static void set_pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user; + + T_pin * pin_data = (T_pin *)parameter;//pin main data + + edt_data->pin_case_edit = pin_data->pin_case; + + TRACE_FUNCTION("MmiPins:set_pin_editor"); + + /* + * depending on event + */ + switch (event) + { + case INPUT_PIN1: + case INPUT_PIN2: + case INPUT_PUK1: + case INPUT_PUK2: + case INPUT_NEW_PIN: + case INPUT_NEW_PIN_AGAIN: + case INPUT_NEW_PIN2: + case INPUT_NEW_PIN2_AGAIN: +#ifdef SIM_PERS + case INPUT_SIM_PLOCK: + case INPUT_SIM_FCPWD: + case INPUT_NEW_SIM_PLOCK: + case INPUT_NEW_SIM_PLOCK_AGAIN: + case PERM_BLK1: + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case INPUT_SIM_MKPWD: + +#endif + //SPR#717 - GW - Wrong structures being cleared + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + memset(edt_data->puk, '\0', sizeof(edt_data->puk)); + memset(edt_data->new_pin, '\0', sizeof(edt_data->new_pin)); + memset(edt_data->old_pin, '\0', sizeof(edt_data->old_pin)); + + /* Set up pin entry attributes */ + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + AUI_edit_SetAttr( &edt_data->editorPinAttr, PIN_EDIT_RESET, COLOUR_EDITOR_XX, EDITOR_FONT, 0, ED_CURSOR_UNDERLINE, ATB_DCS_ASCII, (UBYTE *)edt_data->edtbuf, MAX_DIG); + clear_edit_array(edt_data); /* clear editor buffer */ + edt_data->editor_index = 0; + ATB_edit_Init(edt_data->editor); + ATB_edit_Show(edt_data->editor); +#else /* NEW_EDITOR */ + editor_attr_init( &edt_data->editpinAttr, PIN_EDIT_RESET, edtCurBar1,0,(char*)edt_data->edtbuf,MAX_DIG,COLOUR_EDITOR_XX); + clear_edit_array(edt_data); /* clear editor buffer */ + edt_data->editor_index = 0; + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + + winShow(edt_data->pin_edt_win); + + break; + + default: + break; + } +} + + + +/******************************************************************************* + + $Function: set_pin_kbd_cb + $Description: Callback function for keyboard settings pin + $Returns: status int + $Arguments: event, keyboard control block +*******************************************************************************/ +static int set_pin_kbd_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + char timer = TRUE; + + timStop(edt_data->tim_out_handle);/* stop entering timer */ + + TRACE_FUNCTION("MmiPins:set_pin_kbd_cb"); + +#ifdef SIM_PERS + if( !perm_blocked) +#endif + { + switch(kc->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_3: + case KCD_4: + case KCD_5: + case KCD_6: + case KCD_7: + case KCD_8: + case KCD_9: + case KCD_STAR: + if(edt_data->editor_index < MAX_DIG) + { + /* xreddymn OMAPS00083495 Jul-04-2006 + * Limit PIN1, PIN2 entries to 8 digits. + */ + if(((edt_data->pin_case_edit==INPUT_PIN1) || + (edt_data->pin_case_edit==INPUT_PIN2) || + (edt_data->pin_case_edit==INPUT_NEW_PIN) || + (edt_data->pin_case_edit==INPUT_NEW_PIN_AGAIN) || + (edt_data->pin_case_edit==INPUT_NEW_PIN2) || + (edt_data->pin_case_edit==INPUT_NEW_PIN2_AGAIN)) && + (edt_data->editor_index>=8) && + (!edt_data->gsm_state)) + + return MFW_EVENT_CONSUMED; + else + { + if(kc->code EQ KCD_STAR) + edt_data->pin[edt_data->editor_index] = STAR; + else + edt_data->pin[edt_data->editor_index] = '0' + kc->code; + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, '*', TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,'*');/* hide security code */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index++; + check_set_pins(win,edt_data); /* digits check depends on status pin_case */ + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + } + winShow(edt_data->pin_edt_win); + break; + + case KCD_HASH: + case KCD_LEFT: + + if(pin_emergency_call == TRUE) + { + callNumber((UBYTE *)pin_emerg_call); + pin_emergency_call = FALSE; + } + + /* If it's a hash, insert it into the editor */ + + // change by Sasken ( Rashmi C N) on March 25th 2004 + // Issue Number : MMI-SPR-15692 + // Subject: Wrong entry in last dialed number. + // Bug : While saving PIN, if a hash is entered as a + // delimiter/terminater, the hash is also getting stored + // as a part of pin. This makes it mandatory for the user + // to enter hash as delimiter/terminater while he is authenticating. + // Solution: Avoid copying the hash(delimiter/terminater) in to the pin array. + // Commenting the copying part below in the "if" block. + + // If it's a hash, insert it into the editor + //if(kc->code EQ KCD_HASH) + //xrashmic 1 Jul, 2006 OMAPS00075784 + //To fix the reset while entering the gsm sequence for unblocking + // the pin1 or pin2 + if(!(strncmp((char*)edt_data->pin,"**052*",IDENT_GSM_2))||!(strncmp((char*)edt_data->pin,"**05*",IDENT_GSM_1))) + + { + edt_data->pin[edt_data->editor_index] = HASH; + // SPR#1428 - SH - New Editor changes +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, edt_data->pin[edt_data->editor_index], TRUE); +#else // NEW_EDITOR + edtChar(edt_data->editor_handle,edt_data->pin[edt_data->editor_index]); +#endif // NEW_EDITOR + edt_data->editor_index++; + } + + + + // We save the pin2 entered in to this global variable which we + // use while calling sAT_PlusCLCK(), while locking or unlocking ALS. + memset(g_pin2,0,MAX_PIN+1); + if(edt_data->pin_case_edit EQ INPUT_PIN2 || edt_data->pin_case_edit EQ INPUT_NEW_PIN2) + strncpy(g_pin2,(char*)edt_data->pin,MAX_PIN);//xvilliva SPR17291 + switch(edt_data->pin_case_edit) + { +#ifdef SIM_PERS + case INPUT_SIM_PLOCK: + case INPUT_SIM_FCPWD: + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case INPUT_SIM_MKPWD: + +#endif + /* PIN1 and PIN2 */ + case INPUT_PIN1:/* finish of PIN entering */ + case INPUT_PIN2: + TRACE_EVENT_P1("pin_emergency_call = %d", pin_emergency_call); + TRACE_EVENT("When 'Call' is pressed!"); + + /* PIN is long enough, finish editing */ + + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array(edt_data); /* clear editor array */ + timer = FALSE; + strncpy((char*)edt_data->old_pin,(char*)edt_data->pin,MAX_PIN); + strncpy((char*)pin_data->old_pin, (char*)edt_data->old_pin,MAX_PIN); + if(edt_data->pin_case_edit EQ INPUT_PIN1) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,PIN1_END,0,pin_data); + } + +#ifdef SIM_PERS + else if(edt_data->pin_case_edit EQ INPUT_SIM_PLOCK) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SIM_PLOCK_END,0,pin_data); + } + + else if(edt_data->pin_case_edit EQ INPUT_SIM_FCPWD) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SIM_FCPWD_END,0,pin_data); + } + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + else if(edt_data->pin_case_edit EQ INPUT_SIM_MKPWD) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SIM_MKPWD_END,0,pin_data); + } + +#endif + else + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,PIN2_END,0,pin_data); + } + } + else + { + if(kc->code EQ KCD_HASH) + { + if (!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PIN1) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + /* PUK1 and PUK2 */ + + case INPUT_PUK1: + case INPUT_PUK2: + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) /* finish of PUK entering */ + { + clear_edit_array (edt_data); /* clear editor array */ + timer = FALSE; + strncpy((char*)edt_data->puk,(char*)edt_data->pin,MAX_PIN);/* store puk */ + strncpy((char*)pin_data->puk, (char*)edt_data->puk,MAX_PIN); + if( pin_data->pin_case EQ INPUT_PUK1) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN,0,pin_data);/* entering new pin1 start*/ + } + else + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN2,0,pin_data);/* entering new pin2 start*/ + } + } + else + { + if(kc->code EQ KCD_HASH) + { + if (!(edt_data->gsm_state))/* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + case INPUT_NEW_PIN: + case INPUT_NEW_PIN2: + + #ifdef SIM_PERS + case INPUT_NEW_SIM_PLOCK: + #endif + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array (edt_data); /* clear editor array */ + timer = FALSE; + strncpy((char*)edt_data->new_pin, (char*)edt_data->pin,MAX_PIN); /* store new pin */ + strncpy((char*)pin_data->new_pin, (char*)edt_data->new_pin,MAX_PIN); + if(pin_data->pin_case EQ INPUT_NEW_PIN ) + { + set_pin_edt_destroy(edt_data->pin_edt_win); /* entering new pin1 again*/ + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN_AGAIN,0,pin_data); + } + + #ifdef SIM_PERS + else if(pin_data->pin_case EQ INPUT_NEW_SIM_PLOCK) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_SIM_PLOCK_AGAIN,0,pin_data); + } + #endif + else + { + set_pin_edt_destroy(edt_data->pin_edt_win); /* entering new pin1 again*/ + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN2_AGAIN,0,pin_data); + } + } + else + { + if(kc->code EQ KCD_HASH) + { + if(!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + + if(edt_data->pin_case_edit EQ INPUT_NEW_PIN) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + #ifdef SIM_PERS + case INPUT_NEW_SIM_PLOCK_AGAIN: + #endif + case INPUT_NEW_PIN_AGAIN: + case INPUT_NEW_PIN2_AGAIN: + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array (edt_data); /* clear editor array */ + timer = FALSE; + if(strcmp((char*)edt_data->pin, (char*)pin_data->new_pin) EQ 0) /* compare PINs successfull*/ + { + strncpy((char*)pin_data->new_pin, (char*)edt_data->pin,MAX_PIN); + if(pin_data->pin_case EQ INPUT_NEW_PIN_AGAIN) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,NEW_PIN_END,0,pin_data);/* changing PIN1 */ + } + #ifdef SIM_PERS + else if (pin_data->pin_case EQ INPUT_NEW_SIM_PLOCK_AGAIN) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win, NEW_SIM_PLOCK_END,0,pin_data); + } + #endif + else + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,NEW_PIN2_END,0,pin_data);/* changing PIN2 */ + } + } + else + { /* new PIN != new PIN again */ + + if(pin_data->pin_case EQ INPUT_NEW_PIN_AGAIN) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,NEW_PIN_FAIL,0,NULL); + } + #ifdef SIM_PERS + else if(pin_data->pin_case EQ INPUT_NEW_SIM_PLOCK_AGAIN) + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,NEW_SIM_PLOCK_FAIL,0,NULL); + } + #endif + else + { + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,NEW_PIN2_FAIL,0,NULL); + } + } + } + else + { + if(kc->code EQ KCD_HASH) + { + if (!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + if(edt_data->pin_case_edit EQ INPUT_NEW_PIN_AGAIN) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + default: + break; + } + break; + +/* KCD_HUP */ + case KCD_HUP: + if( edt_data->pin_case_edit != INPUT_PUK1)//xvilliva SPR13623 + { + clear_edit_array(edt_data); + timer = FALSE; + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SETT_ABORT,0,NULL); // abort settings menu + } + break; + +/* KCD RIGHT */ + + case KCD_RIGHT: + //nm, go back to the submenu if there is no character on the screen + if(strlen((char*)edt_data->pin) == 0 && edt_data->pin_case_edit != INPUT_PUK1)//xvilliva SPR13623 + { + clear_edit_array(edt_data); + timer = FALSE; + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,SETT_ABORT,0,NULL); // abort settings menu + return 1; + } + + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ +#endif /* NEW_EDITOR */ + + if(strlen((char*)edt_data->pin)<MIN_PIN) + { + } + + edt_data->emergency_call = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PUK1) /* special case ?? */ + winShow(edt_data->pin_edt_win); + else + { + check_set_pins(win,edt_data); /* check remain for emergency call */ + winShow(edt_data->pin_edt_win); + } + break; + + default: + break; + } + } +#ifdef SIM_PERS + else + { + switch(kc->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_6: + case KCD_8: + case KCD_9: + if(edt_data->editor_index < MAX_DIG) + { + edt_data->pin[edt_data->editor_index] = '0' + kc->code; + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, '*', TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,'*');/* hide security code */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index++; + check_set_pins(win,edt_data); /* digits check depends on status pin_case */ + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + winShow(edt_data->pin_edt_win); + break; + + + case KCD_LEFT: + + if(pin_emergency_call == TRUE) + { + callNumber((UBYTE *)pin_emerg_call); + pin_emergency_call = FALSE; + } + break; + + case KCD_RIGHT: + +// if( edt_data->edtbuf == '\0' ) +// break; + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ +#endif /* NEW_EDITOR */ + + if(strlen((char*)edt_data->pin)<MIN_PIN) + { + } + + edt_data->emergency_call = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PUK1) /* special case ?? */ + winShow(edt_data->pin_edt_win); + else + { + check_set_pins(win,edt_data); /* check remain for emergency call */ + winShow(edt_data->pin_edt_win); + } + break; + + default: + break; + } + } +#endif /* SIM_PERS */ + if (timer) + tim_start(edt_data->tim_out_handle);/* start timer for entering */ + return 1; +} + + + +/******************************************************************************* + + $Function: set_pin_edt_kbd_long_cb + $Description: Callback function for keyboard long + $Returns: status int + $Arguments: event, keyboard control block +*******************************************************************************/ +static int set_pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + TRACE_FUNCTION("MmiPins:set_pin_edt_kbd_long_cb"); + + if ((event & KEY_CLEAR) && (event & KEY_LONG)) + { + timStop(edt_data->tim_out_handle); /* stop entering timer */ + clear_edit_array(edt_data); + memset(edt_data->pin,'\0',sizeof(edt_data->pin));/* initial string */ + + /* SPR#1428 - SH - New Editor: string changed, update word-wrap*/ + #ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); + #endif /* NEW_EDITOR */ + edt_data->editor_index = 0; + edt_data->emergency_call = FALSE; + winShow(edt_data->pin_edt_win); + } + + return MFW_EVENT_CONSUMED; +} + +/******************************************************************************* + + $Function: check_set_pins + $Description: check input string for settings + $Returns: void + $Arguments: window pin editor attributes +*******************************************************************************/ +static void check_set_pins (T_MFW_HND win,void * edt_pin) +{ + T_pin_edt * edt_data = (T_pin_edt *)edt_pin; + + TRACE_FUNCTION("MmiPins: check_set_pins"); + + if(strlen((char*)edt_data->pin)NEQ 0) + { + if (strlen((char*)edt_data->pin) > FIRST_DIGIT) /* for every character */ + gsm_set_test(win,edt_data); /* test if GSM string or not*/ + /*API - 10/10/02 - 1162 - check the value entered into the PIN editor to see if the + value being entered in is an emergency number. + */ + if (strlen((char*)edt_data->pin) EQ (MIN_PIN - 1) || strlen((char*)edt_data->pin) EQ (MIN_PIN -2)) + { + TRACE_FUNCTION("cm_check_emergency() TRACE PINS 1"); + if(cm_check_emergency((U8*)edt_data->pin))/* test emergency call*/ + { + edt_data->emergency_call = TRUE; + pin_emergency_call = TRUE; + memset(pin_emerg_call, '\0',sizeof(pin_emerg_call)); + strcpy((char *)pin_emerg_call, (char *)edt_data->pin); + } + else + { +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if((edt_data->pin_case_edit EQ CARD_REJECTED) OR (edt_data->pin_case_edit EQ INSERT_CARD) + OR (edt_data->pin_case_edit EQ SHOW_IMEI_INVALID) +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + OR(edt_data->pin_case_edit EQ NO_MEPD_DATA) +#endif + ) + { /* delete all digits */ + clear_edit_array (edt_data); /* clear editor array */ + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + edt_data->editor_index = 0; + } + edt_data->emergency_call = FALSE; + pin_emergency_call = FALSE; + } + } + else + { +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if((edt_data->pin_case_edit EQ CARD_REJECTED) OR (edt_data->pin_case_edit EQ INSERT_CARD) + OR (edt_data->pin_case_edit EQ SHOW_IMEI_INVALID) +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + OR (edt_data->pin_case_edit EQ NO_MEPD_DATA) +#endif + ) + { /* delete all digits */ + clear_edit_array (edt_data); /* clear editor array */ + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + edt_data->editor_index = 0; + } + edt_data->emergency_call = FALSE; + pin_emergency_call = FALSE; + } + /*SPR 2145, if entering PIN1, then make sure no more than 8 characters are entered*/ + if(((strlen((char*)edt_data->pin) > MAX_PIN) || /*no more than 16 digits allowed*/ + (edt_data->pin_case_edit EQ INPUT_PIN1 && strlen((char*)edt_data->pin) > MAX_PIN_EN_DIS ))/*PIN1 should be no more than 8 digits*/ + && !(edt_data->gsm_state)) /*allowed up to 30 digits if entering GSM string*/ + { + + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ +#endif /* NEW_EDITOR */ + } + } +} + + + +/******************************************************************************* + + $Function: sett_pin_mess + $Description: help function for message dialog + $Returns: void + $Arguments: window, event +*******************************************************************************/ +static void sett_pin_mess(T_MFW_HND win,USHORT event) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_mess_win; + TRACE_FUNCTION("MmiPins:sett_pin_mess"); + + pin_mess_win = set_pin_mess_create(pin_data->pin_win); + if(pin_mess_win) + { + SEND_EVENT(pin_mess_win,event,0,pin_data); + } +} + + +/******************************************************************************* + + $Function: set_pin_mess_create + $Description: Creation of an instance for the PIN Message dialog settings + Type of dialog : SINGLE_DYNAMIC + $Returns: void + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND set_pin_mess_create(T_MFW_HND parent_window) +{ + T_pin_mess * data = (T_pin_mess *)ALLOC_MEMORY (sizeof (T_pin_mess)); + T_MFW_WIN * win; + + data->pin_mess_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)set_pin_mess_win_cb); + + TRACE_FUNCTION("MmiPins: set_pin_mess_create"); + + if (data->pin_mess_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)set_pin_messages; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_mess_win)->data; + win->user = (void *) data; + + /* + * return window handle + */ + return data->pin_mess_win; +} + + +/******************************************************************************* + + $Function: set pin_mess_destroy + $Description: Destroy the pin message dialog settings + $Returns: void + $Arguments: window +*******************************************************************************/ +void set_pin_mess_destroy (T_MFW_HND own_window) +{ + T_pin_mess * data; + T_MFW_WIN * win; + + + TRACE_FUNCTION("MmiPins: set_pin_mess_destroy"); + + if (own_window) + { + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_mess *)win->user; + + if(data) + { + + /* + * Delete WIN Handler + */ + win_delete (data->pin_mess_win); + FREE_MEMORY((void*)data,(sizeof(T_pin_mess))); + } + } +} + + +/******************************************************************************* + + $Function: set_pin_mess_win_cb + $Description: Callback function for message windows + $Returns: void + $Arguments: event, window +*******************************************************************************/ +static int set_pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + /* + * Top Window has no output + */ + return 1; +} + + +/******************************************************************************* + + $Function: set_pin_messages + $Description: Message Dialog for PIN/PUK handling in settings + $Returns: void + $Arguments: win, event, value, parameter +*******************************************************************************/ +void set_pin_messages(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_mess * mess_data = (T_pin_mess *)win_data->user; + + T_DISPLAY_DATA display_info; + +// U8 uMode; /* Warning Correction */ + + T_MFW_SIM_PIN_STATUS status; //need to check the Pin 1 status + + T_pin * pin_data = (T_pin *)parameter; +#ifdef SIM_PERS +T_MFW status1 = 0, status2; + int max=0,max1=0; + int curr= 0,curr1=0; +#endif + TRACE_FUNCTION("Mmi.Pins:set_pin_messages"); + + /* + * depending on signal + */ + + switch (event) + { + case PIN1_REQ_ATT: + case PIN2_REQ_ATT: + case PUK1_REQ_VER_INFO: + case GSM_FAIL: + case NEW_PIN_FAIL: + case NEW_PIN2_FAIL: + case PIN_OK_INFO: + case PIN1_CH_SUCC: + case PIN2_CH_SUCC: + case PUK1_UNBL_FAIL_INFO: + case PUK1_UNBL_SUCC: + case PUK1_UNBL_FATAL_ERROR: + case PIN1_ENAB_END: + case PIN1_DISAB_END: + case PIN1_ENDIS_FAIL: +#ifdef SIM_PERS + case SIM_LOCK_ENDIS_FAIL: + case SIM_LOCK_ENDSUCC: + case SIM_LOCK_FCPWD_FAIL: + case SIM_LOCK_FCPWDSUCC: + case SIM_LOCK_STATUS: + case NEW_SIM_PLOCK_FAIL: + case SIM_LOCK_NEW_ENDSUCC: + case SIM_LOCK_NEW_ENDISFAIL: + case SIM_LOCK_NEW_ENDSUCC_CKEY: + case SIM_LOCK_ALREADY_ENDIS: + case SIM_LOCK_SIM_REM: + case SMLK_SHOW_FC_FAIL1: +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SIM_LOCK_MKPWD_FAIL: //Master unlock failed + case SIM_LOCK_MKPWDSUCC: //Master unlock success + case SIM_LOCK_BUSY: //Category unlock return with Busy error from ACI + //x0pleel 26 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SIM_LOCK_BUSY_UNBLOCK: //ME unblock return Busy error from aCI +#endif + case FDN_FAIL: + case FDN_ACT_END: + case FDN_DEACT_END: + case PIN1_STATUS: + case PIN2_SIM_FAILURE: // Marcus: Issue 1609: 23/01/2003 - failure to verify PIN2 + + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNull, TxtNull, COLOUR_STATUS_PINS); + + switch(event) + { + case PIN1_REQ_ATT: + pin_data->pin_case = PIN1_REQ_OLD; + display_info.TextId = TxtPINFail; + if(pin_data->pin_retries EQ 1) + display_info.TextId2 = TxtOneAttemptLeft; + else + display_info.TextId2 = TxtTwoAttemptsLeft; + break; + case PIN2_REQ_ATT: + pin_data->pin_case = PIN2_REQ; + display_info.TextId = TxtPINFail; + if(pin_data->pin_retries EQ 1) + display_info.TextId2 = TxtOneAttemptLeft; + else + display_info.TextId2 = TxtTwoAttemptsLeft; + break; + case PIN1_CH_SUCC: + pin_data->pin_case = PIN1_CH_END; + display_info.TextId = TxtChangPin; + break; + case PIN2_CH_SUCC: + pin_data->pin_case = PIN2_CH_END; + display_info.TextId = TxtChangPIN2; + break; +#ifdef SIM_PERS + case SIM_LOCK_NEW_ENDSUCC: + pin_data->pin_case = SIM_LOCK_NEW_ENDSUCC; + display_info.TextId = TxtPsLockChanged; + break; + + case SIM_LOCK_ENDSUCC: + pin_data->pin_case = SIM_LOCK_ENDSUCC; + if(pin_data->set_state == ENABLE) + display_info.TextId = TxtLockActivated; + else if(pin_data->set_state == DISABLE) + display_info.TextId = TxtLockDeactivated; + break; + + case SIM_LOCK_ALREADY_ENDIS: + pin_data->pin_case = SIM_LOCK_ALREADY_ENDIS; + if(pin_data->set_state == ENABLE) + display_info.TextId = TxtAlreadyLocked; + else if(pin_data->set_state == DISABLE) + display_info.TextId = TxtAlreadyUnlocked; + break; + + case SIM_LOCK_NEW_ENDSUCC_CKEY: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + TRACE_FUNCTION("BMI:SIM_LOCK_NEW_ENDSUCC_CKEY"); + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + pin_data->pin_case = SIM_LOCK_NEW_ENDSUCC_CKEY; + sprintf((char*)buf1,"%d attempts left",curr_succ_reset); + sprintf((char*)buf2,"%s", "FC Reset-Success"); + display_info.TextString= buf1; + display_info.TextString2 = buf2; + } + break; + + case SMLK_SHOW_FC_FAIL1: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + pin_data->pin_case = PUK1_REQ; + sprintf((char*)buf1,"%d attempts left",curr_fail_reset); + sprintf((char*)buf2,"%s", "FC Reset-Failure"); + display_info.TextString= buf1; + display_info.TextString2 = buf2; + break; + } + + case SIM_LOCK_FCPWDSUCC: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + sprintf((char*)buf1,"%d attempts left",curr_succ_reset); + sprintf((char*)buf2,"%s", "FC Reset-Success"); + display_info.TextString= buf2; + display_info.TextString2 = buf1; + } + break; + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays a dialog saying "master unlock success" + case SIM_LOCK_MKPWDSUCC: + { + char buf1[25]; + sprintf((char*)buf1,"%s"," Master Unlock Success"); + display_info.TextString= buf1; + display_info.TextString2 = 0; + } + break; +#endif + + case PUK1_REQ_VER_INFO: + if((pin_data->set_state EQ CHANGE_PIN2) || + (pin_data->set_state EQ PIN2_CHECK) || + (pin_data->set_state EQ FDN_ACTIV) || + (pin_data->set_state EQ FDN_DEACTIV)) + { + pin_data->pin_case = PUK2_REQ; + } + else + { + pin_data->pin_case = PUK1_REQ; + } + display_info.TextId =TxtPINBlock; + break; + + case GSM_FAIL: + if(pin_data->set_state EQ IDLE_GSM) + pin_data->pin_case = IDLE_GSM_FAIL; + display_info.TextId = TxtNotAcc; + break; + } + switch(event) + { + case PUK1_UNBL_FATAL_ERROR: + if((pin_data->set_state EQ CHANGE_PIN2) || + (pin_data->set_state EQ FDN_ACTIV) || + (pin_data->set_state EQ FDN_DEACTIV)) + { + pin_data->pin_case = PUK2_REQ; + } + else if(pin_data->set_state == IDLE_GSM) + pin_data->pin_case = IDLE_GSM_FAIL; + else + { + pin_data->pin_case = PUK1_REQ; + } + display_info.TextId = TxtNotAcc; + break; + case NEW_PIN_FAIL: + pin_data->pin_case = INPUT_NEW_PIN; + display_info.TextId = TxtNewPIN; + display_info.TextId2 = TxtCodeInc; + break; + case NEW_PIN2_FAIL: + pin_data->pin_case = INPUT_NEW_PIN2; + display_info.TextId = TxtNewPIN2; + display_info.TextId2 = TxtCodeInc; + break; + case PIN_OK_INFO: + TRACE_FUNCTION("PIN_OK_INFO"); + pin_data->pin_case = PIN_OK; + display_info.TextId = TxtPINOK; + break; + case PUK1_UNBL_FAIL_INFO: + if((pin_data->set_state EQ CHANGE_PIN2) || + (pin_data->set_state EQ PIN2_CHECK) || + (pin_data->set_state EQ FDN_ACTIV) || + (pin_data->set_state EQ FDN_DEACTIV)) + { + pin_data->pin_case = PUK2_REQ; + + } + else if(pin_data->set_state EQ IDLE_GSM) + { + pin_data->pin_case = IDLE_GSM_FAIL; + + } + else + { + pin_data->pin_case = PUK1_REQ; + + } + + display_info.TextId2 = TxtCodeInc; + + break; + case PUK1_UNBL_SUCC: + if((pin_data->set_state EQ CHANGE_PIN2) || + (pin_data->set_state EQ PIN2_CHECK) || + (pin_data->set_state EQ FDN_ACTIV) || + (pin_data->set_state EQ FDN_DEACTIV)) + display_info.TextId = TxtNewPIN2; + else + display_info.TextId = TxtNewPIN; + pin_data->pin_case = UNBL_OK; + display_info.TextId2 = TxtChanged; + break; + case PIN1_ENAB_END: + pin_data->pin_case = UNBL_OK; + pin_data->set_state = DEFAULT; + display_info.TextId = TxtPinCode; + display_info.TextId2 = TxtActivated; + break; + case PIN1_DISAB_END: + pin_data->pin_case = UNBL_OK; + pin_data->set_state = DEFAULT; + display_info.TextId = TxtPinCode; + display_info.TextId2 = TxtDeActivated; + break; + case FDN_ACT_END: + pin_data->pin_case = FDN_UNBL_OK; + display_info.TextId = TxtActivated; + break; + case FDN_DEACT_END: + pin_data->pin_case = FDN_UNBL_OK; + display_info.TextId = TxtDeActivated; + break; + case FDN_FAIL: + pin_data->pin_case = UNBL_OK; + display_info.TextId = TxtFailed; + break; + case PIN1_ENDIS_FAIL: + pin_data->pin_case = PIN1_REQ; + display_info.TextId = TxtPINFail; + if(pin_data->pin_retries EQ 1) + display_info.TextId2 = TxtOneAttemptLeft; + else + display_info.TextId2 = TxtTwoAttemptsLeft; + break; +#ifdef SIM_PERS + case NEW_SIM_PLOCK_FAIL: + pin_data->pin_case = INPUT_NEW_SIM_PLOCK; + display_info.TextId = TxtPsLockConfWrong; + display_info.TextId2 = TxtPsLockConfwrong2; + break; + case SIM_LOCK_NEW_ENDISFAIL: + { + int max=0; + int curr= 0; + char buf[20]; + pin_data->pin_case = FAILURE_PASS_CHG; + mfw_simlock_check_status(mmi_simlock_locktype,&max,&curr); + if( max != 0xff) + { + sprintf((char*)buf,"%d tries left",(curr)); + display_info.TextId = TxtCodeInc; + display_info.TextString2 = (char*)buf; + display_info.Identifier = pin_data->pin_case; + } + else + display_info.TextId = TxtCodeInc; + + } + //display_info.TextId=TxtPassword; + //display_info.TextId2 = TxtPassfailed; + break; + case SIM_LOCK_STATUS: + pin_data->pin_case = SIM_LOCK_STATUS; + switch(mfw_simlock_get_lock_status(mmi_simlock_locktype)) + { + case MFW_SIM_DISABLE:display_info.TextId = TxtLockDisabled;break; + case MFW_SIM_ENABLE:display_info.TextId = TxtLockEnabled; break; + case MFW_SIM_BLOCKED:display_info.TextId = TxtBlckPerm;break; + case MFW_SIM_FAILURE:display_info.TextId = TxtFailed;break; + } + break; + + case SIM_LOCK_SIM_REM: + display_info.TextId=TxtNoCard; + break; + + case SIM_LOCK_ENDIS_FAIL: + if(pin_data->set_state EQ DISABLE) + { + + char buf[20]; + + status1 = mfw_simlock_check_status(mmi_simlock_locktype,&max,&curr); + if(status1 != MFW_SIM_BLOCKED && status1 != MFW_SIM_PERM_BLOCKED && ( max != 0xff)) + { + pin_data->pin_case = TXT_SIM_LOCK_ALL; + dlg_initDisplayData_TextStr(&display_info,TxtNull,TxtNull,NULL,NULL, COLOUR_STATUS_PINS); + TRACE_EVENT(" status is not blocked"); + TRACE_EVENT_P2("The current and max value are %d and %d",curr,max); + sprintf((char*)buf,"%d tries left",(curr)); + display_info.TextId = TxtCodeInc; + display_info.TextString2 = (char*)buf; + display_info.Identifier = pin_data->pin_case; + } + else + display_info.TextId = TxtCodeInc; + + //display_info.TextId = TxtPsLockWrong; + } + else + { + display_info.TextId = TxtCodeInc; + } + break; + + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays a dialog saying "Busy" + case SIM_LOCK_BUSY: + pin_data->pin_case = TXT_SIM_LOCK_ALL; + display_info.TextId = TxtBusy; + break; + + + //x0pleela 26 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays a dialog saying "Busy" for wrong entry of unblocking password + case SIM_LOCK_BUSY_UNBLOCK: + pin_data->pin_case =PUK1_REQ ; + display_info.TextId = TxtBusy; + break; + + case SIM_LOCK_FCPWD_FAIL: + { + char buf1[20], buf2[20] ; + int curr_fail_reset, curr_succ_reset; + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + sprintf((char*)buf1,"%d attempts left",curr_fail_reset); + sprintf((char*)buf2,"%s", "FC Reset-Failure"); + display_info.TextString= buf2; + display_info.TextString2 = buf1; + break; + } + /* display_info.TextId = TxtCodeInc; + break;*/ + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Displays a dialog saying "master unlock failed" + case SIM_LOCK_MKPWD_FAIL: + { + char buf1[25] ; + sprintf((char*)buf1,"%s" , "Master Unlock Failed"); + display_info.TextString= buf1; + display_info.TextString2 = 0; + break; + } +#endif + + + case PIN1_STATUS: + pin_data->pin_case = PIN1_STATUS; + + + + TRACE_FUNCTION("set_pin_messages:check the pinrequest status"); + + status.type = MFW_SIM_PIN1;//check the PIN1 + sim_pin_status(&status); + + if(status.set EQ MFW_SIM_DISABLE) /*Display the "Disabled Pin1 */ + { + display_info.TextId = TxtDisabled; + } + else + { + display_info.TextId = TxtEnabled; /*Display the "Enabled Pin1 */ + } + + + + display_info.TextId2 = 0; + display_info.TextString2 = 0; + break; + + /* Marcus: Issue 1609: 23/01/2003: Start */ + case PIN2_SIM_FAILURE: + /* + * Failure to verify PIN2. Display + * PIN2 Code + * Not Available + * Then cancel back to the menu. + */ + pin_data->pin_case = SETT_ABORT; + display_info.TextId = TxtPin2Code; + display_info.TextId2 = TxtNotAvailable; + display_info.TextString2 = 0; + break; + /* Marcus: Issue 1609: 23/01/2003: End */ + + } + +#ifdef SIM_PERS + TRACE_EVENT_P1(" Status Bef: %d", status1); + status1 = mfw_simlock_check_status(mmi_simlock_locktype,&max,&curr); + status2 = mfw_simlock_check_status(0,&max1,&curr1); + TRACE_EVENT_P1("Status Aft: %d", status1); + + if(((event==SIM_LOCK_NEW_ENDISFAIL)||(event == SIM_LOCK_ENDIS_FAIL)) && (curr == 0)) + { + TRACE_EVENT("SIM_LOCK_ENDIS_FAIL,MFW_SIM_BLOCKED"); + pin_data->puk_request = TRUE; + C_KEY_REQ=1; + FCUnlock_flag=1; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else if(status2 == MFW_SIM_PERM_BLOCKED) + { + TRACE_EVENT("MFW_SIM_PERM_BLOCKED"); + //pin_data->puk_request = TRUE; + //C_KEY_REQ=1; + //FCUnlock_flag=1; + perm_blocked =1; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,0); + } + else +#endif /*SIM_PERS*/ + { + if (display_info.TextId2 == TxtOneAttemptLeft) + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)set_pin_info_cb, FIVE_SECS, KEY_LEFT ); + else + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)set_pin_info_cb, THREE_SECS, KEY_LEFT ); + + display_info.Identifier = pin_data->pin_case; + set_pin_mess_destroy(mess_data->pin_mess_win); + + info_dialog(pin_data->pin_win,&display_info); //information screen + // Nov 03, 2005 DR: OMAPS00052032 - xpradipg + dspl_Enable(1); + } +break; + +#ifdef SIM_PERS + case PERM_BLK: + TRACE_FUNCTION("Enter PERM_BLK"); + pin_data->display_id1 = TxtPhoneBlocked; + pin_data->display_id2 = TxtDealer; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,ME_PERM_BLK,0,pin_data); + break; + + +#endif + case PUK1_REQ: + TRACE_FUNCTION("Enter PUK_REQ"); +#ifdef SIM_PERS + if( C_KEY_REQ ) + pin_data->display_id1 = TxtUnblockCode; + else + +#endif + pin_data->display_id1 = TxtEnterPuk1; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PUK1,0,pin_data); + break; + case PIN1_REQ: + TRACE_FUNCTION(">>>TEXT ID CALLED"); + pin_data->display_id1 = TxtEnterPin1; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PIN1,0,pin_data); + break; + +#ifdef SIM_PERS + case TXT_SIM_LOCK_ALL: + switch(mmi_simlock_locktype) + { + case MFW_SIM_NLOCK: + pin_data->display_id1 = TxtEnterNLock; + break; + case MFW_SIM_SPLOCK: + pin_data->display_id1 = TxtEnterSpLock; + break; + case MFW_SIM_NSLOCK: + pin_data->display_id1 = TxtEnterNsLock; + break; + case MFW_SIM_CLOCK: + pin_data->display_id1 = TxtEnterCLock; + break; + case MFW_SIM_PLOCK: + pin_data->display_id1 = TxtEnterPsLock; + break; + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //Prompting user to enter Blocked Network password + case MFW_SIM_PBLOCK: + pin_data->display_id1 = TxtEnterPbLock; + break; + } + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PLOCK,0,pin_data); + break; + + case SIM_LOCK_REQ_FCPWD: + pin_data->display_id1 = TxtPassword; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_FCPWD,0,pin_data); + break; +//x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + case SIM_LOCK_REQ_MKPWD: + pin_data->display_id1 = TxtEnterMasterKey; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_MKPWD,0,pin_data); + break; +#endif + case PUK2_REQ: + pin_data->display_id1 = TxtEnterPuk2; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PUK2,0,pin_data); + break; + case PIN2_REQ: + pin_data->display_id1 = TxtEnterPin2; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PIN2,0,pin_data); + break; + case INPUT_NEW_PIN: +#ifdef SIM_PERS + if(C_KEY_REQ) + { + + int sta; + int curr_fail_reset, curr_succ_reset; + + + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if( curr_succ_reset ) + { + if( FCUnlock_flag) + sta=mfw_simlock_reset_fc_value((U8*)pin_data->puk,MFW_SIM_FCM) ; + else + sta=mfw_simlock_reset_fc_value((U8*)pin_data->puk,MFW_SIM_FC) ; + + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + TRACE_EVENT_P1("Input_new_pin: %d", sta); + TRACE_EVENT_P1("set_pin_messages: C_KEY_REQ: %d", C_KEY_REQ); + + if(sta== MFW_SS_OK) + { + if(FCUnlock_flag) + FCUnlock_flag=0; + + C_KEY_REQ=0; + TRACE_EVENT_P1("set_pin_messages: C_KEY_REQ: %d", C_KEY_REQ); + TRACE_EVENT("set_pin_messages: SIM_LOCK_NEW_ENDSUCC_CKEY: "); + pin_data->puk_request = FALSE; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,SIM_LOCK_NEW_ENDSUCC_CKEY,0,pin_data); + } + else if(sta==MFW_SS_FAIL ) //UNBLOCK_FAILURE + { + TRACE_EVENT("set_pin_messages: SMLK_SHOW_FC_FAIL1: "); + set_pin_mess_destroy(mess_data->pin_mess_win); + + + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //Check for Ext_ERR_Busy and send the event accordingly to display a dialog "Busy" + //for wrong entry of unblock code + if( ( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + { + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY_UNBLOCK,0,pin_data); + } + + //x0pleela 27 Apr, 2006 DR: OMAPS00067919 + //To avoid executing this during bootup sequence + else if( curr_fail_reset != 0) + SEND_EVENT(pin_data->pin_win,SMLK_SHOW_FC_FAIL1,0,pin_data); + + else + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + } + } + else +#endif + { + pin_data->display_id1 = TxtEnterNewPin; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PIN,0,pin_data); + } + break; + case INPUT_NEW_PIN2: + pin_data->display_id1 = TxtNewPIN2; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PIN2,0,pin_data); + break; + case INPUT_NEW_PIN_AGAIN: + pin_data->display_id1 = TxtConfPin; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PIN_AGAIN,0,pin_data); + break; + case INPUT_NEW_PIN2_AGAIN: + pin_data->display_id1 = TxtConfPin2; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PIN_AGAIN2,0,pin_data); + break; + case PIN1_REQ_OLD: + pin_data->display_id1 = TxtOldPIN; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PIN1,0,pin_data); + break; + case PIN2_REQ_OLD: + pin_data->display_id1 = TxtOldPIN2; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PIN2,0,pin_data); + break; + case FDN_ACTIVATED: + pin_data->display_id1 = TxtPleaseWait;//TxtActivated; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,FDN_WAIT,0,pin_data); + break; + case ADN_ACTIVATED: + pin_data->display_id1 = TxtPleaseWait;//TxtDeActivated; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,FDN_WAIT,0,pin_data); + break; +#ifdef SIM_PERS + case SIM_LOCK_REQ_OLD: + pin_data->display_id1 = TxtEnterOldPsLock; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PLOCK,0,pin_data); + break; + case SIM_LOCK_REQ_NEW: + pin_data->display_id1 = TxtEnterPsLockNew; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_SIMLOCK,0,pin_data); + break; + case INPUT_NEW_SIM_PLOCK_AGAIN: + pin_data->display_id1 = TxtEnterPsLockconf; + set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_SIMLOCK_AGAIN,0,pin_data); + break; +#endif + default: + break; + } + +} + + +/******************************************************************************* + + $Function: set_pin_info_cb + $Description: settings pin information screen call back + $Returns: void + $Arguments: win, identifier, reason +*******************************************************************************/ +void set_pin_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reasons) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + TRACE_FUNCTION("MmiPins: set_pin_info_cb"); + + switch(identifier) + { + + case PIN_OK: + SEND_EVENT(pin_data->pin_win,PIN_OK_END,0,NULL);//PIN was needed + break; + case PIN1_STATUS: + SEND_EVENT(pin_data->pin_win,PIN1_STATUS_END,0,NULL); + break; + case UNBL_OK: + case PIN1_REQ: + case PIN2_REQ: + case PUK1_REQ: + case PUK2_REQ: + case INPUT_NEW_PIN: + case INPUT_NEW_PIN2: + case PIN1_CH_END: + case PIN2_CH_END: + case FDN_UNBL_OK: + case PIN1_REQ_OLD: + case PIN2_REQ_OLD: + case IDLE_GSM_FAIL: + case SETT_ABORT: // Marcus: Issue 1609: 23/01/2003 + SEND_EVENT(pin_data->pin_win,identifier,0,NULL);//pin_main data !! + break; + default: + switch (reasons) + { + case INFO_KCD_LEFT: + case INFO_KCD_RIGHT: + + case INFO_TIMEOUT: +#ifdef SIM_PERS + { + pin_skClear(); + setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + } + +#else + dspl_ClearAll(); +#endif /* SIM_PERS*/ + break; + } + break; + } + +} + +/******************************************************************************* + + $Function: gsm_set_test + $Description: test if gsm string + $Returns: status int + $Arguments: win, pin editor attributes +*******************************************************************************/ +static int gsm_set_test(T_MFW_HND win,void * edt_pin) +{ + int status; + T_pin_edt * edt_data = (T_pin_edt *)edt_pin; + + +// T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; /* Warning Correction */ + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("MmiPins:gsm_set_test"); + + status = ss_check_ss_string((UBYTE*)edt_data->pin);/* check GSM-String */ + switch(status) + { + case MFW_SS_SIM_REG_PW: + if(!(edt_data->gsm_state)) + { + switch(pin_data->set_state) + { + case CHANGE_PIN:/* replace * with string id */ + if(!(strncmp((char*)edt_data->pin,"**04*",IDENT_GSM_1))) + { + edt_data->gsm_state = TRUE; + strncpy((char*)edt_data->edtbuf,(char*)edt_data->pin,edt_data->editor_index-1); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); /* String has changed, refresh editor */ + ATB_edit_Show(edt_data->editor); /* Show the editor */ +#else /* NEW_EDITOR */ + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + + } + else + { + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + if(pin_data->puk_request) + { + pin_data->pin_case = PUK1_REQ; + } + else + { + if((pin_data->set_state EQ ENABLE) || (pin_data->set_state EQ DISABLE)) + pin_data->pin_case = PIN1_REQ; + else + pin_data->pin_case = PIN1_REQ_OLD;/* pin1/2 change */ + } + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + } + break; + case CHANGE_PIN2:/* replace * with string id */ + if(!(strncmp((char*)edt_data->pin,"**042*",IDENT_GSM_2))) + { + edt_data->gsm_state = TRUE; + strncpy((char*)edt_data->edtbuf,(char*)edt_data->pin,edt_data->editor_index-1); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); /* String has changed, refresh editor */ + ATB_edit_Show(edt_data->editor); /* Show the editor */ +#else /* NEW_EDITOR */ + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + } + else + { + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + if(pin_data->puk_request) + { + pin_data->pin_case = PUK2_REQ; + } + else + { + pin_data->pin_case = PIN2_REQ_OLD; + } + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + } + break; + default: + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + if(pin_data->puk_request) + { + if(pin_data->set_state EQ CHANGE_PIN2) + pin_data->pin_case = PUK2_REQ; + else + pin_data->pin_case = PUK1_REQ; + } + else + { + if(pin_data->set_state EQ CHANGE_PIN) + pin_data->pin_case = PIN1_REQ_OLD; + else if(pin_data->set_state EQ CHANGE_PIN2) + pin_data->pin_case = PIN2_REQ_OLD; + else + pin_data->pin_case = PIN1_REQ;/* PIN enable/disable */ + } + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + break; + } + } + return status; + + case MFW_SS_SIM_UNBLCK_PIN: + if(!(edt_data->gsm_state)) + { + switch(edt_data->pin_case_edit) + { + case INPUT_PUK1:/* replace * with string id */ + if(!(strncmp((char*)edt_data->pin,"**05*",IDENT_GSM_1))) + { + edt_data->gsm_state = TRUE; + strncpy((char*)edt_data->edtbuf,(char*)edt_data->pin,edt_data->editor_index-1); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); /* String has changed, refresh editor */ + ATB_edit_Show(edt_data->editor); /* Show the editor */ +#else /* NEW_EDITOR */ + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + } + else + { + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + pin_data->pin_case = PUK1_REQ; + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + } + break; + case INPUT_PUK2:/* replace * with string id */ + if(!(strncmp((char*)edt_data->pin,"**052*",IDENT_GSM_2))) + { + edt_data->gsm_state = TRUE; + strncpy((char*)edt_data->edtbuf,(char*)edt_data->pin,edt_data->editor_index-1); + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); /* String has changed, refresh editor */ + ATB_edit_Show(edt_data->editor); /* Show the editor */ +#else /* NEW_EDITOR */ + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + } + else + { + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + pin_data->pin_case = PUK2_REQ; + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + } + break; + default: + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + if(pin_data->puk_request) + { + if(pin_data->set_state EQ CHANGE_PIN2) + pin_data->pin_case = PUK2_REQ; + else + pin_data->pin_case = PUK1_REQ;/* pin1 change,disable,enable */ + } + else + { + if(pin_data->set_state EQ CHANGE_PIN) + pin_data->pin_case = PIN1_REQ_OLD; + else if(pin_data->set_state EQ CHANGE_PIN2) + pin_data->pin_case = PIN2_REQ_OLD; + else + pin_data->pin_case = PIN1_REQ; /* pin enable/disable */ + } + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + break; + } + } + return status; + case MFW_SS_DIAL: /* string not yet detected */ + case MFW_SS_USSD: /*JVJ SPR 1040- The short USSD strings should also be + considered in this case, since they can be confused with dialled numbers + */ + edt_data->gsm_state = FALSE; + return status; + default: + edt_data->gsm_state = FALSE; + dspl_ClearAll(); + clear_edit_array (edt_data); + set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,GSM_FAIL,0,NULL);/*entering screeen not allowed */ + return status; + } +} + + +/******************************************************************************* + + $Function: set_mode_fdn_adn + $Description: activate/deactivate FDN/ADN + $Returns: none + $Arguments: win, pin editor attributes +*******************************************************************************/ +static void set_mode_fdn_adn(T_MFW_HND win, void * string) +{ + T_pin * pin_data = (T_pin *)string; + + TRACE_FUNCTION("MmiPins:set_mode_fdn_adn"); + + if((pin_data->set_state EQ FDN_ACTIV) || (pin_data->set_state EQ PIN2_CHECK)) + { + if(phb_set_mode(PHB_FDN,pin_data->old_pin) EQ MFW_PHB_OK) + { + SEND_EVENT(pin_data->pin_win,FDN_ACTIVATED,0,pin_data);/* activate FDN successfull */ + } + else + { + SEND_EVENT(pin_data->pin_win,FDN_FAIL,0,pin_data);/* activate FDN unsuccessfull */ + } + } + else + { + if(phb_set_mode(PHB_ADN,pin_data->old_pin) EQ MFW_PHB_OK) + { + SEND_EVENT(pin_data->pin_win,ADN_ACTIVATED,0,pin_data);/* deactivate FDN successfull */ + } + else + { + SEND_EVENT(pin_data->pin_win,FDN_FAIL,0,pin_data);/* deactivate FDN unsuccessfull */ + } + } +} + + +/******************************************************************************* + + $Function: backpinFDNactdeact + $Description: when callback event is received from phonebook + (MmiPhbk:phbkEvent) + $Returns: none + $Arguments: none +*******************************************************************************/ +void backpinFDNactdeact(void) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *)set_pin_windows)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + TRACE_FUNCTION("MmiPins.backpinFDNactdeact"); + + if(pin_data->set_state EQ FDN_ACTIV) + { + SEND_EVENT(pin_data->pin_win,FDN_ACT_END,0,pin_data); + } + else if(pin_data->set_state EQ FDN_DEACTIV) + { + SEND_EVENT(pin_data->pin_win,FDN_DEACT_END,0,pin_data); + } +} + + + +/******************************************************************************* + + $Function: pin2_check + $Description: PIN2 check :call from menu Services and Phonebook + $Returns: status int + $Arguments: parent window +*******************************************************************************/ +int pin2_check (T_MFW_HND parent_window) +{ + T_MFW_HND win = setting_pin_create(parent_window); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + T_MFW_SIM_PIN_STATUS status; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + +// T_DISPLAY_DATA display_info; + + + pin_data->set_state = PIN2_CHECK; + + TRACE_FUNCTION("MmiPins:pin2_check"); + + status.type = MFW_SIM_PIN2; + sim_pin_status(&status); + // June 16, 2005 REF: CRR 31267 x0021334 + // Check if PIN2 and PUK2 are initialised + if((sim_pin_count(MFW_SIM_PIN2) > 0) AND (sim_pin_count(MFW_SIM_PUK2) NEQ 0)) + { + SEND_EVENT(pin_data->pin_win,PIN2_REQ,0,pin_data); + } + // If PIN2 is not initialised, ask for PUK 2 + else if ((sim_pin_count(MFW_SIM_PIN2) EQ 0) AND (sim_pin_count(MFW_SIM_PUK2) > 0)) + { + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK2_REQ,0,pin_data); + } + // Else display that PIN2 is not available + else + { + SEND_EVENT(pin_data->pin_win,PIN2_SIM_FAILURE,0,pin_data); + } + } + return 1; +} + + + + +/******************************************************************************* + + $Function: pin1_check + $Description: PIN1 check :call from menu Services (AOC) + $Returns: status int + $Arguments: parent window +*******************************************************************************/ +int pin1_check (T_MFW_HND parent_window) +{ + T_MFW_HND win = setting_pin_create(parent_window); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; +// T_MFW_SIM_PIN_STATUS status; /* Warning Correction */ + + pin_data->set_state = PIN1_CHECK; + + TRACE_FUNCTION("MmiPins:pin1_check"); + if(sim_pin_count(MFW_SIM_PIN1) > 0) + { + SEND_EVENT(pin_data->pin_win,PIN1_REQ,0,pin_data); + } + else + { /* not included the state of the puk counter ! */ + pin_data->puk_request = TRUE; + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + } + return 1; +} + +/******************************************************************************* + + $Function: fdnActivate + $Description: activate FDN + $Returns: status int + $Arguments: menu, item +*******************************************************************************/ +int fdnActivate(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + TRACE_FUNCTION("MmiPins:fdnActivate"); + pin2_fdn_activate();/* check if PIN2 */ + return 1; +} + + + +/******************************************************************************* + + $Function: fdnDeactivate + $Description: deactivate FDN + $Returns: status int + $Arguments: menu, item +*******************************************************************************/ +int fdnDeactivate(struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + + TRACE_FUNCTION("MmiPins:fdnDeactivate"); + pin2_fdn_deactivate(); // check if PIN2 + return 1; +} + + +/******************************************************************************* + + $Function: set_fdn_on_item_flag + $Description: decision about menu entry FDN "on" + $Returns: 0 if show entry, 1 if not + $Arguments: menu, menu attributes, item +*******************************************************************************/ +U16 set_fdn_on_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + + TRACE_FUNCTION("MmiPins:set_fdn_on_item_flag"); + + if(phb_get_mode()EQ PHB_RESTRICTED) /*if FDN on */ + return MNU_ITEM_HIDE; /* show no entry "on" */ + else + return 0; /* show entry "on" */ +} + + +/******************************************************************************* + + $Function: set_fdn_off_item_flag + $Description: decision about menu entry FDN "off" + $Returns: 0 if show entry off, 1 if not + $Arguments: menu, menu attributes, item +*******************************************************************************/ +U16 set_fdn_off_item_flag (struct MfwMnuTag * m, struct MfwMnuAttrTag * ma, struct MfwMnuItemTag * mi) +{ + TRACE_FUNCTION("MmiPins:set_fdn_off_item_flag"); + + if(phb_get_mode() NEQ PHB_RESTRICTED) /* if FDN off */ + return MNU_ITEM_HIDE; /* show no entry "off" */ + else + return 0; /* show entry "off" */ +} + + + +/******************************************************************************* + + $Function: gsm_idle + $Description: handle gsm string in idle screen (unblock and change pin) + $Returns: Status int + $Arguments: parent window, string +*******************************************************************************/ +int gsm_idle (T_MFW_HND parent_window,char * string) +{ + T_MFW_HND win = setting_pin_create(parent_window); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + pin_data->set_state = IDLE_GSM; + pin_data->gsm_state = TRUE; + + TRACE_FUNCTION("MmiPins:gsm_idle"); + + gsm_sec_execute_set(win,string); + } + return 1; +} + + +/******************************************************************************* + + $Function: gsm_sec_execute_set + $Description: GSM-String will be executed in settings and idle + $Returns: none + $Arguments: win, pin attributes +*******************************************************************************/ +static void gsm_sec_execute_set(T_MFW_HND win,void *string) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + int result; + + TRACE_FUNCTION("MmiPins:gsm_sec_execute_set"); + + if(pin_data->set_state NEQ IDLE_GSM) + { + T_pin_edt * edt_data = (T_pin_edt *)string; + + result = ss_execute_transaction((UBYTE*)edt_data->pin,0);/* ussd_man = 0 while SSD */ + dspl_ClearAll(); + clear_edit_array (edt_data); + pin_edt_destroy(edt_data->pin_edt_win); + //xrashmic 1 Jul, 2006 OMAPS00075784 + //After the PUK is verified, security menu has to be displayed. + //Hence we need to delete the pin window or else the blue + //screen is displayed + //xrashmic 6 Jul, 2006 OMAPS00080708 + //The pin window is necessary for displaying the error message for MFW_SS_FAIL + if(result!=MFW_SS_FAIL) + pin_destroy(pin_data->pin_win); + } + else + result = ss_execute_transaction((UBYTE*)string,0);/* ussd_man = 0 while SSD */ + + switch(result) + { + case MFW_SS_SIM_REG_PW: /* change PIN1/2 */ + TRACE_FUNCTION("MmiPins:gsm_idle:MFW_SS_SIM_REG_PW"); + break; + case MFW_SS_SIM_UNBLCK_PIN: /* unblock PIN1/2 */ + TRACE_FUNCTION("MmiPins:gsm_idle:MFW_SS_SIM_UNBLCK_PIN"); + break; + case MFW_SS_FAIL: + TRACE_FUNCTION("MmiPins:gsm_idle:MFW_SS_FAIL"); + sett_pin_mess(win,GSM_FAIL);/* new PIN and new PIN again are not the same */ + break; + default: + break; + } +} + + +/******************************************************************************* + + $Function: pins_editor_cb + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + +static void pins_editor_cb (T_MFW_HND win, USHORT Identifier, SHORT reason) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; + T_pin * data = (T_pin *)win_data->user; + + T_pin * pin_data = (T_pin *)win_data->user;//pin main data + //T_DISPLAY_DATA display_info; +//x0pleela 21 Apr, 2006 DR: OMAPS00067919 +#ifdef SIM_PERS + int ret; //used to check the retun type of function mfw_simlock_check_lock_bootup() +#endif + TRACE_FUNCTION ("pins_editor_cb()"); + + /* SPR#1746 - SH - In the case INSERT_CARD or CARD_REJECTED, + * the editor has not been destroyed at this point. + * BUT in all other cases it has, so we need to set the + * editor handle to NULL. */ + +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + if (Identifier!=INSERT_CARD && Identifier!=CARD_REJECTED + && Identifier!=SHOW_IMEI_INVALID +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + && Identifier != NO_MEPD_DATA +#endif + ) + { + pin_editor_window = NULL; + } + + switch (reason) + { + + case INFO_EMERGENCY: + TRACE_EVENT_P1(" call %s", data->edtbuf); + + /* SPR#1746 - SH - Function modified to provide context */ + show_confirmation (win, Identifier); + + break; + + case INFO_KCD_LEFT: + switch (Identifier) + { + + case PIN1_REQ: + { TRACE_EVENT ("PIN1_REQ"); + + // verification pin1 + sim_verify_pin(MFW_SIM_PIN1, data->edtbuf); + } + break; +#ifdef SIM_PERS + case PERM_BLK: + break; +#endif + case PUK1_REQ: + { +#ifdef SIM_PERS + int status,curr_fail_reset, curr_succ_reset; + + TRACE_FUNCTION ("PUK1-REQ"); + strncpy((char*)pin_data->puk, data->edtbuf,MAX_PIN); + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); +// Nov 03, 2005 DR: OMAPS00050595 - xpradipg +// the check for C_KEY_REQ is made first to find if the PUK request was for +// SIM Personalization or for the SIM PIN1 + + if(C_KEY_REQ) + { + if((curr_fail_reset!=0) && (curr_succ_reset!=0) ) + { + if( FCUnlock_flag) + { + TRACE_FUNCTION("FCUnlock_flag: TRUE"); + status= mfw_simlock_reset_fc_value((U8*)pin_data->puk,MFW_SIM_FCM); + } + else + { + TRACE_FUNCTION("FCUnlock_flag: FALSE"); + + // June 07, 2006 DR: OMAPS00080701 x0021334 + // Descripton: Phone hangs while unblocking SIMP during bootup. + // Assign 'SIMP_BOOTUP' to 'sim_unlock_in_prog' to indicate that + // the operation is happeneing during boot-up sequence. + sim_unlock_in_prog = SIMP_BOOTUP; + status= mfw_simlock_reset_fc_value((U8*)pin_data->puk,MFW_SIM_FC); + } + + mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + if( status != MFW_SS_OK) + { + TRACE_FUNCTION("UNBLOCK_FAILURE"); + mmi_simlock_aciErrDesc = aciErrDesc; + + if((aciErrDesc & 0x0000FFFF) EQ CME_ERR_SimNotIns) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_SIM_REM,0,pin_data); + + //x0pleela 11 Sep, 2006 DR: OMASP00094215 + //Handling CME error busy while unlocking a locked category + else if( ( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) AND + (aciErrDesc & 0x0000FFFF) EQ EXT_ERR_Busy) + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY_UNBLOCK,0,pin_data); + + else + { + //x0pleela 27 Apr, 2006 DR: OMAPS00067919 + //To avoid executing this during bootup sequence + if(FCUnlock_flag) //x0pleela 27 Apr, 2006 DR: OMAPS00067919 + { + if( curr_fail_reset ) + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_FC_FAIL, 0, pin_data); + else + { + perm_blocked=1; + SEND_EVENT(pin_data->pin_win, PERM_BLK, 0, pin_data); + } + } + } + } + else + { + TRACE_FUNCTION("UNBLOCK_SUCESS"); + if(FCUnlock_flag) + FCUnlock_flag=0; + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Update mmi_simlock_aciErrDesc with the latest CME error + mmi_simlock_aciErrDesc = aciErrDesc; + + if( curr_succ_reset ) + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_FC_SUCC, 0, pin_data); + else + { + perm_blocked=1; + SEND_EVENT(pin_data->pin_win, PERM_BLK, 0, pin_data); + } + } + } + else + { + perm_blocked = 1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + + } + else + { +#endif + strncpy((char*)pin_data->puk, data->edtbuf,MAX_PIN); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN,0,pin_data); +#ifdef SIM_PERS + } +#endif + } + break; + +#ifdef SIM_PERS + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //Performs master unlock and sends corresponding events during bootup + case INPUT_MASTER_KEY_REQ: + { + int status; + strncpy((char*)pin_data->mk_pin, data->edtbuf,MAX_PIN); + status = mfw_simlock_master_unlock((U8*)pin_data->mk_pin, MFW_SIM_MKEY); + if( status EQ MFW_SS_OK ) + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_MK_SUCC, 0, pin_data); + + //x0pleela 13 Nov, 2006 DR: OMAPS00103356 + //send wrong password event + else if ( status EQ MFW_WRONG_PWD) + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_WRONG_PWD, 0, pin_data); + //x0pleela 13 Nov, 2006 DR: OMAPS00103356 + //send event which says all the dependent categories are unlocked + else if ( status EQ MFW_MASTER_OK) + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_DEP_CATS_UNLOCKED, 0, pin_data); + else + SEND_EVENT(pin_data->pin_win, SMLK_SHOW_MK_FAIL, 0, pin_data); + + } + break; + + case INPUT_SIM_PIN_REQ: + case INPUT_NLOCK_PIN_REQ: + case INPUT_NSLOCK_PIN_REQ: + case INPUT_SPLOCK_PIN_REQ: + case INPUT_CLOCK_PIN_REQ: + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + case INPUT_PBLOCK_PIN_REQ: + { + S16 lcktype = 0; + int curr_fail_reset1, curr_succ_reset1; + + mfw_simlock_check_status(0, &curr_fail_reset1, &curr_succ_reset1); + + if ((!curr_fail_reset1)||(!curr_succ_reset1)) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + else + { + + strncpy((char*)pin_data->puk, data->edtbuf,MAX_PIN); + //for CPIN to CLCK change + switch(Identifier) + { + case INPUT_SIM_PIN_REQ: + lcktype=MFW_SIM_PLOCK; + break; + case INPUT_NLOCK_PIN_REQ: + lcktype=MFW_SIM_NLOCK; + break; + case INPUT_NSLOCK_PIN_REQ: + lcktype=MFW_SIM_NSLOCK; + break; + case INPUT_SPLOCK_PIN_REQ: + lcktype=MFW_SIM_SPLOCK; + break; + case INPUT_CLOCK_PIN_REQ: + lcktype=MFW_SIM_CLOCK; + break; + + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + case INPUT_PBLOCK_PIN_REQ: + lcktype=MFW_SIM_PBLOCK; + break; + } + ret = mfw_simlock_check_lock_bootup((char*)pin_data->puk, lcktype); + //x0pleela 20 july, 2006 ER: OMAPS00087586, OMAPS00087587 + //delete the simp list window handler + win_delete(pin_data->simp_list_win); + if( ret == BOOTUP_LOCK_SUCCESS) + { + TRACE_FUNCTION("BOOTUP_LOCK_SUCCESS"); + simp_cpin_flag = FALSE; + SEND_EVENT(pin_data->pin_win,SIM_LOCK_PERS_CHK_OK,0,pin_data); + } + else if (ret ==BOOTUP_OK) + { + sim_simlock_cpin_code (simp_cpin_code); + } + else + { + TRACE_FUNCTION("BOOTUP_LOCK_FAILURE"); + TRACE_EVENT_P1("aciErrDesc %d ",aciErrDesc); + if( simp_cpin_flag ) + sim_simlock_cpin_code (simp_cpin_code); + else + { + //x0pleela 20 July, 2006 ER: OMAPS00087586, OMAPS00087587 + //get the busy state + if( mfw_simlock_get_busy_state() ) + { + //send event to display a dialog Busy for the user + SEND_EVENT(pin_data->pin_win,SIM_LOCK_BUSY_BOOTUP,0,pin_data); + } + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for CME class and handle all CME errors + else if( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Cme) + { + switch(aciErrDesc & 0x0000FFFF) + { + case CME_ERR_NetworkPersPinReq: + TRACE_EVENT("CME_ERR_NetworkPersPinReq"); + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options Network unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_NetworkSubsetPersPinReq: + TRACE_EVENT("CME_ERR_NetworkSubsetPersPinReq"); + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options Network subset unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_NSLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_NSLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_ProviderPersPinReq: + TRACE_EVENT("CME_ERR_ProviderPersPinReq"); + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options service provider unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_SPLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SPLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_CorporatePersPinReq: + TRACE_EVENT("CME_ERR_CorporatePersPinReq"); + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options Corporate unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_CLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_CLOCK_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhSimPinReq: + TRACE_EVENT("CME_ERR_PhSimPinReq"); + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options SIM unlock and Master Unlock + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_SIM_PIN_REQ,0,pin_data); + break; + + case CME_ERR_PhoneFail: + case CME_ERR_NetworkPersPukReq: + case CME_ERR_NetworkSubsetPersPukReq: + case CME_ERR_ProviderPersPukReq: + case CME_ERR_CorporatePersPukReq: + { + int status, curr_fail_reset, curr_succ_reset; + TRACE_EVENT("PUK Req"); + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if( status==MFW_SIM_BLOCKED) + { + C_KEY_REQ = 1; + //x0pleela 20 July, 2006 + //check for Master Unlock option enabled. + //If so, then display the menu with options Unblock ME and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else if (status == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + break; + + + case CME_ERR_WrongPasswd: + default: + TRACE_EVENT("CME_ERR_WrongPasswd"); + SEND_EVENT(pin_data->pin_win,Identifier,0,pin_data); + break; + } + } + //x0pleela 25 Sep, 2006 ER: OMAPS00095524 + //check for Ext class and handle all Extension errors + else if( ((aciErrDesc & 0xFFFF0000) >> 16) EQ ACI_ERR_CLASS_Ext) + { + switch(aciErrDesc & 0x0000FFFF) + { + //Request for Blocked Network Password + case EXT_ERR_BlockedNetworkPersPinReq: + TRACE_EVENT("EXT_ERR_BlockedNetworkPersPinReq"); + if( simlock_get_masterkey_status()) + { + mmi_simlock_locktype = MFW_SIM_PBLOCK; + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,INPUT_PBLOCK_PIN_REQ,0,pin_data); + break; + + //Request for Blocked Network Unblock code + case EXT_ERR_BlockedNetworkPersPukReq: + { + int status,curr_fail_reset, curr_succ_reset; + TRACE_EVENT("PUK Req"); + status = mfw_simlock_check_status(0, &curr_fail_reset, &curr_succ_reset); + + if( status==MFW_SIM_BLOCKED) + { + C_KEY_REQ = 1; + //check for Master Unlock option enabled. + //If so, then display the menu with options Unblock ME and Master Unlock + if( simlock_get_masterkey_status()) + { + pin_data->simp_list_win = mmi_simlock_category_menus(win); + } + else + SEND_EVENT(pin_data->pin_win,PUK1_REQ,0,pin_data); + } + else if (status == MFW_SIM_PERM_BLOCKED) + { + perm_blocked =1; + SEND_EVENT(pin_data->pin_win,PERM_BLK,0,pin_data); + } + } + break; + + default: + break; + } + } + } + } + } + } + break; +#endif + + case INPUT_NEW_PIN: + { TRACE_EVENT ("INPUT_NEW_PIN"); + strncpy((char*)pin_data->new_pin, data->edtbuf,MAX_PIN); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PIN_AGAIN,0,pin_data); + } + break; + + case INPUT_NEW_PIN_AGAIN: + { //if new pins match + if(strcmp((char*)pin_data->new_pin, (char*)data->edtbuf) EQ 0) + sim_unblock_pin(MFW_SIM_PUK1, (char*)pin_data->puk, (char*)pin_data->new_pin);/* unblock pin1 */ + else //otherwise ask for new pin again + SEND_EVENT(pin_data->pin_win,NEW_PIN_FAIL,0,NULL); + } + break; + default: + break; + } + break; + + case INFO_KCD_RIGHT: + case INFO_KCD_CLEAR: + + TRACE_EVENT ("INFO_KCD_RIGHT pressed"); + + switch (Identifier) + { + + default: + break; + } + default: + break; + } +} + + +/******************************************************************************* + + $Function: call emergency confirmation + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + +/* SPR#1746 - SH - Add 'Identifier' so previous context is known */ + +void show_confirmation (T_MFW_HND win, USHORT Identifier) +{ + T_DISPLAY_DATA display_info; + dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtSoftBack, TxtSoftCall, TxtEmergency , COLOUR_STATUS_PINS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)show_confirmation_cb, FOREVER, KEY_HUP | KEY_LEFT| KEY_RIGHT ); + + /* SPR#1746 - SH - Store Identifier in display info, so it can be accessed by callback */ + display_info.Identifier = Identifier; + /* + * Call Info Screen + */ + + info_dialog (win, &display_info); + +} + + +int mmiPinsEmergencyCall(void) +{ + return((int)pin_emergency_call); +} + +void mmiPinsResetEmergencyCall(void) +{ + pin_emergency_call = FALSE; + return; +} + +/******************************************************************************* + + $Function: idle_imei_info_cb + + $Description: + + $Returns: + + $Arguments: + +*******************************************************************************/ + + + +static int show_confirmation_cb(T_MFW_HND win, USHORT identifier, UBYTE reason) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; + T_pin * data = (T_pin *)win_data->user; + + switch (reason) + { + + case INFO_KCD_LEFT: + if (mmiStart_animationComplete() != TRUE) + pin_emergency_call = TRUE; + + // call emergency number + callNumber ((UBYTE*)data->edtbuf); + break; + + case INFO_KCD_HUP: + case INFO_KCD_RIGHT: + pin_emergency_call = FALSE; + + /* SPR#1746 - SH - Now use identifier to return to previous context. + * If the editor handle is not NULL, the editor is still hanging around. + * We want to restart the editor, so we'll destroy it first. */ + + if (pin_editor_window) + { +#ifdef NEW_EDITOR + AUI_pin_Destroy(pin_editor_window); +#else + editor_destroy(pin_editor_window); +#endif + pin_editor_window = NULL; + } + + /* SPR#1746 - SH - For most identifiers, the number can just be passed to pin_main as + * an event. However, INSERT_CARD and CARD_REJECTED actually + * correspond to the pin_main events NO_SIM_CARD and INVALID_CARD + * respectively. Make this conversion */ + if (identifier==INSERT_CARD) + identifier = NO_SIM_CARD; + else if (identifier==CARD_REJECTED) + identifier = INVALID_CARD; +// Nov 24, 2005, a0876501, DR: OMAPS00045909 + else if (identifier == SHOW_IMEI_INVALID) + identifier = INVALID_IMEI; +//x0pleela 18 Oct, 2006 DR: OMAPS00099660 +//Added the following code inside the SIM_PERS flag +#ifdef SIM_PERS + //x0pleela 30 Aug, 2006 DR: OMAPS00091250 + else if( identifier == NO_MEPD_DATA ) + identifier = NO_MEPD; +#endif + + /* Restart the appropriate editor */ + SEND_EVENT(win, identifier, 0, data); + break; + } + + return 1; +} +/******************************************************************************* + + $Function: pins_loadEditDefault + + $Description: fill up editor-sttribut with default + + $Returns: + + $Arguments: + +*******************************************************************************/ +//GW-SPR#844 - Zero editor data structure to reset all values to a known state. + +/* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR +void pins_loadEditDefault (T_AUI_EDITOR_DATA *editor_data, USHORT TitleId, USHORT Identifier) +{ + TRACE_FUNCTION ("pins_loadEditDefault()"); + AUI_edit_SetDefault(editor_data); + AUI_edit_SetDisplay(editor_data, PASSWORD_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); + AUI_edit_SetMode(editor_data, ED_MODE_HIDDEN, ED_CURSOR_UNDERLINE); + AUI_edit_SetEvents(editor_data, Identifier, TRUE, FOREVER, (T_AUI_EDIT_CB)pins_editor_cb); + if (pin1Flag EQ TRUE) // June 16, 2005 REF: CRR 31267 x0021334 + AUI_edit_SetTextStr(editor_data, TxtSoftOK, TxtDelete, TitleId, NULL); //display RSK as delete + else + AUI_edit_SetTextStr(editor_data, TxtSoftOK, TxtSoftBack, TitleId, NULL); // display RSK as back + AUI_edit_SetAltTextStr(editor_data, 4, TxtNull, TRUE, TxtNull); + + return; +} +#else /* NEW_EDITOR */ +void pins_loadEditDefault (T_EDITOR_DATA *editor_data) +{ + TRACE_EVENT ("pins_loadEditDefault()"); + memset(editor_data,0x00,sizeof(T_EDITOR_DATA)); + + editor_attr_init(&editor_data->editor_attr, PASSWORD_EDITOR, edtCurBar1, NULL, NULL, 0, COLOUR_EDITOR_XX); + + editor_data->hide = FALSE; + editor_data->Identifier = 0; /* optional */ + editor_data->mode = PIN_SECURITY; + editor_data->destroyEditor = TRUE; + editor_data->LeftSoftKey = TxtSoftSelect; + editor_data->AlternateLeftSoftKey = TxtNull; + editor_data->RightSoftKey = TxtSoftBack; + editor_data->TextId = '\0'; + editor_data->TextString = NULL; + editor_data->min_enter = 1; // Avoid to return empty strings + editor_data->timeout = FOREVER; + editor_data->Callback = (T_EDIT_CB)pins_editor_cb; + +} +#endif /* NEW_EDITOR */ + + +//Clear PIN area +void pin_rectClear( MfwRect *win ) +{ + + dspl_Clear(win->px,win->py,win->px+win->sx-1,win->py+win->sy-1); +} +void pin_skClear( void ) +{ + MfwRect skRect; + Mmi_layout_softkeyArea( &skRect ); + pin_rectClear( &skRect ); +} + +// June 16, 2005 REF: CRR 31267 x0021334 +// Call back function to display editor after info dialog +void pin1_cb_function (T_MFW_HND win, UBYTE identifier, UBYTE reason) +{ + TRACE_FUNCTION ("pin1_cb_function"); + + // Post SIM_LOCKED_EMR_EDITOR event to start the editor + SEND_EVENT(win, SIM_LOCKED_EMR_EDITOR, 0, 0); +} +/******************************************************************************* + + $Function: getBootUpState + + $Description: returns the current state during bootup + + $Returns: T_BOOTUP_STATE + + $Arguments: None + +//xashmic 21 Sep 2006, OMAPS00095831 +*******************************************************************************/ +T_BOOTUP_STATE getBootUpState(void) +{ + return BootUpState; +} +//x0pleela 21 Feb, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK +/******************************************************************************* + $Function: phLock_Enable_Lock + $Description: sets the global flag to the network lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_Enable_Lock (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = phlock_setting_pin_create(idle_win); + UBYTE phlock_status, auto_phlock_status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + TRACE_FUNCTION("phLock_Enable_Lock"); + + if(win != NULL) + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + //x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + //check the status of Phone lock + phlock_status= mfw_phlock_get_lock_status(MFW_PH_LOCK); + //check the status of Automatic Phone lock + auto_phlock_status = mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK); + + //x0pleela 28 May, 2007 DR: OMAPS132483 + //set the phonelock and auto ph lock status to TRUE if lock is enabled + if( phlock_status EQ MFW_PH_LOCK_DISABLE) + mfw_set_Phlock_status(FALSE); + else + mfw_set_Phlock_status(TRUE); + + if( auto_phlock_status EQ MFW_PH_LOCK_DISABLE) + mfw_set_Auto_Phlock_status(FALSE); + else + mfw_set_Auto_Phlock_status(TRUE); + + pin_data->set_state = ENABLE; + + if( (phlock_status EQ MFW_PH_LOCK_DISABLE) && + (auto_phlock_status EQ MFW_PH_LOCK_DISABLE))/*if Phone lock is disabled*/ + { + SEND_EVENT(pin_data->pin_win,TXT_PH_LOCK_ALL,0,pin_data); + } + else + SEND_EVENT(pin_data->pin_win,PH_LOCK_ALREADY_ENDIS,0,pin_data); + } + return 1; +} + +/******************************************************************************* + $Function: phLock_Lock + $Description: sets the global flag to the network lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_Lock (void) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = phlock_setting_pin_create(idle_win); + UBYTE slock_status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + T_MFW_SS_RETURN ret; + T_DISPLAY_DATA display_info; + + TRACE_FUNCTION("phLock_Lock"); + + if(win != NULL) + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + +//x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + slock_status= mfw_phlock_get_lock_status(MFW_PH_LOCK); + + if(slock_status EQ MFW_PH_LOCK_DISABLE) /*if Phone lock is enabled*/ + { + ret = mfw_phlock_enable_lock(NULL, MFW_PH_LOCK); + + if ( ret == MFW_SS_FAIL) + { + SEND_EVENT(pin_data->pin_win,PH_LOCK_EN_FAIL,0,pin_data); + } + else if( ret == MFW_EXCT) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull,TxtPleaseWait,TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, FOREVER, KEY_CLEAR | KEY_LEFT ); + phlock_info_dialog (pin_data->pin_win, &display_info); + } + else + { + //x0pleela 29 May, 2007 DR: OMAPS00132483 + //set the phlock status to TRUE + mfw_set_Phlock_status( TRUE ); + SEND_EVENT(pin_data->pin_win,PH_LOCK_SUCC,0,pin_data); + } + } + return 1; + } + return 0; +} + +/******************************************************************************* + $Function: phLock_UnLock + $Description: sets the global flag to the network lock + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_UnLock (void) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = phlock_setting_pin_create(idle_win); + UBYTE slock_status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + TRACE_FUNCTION("phLock_UnLock"); + + if(win != NULL) + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + + //x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + slock_status= mfw_phlock_get_lock_status(MFW_PH_LOCK); + + pin_data->set_state = DISABLE; + + if(slock_status EQ MFW_PH_LOCK_ENABLE) /*if Phone lock is disabled*/ + { + SEND_EVENT(pin_data->pin_win,TXT_PH_LOCK_ALL,0,pin_data); + } + else + SEND_EVENT(pin_data->pin_win,PH_LOCK_ALREADY_ENDIS,0,pin_data); + } + return 1; +} + +/******************************************************************************* + $Function: phLock_Automatic_On + $Description: sets automaticPhLock flag to ON + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_Automatic_On (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + T_MFW_HND idle_win = mfwParent( mfw_header() ); + T_MFW_HND win = phlock_setting_pin_create(idle_win); + UBYTE slock_status; + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + + TRACE_FUNCTION("phLock_Automatic_On"); + autoPhLock_menu = TRUE; + + if(win != NULL) + { + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + +//x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + slock_status = mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK); + + pin_data->set_state = ENABLE; + + if(slock_status EQ MFW_PH_LOCK_DISABLE) /*if Phone lock is disabled*/ + { + SEND_EVENT(pin_data->pin_win,TXT_PH_LOCK_ALL,0,pin_data); + } + else + SEND_EVENT(pin_data->pin_win,PH_LOCK_ALREADY_ENDIS,0,pin_data); + } + return 1; +} + +/******************************************************************************* + $Function: phLock_Automatic_Off + $Description: sets automaticPhLock flag to OFF + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_Automatic_Off (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ + int status; + + TRACE_FUNCTION("phLock_Automatic_Off"); + + //x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + status = mfw_phlock_disable_autoLock(MFW_AUTO_PH_LOCK); + if( status == MFW_SS_OK ) + { + //x0pleela 09 Mar, 2007 DR: OMAPS00129014 + //set the flag to FALSE + phlock_auto = FALSE; + + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //Set the auto phone lock status to FALSE + mfw_set_Auto_Phlock_status(FALSE); + + mmi_phlock_show_info(0, TxtAutoLockDisable, TxtSuccess, NULL); + } + else if ( status == MFW_SS_ALRDY_DIS ) + mmi_phlock_show_info(0, TxtPhoneLock, TxtAlreadyDisabled, NULL); + else + mmi_phlock_show_info(0, TxtAutoLockDisable, TxtFailed, NULL); + + return 1; +} + +/******************************************************************************* + $Function: phLock_Change_UnlockCode + $Description: + $Returns: none + $Arguments: none +*******************************************************************************/ +int phLock_Change_UnlockCode (struct MfwMnuTag * m, struct MfwMnuItemTag * i) +{ +T_MFW_HND idle_win = mfwParent( mfw_header()); + T_MFW_HND win = phlock_setting_pin_create(idle_win); + T_MFW_WIN * win_data = NULL; + T_pin * pin_data = NULL; + int status, auto_lock_status; + TRACE_FUNCTION("MmiPins:phLock_Change_UnlockCode"); + + if(win != NULL) /* x0039928 - Lint warning removal */ + { + //x0pleela 23 May, 2007 DR: OMAPS00132483 + //stop the audio file if playing +#ifdef FF_MMI_AUDIO_PROFILE + if( mfwAudPlay) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } +#endif //FF_MMI_AUDIO_PROFILE + + win_data = ((T_MFW_HDR *)win)->data; + pin_data = (T_pin *)win_data->user; + pin_data->set_state = CHANGE_PIN; + status = mfw_phlock_get_lock_status(MFW_PH_LOCK); + auto_lock_status = mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK); + if( ( status == MFW_PH_LOCK_ENABLE) || + auto_lock_status == MFW_PH_LOCK_ENABLE) + { + SEND_EVENT(pin_data->pin_win,PH_LOCK_STATUS,0,pin_data); + } + else + { + SEND_EVENT(pin_data->pin_win,PH_LOCK_REQ_OLD,0,pin_data); + } + } + return 1; +} + + +/******************************************************************************* + $Function: mmi_phlock_en_dis_verify + $Description: performs the operation of enabling/disabling and verifying a given + lock type after the input of the password + $Returns: none + $Arguments: none +*******************************************************************************/ + +static void mmi_phlock_en_dis_verify(T_MFW_HND win) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + T_MFW_SS_RETURN ret; + T_DISPLAY_DATA display_info; + + TRACE_FUNCTION("mmi_phlock_en_dis_verify()"); + if((pin_data->set_state != ENABLE) && (pin_data->set_state != DISABLE)) + { + + TRACE_FUNCTION("We're verifying SIMLock"); + + SEND_EVENT(pin_data->pin_win,PH_LOCK_REQ_NEW,0,pin_data); + + } + else if(pin_data->set_state EQ ENABLE) + { + TRACE_FUNCTION("MmiPins:Enable Lock now"); + if( autoPhLock_menu ) + { + ret = mfw_phlock_enable_lock((U8*)pin_data->old_pin, MFW_AUTO_PH_LOCK); + } + else + { + ret = mfw_phlock_enable_lock((U8*)pin_data->old_pin, MFW_PH_LOCK); + } + if ( ret == MFW_SS_FAIL) + { + SEND_EVENT(pin_data->pin_win,PH_LOCK_ENDIS_FAIL,0,pin_data); + } + else if( ret == MFW_EXCT) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull,TxtPleaseWait,TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, FOREVER, KEY_CLEAR | KEY_LEFT ); + phlock_info_dialog (pin_data->pin_win, &display_info); + } + else + { + if( autoPhLock_menu ) + { + //x0pleela 09 Mar, 2007 DR: OMAPS00129014 + //set the flag to TRUE + phlock_auto = TRUE; + + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //Set the auto phone lock status to TRUE + mfw_set_Auto_Phlock_status(TRUE); + SEND_EVENT(pin_data->pin_win,PH_LOCK_AUTO_SUCC,0,pin_data); + } + else + { + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //Set the phone lock status to TRUE + mfw_set_Phlock_status(TRUE); + SEND_EVENT(pin_data->pin_win,PH_LOCK_ENDSUCC,0,pin_data); + } + } + } + else if(pin_data->set_state EQ DISABLE) + { + TRACE_FUNCTION("MmiPins:Disable Lock now"); + ret = mfw_phlock_disable_lock((U8*)pin_data->old_pin,MFW_PH_LOCK); + if (ret == MFW_SS_FAIL) + { + SEND_EVENT(pin_data->pin_win,PH_LOCK_ENDIS_FAIL,0,pin_data); + } + else + { + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //Set the phone lock status to FALSE + mfw_set_Phlock_status(FALSE); + + SEND_EVENT(pin_data->pin_win,PH_LOCK_ENDSUCC,0,pin_data); + } + } + +} + + +/******************************************************************************* + $Function: mmi_phlock_change_pin + $Description: Performs the change password for a given lock type + $Returns: success or failure + $Arguments: lock type, oldpassword, new password +*******************************************************************************/ + +void mmi_phlock_change_pin(T_MFW_HND win,int type,char* oldpsw,char* newpsw) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + TRACE_FUNCTION("mmi_phlock_change_pin()"); + TRACE_EVENT_P2(" old pasword%s new password%s ",oldpsw,newpsw); + if(mfw_phlock_change_lock_code(type,oldpsw,newpsw) !=MFW_SS_OK) + { + TRACE_EVENT("mmi_phlock_change_pin: FAILED"); + SEND_EVENT(pin_data->pin_win,PH_LOCK_NEW_ENDISFAIL,0,pin_data); + } + else + { + TRACE_EVENT("mmi_phlock_change_pin: SUCCESS"); + SEND_EVENT(pin_data->pin_win,PH_LOCK_NEW_ENDSUCC,0,pin_data); + } +} + +/******************************************************************************* + + $Function: mmi_phlock_show_info + + $Description: Display the Dialog + + $Returns: + + $Arguments: + +*******************************************************************************/ +static MfwHnd mmi_phlock_show_info(T_MFW_HND parent, int str1, int str2, T_VOID_FUNC callback) +{ + T_DISPLAY_DATA display_info; + + TRACE_FUNCTION ("mmi_phlock_show_info()"); + + /* + ** Create a timed dialog to display the Message "Failed" + */ + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, str1, str2, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, callback, THREE_SECS, KEY_LEFT | KEY_CLEAR | KEY_HUP); + return phlock_info_dialog(parent, &display_info); +} + + +/******************************************************************************* + + $Function: phlock_setting_pin_create + $Description: Creation of an instance for the Settings PIN main dialog. + Type of dialog : SINGLE_DYNAMIC + Top Window must be available at any time, only one instance. + $Returns: window + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND phlock_setting_pin_create (T_MFW_HND parent_window) +{ + + T_pin * data = (T_pin *)ALLOC_MEMORY (sizeof (T_pin)); + T_MFW_WIN * win; + + data->pin_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)phlock_setting_pin_win_cb); + + TRACE_FUNCTION("MmiPins:phlock_setting_pin_create"); + + set_pin_windows = data->pin_win; + + if (data->pin_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)phlock_setting_pin_main; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->sim_handle = sim_create(data->pin_win,E_SIM_ALL_SERVICES,(MfwCb)sim_event_cb_setting); + + /* + * Initialise + */ + data->set_state = DEFAULT; + data->puk_request = FALSE; + + + mfwSetSignallingMethod(1);//mfw focus handling + winShow(data->pin_win);//focus on settings:PIN/PIN2 Change/act/Deac + + + /* + * return window handle + */ + return data->pin_win; +} +/******************************************************************************* + + $Function: phlock_setting_pin_win_cb + $Description: Callback function for main windows in settings + $Returns: Status int + $Arguments: event, window +*******************************************************************************/ +static int phlock_setting_pin_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ + TRACE_FUNCTION("phlock_setting_pin_win_cb()"); + if (event EQ MfwWinVisible) + { + /* + * Top Window has no output + */ + /* NDH : Removed to prevent Blue Screen on Pin Entry */ + return 1; + } + return 0; + +} + +/******************************************************************************* + + $Function: phlock_setting_pin_main + $Description: PIN Settings Dialog Handling function + $Returns: none + $Arguments: win, event, value, parameters +*******************************************************************************/ +void phlock_setting_pin_main(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user;//pin main data + + TRACE_FUNCTION("phlock_setting_pin_main()"); + + switch(event) + { + case PH_LOCK_ALREADY_ENDIS: + case PH_LOCK_STATUS: + case PH_LOCK_REQ_OLD: + case PH_LOCK_REQ_NEW: + case INPUT_NEW_PH_LOCK_AGAIN: + case NEW_PH_LOCK_FAIL: + case PH_LOCK_NEW_ENDISFAIL: + case PH_LOCK_NEW_ENDSUCC: + case TXT_PH_LOCK_ALL: + case PH_LOCK_ENDSUCC: + case PH_UNLOCK_REQ: + case PH_LOCK_AUTO_SUCC: + case PH_LOCK_SUCC: + case PH_LOCK_ENDIS_FAIL: + phlock_sett_pin_mess(win,event); + break; + } + + switch(event) + { + case TXT_ENTER_PHLOCK: + TRACE_EVENT("phlock_setting_pin_main: TXT_ENTER_PHLOCK"); + pin_data->pin_case = INPUT_PH_LOCK; + phlock_sett_pin_edit(win,INPUT_PH_LOCK); + break; + + case TXT_ENTER_NEW_PHLOCK: + pin_data->pin_case = INPUT_NEW_PH_LOCK; + phlock_sett_pin_edit(win,INPUT_NEW_PH_LOCK); + break; + + case TXT_ENTER_NEW_PHLOCK_AGAIN: + pin_data->pin_case = INPUT_NEW_PH_LOCK_AGAIN; + phlock_sett_pin_edit(win,INPUT_NEW_PH_LOCK_AGAIN); + break; + + case NEW_PH_LOCK_END: + mmi_phlock_change_pin(win,MFW_PH_LOCK,(char*)pin_data->old_pin,(char*)pin_data->new_pin); + break; + + case PH_LOCK_END: + TRACE_EVENT("phlock_setting_pin_main:PH_LOCK_END"); + + //x0pleela 15 May, 2007 DR: OMAPS00127483 + //When ringer for either incoming call or alarm is playing in phone locked state, Audio usues the DMA channels + //which will be active. The DMA channels will be available only after the audio file is fully played. + //This will cause that process to be blocked until the DMA channel becomes in-active and in turn if we try to + //query or access secure driver we are blocked until the audio file is completely played. + //Since this is a hardware constraint, we found a workaround for this issue and are stopping the ringer + //either for incoming call or alarm before accessing secure driver for enabling or disbaling the phone lock. + + if( (( call_data.call_direction == MFW_CM_MTC ) && phlock_dialog_mtc_win_handle) + || (phlock_alarm) ) + { + if( (!phlock_win_handle) + #ifdef FF_MMI_AUDIO_PROFILE + && ( mfwAudPlay) + #endif + ) + { + // Stopping the current ring tone. + #ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + #endif + } + } + mmi_phlock_en_dis_verify(win); + break; + + + case PH_LOCK_SETT_ABORT: + TRACE_EVENT("phlock_setting_pin_main: PH_LOCK_SETT_ABORT"); + phlock_setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + break; + + default: + break; + } + +} + +/******************************************************************************* + + $Function: phlock_sett_pin_mess + $Description: help function for message dialog + $Returns: void + $Arguments: window, event +*******************************************************************************/ +static void phlock_sett_pin_mess(T_MFW_HND win,USHORT event) +{ + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_mess_win; + TRACE_FUNCTION("MmiPins:phlock_sett_pin_mess()"); + + pin_mess_win = phlock_set_pin_mess_create(pin_data->pin_win); + if(pin_mess_win) + { + SEND_EVENT(pin_mess_win,event,0,pin_data); + } +} + + +/******************************************************************************* + + $Function: phlock_set_pin_mess_create + $Description: Creation of an instance for the PIN Message dialog settings + Type of dialog : SINGLE_DYNAMIC + $Returns: void + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND phlock_set_pin_mess_create(T_MFW_HND parent_window) +{ + T_pin_mess * data = (T_pin_mess *)ALLOC_MEMORY (sizeof (T_pin_mess)); + T_MFW_WIN * win; + + data->pin_mess_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)phlock_set_pin_mess_win_cb); + + TRACE_FUNCTION("MmiPins: phlock_set_pin_mess_create"); + + if (data->pin_mess_win EQ 0) + return 0; + + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)phlock_set_pin_messages; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_mess_win)->data; + win->user = (void *) data; + + /* + * return window handle + */ + return data->pin_mess_win; +} + + +/******************************************************************************* + + $Function: phlock_set pin_mess_destroy + $Description: Destroy the pin message dialog settings + $Returns: void + $Arguments: window +*******************************************************************************/ +void phlock_set_pin_mess_destroy (T_MFW_HND own_window) +{ + T_pin_mess * data; + T_MFW_WIN * win; + + + TRACE_FUNCTION("MmiPins: phlock_set_pin_mess_destroy()"); + + if (own_window) + { + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_mess *)win->user; + + if(data) + { + + /* + * Delete WIN Handler + */ + win_delete (data->pin_mess_win); + FREE_MEMORY((void*)data,(sizeof(T_pin_mess))); + } + } +} + +/******************************************************************************* + + $Function: phlock_set_pin_mess_win_cb + $Description: Callback function for message windows + $Returns: void + $Arguments: event, window +*******************************************************************************/ +static int phlock_set_pin_mess_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) +{ +TRACE_FUNCTION("phlock_set_pin_mess_win_cb()"); + /* + * Top Window has no output + */ + return 1; +} + + +/******************************************************************************* + + $Function: phlock_set_pin_messages + $Description: Message Dialog for PIN/PUK handling in settings + $Returns: void + $Arguments: win, event, value, parameter +*******************************************************************************/ +void phlock_set_pin_messages(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_mess * mess_data = (T_pin_mess *)win_data->user; + + T_DISPLAY_DATA display_info; + T_pin * pin_data = (T_pin *)parameter; + TRACE_FUNCTION("Mmi.Pins:phlock_set_pin_messages"); + + /* + * depending on signal + */ + + switch (event) + { + case PH_LOCK_ALREADY_ENDIS: + case PH_LOCK_NEW_ENDSUCC: + case PH_LOCK_ENDSUCC: + case PH_LOCK_AUTO_SUCC: + case PH_LOCK_SUCC: + case PH_LOCK_STATUS: + case NEW_PH_LOCK_FAIL: + case PH_LOCK_NEW_ENDISFAIL: + case PH_LOCK_ENDIS_FAIL: + case PH_LOCK_EN_FAIL: + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNull, TxtNull, COLOUR_STATUS_PINS); + + switch(event) + { + case PH_LOCK_ALREADY_ENDIS: + pin_data->pin_case = PH_LOCK_ALREADY_ENDIS; + display_info.TextId = TxtPhoneLock; + + if(pin_data->set_state == ENABLE) + display_info.TextId2 = TxtAlreadyEnabled; + else if(pin_data->set_state == DISABLE) + display_info.TextId2 = TxtAlreadyDisabled; + + break; + + case PH_LOCK_NEW_ENDSUCC: + if(phlock_win_handle) + phlock_win_handle = NULL; + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + pin_data->pin_case = PH_LOCK_NEW_ENDSUCC; + display_info.TextId = TxtPhoneLock; + display_info.TextId2 = TxtPsLockChanged; + break; + + case PH_LOCK_ENDSUCC: + TRACE_EVENT("phlock_set_pin_messages: PH_LOCK_ENDSUCC"); + if(phlock_win_handle) + phlock_win_handle = NULL; + + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //get the phone lock status + if( mfw_get_Phlock_status() ) + { + TRACE_EVENT("LOCK ENABLED"); + //For USB MS + if( mmi_get_usbms_enum() ) + { + #ifdef FF_MMI_USBMS + //unregister USB enumeration + TRACE_EVENT("USB de-enumeration"); + mfw_usbms_enum_control(MFW_USB_NO_ENUM , MFW_USB_TYPE_ALL); + #endif /*FF_MMI_USBMS*/ + } + //For Headset + if( mmi_get_Headset_Reg() ) + { + #ifdef FF_MMI_AUDIO_PROFILE + //unregister headset + //mfw_headset_unregister(); + TRACE_EVENT("headset unregister"); + mfw_hook_unregister(); + #endif /*FF_MMI_AUDIO_PROFILE*/ + } + pin_data->pin_case = PH_LOCK_ENDSUCC; + } + else + { + TRACE_EVENT("LOCK DISABLED"); + //For USB MS + if( mmi_get_usbms_enum() ) + { + #ifdef FF_MMI_USBMS + //register USB enumeration + TRACE_EVENT("USB re-enumeration"); + mfw_usbms_enum_control(MFW_USB_ENUM , MFW_USB_TYPE_ALL); + #endif /*FF_MMI_USBMS*/ + } + //For Headset + if( mmi_get_Headset_Reg() ) + { + #ifdef FF_MMI_AUDIO_PROFILE + //register headset + //mfw_headset_register(); + if(call_data.win_calling OR call_data.win_incoming OR call_data.calls.numCalls) + { + TRACE_EVENT("headset register"); + mfw_hook_register(); + } + #endif /*FF_MMI_AUDIO_PROFILE*/ + } + pin_data->pin_case = PH_LOCK_SUCCESS; + + } + display_info.TextId = TxtPhone; + display_info.Identifier = pin_data->pin_case; + + if(pin_data->set_state == ENABLE) + { + display_info.TextId2 = TxtLockActivated; + TRACE_EVENT("phlock_set_pin_messages: PH_LOCK_ENDSUCC: Activated"); + } + else if(pin_data->set_state == DISABLE) + { + display_info.TextId2 = TxtLockDeactivated; + TRACE_EVENT("phlock_set_pin_messages: PH_LOCK_ENDSUCC: Deactivated"); + } + + break; + + case PH_LOCK_AUTO_SUCC: + TRACE_EVENT("phlock_set_pin_messages: PH_LOCK_AUTO_SUCC"); + if(phlock_win_handle) + phlock_win_handle = NULL; + + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + //x0pleela 29 May, 2007 DR: OMAPS00132483 + //get the auto phone lock status + if( mfw_get_Auto_Phlock_status() ) + { + display_info.TextId = TxtAutoPhone; + pin_data->pin_case = PH_LOCK_AUTO_SUCC; + autoPhLock_menu = FALSE; + } + if(pin_data->set_state == ENABLE) + { + display_info.TextId2 = TxtLockActivated; + } + else if(pin_data->set_state == DISABLE) + { + display_info.TextId2 = TxtLockDeactivated; + } + break; + + case PH_LOCK_SUCC: + TRACE_EVENT("set_pin_msgs: PH_LOCK_SUCC"); + if(phlock_win_handle) + phlock_win_handle = NULL; + + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //get the phone lock status + if( mfw_get_Phlock_status() ) + { + TRACE_EVENT("LOCK ENABLED"); + //For USB MS + if( mmi_get_usbms_enum() ) + { + #ifdef FF_MMI_USBMS + //unregister USB enumeration + TRACE_EVENT("USB de-enumeration"); + mfw_usbms_enum_control(MFW_USB_NO_ENUM , MFW_USB_TYPE_ALL); + #endif /*FF_MMI_USBMS*/ + } + //For Headset + if( mmi_get_Headset_Reg() ) + { + #ifdef FF_MMI_AUDIO_PROFILE + //unregister headset + //mfw_headset_unregister(); + TRACE_EVENT("headset unregister"); + mfw_hook_unregister(); + #endif /*FF_MMI_AUDIO_PROFILE*/ + } + } + else + { + TRACE_EVENT("LOCK DISABLED"); + //For USB MS + if( mmi_get_usbms_enum() ) + { + #ifdef FF_MMI_USBMS + //register USB enumeration + TRACE_EVENT("USB re-enumeration"); + mfw_usbms_enum_control(MFW_USB_ENUM , MFW_USB_TYPE_ALL); + #endif /*FF_MMI_USBMS*/ + } + //For Headset + if( mmi_get_Headset_Reg() ) + { + #ifdef FF_MMI_AUDIO_PROFILE + //register headset + //mfw_headset_register(); + if(call_data.win_calling OR call_data.win_incoming OR call_data.calls.numCalls) + { + TRACE_EVENT("headset register"); + mfw_hook_register(); + } + #endif /*FF_MMI_AUDIO_PROFILE*/ + } + } + + display_info.TextId = TxtLockActivated; + pin_data->pin_case = PH_LOCK_ENDSUCC; + display_info.Identifier = pin_data->pin_case; + + break; + + case PH_LOCK_STATUS: + pin_data->pin_case = PH_LOCK_STATUS; + display_info.TextId = TxtPhone; + switch(mfw_phlock_get_lock_status(MFW_PH_LOCK)) + { + case MFW_PH_LOCK_DISABLE: + display_info.TextId2 = TxtLockDisabled; + break; + case MFW_PH_LOCK_ENABLE: + display_info.TextId2 = TxtLockEnabled; + break; + } + break; + + case PH_LOCK_NEW_ENDISFAIL: + { + if(phlock_win_handle) + phlock_win_handle = NULL; + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + pin_data->pin_case = FAILURE_PASS_CHG; + display_info.TextId = TxtCodeInc; + display_info.Identifier = pin_data->pin_case; + + } + break; + case NEW_PH_LOCK_FAIL: + if(phlock_win_handle) + phlock_win_handle = NULL; + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + + pin_data->pin_case = INPUT_NEW_PH_LOCK; + display_info.TextId = TxtPsLockConfWrong; + display_info.TextId2 = TxtPsLockConfwrong2; + break; + + case PH_LOCK_ENDIS_FAIL: + TRACE_EVENT("phlock_set_pin_msgs:PH_LOCK_ENDIS_FAIL"); + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //get the phone lock status + if ( mfw_get_Phlock_status() ) + pin_data->pin_case = PH_LOCK_ENDIS_FAIL; + else + pin_data->pin_case = PH_LOCK_FAILURE; + display_info.Identifier = pin_data->pin_case; + + if (autoPhLock_menu ) + autoPhLock_menu = FALSE; + + display_info.TextId = TxtCodeInc; + break; + + case PH_LOCK_EN_FAIL: + pin_data->pin_case = PH_LOCK_FAILURE; + display_info.TextId = TxtNotLocked; + break; + + } + + { + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)phlock_set_pin_info_cb, THREE_SECS, KEY_LEFT ); + display_info.Identifier = pin_data->pin_case; + phlock_set_pin_mess_destroy(mess_data->pin_mess_win); + + phlock_info_dialog(pin_data->pin_win,&display_info); //information screen + dspl_Enable(1); + } + break; + + case TXT_PH_LOCK_ALL: + case PH_UNLOCK_REQ: + TRACE_EVENT(":phlock_set_pin_msgs: TXT_PH_LOCK_ALL"); + pin_data->display_id1 = TxtEnterPhUnlockCode; + phlock_set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PHLOCK,0,pin_data); + break; + case PH_LOCK_REQ_OLD: + pin_data->display_id1 = TxtEnterOldPsLock; + phlock_set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_PHLOCK,0,pin_data); + break; + + case PH_LOCK_REQ_NEW: + pin_data->display_id1 = TxtEnterPsLockNew; + phlock_set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PHLOCK,0,pin_data); + break; + + case INPUT_NEW_PH_LOCK_AGAIN: + pin_data->display_id1 = TxtEnterPsLockconf; + phlock_set_pin_mess_destroy(mess_data->pin_mess_win); + SEND_EVENT(pin_data->pin_win,TXT_ENTER_NEW_PHLOCK_AGAIN,0,pin_data); + break; + default: + break; + } + +} + + +/******************************************************************************* + + $Function: phlock_set_pin_info_cb + $Description: settings pin information screen call back + $Returns: void + $Arguments: win, identifier, reason +*******************************************************************************/ +void phlock_set_pin_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reasons) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; + + TRACE_FUNCTION("MmiPins: phlock_set_pin_info_cb()"); + + switch(identifier) + { + + case PH_LOCK_ENDSUCC: + TRACE_EVENT("PH_LOCK_ENDSUCC"); + + //x0pleela 28 May, 2007 DR: OMAPS00132483 + //get the phone lock status + if( mfw_get_Phlock_status() ) + { + TRACE_EVENT("phlock_set_pin_info_cb: LOCK ENABLED"); + + //For USB MS + if( mmi_get_usbms_enum() ) + { + #ifdef FF_MMI_USBMS + //unregister USB enumeration + TRACE_EVENT("USB de-enumeration"); + mfw_usbms_enum_control(MFW_USB_NO_ENUM , MFW_USB_TYPE_ALL); + #endif /*FF_MMI_USBMS*/ + } + + pin_data->set_state = DISABLE; + identifier = pin_data->pin_case = PH_UNLOCK_REQ; + SEND_EVENT(pin_data->pin_win,identifier,0,NULL); + } + + break; + + case PH_LOCK_ENDIS_FAIL: + TRACE_EVENT("PH_LOCK_ENDIS_FAIL"); + dspl_Enable(1); + pin_data->set_state = DISABLE; + identifier = pin_data->pin_case = PH_UNLOCK_REQ; + + //x0pleela 15 May, 2007 DR: OMAPS00127483 + //Starting the ringer again for either incoming call or alarm if the user has entered wrong unlocking pasword. + if( ( ( ( call_data.call_direction == MFW_CM_MTC ) && (phlock_dialog_mtc_win_handle) ) || ( phlock_alarm ) ) + && (phlock_win_handle) + #ifdef FF_MMI_AUDIO_PROFILE + && ( !mfwAudPlay) + #endif + ) + { + if( call_data.call_direction == MFW_CM_MTC ) + { + #ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_IC, TRUE, sounds_midi_ringer_start_cb); + #endif + } + else if ( phlock_alarm ) + { + #ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_ALARM, TRUE, sounds_midi_ringer_start_cb); + #endif + } + + } + SEND_EVENT(pin_data->pin_win,identifier,0,NULL); + break; + + case PH_LOCK_SETT_ABORT: + SEND_EVENT(pin_data->pin_win,identifier,0,NULL);//pin_main data !! + break; + + + default: + switch (reasons) + { + case INFO_KCD_LEFT: + case INFO_KCD_RIGHT: + + case INFO_TIMEOUT: + { + pin_skClear(); + phlock_setting_pin_destroy(pin_data->pin_win);// destroy pin settings dialog + //x0pleela 07 Apr, 2007 ER: OMAPS00122561 + if( phlock_alarm) + { + TRACE_EVENT("phlock_set_pin_info_cb: INFO_TIMEOUT "); + if( phlock_alarm_win_handle ) + winShow(phlock_alarm_win_handle); + } + if( call_data.call_direction == MFW_CM_MTC ) + { + if( phlock_mtc_win_handle ) + winShow(phlock_mtc_win_handle); + + if( phlock_dialog_mtc_win_handle ) + winShow(phlock_dialog_mtc_win_handle); + } + } + + break; + } + break; + } + return; +} + +/******************************************************************************* + + $Function: phlock_sett_pin_edit + $Description: help function for editor dialog + $Returns: none + $Arguments: window, event +*******************************************************************************/ +static void phlock_sett_pin_edit(T_MFW_HND win, USHORT event) +{ + +//open the editor for entering the pin + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin * pin_data = (T_pin *)win_data->user; // pin main data + + T_MFW_HND pin_edt_win; + + +TRACE_FUNCTION("phlock_sett_pin_edit()"); + pin_edt_win = phlock_set_pin_edt_create(pin_data->pin_win); + + + + if(pin_edt_win) + { + SEND_EVENT(pin_edt_win,event,0,pin_data); + } + + + +} + + +/******************************************************************************* + + $Function: phlock_set_pin_edt_create + $Description: Creation of an instance for the PIN Editor dialog settings + Type of dialog : SINGLE_DYNAMIC + $Returns: window + $Arguments: parent window +*******************************************************************************/ +T_MFW_HND phlock_set_pin_edt_create (T_MFW_HND parent_window) +{ + T_pin_edt * data = (T_pin_edt *)ALLOC_MEMORY (sizeof (T_pin_edt)); + T_MFW_WIN * win; + + data->pin_edt_win = win_create (parent_window, 0, MfwWinVisible, (T_MFW_CB)phlock_set_pin_edt_win_cb); + + TRACE_FUNCTION("MmiPins:phlock_set_pin_edt_create"); + + if (data->pin_edt_win EQ 0) + return 0; + + phlock_win_handle = data->pin_edt_win; + /* + * Create window handler + */ + data->mmi_control.dialog = (T_DIALOG_FUNC)phlock_set_pin_editor; + data->mmi_control.data = data; + data->parent_win = parent_window; + win = ((T_MFW_HDR *)data->pin_edt_win)->data; + win->user = (void *) data; + + /* + * Create any other handler + */ + + data->tim_out_handle = tim_create(data->pin_edt_win,TIMEOUT,(T_MFW_CB)phlock_pin_edt_tim_out_cb); + +/* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + data->editor = ATB_edit_Create(&data->editorPinAttr,0); +#else /* NEW_EDITOR */ + data->editor_handle = edt_create(data->pin_edt_win,&data->editpinAttr,0,0); +#endif /* NEW_EDITOR */ + data->kbd_handle = kbd_create(data->pin_edt_win,KEY_ALL,(T_MFW_CB)phlock_set_pin_kbd_cb); +phlock_kbd_handle = data->kbd_handle; + + data->kbd_long_handle = kbd_create(data->pin_edt_win,KEY_ALL | KEY_LONG,(T_MFW_CB)phlock_set_pin_edt_kbd_long_cb); + /* + * return window handle + */ + return data->pin_edt_win; +} + +/******************************************************************************* + + $Function: phlock_set_pin_edt_win_cb + $Description: Callback function for editor windows + $Returns: status int + $Arguments: event, window +*******************************************************************************/ +static int phlock_set_pin_edt_win_cb (T_MFW_EVENT event,T_MFW_WIN * win) +{ + T_pin_edt * edt_data = (T_pin_edt *)win->user;//pin edt data + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("phlock_set_pin_edt_win_cb"); + + if (event EQ MfwWinVisible) + { + + /* SPR#1428 - SH - New Editor changes */ + #ifdef NEW_EDITOR + ATB_edit_Show(edt_data->editor); + + if (edt_data->editor->update!=ED_UPDATE_TRIVIAL) + { + /* Set the colour for drawing title */ + + resources_setTitleColour(COLOUR_EDITOR); + + dspl_Clear(0,0, SCREEN_SIZE_X-1, edt_data->editor->attr->win_size.py-1); + + /* Title */ + + if(pin_emergency_call == TRUE) + { + PROMPT(0,0,0,TxtEmergency); + } + else + { + PROMPT(0,0,0,pin_data->display_id1); +#ifdef SIM_PERS + if( pin_data->display_id2) + PROMPT(0,20,0,pin_data->display_id2); +#endif + } + + /* Soft keys */ + + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && (strlen((char*)edt_data->pin) < (MAX_PIN + 1))) + { + if(!(edt_data->gsm_state)) /* usual way for PIN 4 digits */ + { +#ifdef SIM_PERS + if(pin_data->display_id1 == TxtPhoneBlocked) + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + else +#endif + softKeys_displayId(TxtSoftOK,TxtDelete,0, COLOUR_EDITOR_XX); + } + } + //xvilliva - Added the below "if" and moved the existing "if" in to "else". "if" avoids "delete" key display. + if((strlen((char*)edt_data->pin) == 0))// May 13, 2004 REF: CRR 13623 xvilliva + { + TRACE_EVENT("clear softkey 16 - zero length"); + softKeys_displayId(TxtNull,TxtNull,0, COLOUR_EDITOR_XX); + } + else if((strlen((char*)edt_data->pin) < MIN_PIN) && (edt_data->emergency_call != TRUE)) + { + TRACE_EVENT("clear softkey 16"); + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + } +#ifdef SIM_PERS + else if((strlen((char*)edt_data->pin) < MIN_PIN) && (edt_data->emergency_call == TRUE)) + { + TRACE_EVENT("clear softkey 16"); + if(pin_emergency_call == TRUE) + softKeys_displayId(TxtSoftCall,TxtDelete,0, COLOUR_EDITOR_XX); + else + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); + } +#endif + } + + edt_data->editor->update = ED_UPDATE_DEFAULT; + +#else /* NEW_EDITOR */ + pin_icons(); + PROMPT(INFO_TEXT_X,INFO_TEXT_Y,0,pin_data->display_id1); + + TRACE_FUNCTION("softkey 6"); + softKeys_displayId(TxtNull,TxtDelete,0, COLOUR_EDITOR_XX); +#endif /* NEW_EDITOR */ + + return 1; + } + return 0; +} + + + +/******************************************************************************* + + $Function: phlock_set_pin_editor + $Description: Pin editor Dialog Signal Handling function + $Returns: void + $Arguments: window, event, value, parameters +*******************************************************************************/ +static void phlock_set_pin_editor(T_MFW_HND win, USHORT event, SHORT value, void * parameter) +{ + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user; + + T_pin * pin_data = (T_pin *)parameter;//pin main data + + edt_data->pin_case_edit = pin_data->pin_case; + + TRACE_FUNCTION("MmiPins:phlock_set_pin_editor"); + + /* + * depending on event + */ + switch (event) + { + +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK + case INPUT_PH_LOCK: + case INPUT_NEW_PH_LOCK: + case INPUT_NEW_PH_LOCK_AGAIN: +#endif /*FF_PHONE_LOCK*/ + //SPR#717 - GW - Wrong structures being cleared + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ + memset(edt_data->puk, '\0', sizeof(edt_data->puk)); + memset(edt_data->new_pin, '\0', sizeof(edt_data->new_pin)); + memset(edt_data->old_pin, '\0', sizeof(edt_data->old_pin)); + + /* Set up pin entry attributes */ + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + AUI_edit_SetAttr( &edt_data->editorPinAttr, PIN_EDIT_RESET, COLOUR_EDITOR_XX, EDITOR_FONT, 0, ED_CURSOR_UNDERLINE, ATB_DCS_ASCII, (UBYTE *)edt_data->edtbuf, MAX_DIG); + clear_edit_array(edt_data); /* clear editor buffer */ + edt_data->editor_index = 0; + ATB_edit_Init(edt_data->editor); + ATB_edit_Show(edt_data->editor); +#else /* NEW_EDITOR */ + editor_attr_init( &edt_data->editpinAttr, PIN_EDIT_RESET, edtCurBar1,0,(char*)edt_data->edtbuf,MAX_DIG,COLOUR_EDITOR_XX); + clear_edit_array(edt_data); /* clear editor buffer */ + edt_data->editor_index = 0; + edtShow(edt_data->editor_handle); +#endif /* NEW_EDITOR */ + + winShow(edt_data->pin_edt_win); + + break; + + default: + break; + } +} + + + +/******************************************************************************* + + $Function: set_pin_kbd_cb + $Description: Callback function for keyboard settings pin + $Returns: status int + $Arguments: event, keyboard control block +*******************************************************************************/ +static int phlock_set_pin_kbd_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + char timer = TRUE; + + timStop(edt_data->tim_out_handle);/* stop entering timer */ + + TRACE_FUNCTION("MmiPins:phlock_set_pin_kbd_cb"); + +//x0pleela 12 Mar, 2007 ER: OMAPS00122561 +#if defined ( SIM_PERS) || defined (FF_PHONE_LOCK) + #if defined (SIM_PERS ) AND !defined (FF_PHONE_LOCK) + if ( !perm_blocked) + #elif defined (FF_PHONE_LOCK ) AND !defined (SIM_PERS) + if ((mfw_phlock_get_lock_status(MFW_PH_LOCK) == MFW_PH_LOCK_DISABLE) || + (mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK) == MFW_PH_LOCK_DISABLE) ) + #elif defined (SIM_PERS ) AND defined (FF_PHONE_LOCK) + if( ( !perm_blocked) || + (mfw_phlock_get_lock_status(MFW_PH_LOCK) == MFW_PH_LOCK_DISABLE) || + (mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK) == MFW_PH_LOCK_DISABLE)) + #endif + +#endif /* SIM_PERS OR FF_PHONE_LOCK */ + { + switch(kc->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_3: + case KCD_4: + case KCD_5: + case KCD_6: + case KCD_7: + case KCD_8: + case KCD_9: + case KCD_STAR: +//x0pleela 12 Mar, 2007 ER: OMAPS00122561 + if(edt_data->editor_index < PH_MAX_DIG) + { + /* xreddymn OMAPS00083495 Jul-04-2006 + * Limit PIN1, PIN2 entries to 8 digits. + */ + if(( + (edt_data->pin_case_edit==INPUT_PH_LOCK) || + (edt_data->pin_case_edit==INPUT_NEW_PH_LOCK) || + (edt_data->pin_case_edit==INPUT_NEW_PH_LOCK_AGAIN) + ) + &&(edt_data->editor_index>=4) + + && (!edt_data->gsm_state)) + return MFW_EVENT_CONSUMED; + else + { + if(kc->code EQ KCD_STAR) + edt_data->pin[edt_data->editor_index] = STAR; + else + edt_data->pin[edt_data->editor_index] = '0' + kc->code; + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, '*', TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,'*');/* hide security code */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index++; + check_set_pins(win,edt_data); /* digits check depends on status pin_case */ + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + } + winShow(edt_data->pin_edt_win); + break; + + case KCD_HASH: + case KCD_LEFT: + + if(pin_emergency_call == TRUE) + { + callNumber((UBYTE *)pin_emerg_call); + pin_emergency_call = FALSE; +#ifdef FF_PHONE_LOCK + break; +#endif //FF_PHONE_LOCK + } + + + if(!(strncmp((char*)edt_data->pin,"**052*",IDENT_GSM_2))||!(strncmp((char*)edt_data->pin,"**05*",IDENT_GSM_1))) + + { + edt_data->pin[edt_data->editor_index] = HASH; + // SPR#1428 - SH - New Editor changes +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, edt_data->pin[edt_data->editor_index], TRUE); +#else // NEW_EDITOR + edtChar(edt_data->editor_handle,edt_data->pin[edt_data->editor_index]); +#endif // NEW_EDITOR + edt_data->editor_index++; + } + + + + // We save the pin2 entered in to this global variable which we + // use while calling sAT_PlusCLCK(), while locking or unlocking ALS. + memset(g_pin2,0,MAX_PIN+1); + if(edt_data->pin_case_edit EQ INPUT_PIN2 || edt_data->pin_case_edit EQ INPUT_NEW_PIN2) + strncpy(g_pin2,(char*)edt_data->pin,MAX_PIN);//xvilliva SPR17291 + switch(edt_data->pin_case_edit) + { +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK + case INPUT_PH_LOCK: +#endif /*FF_PHONE_LOCK*/ + + TRACE_EVENT_P1("pin_emergency_call = %d", pin_emergency_call); + TRACE_EVENT("When 'Call' is pressed!"); + + /* PIN is long enough, finish editing */ + + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array(edt_data); /* clear editor array */ + timer = FALSE; + strncpy((char*)edt_data->old_pin,(char*)edt_data->pin,MAX_PIN); + strncpy((char*)pin_data->old_pin, (char*)edt_data->old_pin,MAX_PIN); + + if(edt_data->pin_case_edit EQ INPUT_PH_LOCK) + { + TRACE_EVENT("phlock_set_pin_kbd_cb: INPUT_PH_LOCK"); + if(phlock_win_handle) + phlock_win_handle = NULL; + + if( phlock_kbd_handle) + phlock_kbd_handle = NULL; + + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,PH_LOCK_END,0,pin_data); + } + + } + else + { + if(kc->code EQ KCD_HASH) + { + if (!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PIN1) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK + case INPUT_NEW_PH_LOCK: +#endif /*FF_PHONE_LOCK*/ + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array (edt_data); /* clear editor array */ + timer = FALSE; + strncpy((char*)edt_data->new_pin, (char*)edt_data->pin,MAX_PIN); /* store new pin */ + strncpy((char*)pin_data->new_pin, (char*)edt_data->new_pin,MAX_PIN); + + //x0pleela 06 Mar, 2007 ER: OMAPS00122561 + #ifdef FF_PHONE_LOCK + if(pin_data->pin_case EQ INPUT_NEW_PH_LOCK) + { + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,INPUT_NEW_PH_LOCK_AGAIN,0,NULL); + } + #endif /* FF_PHONE_LOCK */ + + } + else + { + if(kc->code EQ KCD_HASH) + { + if(!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + + if(edt_data->pin_case_edit EQ INPUT_NEW_PIN) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; +//x0pleela 06 Mar, 2007 ER: OMAPS00122561 +#ifdef FF_PHONE_LOCK + case INPUT_NEW_PH_LOCK_AGAIN: +#endif /*FF_PHONE_LOCK*/ + + if ((strlen((char*)edt_data->pin) >= MIN_PIN) && !(edt_data->gsm_state)) + { + clear_edit_array (edt_data); /* clear editor array */ + timer = FALSE; + if(strcmp((char*)edt_data->pin, (char*)pin_data->new_pin) EQ 0) /* compare PINs successfull*/ + { + strncpy((char*)pin_data->new_pin, (char*)edt_data->pin,MAX_PIN); + + //x0pleela 06 Mar, 2007 ER: OMAPS00122561 + #ifdef FF_PHONE_LOCK + if (pin_data->pin_case EQ INPUT_NEW_PH_LOCK_AGAIN) + { + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win, NEW_PH_LOCK_END,0,pin_data); + } + #endif /*FF_PHONE_LOCK*/ + + } + else + { /* new PIN != new PIN again */ + + + //x0pleela 06 Mar, 2007 ER: OMAPS00122561 + #ifdef FF_PHONE_LOCK + if (pin_data->pin_case EQ INPUT_NEW_PH_LOCK_AGAIN) + { + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win, NEW_PH_LOCK_FAIL,0,pin_data); + } + #endif /*FF_PHONE_LOCK*/ + + } + } + else + { + if(kc->code EQ KCD_HASH) + { + if (!(edt_data->gsm_state)) /* could become gsm */ + { + check_pins(win,edt_data); + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + else /* finish gsm string */ + { + timer = FALSE; + if(edt_data->pin_case_edit EQ INPUT_NEW_PIN_AGAIN) + pin_data->pin_case = PIN1_REQ_OLD; + else + pin_data->pin_case = PIN2_REQ_OLD; + //xrashmic 1 Jul, 2006 OMAPS00075784 + //Blue screen fix - Wrong window was being sent + gsm_sec_execute_set(pin_data->pin_win,edt_data); /* execute gsm string */ + + } + } + } + break; + + default: + break; + } + break; + +/* KCD_HUP */ + case KCD_HUP: + if( edt_data->pin_case_edit != INPUT_PUK1)//xvilliva SPR13623 + { + clear_edit_array(edt_data); + timer = FALSE; +//x0pleela 30 Mar, 2007 ER OMAPS00122561 +#ifdef FF_PHONE_LOCK + if( (!phlock_win_handle) || (pin_data->set_state != DISABLE) ) + { +#endif //FF_PHONE_LOCK + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,PH_LOCK_SETT_ABORT,0,NULL); // abort settings menu +#ifdef FF_PHONE_LOCK + } +#endif //FF_PHONE_LOCK + } + break; + +/* KCD RIGHT */ + + case KCD_RIGHT: + //nm, go back to the submenu if there is no character on the screen + if(strlen((char*)edt_data->pin) == 0 && edt_data->pin_case_edit != INPUT_PUK1)//xvilliva SPR13623 + { + clear_edit_array(edt_data); + timer = FALSE; +//x0pleela 30 Mar, 2007 ER OMAPS00122561 +#ifdef FF_PHONE_LOCK + if( (!phlock_win_handle) || (pin_data->set_state != DISABLE) ) + { +#endif //FF_PHONE_LOCK + phlock_set_pin_edt_destroy(edt_data->pin_edt_win); + SEND_EVENT(pin_data->pin_win,PH_LOCK_SETT_ABORT,0,NULL); // abort settings menu + return 1; +#ifdef FF_PHONE_LOCK + } +#endif //FF_PHONE_LOCK + } + + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ +#endif /* NEW_EDITOR */ + + if(strlen((char*)edt_data->pin)<MIN_PIN) + { + } + + edt_data->emergency_call = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PUK1) /* special case ?? */ + winShow(edt_data->pin_edt_win); + else + { + check_set_pins(win,edt_data); /* check remain for emergency call */ + winShow(edt_data->pin_edt_win); + } + break; + + default: + break; + } + } +//x0pleela 12 Mar, 2007 ER: OMAPS00122561 +#if defined (SIM_PERS) || defined ( FF_PHONE_LOCK ) + else +#ifdef FF_PHONE_LOCK + if((mfw_phlock_get_lock_status(MFW_PH_LOCK) == MFW_PH_LOCK_ENABLE) || + (mfw_phlock_get_autolock_status(MFW_AUTO_PH_LOCK) == MFW_PH_LOCK_ENABLE) ) +#endif /*FF_PHONE_LOCK*/ + { + switch(kc->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_6: + case KCD_8: + case KCD_9: + if(edt_data->editor_index < MAX_DIG) + { + edt_data->pin[edt_data->editor_index] = '0' + kc->code; + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_AsciiChar(edt_data->editor, '*', TRUE); +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,'*');/* hide security code */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index++; + check_set_pins(win,edt_data); /* digits check depends on status pin_case */ + if(edt_data->gsm_state) + pin_data->gsm_state = edt_data->gsm_state; + } + winShow(edt_data->pin_edt_win); + break; + + + case KCD_LEFT: + + if(pin_emergency_call == TRUE) + { + callNumber((UBYTE *)pin_emerg_call); + pin_emergency_call = FALSE; + } + break; + + case KCD_RIGHT: + +// if( edt_data->edtbuf == '\0' ) +// break; + if(edt_data->editor_index EQ 0) + ; + else + edt_data->editor_index--; + + edt_data->pin[edt_data->editor_index] = '\0'; + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_DeleteLeft(edt_data->editor, TRUE); /* SPR#2342 - SH */ +#else /* NEW_EDITOR */ + edtChar(edt_data->editor_handle,ecBack);/* delete character */ +#endif /* NEW_EDITOR */ + + if(strlen((char*)edt_data->pin)<MIN_PIN) + { + } + + edt_data->emergency_call = FALSE; + if(edt_data->pin_case_edit EQ INPUT_PUK1) /* special case ?? */ + winShow(edt_data->pin_edt_win); + else + { + check_set_pins(win,edt_data); /* check remain for emergency call */ + winShow(edt_data->pin_edt_win); + } + break; + + default: + break; + } + } +#endif /* SIM_PERS OR FF_PHONE_LOCK*/ + if (timer) + tim_start(edt_data->tim_out_handle);/* start timer for entering */ + return 1; +} + + + +/******************************************************************************* + + $Function: phlock_set_pin_edt_kbd_long_cb + $Description: Callback function for keyboard long + $Returns: status int + $Arguments: event, keyboard control block +*******************************************************************************/ +static int phlock_set_pin_edt_kbd_long_cb (T_MFW_EVENT event,T_MFW_KBD * kc) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user;//pin edt data + + TRACE_FUNCTION("MmiPins:phlock_set_pin_edt_kbd_long_cb"); + + if ((event & KEY_CLEAR) && (event & KEY_LONG)) + { + timStop(edt_data->tim_out_handle); /* stop entering timer */ + clear_edit_array(edt_data); + memset(edt_data->pin,'\0',sizeof(edt_data->pin));/* initial string */ + + /* SPR#1428 - SH - New Editor: string changed, update word-wrap*/ + #ifdef NEW_EDITOR + ATB_edit_Refresh(edt_data->editor); + #endif /* NEW_EDITOR */ + edt_data->editor_index = 0; + edt_data->emergency_call = FALSE; + winShow(edt_data->pin_edt_win); + } + + return MFW_EVENT_CONSUMED; +} + +/******************************************************************************* + + $Function: phlock_pin_edt_tim_out_cb + $Description: Callback function for timer (watchdog entering) + $Returns: void + $Arguments: window handler event, timer control block + +*******************************************************************************/ +static void phlock_pin_edt_tim_out_cb (T_MFW_EVENT event,T_MFW_TIM * t) +{ + T_MFW_HND win = mfw_parent(mfw_header()); + + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_pin_edt * edt_data = (T_pin_edt *)win_data->user; + + T_MFW_WIN * win_pin =((T_MFW_HDR *)edt_data->parent_win)->data; + T_pin * pin_data = (T_pin *)win_pin->user; // pin main data + + TRACE_FUNCTION("MmiPins:phlock_pin_edt_tim_out_cb"); + + + TRACE_FUNCTION("clear softkey 7"); + + // clear the softkeys + pin_skClear(); + clear_edit_array(edt_data); + // clear the input + + /* SPR#1428 - SH - New Editor changes */ +#ifdef NEW_EDITOR + ATB_edit_ClearAll(edt_data->editor); +#else /* NEW_EDITOR */ + pin_rectClear( &edt_data->editpinAttr.win ); + memset(edt_data->pin, '\0', sizeof(edt_data->pin));/* initial string */ +#endif /* NEW_EDITOR */ + + edt_data->editor_index = 0; + edt_data->gsm_state = FALSE; + pin_data->gsm_state = FALSE; + + winShow(edt_data->pin_edt_win); +} + +/******************************************************************************* + + $Function: phlock_setting_pin_destroy + $Description: Destroy the settings pin main dialog. + $Returns: none + $Arguments: window +*******************************************************************************/ +void phlock_setting_pin_destroy (T_MFW_HND own_window) +{ + T_pin * data; + T_MFW_WIN * win; + + if (own_window) + { + TRACE_FUNCTION("MmiPins:phlock_setting_pin_destroy"); + + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin *)win->user; + + if(data) + { + /* + * Exit SIM and Delete SIM Handler + */ + sim_delete (data->sim_handle); + + /* + * Delete WIN Handler + */ + set_pin_windows = 0; + win_delete (data->pin_win); + data->pin_win=0; + if(data) + FREE_MEMORY((void *)data,(sizeof(T_pin))); + } + } +} + +/******************************************************************************* + + $Function: phlock_set_pin_edt_destroy + $Description: Destroy the pin editor dialog + $Returns: none + $Arguments: window +*******************************************************************************/ +void phlock_set_pin_edt_destroy(T_MFW_HND own_window) +{ + T_pin_edt * data ; + T_MFW_WIN * win; + + if (own_window) + { + TRACE_FUNCTION("MmiPins:phlock_set_pin_edt_destroy"); + + win = ((T_MFW_HDR *)own_window)->data; + data = (T_pin_edt *)win->user; + + if(data) + { + /* + * Delete WIN Handler + */ + win_delete (data->pin_edt_win); + FREE_MEMORY((void *)data,(sizeof(T_pin_edt))); + } + } +} +#endif /* FF_PHONE_LOCK */ + + +