author | mikaruus |
Tue, 19 Oct 2010 13:16:20 +0300 | |
changeset 9 | 8486d82aef45 |
parent 5 | 8ccc39f9d787 |
permissions | -rw-r--r-- |
0 | 1 |
/* |
2 |
* Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies). |
|
3 |
* All rights reserved. |
|
4 |
* This component and the accompanying materials are made available |
|
5 |
* under the terms of the License "Eclipse Public License v1.0" |
|
6 |
* which accompanies this distribution, and is available |
|
7 |
* at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
8 |
* |
|
9 |
* Initial Contributors: |
|
10 |
* Nokia Corporation - initial contribution. |
|
11 |
* |
|
12 |
* Contributors: |
|
13 |
* |
|
14 |
* Description: |
|
15 |
* |
|
16 |
*/ |
|
17 |
||
18 |
||
19 |
#ifndef CMMSECURITYMESSHANDLER_H |
|
20 |
#define CMMSECURITYMESSHANDLER_H |
|
21 |
||
22 |
// INCLUDES |
|
23 |
#include <e32base.h> // Symbian base types |
|
24 |
#include <etelmm.h> //Symbian Etel related types |
|
25 |
||
26 |
#include "mmmmesshandlerbase.h" |
|
27 |
#include "cmmphonetreceiver.h" |
|
28 |
#include "nokiatsy_internal_variation.h" |
|
29 |
#include "cmmuiccmesshandler.h" |
|
30 |
||
31 |
// CONSTANTS |
|
32 |
//none |
|
33 |
||
34 |
// MACROS |
|
35 |
//none |
|
36 |
||
37 |
// DATA TYPES |
|
38 |
//none |
|
39 |
||
40 |
// FUNCTION PROTOTYPES |
|
41 |
//none |
|
42 |
||
43 |
// FORWARD DECLARATIONS |
|
44 |
class CMmNetMessHandler; |
|
45 |
class CMmCallMessHandler; |
|
46 |
class CMmPhoNetSender; |
|
47 |
class CMmDataPackage; |
|
48 |
class TIsiReceiveC; |
|
49 |
class CMmMessageRouter; |
|
50 |
class CMmUiccMessHandler; |
|
51 |
// CLASS DECLARATION |
|
52 |
||
53 |
// DESCRIPTION |
|
54 |
/** |
|
55 |
* Used for creating and sending SECURITY server's ISI messages to |
|
56 |
* PhoNet via PhoNetSender. It also receives SECURITY server's |
|
57 |
* ISI messages from PhoNetReceiver. |
|
58 |
* |
|
59 |
* @lib (unknown) |
|
60 |
* @since 2.6 |
|
61 |
*/ |
|
62 |
class CMmSecurityMessHandler |
|
9 | 63 |
: public CBase, |
64 |
public MMmMessHandlerBase, |
|
65 |
public MMmMessageReceiver, |
|
0 | 66 |
public MUiccOperationBase |
67 |
{ |
|
68 |
||
69 |
public: |
|
70 |
struct CNosBootState |
|
71 |
{ |
|
72 |
TBool iSIMReady; |
|
73 |
TBool iSecReady; |
|
74 |
TBool iSecCodeRequired; |
|
75 |
TBool iPinRequired; |
|
76 |
TBool iPinVerified; |
|
77 |
TBool iSmsPReady; |
|
78 |
TBool iCachingActive; |
|
79 |
#ifdef INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING |
|
80 |
TUint8 iMtcCurrentState; |
|
81 |
#else /* INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING */ |
|
82 |
TUint8 iMceCurrentState; |
|
83 |
#endif /* INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING */ |
|
84 |
}; |
|
85 |
// This enumeration is needed because different phonebook specific |
|
86 |
// requests can be made using the same SIM_PB_REQ/RESP messages. |
|
87 |
// Used as a transaction ID. Storage classes use traId values 0-10. |
|
88 |
enum TFDNListRequestType |
|
89 |
{ |
|
90 |
EGetCurrentFDNListStatus = 11, |
|
91 |
ESetCurrentFDNListStatusToEnabled = 12, |
|
92 |
ESetCurrentFDNListStatusToDisabled = 13 |
|
93 |
}; |
|
94 |
||
95 |
public: // Constructors and destructor |
|
96 |
||
97 |
/** |
|
98 |
* Two-phased constructor. |
|
99 |
* @param aPhoNetSender Pointer to the Phonet sender |
|
100 |
* @param aPhoNetReceiver Pointer to the Phonet receiver |
|
101 |
* @param aNetMessHandler pointer to the net mess handler |
|
102 |
* @param aCallMessHandler pointer to the call mess handler |
|
103 |
* @param aMessageRouter Pointer to the message router |
|
104 |
* @return created message handler object |
|
105 |
*/ |
|
106 |
static CMmSecurityMessHandler* NewL( |
|
107 |
CMmPhoNetSender* aPhoNetSender, |
|
108 |
CMmPhoNetReceiver* aPhoNetReceiver, |
|
109 |
CMmNetMessHandler* aNetMessHandler, |
|
110 |
CMmCallMessHandler* aCallMessHandler, |
|
111 |
CMmMessageRouter* aMessageRouter, |
|
112 |
CMmUiccMessHandler* aUiccMessHandler ); |
|
113 |
||
114 |
/** |
|
115 |
* Destructor. |
|
116 |
*/ |
|
117 |
~CMmSecurityMessHandler(); |
|
118 |
||
119 |
/** |
|
120 |
* Entry point for request from the message manager |
|
121 |
* @param aIpc |
|
122 |
* @param CMmDataPackage |
|
123 |
*/ |
|
124 |
TInt ExtFuncL( |
|
125 |
TInt aIpc, |
|
126 |
const CMmDataPackage* aDataPackage ); |
|
127 |
||
128 |
/** |
|
129 |
* Handles a received message by calling the specific |
|
130 |
* message handling method. |
|
131 |
* @param TIsiReceiveC, reference to the received message. |
|
132 |
* @return TInt: True if message been handled in this message handler |
|
133 |
*/ |
|
134 |
void ReceiveMessageL( const TIsiReceiveC& aIsiMessage ); |
|
135 |
||
136 |
/** |
|
137 |
* Returns GetPukCodeRequired |
|
138 |
* @param None |
|
139 |
* @return TInt |
|
140 |
*/ |
|
141 |
TInt GetPukCodeReq(); |
|
142 |
||
143 |
||
144 |
private: |
|
145 |
||
146 |
/** |
|
147 |
* 2nd phase constructor |
|
148 |
*/ |
|
149 |
void ConstructL(); |
|
150 |
||
151 |
/** |
|
152 |
* Handles requests to verify a security code |
|
153 |
* @param RMobilePhone::TMobilePhoneSecurityCode*: type of sec code |
|
154 |
* @param const RMobilePhone::TCodeAndUnblockCode* aCodes |
|
155 |
* return TInt, success/failure value |
|
156 |
*/ |
|
157 |
TInt VerifySecurityCode( |
|
158 |
RMobilePhone::TMobilePhoneSecurityCode* aType, |
|
159 |
RMobilePhone::TCodeAndUnblockCode* aCodes ); |
|
160 |
||
161 |
||
162 |
/** |
|
163 |
* Handles requsests to change a security code |
|
164 |
* @param TUint8 aTransactionId: Transactionid |
|
165 |
* @param RMobilePhone::TMobilePhoneSecurityCode*: type of sec code |
|
166 |
* @param const RMobilePhone::TMobilePhonePasswordChangeV1* aChange |
|
167 |
* return TInt, success/failure value |
|
168 |
*/ |
|
169 |
TInt SecCodeChangeReq( TUint8 aTransactionId, |
|
170 |
RMobilePhone::TMobilePhoneSecurityCode* aType, |
|
171 |
RMobilePhone::TMobilePhonePasswordChangeV1* aChange ); |
|
172 |
||
173 |
#ifdef INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING |
|
174 |
/** |
|
175 |
* Forms a MTC_RF_STATUS_QUERY_REQ ISI-message. |
|
176 |
* @param TUint8 aTransactionId: Transaction id |
|
177 |
* @return TInt, success/failure value |
|
178 |
*/ |
|
179 |
TInt MtcRfStatusQueryReq( TUint8 aTransactionId ) const; |
|
180 |
||
181 |
/** |
|
182 |
* Breaks a MTC_RF_STATUS_QUERY_RESP ISI-message. |
|
183 |
* @param const TIsiReceiveC& aIsiMessage: Received ISI message |
|
184 |
* @return None |
|
185 |
*/ |
|
186 |
void MtcRfStatusQueryResp( const TIsiReceiveC& aIsiMessage ) const; |
|
187 |
||
188 |
/** |
|
189 |
* Forms a MTC_STATE_QUERY_REQ ISI-message. |
|
190 |
* @param TUint8 aTransactionId: Transaction id |
|
191 |
* @return TInt, success/failure value |
|
192 |
*/ |
|
193 |
TInt MtcStateQueryReq( TUint8 aTransactionId ) const; |
|
194 |
||
195 |
/** |
|
196 |
* Breaks a MTC_STATE_QUERY_RESP ISI-message. |
|
197 |
* @param const TIsiReceiveC& aIsiMessage: Received ISI message |
|
198 |
* @return None |
|
199 |
*/ |
|
200 |
void MtcStateQueryRespL( const TIsiReceiveC& aIsiMessage ); |
|
201 |
||
202 |
/** |
|
203 |
* MTC state info indication. |
|
204 |
* @param const TIsiReceiveC& aIsiMessage: Received ISI message |
|
205 |
* @return void : None |
|
206 |
*/ |
|
207 |
void MtcStateInfoIndL( const TIsiReceiveC& aIsiMessage ); |
|
208 |
#else /* INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING */ |
|
209 |
/** |
|
210 |
* Forms a MCE_RF_STATE_QUERY_REQ ISI-message. |
|
211 |
* @return Error code |
|
212 |
*/ |
|
213 |
TInt MceRfStateQueryReq() const; |
|
214 |
||
215 |
/** |
|
216 |
* Breaks a MCE_RF_STATE_QUERY_RESP ISI-message. |
|
217 |
* @param aIsiMessage: Received ISI message |
|
218 |
* @return None |
|
219 |
*/ |
|
220 |
void MceRfStateQueryResp( const TIsiReceiveC& aIsiMessage ) const; |
|
221 |
||
222 |
/** |
|
223 |
* Forms a MCE_MODEM_STATE_QUERY_REQ ISI-message. |
|
224 |
* @return Error code |
|
225 |
*/ |
|
226 |
TInt MceModemStateQueryReq() const; |
|
227 |
||
228 |
/** |
|
229 |
* Breaks a MCE_MODEM_STATE_QUERY_RESP ISI-message. |
|
230 |
* @param aIsiMessage Received ISI message |
|
231 |
* @return None |
|
232 |
*/ |
|
233 |
void MceModemStateQueryResp( const TIsiReceiveC& aIsiMessage ); |
|
234 |
||
235 |
/** |
|
236 |
* MCE state indication. |
|
237 |
* @param aIsiMessage Received ISI message |
|
238 |
* @return None |
|
239 |
*/ |
|
240 |
void MceModemStateInd( const TIsiReceiveC& aIsiMessage ); |
|
241 |
#endif /* INTERNAL_TESTING_OLD_IMPLEMENTATION_FOR_UICC_TESTING */ |
|
242 |
||
243 |
/** |
|
244 |
* Handles UICC_CARD_IND |
|
245 |
* @param aIsiMessage Received ISI message |
|
246 |
* @return void |
|
247 |
*/ |
|
248 |
void UiccCardInd( const TIsiReceiveC& aIsiMessage ); |
|
249 |
||
250 |
/** |
|
251 |
* Handles UICC_PIN_IND |
|
252 |
* @param aIsiMessage Received ISI message |
|
253 |
* @return void |
|
254 |
*/ |
|
255 |
void UiccPinInd( const TIsiReceiveC& aIsiMessage ); |
|
256 |
||
257 |
/** |
|
258 |
* Creates and sends UICC_PIN_REQ ISI message |
|
259 |
* @param aServiceType Service type |
|
260 |
* @param aCode Code |
|
261 |
* @param aUnblockCode Unblocking code |
|
262 |
* @return Error code |
|
263 |
*/ |
|
264 |
TInt UiccPinReqVerify( |
|
265 |
const TUint8 aServiceType, |
|
266 |
const RMobilePhone::TMobilePassword& aCode, |
|
267 |
const RMobilePhone::TMobilePassword& aUnblockCode); |
|
268 |
||
269 |
/** |
|
270 |
* Handles UICC_PIN_RESP |
|
271 |
* @param aIsiMessage Received ISI message |
|
272 |
* @return void |
|
273 |
*/ |
|
274 |
void UiccPinResp( const TIsiReceiveC& aIsiMessage ); |
|
275 |
||
276 |
/** |
|
277 |
* Creates and sends UICC_PIN_REQ ISI message |
|
278 |
* @param aLock Lock to be queried |
|
279 |
* @return Error code |
|
280 |
*/ |
|
281 |
TInt UiccPinReqStateQuery( |
|
282 |
const RMobilePhone::TMobilePhoneLock aLock ); |
|
283 |
||
284 |
/** |
|
285 |
* Creates and sends UICC_PIN_REQ ISI message |
|
286 |
* @param aType Code type |
|
287 |
* @param aOldCode Current PIN code |
|
288 |
* @param aNewCode New PIN code |
|
289 |
* @return Error code |
|
290 |
*/ |
|
291 |
TInt UiccPinReqChange( |
|
292 |
RMobilePhone::TMobilePhoneSecurityCode& aType, |
|
293 |
const RMobilePhone::TMobilePassword& aOldCode, |
|
294 |
const RMobilePhone::TMobilePassword& aNewCode ); |
|
295 |
||
296 |
/** |
|
297 |
* Creates and sends UICC_PIN_REQ ISI message |
|
298 |
* @param aLock Lock type |
|
299 |
* @param aSetting New setting to be changed |
|
300 |
* @param aCode PIN code |
|
301 |
* @return Error code |
|
302 |
*/ |
|
303 |
TInt UiccPinReqChangeState( |
|
304 |
const RMobilePhone::TMobilePhoneLock aLock, |
|
305 |
const RMobilePhone::TMobilePhoneLockSetting& aSetting, |
|
306 |
const RMobilePhone::TMobilePassword& aCode ); |
|
307 |
||
308 |
/** |
|
309 |
* Handles PIN code verify response |
|
310 |
* @param aStatus Status |
|
311 |
* @param aIsiMessage ISI message |
|
312 |
* @return void |
|
313 |
*/ |
|
314 |
void HandleUiccPinVerifyResp( |
|
315 |
const TUint8 aStatus, |
|
316 |
const TIsiReceiveC& aIsiMessage ); |
|
317 |
||
318 |
/** |
|
319 |
* Handles PIN code state query response |
|
320 |
* @param aStatus Status |
|
321 |
* @param aIsiMessage ISI message |
|
322 |
* @return void |
|
323 |
*/ |
|
324 |
void HandleUiccPinInfoResp( |
|
325 |
const TUint8 aStatus, |
|
326 |
const TIsiReceiveC& aIsiMessage ); |
|
327 |
||
328 |
/** |
|
329 |
* Handles PIN code changing response |
|
330 |
* @param aStatus Status |
|
331 |
* @param aIsiMessage ISI message |
|
332 |
* @return void |
|
333 |
*/ |
|
334 |
void HandleUiccPinChangeResp( |
|
335 |
const TUint8 aStatus, |
|
336 |
const TIsiReceiveC& aIsiMessage ); |
|
337 |
||
338 |
/** |
|
339 |
* Handles PIN code disabling/enabling response |
|
340 |
* @param aStatus Status |
|
341 |
* @param aIsiMessage ISI message |
|
342 |
* @return void |
|
343 |
*/ |
|
344 |
void HandleUiccPinStateChangeResp( |
|
345 |
const TUint8 aStatus, |
|
346 |
const TIsiReceiveC& aIsiMessage ); |
|
347 |
||
348 |
/** |
|
349 |
* Creates and sends SEC_CODE_VERIFY_REQ ISI message |
|
350 |
* @param aCode Code to be verified |
|
351 |
* @return Error code |
|
352 |
*/ |
|
353 |
TInt SecCodeVerifyReq( const RMobilePhone::TMobilePassword& aCode ); |
|
354 |
||
355 |
/** |
|
356 |
* Reads ICC type from UICC message handler and completes it |
|
357 |
* @return void |
|
358 |
*/ |
|
359 |
void GetIccType(); |
|
360 |
||
361 |
/** |
|
362 |
* Reads active PIN from UICC message handler and completes it |
|
363 |
* @return void |
|
364 |
*/ |
|
365 |
void GetActivePin(); |
|
366 |
||
367 |
/** |
|
368 |
* Reads AID of active USIM application from UICC message handler |
|
369 |
* and completes it |
|
370 |
* @return void |
|
371 |
*/ |
|
372 |
void GetActiveUsimApplication(); |
|
373 |
||
374 |
/** |
|
375 |
* Reads elementary file EFest in case of UICC card |
|
376 |
* @param aTraId transaction id used in read req |
|
377 |
* @return Error code |
|
378 |
*/ |
|
379 |
TInt ReadEfEst( TUiccTrId aTraId ); |
|
380 |
||
381 |
/** |
|
382 |
* Sends INVALIDATE/REHABILITATE command for setting |
|
383 |
* FDN state in case of ICC card |
|
384 |
* @return Error code |
|
385 |
*/ |
|
386 |
TInt SendFdnStateCommand(); |
|
387 |
||
388 |
/** |
|
389 |
* Handle UICC response messages |
|
390 |
* @param aTraId Transaction ID |
|
391 |
* @param aFileData Descriptor for file data |
|
392 |
* @return KErrNone or error code |
|
393 |
*/ |
|
394 |
TInt ProcessUiccMsg( |
|
395 |
TInt aTraId, |
|
396 |
TInt aStatus, |
|
5
8ccc39f9d787
New release based on our 2010wk02 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents:
0
diff
changeset
|
397 |
TUint8 aDetails, |
0 | 398 |
const TDesC8& aFileData ); |
399 |
||
400 |
/** |
|
401 |
* Handles EFest read response in FDN state setting |
|
402 |
* @param aStatus Status |
|
403 |
* @param aFileData EFest data |
|
404 |
* @return void |
|
405 |
*/ |
|
406 |
void FdnSetReadEfEstResp( |
|
407 |
TInt aStatus, |
|
408 |
const TDesC8& aFileData ); |
|
409 |
||
410 |
/** |
|
411 |
* Handles EFest read response in FDN state getting |
|
412 |
* @param aStatus Status |
|
413 |
* @param aFileData EFest data |
|
414 |
* @return void |
|
415 |
*/ |
|
416 |
void FdnGetReadEfEstResp( |
|
417 |
TInt aStatus, |
|
418 |
const TDesC8& aFileData ); |
|
419 |
||
420 |
/** |
|
421 |
* Handles EFest read response |
|
422 |
* @param aStatus Status |
|
423 |
* @return void |
|
424 |
*/ |
|
425 |
void WriteEfEstResp( const TInt aStatus ); |
|
9 | 426 |
|
0 | 427 |
/** |
428 |
* Handles INVALIDATE/REHABILITATE command response |
|
429 |
* in case of ICC card |
|
430 |
* @param aStatus Status |
|
431 |
* @param aFileData response from ICC card |
|
432 |
* @return void |
|
433 |
*/ |
|
434 |
void FdnStateCommandResp( |
|
435 |
TInt aStatus, |
|
436 |
const TDesC8& aFileData ); |
|
437 |
||
438 |
/** |
|
439 |
* Sends UICC_APPL_CMD_REQ with service type UICC_APPL_FILE_INFO |
|
440 |
* for reading file info for elementary file EFadn in case of ICC card. |
|
441 |
* @param aTraId Transaction ID |
|
442 |
* @return Error code |
|
443 |
*/ |
|
444 |
TInt ReadEfAdnFileInfo( TUiccTrId aTraId ); |
|
445 |
||
446 |
/** |
|
447 |
* Handles UICC_APPL_CMD_RESP with service type UICC_APPL_FILE_INFO |
|
448 |
* for handling file info for elementary file EFadn in case of ICC card |
|
449 |
* and FDN setting. |
|
450 |
* @param aStatus Status |
|
451 |
* @param aFileData response from ICC card |
|
452 |
* @return void |
|
453 |
*/ |
|
454 |
void FdnSetReadEfAdnFileInfoResp( |
|
455 |
TInt aStatus, |
|
456 |
const TDesC8& aFileData ); |
|
457 |
||
458 |
/** |
|
459 |
* Handles UICC_APPL_CMD_RESP with service type UICC_APPL_FILE_INFO |
|
460 |
* for handling file info for elementary file EFadn in case of ICC card |
|
461 |
* and FDN getting. |
|
462 |
* @param aStatus Status |
|
463 |
* @param aFileData response from ICC card |
|
464 |
* @return void |
|
465 |
*/ |
|
466 |
void FdnGetReadEfAdnFileInfoResp( |
|
467 |
TInt aStatus, |
|
468 |
const TDesC8& aFileData ); |
|
469 |
||
9 | 470 |
/** |
471 |
* Sends pin verified event notification to upper level. |
|
472 |
* @param aStatus Status |
|
473 |
* @return void |
|
474 |
*/ |
|
475 |
void CompleteIfCodeVerified( const TUint8 aStatus ); |
|
476 |
||
0 | 477 |
protected: |
478 |
||
479 |
/** |
|
480 |
* C++ default constructor. |
|
481 |
*/ |
|
482 |
CMmSecurityMessHandler(); |
|
483 |
||
484 |
private: // Data |
|
485 |
||
9 | 486 |
//keep record of security code type when verify it |
487 |
RMobilePhone::TMobilePhoneSecurityCode iSecurityCode; |
|
488 |
||
0 | 489 |
//Pointer to the Message Router |
490 |
CMmMessageRouter* iMessageRouter; |
|
491 |
||
492 |
//Pointer to the Net Message Handler |
|
493 |
CMmNetMessHandler* iNetMessHandler; |
|
494 |
||
495 |
//Pointer to the Call Message Handler |
|
496 |
CMmCallMessHandler* iCallMessHandler; |
|
497 |
||
498 |
//ApplicationNumber of ISIM application |
|
499 |
TUint8 iApplicationNumber; |
|
500 |
||
501 |
// Type of security code in case verify code |
|
502 |
RMobilePhone::TMobilePhoneSecurityCode iSecCodeTypeForVerifyCode; |
|
503 |
||
504 |
// Type of security code in case change code |
|
505 |
RMobilePhone::TMobilePhoneSecurityCode iSecCodeTypeForChangeCode; |
|
506 |
||
507 |
protected: // Data |
|
508 |
||
509 |
//Pointer to the PhonetSender |
|
510 |
CMmPhoNetSender* iPhoNetSender; |
|
511 |
||
512 |
// Pointer to UICC message handler |
|
513 |
CMmUiccMessHandler* iMmUiccMessHandler; |
|
514 |
||
515 |
//Boot state |
|
516 |
CNosBootState iBootState; |
|
517 |
||
518 |
//Is puk code required |
|
519 |
TBool iPukCodeRequired; |
|
520 |
||
521 |
// Active PIN |
|
522 |
RMobilePhone::TMobilePhoneSecurityCode iActivePin; |
|
523 |
||
524 |
// Application ID |
|
525 |
TUint8 iApplicationId; |
|
526 |
||
527 |
// PIN key reference |
|
528 |
TUint8 iPinId; |
|
529 |
||
530 |
// Flag indicating if PIN attempts left query is in case |
|
531 |
TBool iPinAttemptsLeftQuery; |
|
532 |
||
533 |
// Flag indicating if lock state query is in case |
|
534 |
TBool iLockStateQuery; |
|
535 |
||
536 |
// Security code type |
|
537 |
RMobilePhone::TMobilePhoneSecurityCode iCodeType; |
|
9 | 538 |
|
0 | 539 |
// variable to store FDN state which is going |
540 |
// to be set |
|
541 |
RMobilePhone::TMobilePhoneFdnSetting iFdnSetting; |
|
542 |
||
543 |
}; |
|
544 |
||
545 |
||
546 |
#endif // CMMSECURITYMESSHANDLER_H |
|
547 |
||
548 |
// End of File |