SecSetCuiGprot.h
10.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
/*****************************************************************************
* Copyright Statement:
* --------------------
* This software is protected by Copyright and the information contained
* herein is confidential. The software may not be copied and the information
* contained herein may not be used or disclosed except with the written
* permission of MediaTek Inc. (C) 2005
*
* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
*
* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/
/*****************************************************************************
*
* Filename:
* ---------
* SecSetCuiGprot.h
*
* Project:
* --------
* MAUI
*
* Description:
* ------------
* Security setting CUI
*
* Author:
* -------
* -------
*
*============================================================================
* HISTORY
* Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
*------------------------------------------------------------------------------
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
*
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
*------------------------------------------------------------------------------
* Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
*============================================================================
****************************************************************************/
#ifndef __CUI_SECSET_GPROT_H__
#define __CUI_SECSET_GPROT_H__
/****************************************************************************
* Include
****************************************************************************/
#include "MMI_features.h"
#include "MMIDataType.h"
#include "mmi_res_range_def.h"
#include "kal_general_types.h"
#include "SecSetProt.h"
/****************************************************************************
* API
****************************************************************************/
/*
* DESCRIPTION
* Return value to disallow closing on PASSIVE_CLOSING event.
* SEE ALSO
* EVT_ID_CUI_VERIFY_PASSIVE_CLOSING
*/
#define CUI_SECSET_DONT_CLOSE (-1)
/*
* DESCRIPTION
* Type of verification CUI.
* SEE ALSO
* cui_verify_create, cui_verify_set_sim
*/
typedef enum
{
#ifndef __MMI_SECSET_SLIM__
CUI_VERIFY_TYPE_CHV1, /* CHV1; need to specify SIM by cui_verify_set_sim() */
#endif
CUI_VERIFY_TYPE_CHV2, /* CHV2; need to specify SIM by cui_verify_set_sim() */
CUI_VERIFY_TYPE_PHONE_PASSWORD, /* Phone password */
CUI_VERIFY_TYPE_END_OF_ENUM
} cui_verify_type_enum;
/*****************************************************************************
* FUNCTION
* cui_verify_create
* DESCRIPTION
* Create a verification CUI
* Note: before using verification CUI, please check whether the password
* is allowed to be verified. For example, CHV2 may be blocked or disabled.
* PARAMETERS
* grp_id : [IN] Parent group ID
* type : [IN] Verification type. If type is CHV1 or CHV2, please call
* cui_verify_set_sim() to specify which SIM.
* RETURNS
* Instance ID
*****************************************************************************/
mmi_id cui_verify_create(mmi_id grp_id, cui_verify_type_enum type);
/*****************************************************************************
* FUNCTION
* cui_verify_set_proc
* DESCRIPTION
* Set proc for the events.
* If application wants to specify the destination of events, can use this
* API to register. Otherwise, the events will be passed to parent's group
* proc.
* Note: events may be still posted into the proc even if parent's group
* destroyed. User should check the validity of user_data, to avoid potential
* violation.
* PARAMETERS
* instance_id : [IN] Instance ID
* proc : [IN] Proc to subscribes events
* user_data : [IN] To be carried in events
* RETURNS
* void
*****************************************************************************/
void cui_verify_set_proc(mmi_id instance_id, mmi_proc_func proc, void *user_data);
/*****************************************************************************
* FUNCTION
* cui_verify_set_sim
* DESCRIPTION
* To specify the SIM. If application create a CHV1 or CHV2 verification CUI,
* it is also needed to give the SIM.
* PARAMETERS
* instance_id : [IN] Instance ID
* sim : [IN] SIM ID.
* On single SIM project, this value can only be MMI_SIM1.
* RETURNS
* void
*****************************************************************************/
void cui_verify_set_sim(mmi_id instance_id, mmi_sim_enum sim);
/*****************************************************************************
* FUNCTION
* cui_verify_run
* DESCRIPTION
* Show the verification screen.
* If the password can not be verified, for example, BLOCKED or DISABLED,
* an result/cancel event will be emitted directly and no screen will be shown.
* PARAMETERS
* instance_id : [IN] Instance ID
* RETURNS
* void
*****************************************************************************/
void cui_verify_run(mmi_id instance_id);
/*****************************************************************************
* FUNCTION
* cui_verify_close
* DESCRIPTION
* Close the verification CUI.
* PARAMETERS
* instance_id : [IN] Instance ID
* RETURNS
* void
*****************************************************************************/
void cui_verify_close(mmi_id instance_id);
/*****************************************************************************
* Events
*****************************************************************************/
/*
* DESCRIPTION
* Verification CUI events.
*/
//#ifdef __MMI_TELEPHONY_SUPPORT__
typedef enum
{
/*
* Verification result.
* If user inputs wrong password, the verification will be continued and
* no event will be emitted, until the verification blocked, cancelled or
* error happens.
*
* Structure:
* cui_verify_result_evt_struct
*/
EVT_ID_CUI_VERIFY_RESULT = CUI_VERIFY_BASE,
/*
* Cancel.
* User selects cancel or SIM status changed and unable to continue
* the verification.
*
* Structure:
* cui_verify_cancel_evt_struct
*/
EVT_ID_CUI_VERIFY_CANCEL,
/*
* Verification is being closed unexpectedly.
* For example, some application calls mmi_frm_group_close() or
* user presses End key to go back to idle.
* User can return CUI_SECSET_DONT_CLOSE to forbid the CUI from being
* closed.
* cui_verify_close() will not trigger this event.
*
* Structure:
* cui_verify_passive_closing_evt_struct
*/
EVT_ID_CUI_VERIFY_PASSIVE_CLOSING,
EVT_ID_CUI_VERIFY_END_OF_ENUM
} cui_verify_event_enum;
//#endif
/*
* DESCRIPTION
* Fail cause of operation.
*/
typedef enum
{
CUI_VERIFY_FAIL_CAUSE_NONE, /* None */
CUI_VERIFY_FAIL_CAUSE_WRONG_PASSWORD, /* Wrong password */
CUI_VERIFY_FAIL_CAUSE_OPERATION_BLOCKED, /* Operation blocked */
CUI_VERIFY_FAIL_CAUSE_DISABLED, /* Password disabled */
CUI_VERIFY_FAIL_CAUSE_TEMP_FAIL, /* Operation blocked */
CUI_VERIFY_FAIL_CAUSE_SIM_ERROR, /* SIM error */
CUI_VERIFY_FAIL_CAUSE_END_OF_ENUM
} cui_verify_fail_cause_enum;
/*
* DESCRIPTION
* Structure of EVT_ID_CUI_VERIFY_RESULT.
* SEE ALSO
* EVT_ID_CUI_VERIFY_RESULT
*/
typedef struct
{
MMI_EVT_GROUP_PARAM_HEADER
MMI_BOOL success; /* Success or not */
cui_verify_fail_cause_enum fail_cause; /* If failed, the cause */
} cui_verify_result_evt_struct;
/*
* DESCRIPTION
* Cause of cancel event.
*/
typedef enum
{
CUI_VERIFY_CANCEL_CAUSE_USER_CANCEL, /* User selects to cancel */
CUI_VERIFY_CANCEL_CAUSE_UNAVAILABLE, /* SIM become unavailable while the CUI is displaying */
CUI_VERIFY_CANCEL_CAUSE_ANOTHER_INST_RUN, /* Another instance with the same SIM & the same type is launched */
CUI_VERIFY_CANCEL_CAUSE_END_OF_ENUM
} cui_verify_cancel_cause_enum;
/*
* DESCRIPTION
* Structure of EVT_ID_CUI_VERIFY_CANCEL.
* SEE ALSO
* EVT_ID_CUI_VERIFY_CANCEL
*/
typedef struct
{
MMI_EVT_GROUP_PARAM_HEADER
cui_verify_cancel_cause_enum cause; /* Cause of the cancel event */
} cui_verify_cancel_evt_struct;
/*
* DESCRIPTION
* Structure of EVT_ID_CUI_VERIFY_PASSIVE_CLOSING.
* SEE ALSO
* EVT_ID_CUI_VERIFY_PASSIVE_CLOSING
*/
typedef struct
{
MMI_EVT_GROUP_PARAM_HEADER
} cui_verify_passive_closing_evt_struct;
#endif /* __CUI_SECSET_GPROT_H__ */