• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# @ohos.account.osAccount (System Account) (System API)
2
3The **osAccount** module provides basic capabilities for managing system (OS) accounts, including adding, deleting, querying, setting, subscribing to, and enabling a system account.
4
5> **NOTE**
6>
7> - The initial APIs of this module are supported since API version 7. Newly added APIs will be marked with a superscript to indicate their earliest API version.
8> - This topic describes only the system APIs provided by the module. For details about its public APIs, see [ohos.account.osAccount (System Account Management)](js-apis-osAccount.md).
9
10## Modules to Import
11
12```ts
13import { osAccount } from '@kit.BasicServicesKit';
14```
15
16## AccountManager
17
18Provides APIs for managing system accounts.
19
20### activateOsAccount
21
22activateOsAccount(localId: number, callback: AsyncCallback<void>): void
23
24Activates a system account. This API uses an asynchronous callback to return the result.
25
26**System API**: This is a system API.
27
28**Required permissions**: ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
29
30**System capability**: SystemCapability.Account.OsAccount
31
32**Parameters**
33
34| Name  | Type                      | Mandatory| Description                                               |
35| -------- | ------------------------- | ---- | -------------------------------------------------- |
36| localId  | number                    | Yes  | ID of the target system account.                 |
37| callback | AsyncCallback<void> | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object.|
38
39**Error codes**
40
41| ID| Error Message            |
42| -------- | ------------------- |
43| 201 | Permission denied.|
44| 202 | Not system application.|
45| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
46| 12300001 | The system service works abnormally. |
47| 12300002 | Invalid localId.    |
48| 12300003 | Account not found. |
49| 12300008 | Restricted Account. |
50| 12300016 | The number of logged in accounts reaches the upper limit. |
51
52**Example**: Activate system account 100.
53  ```ts
54  import { BusinessError } from '@kit.BasicServicesKit';
55  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
56  let localId: number = 100;
57  try {
58    accountManager.activateOsAccount(localId, (err: BusinessError)=>{
59      if (err) {
60        console.error(`activateOsAccount failed, code is ${err.code}, message is ${err.message}`);
61      } else {
62        console.log('activateOsAccount successfully');
63      }
64    });
65  } catch (err) {
66    console.log('activateOsAccount failed, error:' + JSON.stringify(err));
67  }
68  ```
69
70### activateOsAccount
71
72activateOsAccount(localId: number): Promise<void>
73
74Activates a system account. This API uses a promise to return the result.
75
76**System API**: This is a system API.
77
78**Required permissions**: ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
79
80**System capability**: SystemCapability.Account.OsAccount
81
82**Parameters**
83
84| Name | Type  | Mandatory| Description                |
85| ------- | ------ | ---- | -------------------- |
86| localId | number | Yes  | ID of the target system account.|
87
88**Return value**
89
90| Type               | Description                                 |
91| ------------------- | ------------------------------------ |
92| Promise<void> | Promise that returns no value.|
93
94**Error codes**
95
96| ID| Error Message            |
97| -------- | ------------------- |
98| 201 | Permission denied.|
99| 202 | Not system application.|
100| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
101| 12300001 | The system service works abnormally. |
102| 12300002 | Invalid localId.    |
103| 12300003 | Account not found. |
104| 12300008 | Restricted Account. |
105| 12300016 | The number of logged in accounts reaches the upper limit. |
106
107**Example**: Activate system account 100.
108  ```ts
109  import { BusinessError } from '@kit.BasicServicesKit';
110  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
111  let localId: number = 100;
112  try {
113    accountManager.activateOsAccount(localId).then(() => {
114      console.log('activateOsAccount successfully');
115    }).catch((err: BusinessError) => {
116      console.log('activateOsAccount failed, err:' + JSON.stringify(err));
117    });
118  } catch (e) {
119    console.log('activateOsAccount exception: ' + JSON.stringify(e));
120  }
121  ```
122
123### deactivateOsAccount<sup>12+</sup>
124
125deactivateOsAccount(localId: number): Promise&lt;void&gt;
126
127Deactivates (logs out of) a system account. This API uses a promise to return the result.
128
129**System API**: This is a system API.
130
131**Required permissions**: ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
132
133**System capability**: SystemCapability.Account.OsAccount
134
135**Parameters**
136
137| Name | Type  | Mandatory| Description                |
138| ------- | ------ | ---- | -------------------- |
139| localId | number | Yes  | ID of the target system account.|
140
141**Return value**
142
143| Type               | Description                                 |
144| ------------------- | ------------------------------------ |
145| Promise&lt;void&gt; | Promise that returns no value.|
146
147**Error codes**
148
149| ID| Error Message            |
150| -------- | ------------------- |
151| 201 | Permission denied.|
152| 202 | Not system application.|
153| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
154| 12300001 | The system service works abnormally. |
155| 12300003 | Account not found. |
156| 12300008 | Restricted Account. |
157
158**Example**: Deactivate system account 100.
159  ```ts
160  import { BusinessError } from '@kit.BasicServicesKit';
161  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
162  let localId: number = 100;
163  try {
164    accountManager.deactivateOsAccount(localId).then(() => {
165      console.log('deactivateOsAccount successfully');
166    }).catch((err: BusinessError) => {
167      console.log('deactivateOsAccount failed, err:' + JSON.stringify(err));
168    });
169  } catch (e) {
170    console.log('deactivateOsAccount exception: ' + JSON.stringify(e));
171  }
172  ```
173
174### isOsAccountActivated<sup>11+</sup>
175
176isOsAccountActivated(localId: number): Promise&lt;boolean&gt;
177
178Checks whether a system account is activated. This API uses a promise to return the result.
179
180**System API**: This is a system API.
181
182**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
183
184**System capability**: SystemCapability.Account.OsAccount
185
186**Parameters**
187
188| Name | Type  | Mandatory| Description                              |
189| ------- | ------ | ---- | --------------------------------- |
190| localId | number | Yes  | ID of the target system account.|
191
192**Return value**
193
194| Type                  | Description                                                      |
195| ---------------------- | ---------------------------------------------------------- |
196| Promise&lt;boolean&gt; | Promise used to return the result. The value **true** means the account is activated; the value **false** means the opposite.|
197
198**Error codes**
199
200| ID| Error Message            |
201| -------- | ------------------- |
202| 201 | Permission denied.|
203| 202 | Not system application.|
204| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
205| 12300001 | The system service works abnormally. |
206| 12300003 | Account not found. |
207
208**Example**: Check whether system account 100 is activated.
209
210  ```ts
211  import { BusinessError } from '@kit.BasicServicesKit';
212  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
213  let localId: number = 100;
214  try {
215    accountManager.isOsAccountActivated(localId).then((isActivated: boolean) => {
216      console.log('isOsAccountActivated successfully, isActivated: ' + isActivated);
217    }).catch((err: BusinessError) => {
218      console.log('isOsAccountActivated failed, error: ' + JSON.stringify(err));
219    });
220  } catch (err) {
221    console.log('isOsAccountActivated exception: ' + JSON.stringify(err));
222  }
223  ```
224
225### isOsAccountConstraintEnabled<sup>11+</sup>
226
227isOsAccountConstraintEnabled(localId: number, constraint: string): Promise&lt;boolean&gt;
228
229Checks whether a constraint is enabled for a system account. This API uses a promise to return the result.
230
231**System API**: This is a system API.
232
233**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
234
235**System capability**: SystemCapability.Account.OsAccount
236
237**Parameters**
238
239| Name    | Type  | Mandatory| Description                               |
240| ---------- | ------ | ---- | ---------------------------------- |
241| localId    | number | Yes  | ID of the target system account. |
242| constraint | string | Yes  | [Constraint](js-apis-osAccount.md#constraints) to check.|
243
244**Return value**
245
246| Type                  | Description                                                                 |
247| --------------------- | --------------------------------------------------------------------- |
248| Promise&lt;boolean&gt; | Promise used to return the result. The value **true** means the specified constraint is enabled; the value **false** means the opposite.|
249
250**Error codes**
251
252| ID| Error Message            |
253| -------- | ------------------- |
254| 201 | Permission denied.|
255| 202 | Not system application.|
256| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
257| 12300001 | The system service works abnormally. |
258| 12300003 | Account not found. |
259
260**Example**: Check whether system account 100 is forbidden to use Wi-Fi.
261
262  ```ts
263  import { BusinessError } from '@kit.BasicServicesKit';
264  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
265  let localId: number = 100;
266  let constraint: string = 'constraint.wifi';
267  try {
268    accountManager.isOsAccountConstraintEnabled(localId, constraint).then((isEnabled: boolean) => {
269      console.log('isOsAccountConstraintEnabled successfully, isEnabled: ' + isEnabled);
270    }).catch((err: BusinessError) => {
271      console.log('isOsAccountConstraintEnabled failed, error: ' + JSON.stringify(err));
272    });
273  } catch (err) {
274    console.log('isOsAccountConstraintEnabled exception: ' + JSON.stringify(err));
275  }
276  ```
277
278### isOsAccountUnlocked<sup>11+</sup>
279
280isOsAccountUnlocked(localId: number): Promise&lt;boolean&gt;
281
282Checks whether a system account has been verified. This API uses a promise to return the result.
283
284**System API**: This is a system API.
285
286**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
287
288**System capability**: SystemCapability.Account.OsAccount
289
290**Parameters**
291
292| Name | Type  | Mandatory| Description                                                             |
293| ------- | ------ | ---- | --------------------------------------------------------------- |
294| localId | number | Yes  | ID of the target system account. If this parameter is not specified, this API checks whether the current system account has been verified.|
295
296**Return value**
297
298| Type                  | Description                                                              |
299| ---------------------- | ----------------------------------------------------------------- |
300| Promise&lt;boolean&gt; | Promise used to return the result. The value **true** means the system account has been verified; the value **false** means the opposite.|
301
302**Error codes**
303
304| ID| Error Message            |
305| -------- | ------------------- |
306| 201 | Permission denied.|
307| 202 | Not system application.|
308| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
309| 12300001 | The system service works abnormally. |
310| 12300003 | Account not found. |
311
312**Example**
313
314  ```ts
315  import { BusinessError } from '@kit.BasicServicesKit';
316  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
317  let localId: number = 100;
318  try {
319    accountManager.isOsAccountUnlocked(localId).then((isVerified: boolean) => {
320      console.log('isOsAccountUnlocked successfully, isVerified: ' + isVerified);
321    }).catch((err: BusinessError) => {
322      console.log('isOsAccountUnlocked failed, error: ' + JSON.stringify(err));
323    });
324  } catch (err) {
325    console.log('isOsAccountUnlocked exception: ' + JSON.stringify(err));
326  }
327  ```
328
329### removeOsAccount
330
331removeOsAccount(localId: number, callback: AsyncCallback&lt;void&gt;): void
332
333Removes a system account. This API uses an asynchronous callback to return the result.
334
335**System API**: This is a system API.
336
337**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
338
339**System capability**: SystemCapability.Account.OsAccount
340
341**Parameters**
342
343| Name  | Type                     | Mandatory| Description                                                |
344| -------- | ------------------------- | ---- | -------------------------------------------------- |
345| localId  | number                    | Yes  | ID of the target system account.                 |
346| callback | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object.|
347
348**Error codes**
349
350| ID| Error Message            |
351| -------- | ------------------- |
352| 201 | Permission denied.|
353| 202 | Not system application.|
354| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
355| 12300001 | The system service works abnormally. |
356| 12300002 | Invalid localId.    |
357| 12300003 | Account not found. |
358| 12300008 | Restricted Account. |
359| 12300010 | Service busy. Possible causes: The target account is being operated. |
360
361**Example**
362
363  ```ts
364  import { BusinessError } from '@kit.BasicServicesKit';
365  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
366  let accountName: string = 'testAccountName';
367  try {
368    accountManager.createOsAccount(accountName, osAccount.OsAccountType.NORMAL,
369      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo) => {
370        accountManager.removeOsAccount(osAccountInfo.localId, (err: BusinessError)=>{
371          if (err) {
372            console.log('removeOsAccount failed, error: ' + JSON.stringify(err));
373          } else {
374            console.log('removeOsAccount successfully');
375          }
376      });
377    });
378  } catch (err) {
379    console.log('removeOsAccount exception: ' + JSON.stringify(err));
380  }
381  ```
382
383### removeOsAccount
384
385removeOsAccount(localId: number): Promise&lt;void&gt;
386
387Removes a system account. This API uses a promise to return the result.
388
389**System API**: This is a system API.
390
391**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
392
393**System capability**: SystemCapability.Account.OsAccount
394
395**Parameters**
396
397| Name | Type  | Mandatory| Description                              |
398| ------- | ------ | ---- | --------------------------------- |
399| localId | number | Yes  | ID of the target system account.|
400
401**Return value**
402
403| Type               | Description                                 |
404| ------------------- | ------------------------------------ |
405| Promise&lt;void&gt; | Promise that returns no value.|
406
407**Error codes**
408
409| ID| Error Message            |
410| -------- | ------------------- |
411| 201 | Permission denied.|
412| 202 | Not system application.|
413| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
414| 12300001 | The system service works abnormally. |
415| 12300002 | Invalid localId.    |
416| 12300003 | Account not found. |
417| 12300008 | Restricted Account. |
418| 12300010 | Service busy. Possible causes: The target account is being operated. |
419
420**Example**
421
422  ```ts
423  import { BusinessError } from '@kit.BasicServicesKit';
424  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
425  let accountName: string = 'testAccountName';
426  try {
427    accountManager.createOsAccount(accountName, osAccount.OsAccountType.NORMAL,
428      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
429        accountManager.removeOsAccount(osAccountInfo.localId).then(() => {
430          console.log('removeOsAccount successfully');
431        }).catch((err: BusinessError) => {
432            console.log('removeOsAccount failed, error: ' + JSON.stringify(err));
433        });
434    });
435  } catch (err) {
436    console.log('removeOsAccount exception: ' + JSON.stringify(err));
437  }
438  ```
439
440### setOsAccountConstraints
441
442setOsAccountConstraints(localId: number, constraints: Array&lt;string&gt;, enable: boolean,callback: AsyncCallback&lt;void&gt;): void
443
444Sets or removes constraints for a system account. This API uses an asynchronous callback to return the result.
445
446**System API**: This is a system API.
447
448**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
449
450**System capability**: SystemCapability.Account.OsAccount
451
452**Parameters**
453
454| Name     | Type                     | Mandatory| Description                                            |
455| ----------- | ------------------------- | ---- | ----------------------------------------------- |
456| localId     | number                    | Yes  | ID of the target system account.              |
457| constraints | Array&lt;string&gt;       | Yes  | [Constraints](js-apis-osAccount.md#constraints) to set or remove.       |
458| enable      | boolean                   | Yes  | Whether to set or remove constraints. The value **true** means to set constraints, and **false** means to remove constraints.                         |
459| callback    | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object.|
460
461**Error codes**
462
463| ID| Error Message            |
464| -------- | ------------------- |
465| 201 | Permission denied.|
466| 202 | Not system application.|
467| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
468| 12300001 | The system service works abnormally. |
469| 12300002 | Invalid localId or constraints.    |
470| 12300003 | Account not found. |
471| 12300008 | Restricted Account. |
472
473**Example**: Disable Wi-Fi for system account 100.
474
475  ```ts
476  import { BusinessError } from '@kit.BasicServicesKit';
477  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
478  let localId: number = 100;
479  let constraint: string = 'constraint.wifi';
480  try {
481    accountManager.setOsAccountConstraints(localId, [constraint], true, (err: BusinessError) => {
482      if (err) {
483        console.log('setOsAccountConstraints failed, error: ' + JSON.stringify(err));
484      } else {
485        console.log('setOsAccountConstraints successfully');
486      }
487    });
488  } catch (err) {
489    console.log('setOsAccountConstraints exception: ' + JSON.stringify(err));
490  }
491  ```
492
493### setOsAccountConstraints
494
495setOsAccountConstraints(localId: number, constraints: Array&lt;string&gt;, enable: boolean): Promise&lt;void&gt;
496
497Sets or removes constraints for a system account. This API uses a promise to return the result.
498
499**System API**: This is a system API.
500
501**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
502
503**System capability**: SystemCapability.Account.OsAccount
504
505**Parameters**
506
507| Name     | Type               | Mandatory| Description                                        |
508| ----------- | ------------------- | ---- | -------------------------------------------- |
509| localId     | number              | Yes  | ID of the target system account.          |
510| constraints | Array&lt;string&gt; | Yes  | [Constraints](js-apis-osAccount.md#constraints) to set or remove.   |
511| enable      | boolean             | Yes  | Set or remove constraints. The value **true** means to set constraints, and **false** means to remove constraints.                    |
512
513**Return value**
514
515| Type               | Description                                |
516| :------------------ | :----------------------------------- |
517| Promise&lt;void&gt; | Promise that returns no value.|
518
519**Error codes**
520
521| ID| Error Message            |
522| -------- | ------------------- |
523| 201 | Permission denied.|
524| 202 | Not system application.|
525| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
526| 12300001 | The system service works abnormally. |
527| 12300002 | Invalid localId or constraints.    |
528| 12300003 | Account not found. |
529| 12300008 | Restricted Account. |
530
531**Example**: Remove the constraint on the use of Wi-Fi for system account 100.
532
533  ```ts
534  import { BusinessError } from '@kit.BasicServicesKit';
535  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
536  let localId: number = 100;
537  try {
538    accountManager.setOsAccountConstraints(localId, ['constraint.location.set'], false).then(() => {
539      console.log('setOsAccountConstraints succsuccessfully');
540    }).catch((err: BusinessError) => {
541      console.log('setOsAccountConstraints failed, error: ' + JSON.stringify(err));
542    });
543  } catch (err) {
544    console.log('setOsAccountConstraints exception: ' + JSON.stringify(err));
545  }
546  ```
547
548### setOsAccountName
549
550setOsAccountName(localId: number, localName: string, callback: AsyncCallback&lt;void&gt;): void
551
552Sets the name of a system account. This API uses an asynchronous callback to return the result.
553
554**System API**: This is a system API.
555
556**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
557
558**System capability**: SystemCapability.Account.OsAccount
559
560**Parameters**
561
562| Name   | Type                     | Mandatory| Description                                            |
563| :-------- | ------------------------- | ---- | ----------------------------------------------- |
564| localId   | number                    | Yes  | ID of the target system account.              |
565| localName | string                    | Yes  | Account name to set. The value cannot exceed 1024 characters.                         |
566| callback  | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object.|
567
568**Error codes**
569
570| ID| Error Message            |
571| -------- | ------------------- |
572| 201 | Permission denied.|
573| 202 | Not system application.|
574| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
575| 12300001 | The system service works abnormally. |
576| 12300002 | Invalid localId or localName. |
577| 12300003 | Account not found. |
578| 12300008 | Restricted Account. |
579
580**Example**: Set the name of system account 100 to **demoName**.
581
582  ```ts
583  import { BusinessError } from '@kit.BasicServicesKit';
584  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
585  let localId: number = 100;
586  let name: string = 'demoName';
587  try {
588    accountManager.setOsAccountName(localId, name, (err: BusinessError) => {
589      if (err) {
590        console.log('setOsAccountName failed, error: ' + JSON.stringify(err));
591      } else {
592        console.log('setOsAccountName successfully');
593      }
594    });
595  } catch (err) {
596    console.log('setOsAccountName exception: ' + JSON.stringify(err));
597  }
598  ```
599
600### setOsAccountName
601
602setOsAccountName(localId: number, localName: string): Promise&lt;void&gt;
603
604Sets the name of a system account. This API uses a promise to return the result.
605
606**System API**: This is a system API.
607
608**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
609
610**System capability**: SystemCapability.Account.OsAccount
611
612**Parameters**
613
614| Name   | Type  | Mandatory| Description                               |
615| --------- | ------ | ---- | --------------------------------- |
616| localId   | number | Yes  | ID of the target system account.|
617| localName | string | Yes  | Account name to set. The value cannot exceed 1024 characters.           |
618
619**Return value**
620
621| Type               | Description                                 |
622| ------------------- | ------------------------------------ |
623| Promise&lt;void&gt; | Promise that returns no value.|
624
625**Error codes**
626
627| ID| Error Message            |
628| -------- | ------------------- |
629| 201 | Permission denied.|
630| 202 | Not system application.|
631| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
632| 12300001 | The system service works abnormally. |
633| 12300002 | Invalid localId or localName.    |
634| 12300003 | Account not found. |
635| 12300008 | Restricted Account. |
636
637**Example**: Set the name of system account 100 to **demoName**.
638
639  ```ts
640  import { BusinessError } from '@kit.BasicServicesKit';
641  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
642  let localId: number = 100;
643  let name: string = 'testName';
644  try {
645    accountManager.setOsAccountName(localId, name).then(() => {
646      console.log('setOsAccountName successfully');
647    }).catch((err: BusinessError) => {
648      console.log('setOsAccountName failed, error: ' + JSON.stringify(err));
649    });
650  } catch (err) {
651    console.log('setOsAccountName exception: ' + JSON.stringify(err));
652  }
653  ```
654
655### queryMaxOsAccountNumber
656
657queryMaxOsAccountNumber(callback: AsyncCallback&lt;number&gt;): void
658
659Queries the maximum number of system accounts that can be created. This API uses an asynchronous callback to return the result.
660
661**System API**: This is a system API.
662
663**System capability**: SystemCapability.Account.OsAccount
664
665**Parameters**
666
667| Name  | Type                       | Mandatory| Description                                                                             |
668| -------- | --------------------------- | ---- | -------------------------------------------------------------------------------- |
669| callback | AsyncCallback&lt;number&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the maximum number of system accounts that can be created. Otherwise, **err** is an error object.|
670
671**Error codes**
672
673| ID| Error Message      |
674| -------- | ------------- |
675| 202 | Not system application.|
676| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
677| 12300001 | The system service works abnormally. |
678
679**Example**
680
681  ```ts
682  import { BusinessError } from '@kit.BasicServicesKit';
683  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
684  try {
685    accountManager.queryMaxOsAccountNumber((err: BusinessError, maxCnt: number) => {
686      if (err) {
687        console.log('queryMaxOsAccountNumber failed, error:' + JSON.stringify(err));
688      } else {
689        console.log('queryMaxOsAccountNumber successfully, maxCnt:' + maxCnt);
690      }
691    });
692  } catch (err) {
693    console.log('queryMaxOsAccountNumber exception: ' + JSON.stringify(err));
694  }
695  ```
696
697### queryMaxOsAccountNumber
698
699queryMaxOsAccountNumber(): Promise&lt;number&gt;
700
701Queries the maximum number of system accounts that can be created. This API uses a promise to return the result.
702
703**System API**: This is a system API.
704
705**System capability**: SystemCapability.Account.OsAccount
706
707**Return value**
708
709| Type                 | Description                                        |
710| --------------------- | ------------------------------------------- |
711| Promise&lt;number&gt; | Promise used to return the maximum number of system accounts that can be created.|
712
713**Error codes**
714
715| ID| Error Message      |
716| -------- | ------------- |
717| 202 | Not system application.|
718| 12300001 | The system service works abnormally. |
719
720**Example**
721
722  ```ts
723  import { BusinessError } from '@kit.BasicServicesKit';
724  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
725  try {
726    accountManager.queryMaxOsAccountNumber().then((maxCnt: number) => {
727      console.log('queryMaxOsAccountNumber successfully, maxCnt: ' + maxCnt);
728    }).catch((err: BusinessError) => {
729      console.log('queryMaxOsAccountNumber failed, error: ' + JSON.stringify(err));
730    });
731  } catch (err) {
732    console.log('queryMaxOsAccountNumber exception: ' + JSON.stringify(err));
733  }
734  ```
735
736### queryMaxLoggedInOsAccountNumber<sup>12+</sup>
737
738queryMaxLoggedInOsAccountNumber(): Promise&lt;number&gt;
739
740Queries the maximum number of system accounts allowed to log in to the system. This API uses a promise to return the result.
741
742**System API**: This is a system API.
743
744**System capability**: SystemCapability.Account.OsAccount
745
746**Return value**
747
748| Type                 | Description                                        |
749| --------------------- | ------------------------------------------- |
750| Promise&lt;number&gt; | Promise used to return the result.|
751
752**Error codes**
753
754| ID| Error Message      |
755| -------- | ------------- |
756| 202 | Not system application.|
757| 12300001 | The system service works abnormally. |
758
759**Example**
760
761  ```ts
762  import { BusinessError } from '@kit.BasicServicesKit';
763  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
764  try {
765    accountManager.queryMaxLoggedInOsAccountNumber().then((maxNum: number) => {
766      console.log('queryMaxLoggedInOsAccountNumber successfully, maxNum: ' + maxNum);
767    }).catch((err: BusinessError) => {
768      console.log('queryMaxLoggedInOsAccountNumber failed, error: ' + JSON.stringify(err));
769    });
770  } catch (err) {
771    console.log('queryMaxLoggedInOsAccountNumber exception: ' + JSON.stringify(err));
772  }
773  ```
774
775### getEnabledOsAccountConstraints<sup>11+</sup>
776
777getEnabledOsAccountConstraints(localId: number): Promise&lt;Array&lt;string&gt;&gt;
778
779Obtains all the enabled constraints of a system account. This API uses a promise to return the result.
780
781**System API**: This is a system API.
782
783**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
784
785**System capability**: SystemCapability.Account.OsAccount
786
787**Parameters**
788
789| Name | Type  | Mandatory| Description        |
790| ------- | ------ | ---- | ------------ |
791| localId | number | Yes  | ID of the target system account.|
792
793**Return value**
794
795| Type                              | Description                                                      |
796| ---------------------------------- | ---------------------------------------------------------- |
797| Promise&lt;Array&lt;string&gt;&gt; | Promise used to return all the enabled [constraints](js-apis-osAccount.md#constraints) of the system account.|
798
799**Error codes**
800
801| ID| Error Message            |
802| -------- | ------------------- |
803| 201 | Permission denied.|
804| 202 | Not system application.|
805| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
806| 12300001 | The system service works abnormally. |
807| 12300003 | Account not found. |
808
809**Example**: Obtain all constraints of system account 100.
810
811  ```ts
812  import { BusinessError } from '@kit.BasicServicesKit';
813  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
814  let localId: number = 100;
815  try {
816    accountManager.getEnabledOsAccountConstraints(localId).then((constraints: string[]) => {
817      console.log('getEnabledOsAccountConstraints, constraints: ' + constraints);
818    }).catch((err: BusinessError) => {
819      console.log('getEnabledOsAccountConstraints err: ' + JSON.stringify(err));
820    });
821  } catch (e) {
822    console.log('getEnabledOsAccountConstraints exception: ' + JSON.stringify(e));
823  }
824  ```
825
826### queryAllCreatedOsAccounts
827
828queryAllCreatedOsAccounts(callback: AsyncCallback&lt;Array&lt;OsAccountInfo&gt;&gt;): void
829
830Queries information about all the system accounts created. This API uses an asynchronous callback to return the result.
831
832**System API**: This is a system API.
833
834**System capability**: SystemCapability.Account.OsAccount
835
836**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
837
838**Parameters**
839
840| Name  | Type                                                        | Mandatory| Description                                              |
841| -------- | ------------------------------------------------------------ | ---- | -------------------------------------------------- |
842| callback | AsyncCallback&lt;Array&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt;&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is a list of all created system accounts. Otherwise, **data** is an error object.|
843
844**Error codes**
845
846| ID| Error Message      |
847| -------- | ------------- |
848| 201 | Permission denied.|
849| 202 | Not system application.|
850| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
851| 12300001 | The system service works abnormally. |
852
853**Example**
854
855  ```ts
856  import { BusinessError } from '@kit.BasicServicesKit';
857  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
858  try {
859    accountManager.queryAllCreatedOsAccounts((err: BusinessError, accountArr: osAccount.OsAccountInfo[])=>{
860      console.log('queryAllCreatedOsAccounts err:' + JSON.stringify(err));
861      console.log('queryAllCreatedOsAccounts accountArr:' + JSON.stringify(accountArr));
862    });
863  } catch (e) {
864    console.log('queryAllCreatedOsAccounts exception: ' + JSON.stringify(e));
865  }
866  ```
867
868### queryAllCreatedOsAccounts
869
870queryAllCreatedOsAccounts(): Promise&lt;Array&lt;OsAccountInfo&gt;&gt;
871
872Queries information about all the system accounts created. This API uses a promise to return the result.
873
874**System API**: This is a system API.
875
876**System capability**: SystemCapability.Account.OsAccount
877
878**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
879
880**Return value**
881
882| Type                                                       | Description                                          |
883| ----------------------------------------------------------- | --------------------------------------------- |
884| Promise&lt;Array&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt;&gt; | Promise used to return the information about all the system accounts created.|
885
886**Error codes**
887
888| ID| Error Message      |
889| -------- | ------------- |
890| 201 | Permission denied.|
891| 202 | Not system application.|
892| 12300001 | The system service works abnormally. |
893
894**Example**
895
896  ```ts
897  import { BusinessError } from '@kit.BasicServicesKit';
898  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
899  try {
900    accountManager.queryAllCreatedOsAccounts().then((accountArr: osAccount.OsAccountInfo[]) => {
901      console.log('queryAllCreatedOsAccounts, accountArr: ' + JSON.stringify(accountArr));
902    }).catch((err: BusinessError) => {
903      console.log('queryAllCreatedOsAccounts err: ' + JSON.stringify(err));
904    });
905  } catch (e) {
906    console.log('queryAllCreatedOsAccounts exception: ' + JSON.stringify(e));
907  }
908  ```
909
910### createOsAccount
911
912createOsAccount(localName: string, type: OsAccountType, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
913
914Creates a system account. This API uses an asynchronous callback to return the result.
915
916**System API**: This is a system API.
917
918**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
919
920**System capability**: SystemCapability.Account.OsAccount
921
922**Parameters**
923
924| Name   | Type                                                | Mandatory| Description                                                                        |
925| :-------- | ---------------------------------------------------- | ---- | --------------------------------------------------------------------------- |
926| localName | string                                               | Yes  | Name of the system account to create.                                                       |
927| type      | [OsAccountType](js-apis-osAccount.md#osaccounttype)                      | Yes  | Type of the system account to create.                                                       |
928| callback  | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the created system account. Otherwise, **err** is an error object.|
929
930**Error codes**
931
932| ID | Error Message                  |
933| -------- | ------------------------- |
934| 201 | Permission denied.|
935| 202 | Not system application.|
936| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
937| 12300001 | The system service works abnormally. |
938| 12300002 | Invalid localName or type. |
939| 12300004 | Local name already exists. |
940| 12300005 | Multi-user not supported. |
941| 12300006 | Unsupported account type. |
942| 12300007 | The number of accounts has reached the upper limit. |
943
944**Example**
945
946  ```ts
947  import { BusinessError } from '@kit.BasicServicesKit';
948  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
949  try {
950    accountManager.createOsAccount('testName', osAccount.OsAccountType.NORMAL,
951      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
952      console.log('createOsAccount err:' + JSON.stringify(err));
953      console.log('createOsAccount osAccountInfo:' + JSON.stringify(osAccountInfo));
954    });
955  } catch (e) {
956    console.log('createOsAccount exception: ' + JSON.stringify(e));
957  }
958  ```
959
960### createOsAccount
961
962createOsAccount(localName: string, type: OsAccountType, options?: CreateOsAccountOptions): Promise&lt;OsAccountInfo&gt;
963
964Creates a system account. This API uses a promise to return the result.
965
966**System API**: This is a system API.
967
968**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
969
970**System capability**: SystemCapability.Account.OsAccount
971
972**Parameters**
973
974| Name   | Type                           | Mandatory| Description                  |
975| --------- | ------------------------------- | ---- | ---------------------- |
976| localName | string                          | Yes  | Name of the system account to create.|
977| type      | [OsAccountType](js-apis-osAccount.md#osaccounttype) | Yes  | Type of the system account to create.|
978| options      | [CreateOsAccountOptions](js-apis-osAccount-sys.md#createosaccountoptions12) | No  | Options for creating a system account. By default, this parameter is left blank.<br>This parameter is supported since API version 12.|
979
980**Return value**
981
982| Type                                          | Description                                 |
983| ---------------------------------------------- | ------------------------------------- |
984| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise used to return the information about the created system account.|
985
986**Error codes**
987
988| ID | Error Message                  |
989| -------- | ------------------------- |
990| 201 | Permission denied.|
991| 202 | Not system application.|
992| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
993| 12300001 | The system service works abnormally. |
994| 12300002 | Invalid localName, type or options. |
995| 12300004 | Local name already exists. |
996| 12300005 | Multi-user not supported. |
997| 12300006 | Unsupported account type. |
998| 12300007 | The number of accounts has reached the upper limit. |
999| 12300015 | The short name already exists. |
1000
1001**Example**
1002
1003  ```ts
1004  import { BusinessError } from '@kit.BasicServicesKit';
1005  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1006  let options: osAccount.CreateOsAccountOptions = {
1007    shortName: 'myShortName'
1008  }
1009  try {
1010    accountManager.createOsAccount('testAccountName', osAccount.OsAccountType.NORMAL, options).then(
1011      (accountInfo: osAccount.OsAccountInfo) => {
1012      console.log('createOsAccount, accountInfo: ' + JSON.stringify(accountInfo));
1013    }).catch((err: BusinessError) => {
1014      console.log('createOsAccount err: ' + JSON.stringify(err));
1015    });
1016  } catch (e) {
1017    console.log('createOsAccount exception: ' + JSON.stringify(e));
1018  }
1019  ```
1020
1021### createOsAccountForDomain<sup>8+</sup>
1022
1023createOsAccountForDomain(type: OsAccountType, domainInfo: DomainAccountInfo, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
1024
1025Creates a system account and associates it with the specified domain account. This API uses an asynchronous callback to return the result.
1026
1027**System API**: This is a system API.
1028
1029**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1030
1031**System capability**: SystemCapability.Account.OsAccount
1032
1033**Parameters**
1034
1035| Name    | Type                                                | Mandatory| Description                                                                        |
1036| ---------- | ---------------------------------------------------- | ---- | -------------------------------------------------------------------------- |
1037| type       | [OsAccountType](js-apis-osAccount.md#osaccounttype)                      | Yes  | Type of the system account to create.                                                      |
1038| domainInfo | [DomainAccountInfo](#domainaccountinfo8)              | Yes  | Domain account information.                                                              |
1039| callback   | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the created system account. Otherwise, **err** is an error object.|
1040
1041**Error codes**
1042
1043| ID| Error Message                    |
1044| -------- | ------------------- |
1045| 201 | Permission denied.|
1046| 202 | Not system application.|
1047| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1048| 801 | Capability not supported.|
1049| 12300001 | The system service works abnormally. |
1050| 12300002 | Invalid type or domainInfo. |
1051| 12300004 | Account already exists. |
1052| 12300005 | Multi-user not supported. |
1053| 12300006 | Unsupported account type. |
1054| 12300007 | The number of accounts has reached the upper limit. |
1055
1056**Example**
1057
1058  ```ts
1059  import { BusinessError } from '@kit.BasicServicesKit';
1060  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1061  let domainInfo: osAccount.DomainAccountInfo =
1062    {domain: 'testDomain', accountName: 'testAccountName'};
1063  try {
1064    accountManager.createOsAccountForDomain(osAccount.OsAccountType.NORMAL, domainInfo,
1065      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
1066      console.log('createOsAccountForDomain err:' + JSON.stringify(err));
1067      console.log('createOsAccountForDomain osAccountInfo:' + JSON.stringify(osAccountInfo));
1068    });
1069  } catch (e) {
1070    console.log('createOsAccountForDomain exception: ' + JSON.stringify(e));
1071  }
1072  ```
1073
1074### createOsAccountForDomain<sup>8+</sup>
1075
1076createOsAccountForDomain(type: OsAccountType, domainInfo: DomainAccountInfo, options?: CreateOsAccountForDomainOptions): Promise&lt;OsAccountInfo&gt;
1077
1078Creates a system account and associates it with the specified domain account. This API uses a promise to return the result.
1079
1080**System API**: This is a system API.
1081
1082**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1083
1084**System capability**: SystemCapability.Account.OsAccount
1085
1086**Parameters**
1087
1088| Name    | Type                                     | Mandatory| Description                |
1089| ---------- | ---------------------------------------- | ---- | -------------------- |
1090| type       | [OsAccountType](js-apis-osAccount.md#osaccounttype)          | Yes  | Type of the system account to create.|
1091| domainInfo | [DomainAccountInfo](#domainaccountinfo8) | Yes  | Domain account information.         |
1092| options      | [CreateOsAccountForDomainOptions](#createosaccountfordomainoptions12) | No  | Optional parameters for creating the account. By default, this parameter is left blank.<br>This parameter is supported since API version 12.|
1093
1094**Return value**
1095
1096| Type                                          | Description                                   |
1097| ---------------------------------------------- | -------------------------------------- |
1098| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise used to return the information about the created system account.|
1099
1100**Error codes**
1101
1102| ID| Error Message                    |
1103| -------- | ------------------- |
1104| 201 | Permission denied.|
1105| 202 | Not system application.|
1106| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1107| 801 | Capability not supported.|
1108| 12300001 | The system service works abnormally. |
1109| 12300002 | Invalid type, domainInfo or options. |
1110| 12300004 | Account already exists. |
1111| 12300005 | Multi-user not supported. |
1112| 12300006 | Unsupported account type. |
1113| 12300007 | The number of accounts has reached the upper limit. |
1114| 12300015 | The short name already exists. |
1115
1116**Example**
1117
1118  ```ts
1119  import { BusinessError } from '@kit.BasicServicesKit';
1120  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1121  let domainInfo: osAccount.DomainAccountInfo =
1122    {domain: 'testDomain', accountName: 'testAccountName'};
1123  let options: osAccount.CreateOsAccountForDomainOptions = {
1124    shortName: 'myShortName'
1125  }
1126  try {
1127    accountManager.createOsAccountForDomain(osAccount.OsAccountType.NORMAL, domainInfo, options).then(
1128      (accountInfo: osAccount.OsAccountInfo) => {
1129      console.log('createOsAccountForDomain, account info: ' + JSON.stringify(accountInfo));
1130    }).catch((err: BusinessError) => {
1131      console.log('createOsAccountForDomain err: ' + JSON.stringify(err));
1132    });
1133  } catch (e) {
1134    console.log('createOsAccountForDomain exception: ' + JSON.stringify(e));
1135  }
1136  ```
1137
1138### queryOsAccount<sup>11+</sup>
1139
1140queryOsAccount(): Promise&lt;OsAccountInfo&gt;
1141
1142Obtains information about the system account to which the current process belongs. This API uses a promise to return the result.
1143
1144**System API**: This is a system API.
1145
1146**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.GET_LOCAL_ACCOUNTS
1147
1148**System capability**: SystemCapability.Account.OsAccount
1149
1150**Return value**
1151
1152| Type                                          | Description                                      |
1153| ---------------------------------------------- | ----------------------------------------- |
1154| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise used to return the system account information obtained.|
1155
1156**Error codes**
1157
1158| ID| Error Message            |
1159| -------- | ------------------- |
1160| 201 | Permission denied.|
1161| 202 | Not system application.|
1162| 12300001 | The system service works abnormally. |
1163
1164**Example**
1165
1166  ```ts
1167  import { BusinessError } from '@kit.BasicServicesKit';
1168  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1169  try {
1170    accountManager.queryOsAccount().then((accountInfo: osAccount.OsAccountInfo) => {
1171      console.log('queryOsAccount, accountInfo: ' + JSON.stringify(accountInfo));
1172    }).catch((err: BusinessError) => {
1173      console.log('queryOsAccount err: ' + JSON.stringify(err));
1174    });
1175  } catch (e) {
1176    console.log('queryOsAccount exception: ' + JSON.stringify(e));
1177  }
1178  ```
1179
1180### queryOsAccountById
1181
1182queryOsAccountById(localId: number, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
1183
1184Queries information about the system account of the given ID. This API uses an asynchronous callback to return the result.
1185
1186**System API**: This is a system API.
1187
1188**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1189
1190**System capability**: SystemCapability.Account.OsAccount
1191
1192**Parameters**
1193
1194| Name  | Type                                                | Mandatory| Description                                                                      |
1195| -------- | ---------------------------------------------------- | ---- | ------------------------------------------------------------------------ |
1196| localId  | number                                               | Yes  | ID of the target system account.                                                     |
1197| callback | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the system account information obtained. Otherwise, **data** is an error object.|
1198
1199**Error codes**
1200
1201| ID| Error Message            |
1202| -------- | ------------------- |
1203| 201 | Permission denied.|
1204| 202 | Not system application.|
1205| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1206| 12300001 | The system service works abnormally. |
1207| 12300002 | Invalid localId.    |
1208| 12300003 | Account not found. |
1209
1210**Example**: Query information about system account 100.
1211
1212  ```ts
1213  import { BusinessError } from '@kit.BasicServicesKit';
1214  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1215  let localId: number = 100;
1216  try {
1217    accountManager.queryOsAccountById(localId, (err: BusinessError, accountInfo: osAccount.OsAccountInfo)=>{
1218      console.log('queryOsAccountById err:' + JSON.stringify(err));
1219      console.log('queryOsAccountById accountInfo:' + JSON.stringify(accountInfo));
1220    });
1221  } catch (e) {
1222    console.log('queryOsAccountById exception: ' + JSON.stringify(e));
1223  }
1224  ```
1225
1226### queryOsAccountById
1227
1228queryOsAccountById(localId: number): Promise&lt;OsAccountInfo&gt;
1229
1230Queries information about the system account of the given ID. This API uses a promise to return the result.
1231
1232**System API**: This is a system API.
1233
1234**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1235
1236**System capability**: SystemCapability.Account.OsAccount
1237
1238**Parameters**
1239
1240| Name | Type  | Mandatory| Description                |
1241| ------- | ------ | ---- | -------------------- |
1242| localId | number | Yes  | ID of the target system account.|
1243
1244**Return value**
1245
1246| Type                                          | Description                                |
1247| ---------------------------------------------- | ------------------------------------ |
1248| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise used to return the system account information obtained.|
1249
1250**Error codes**
1251
1252| ID| Error Message            |
1253| -------- | ------------------- |
1254| 201 | Permission denied.|
1255| 202 | Not system application.|
1256| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1257| 12300001 | The system service works abnormally. |
1258| 12300002 | Invalid localId. |
1259| 12300003 | Account not found. |
1260
1261**Example**: Query information about system account 100.
1262
1263  ```ts
1264  import { BusinessError } from '@kit.BasicServicesKit';
1265  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1266  let localId: number = 100;
1267  try {
1268    accountManager.queryOsAccountById(localId).then((accountInfo: osAccount.OsAccountInfo) => {
1269      console.log('queryOsAccountById, accountInfo: ' + JSON.stringify(accountInfo));
1270    }).catch((err: BusinessError) => {
1271      console.log('queryOsAccountById err: ' + JSON.stringify(err));
1272    });
1273  } catch (e) {
1274    console.log('queryOsAccountById exception: ' + JSON.stringify(e));
1275  }
1276  ```
1277
1278### getOsAccountProfilePhoto
1279
1280getOsAccountProfilePhoto(localId: number, callback: AsyncCallback&lt;string&gt;): void
1281
1282Obtains the profile photo of a system account. This API uses an asynchronous callback to return the result.
1283
1284**System API**: This is a system API.
1285
1286**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1287
1288**System capability**: SystemCapability.Account.OsAccount
1289
1290**Parameters**
1291
1292| Name  | Type                       | Mandatory| Description                                                                        |
1293| -------- | --------------------------- | ---- | -------------------------------------------------------------------------- |
1294| localId  | number                      | Yes  | ID of the target system account.                                                               |
1295| callback | AsyncCallback&lt;string&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the profile photo information obtained. Otherwise, **err** is an error object.|
1296
1297**Error codes**
1298
1299| ID| Error Message            |
1300| -------- | ------------------- |
1301| 201 | Permission denied.|
1302| 202 | Not system application.|
1303| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1304| 12300001 | The system service works abnormally. |
1305| 12300002 | Invalid localId.    |
1306| 12300003 | Account not found. |
1307
1308**Example**: Obtain the profile photo of system account 100.
1309
1310  ```ts
1311  import { BusinessError } from '@kit.BasicServicesKit';
1312  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1313  let localId: number = 100;
1314  try {
1315    accountManager.getOsAccountProfilePhoto(localId, (err: BusinessError, photo: string)=>{
1316      console.log('getOsAccountProfilePhoto err:' + JSON.stringify(err));
1317      console.log('get photo:' + photo + ' by localId: ' + localId);
1318    });
1319  } catch (e) {
1320    console.log('getOsAccountProfilePhoto exception: ' + JSON.stringify(e));
1321  }
1322  ```
1323
1324### getOsAccountProfilePhoto
1325
1326getOsAccountProfilePhoto(localId: number): Promise&lt;string&gt;
1327
1328Obtains the profile photo of a system account. This API uses a promise to return the result.
1329
1330**System API**: This is a system API.
1331
1332**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1333
1334**System capability**: SystemCapability.Account.OsAccount
1335
1336**Parameters**
1337
1338| Name | Type  | Mandatory| Description        |
1339| ------- | ------ | ---- | ------------ |
1340| localId | number | Yes  | ID of the target system account.|
1341
1342**Return value**
1343
1344| Type                 | Description                                   |
1345| --------------------- | -------------------------------------- |
1346| Promise&lt;string&gt; | Promise used to return the profile photo information obtained.|
1347
1348**Error codes**
1349
1350| ID| Error Message            |
1351| -------- | ------------------- |
1352| 201 | Permission denied.|
1353| 202 | Not system application.|
1354| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1355| 12300001 | The system service works abnormally. |
1356| 12300002 | Invalid localId.    |
1357| 12300003 | Account not found. |
1358
1359**Example**: Obtain the profile photo of system account 100.
1360
1361  ```ts
1362  import { BusinessError } from '@kit.BasicServicesKit';
1363  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1364  let localId: number = 100;
1365  try {
1366    accountManager.getOsAccountProfilePhoto(localId).then((photo: string) => {
1367      console.log('getOsAccountProfilePhoto: ' + photo);
1368    }).catch((err: BusinessError) => {
1369      console.log('getOsAccountProfilePhoto err: ' + JSON.stringify(err));
1370    });
1371  } catch (e) {
1372    console.log('getOsAccountProfilePhoto exception: ' + JSON.stringify(e));
1373  }
1374  ```
1375
1376### setOsAccountProfilePhoto
1377
1378setOsAccountProfilePhoto(localId: number, photo: string, callback: AsyncCallback&lt;void&gt;): void
1379
1380Sets a profile photo for a system account. This API uses an asynchronous callback to return the result.
1381
1382**System API**: This is a system API.
1383
1384**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1385
1386**System capability**: SystemCapability.Account.OsAccount
1387
1388**Parameters**
1389
1390| Name  | Type                     | Mandatory| Description        |
1391| -------- | ------------------------- | ---- | ------------ |
1392| localId  | number                    | Yes  | ID of the target system account.|
1393| photo    | string                    | Yes  | Profile photo information.  |
1394| callback | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object. |
1395
1396**Error codes**
1397
1398| ID| Error Message            |
1399| -------- | ------------------- |
1400| 201 | Permission denied.|
1401| 202 | Not system application.|
1402| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1403| 12300001 | The system service works abnormally. |
1404| 12300002 | Invalid localId or photo.    |
1405| 12300003 | Account not found. |
1406| 12300008 | Restricted Account. |
1407
1408**Example**: Set a profile photo for system account 100.
1409
1410  ```ts
1411  import { BusinessError } from '@kit.BasicServicesKit';
1412  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1413  let localId: number = 100;
1414  let photo: string = ''+
1415  'Cxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAACwSURBVDhPvZLBDYMwDEV/ugsXRjAT0EHCOuFIBwkbdIRewi6unbiAyoGgSn1SFH85+Y'+
1416  'q/4ljARW62X+LHS8uIzjm4dXUYF+utzBikB52Jo5e5iEPKqpACk7R9NM2RvWm5tIkD2czLCUFNKLD6IjdMHFHDzws285MgGrT0xCtp3WOKHo'+
1417  '+7q0mP0DZW9pNmoEFUzrQjp5cCnaen2kSJXLFD8ghbXyZCMQf/8e8Ns1XVAG/XAgqKzVnJFAAAAABJRU5ErkJggg=='
1418  try {
1419    accountManager.setOsAccountProfilePhoto(localId, photo, (err: BusinessError)=>{
1420      console.log('setOsAccountProfilePhoto err:' + JSON.stringify(err));
1421    });
1422  } catch (e) {
1423    console.log('setOsAccountProfilePhoto exception: ' + JSON.stringify(e));
1424  }
1425  ```
1426
1427### setOsAccountProfilePhoto
1428
1429setOsAccountProfilePhoto(localId: number, photo: string): Promise&lt;void&gt;
1430
1431Sets a profile photo for a system account. This API uses a promise to return the result.
1432
1433**System API**: This is a system API.
1434
1435**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1436
1437**System capability**: SystemCapability.Account.OsAccount
1438
1439**Parameters**
1440
1441| Name | Type  | Mandatory| Description        |
1442| ------- | ------ | ---- | ------------ |
1443| localId | number | Yes  | ID of the target system account.|
1444| photo   | string | Yes  | Profile photo information.  |
1445
1446**Return value**
1447
1448| Type               | Description                                |
1449| ------------------- | ------------------------------------ |
1450| Promise&lt;void&gt; | Promise that returns no value.|
1451
1452**Error codes**
1453
1454| ID| Error Message            |
1455| -------- | ------------------- |
1456| 201 | Permission denied.|
1457| 202 | Not system application.|
1458| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1459| 12300001 | The system service works abnormally. |
1460| 12300002 | Invalid localId or photo.    |
1461| 12300003 | Account not found. |
1462| 12300008 | Restricted Account. |
1463
1464**Example**: Set a profile photo for system account 100.
1465
1466  ```ts
1467  import { BusinessError } from '@kit.BasicServicesKit';
1468  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1469  let localId: number = 100;
1470  let photo: string = ''+
1471  'Cxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAACwSURBVDhPvZLBDYMwDEV/ugsXRjAT0EHCOuFIBwkbdIRewi6unbiAyoGgSn1SFH85+Y'+
1472  'q/4ljARW62X+LHS8uIzjm4dXUYF+utzBikB52Jo5e5iEPKqpACk7R9NM2RvWm5tIkD2czLCUFNKLD6IjdMHFHDzws285MgGrT0xCtp3WOKHo'+
1473  '+7q0mP0DZW9pNmoEFUzrQjp5cCnaen2kSJXLFD8ghbXyZCMQf/8e8Ns1XVAG/XAgqKzVnJFAAAAABJRU5ErkJggg=='
1474  try {
1475    accountManager.setOsAccountProfilePhoto(localId, photo).then(() => {
1476      console.log('setOsAccountProfilePhoto success');
1477    }).catch((err: BusinessError) => {
1478      console.log('setOsAccountProfilePhoto err: ' + JSON.stringify(err));
1479    });
1480  } catch (e) {
1481    console.log('setOsAccountProfilePhoto exception: ' + JSON.stringify(e));
1482  }
1483  ```
1484
1485### on
1486
1487on(type: 'activate' | 'activating', name: string, callback: Callback&lt;number&gt;): void
1488
1489Subscribes to the system account activation states, including the states of the account being activated and the account with activation completed. This API uses an asynchronous callback to return the result.
1490
1491**System API**: This is a system API.
1492
1493**Required permissions**: ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1494
1495**System capability**: SystemCapability.Account.OsAccount
1496
1497**Parameters**
1498
1499| Name  | Type                      | Mandatory| Description                                                        |
1500| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1501| type     | 'activate' \| 'activating' | Yes  | Type of the event to subscribe to. The value **activate** indicates that a system account is activated, and **activating** indicates that a system account is being activated.|
1502| name     | string                     | Yes  | Subscription name, which can be customized. The value cannot be empty or exceed 1024 bytes.          |
1503| callback | Callback&lt;number&gt;     | Yes  | Callback used to return the ID of the system account being activated or activated.   |
1504
1505**Error codes**
1506
1507| ID| Error Message      |
1508| -------- | ------------- |
1509| 201 | Permission denied.|
1510| 202 | Not system application.|
1511| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1512| 12300001 | The system service works abnormally. |
1513| 12300002 | Invalid type or name. |
1514
1515**Example**
1516
1517  ```ts
1518  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1519  function onCallback(receiveLocalId: number){
1520    console.log('receive localId:' + receiveLocalId);
1521  }
1522  try {
1523    accountManager.on('activating', 'osAccountOnOffNameA', onCallback);
1524  } catch (e) {
1525    console.log('receive localId exception: ' + JSON.stringify(e));
1526  }
1527  ```
1528
1529### off
1530
1531off(type: 'activate' | 'activating', name: string, callback?: Callback&lt;number&gt;): void
1532
1533Unsubscribes from the system account activation states, including the states of the account being activated and the account with activation completed. This API uses an asynchronous callback to return the result.
1534
1535**System API**: This is a system API.
1536
1537**Required permissions**: ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1538
1539**System capability**: SystemCapability.Account.OsAccount
1540
1541**Parameters**
1542
1543| Name  | Type                      | Mandatory| Description                                                        |
1544| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1545| type     | 'activate' \| 'activating' | Yes  | Type of the event to unsubscribe from. The value **activate** indicates that a system account is activated, and **activating** indicates that a system account is being activated.|
1546| name     | string                     | Yes  | Subscription name, which can be customized. The value cannot be empty or exceed 1024 bytes, and must be the same as the value passed by **on()**.|
1547| callback | Callback&lt;number&gt;     | No  | Callback to unregister. By default, this parameter is left empty, which unregisters all callbacks for the system account activation states.                     |
1548
1549**Error codes**
1550
1551| ID| Error Message      |
1552| -------- | ------------- |
1553| 201 | Permission denied.|
1554| 202 | Not system application.|
1555| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1556| 12300001 | The system service works abnormally. |
1557| 12300002 | Invalid type or name. |
1558
1559**Example**
1560
1561  ```ts
1562  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1563  function offCallback(){
1564    console.log('off enter')
1565  }
1566  try {
1567    accountManager.off('activating', 'osAccountOnOffNameA', offCallback);
1568  } catch (e) {
1569    console.log('off exception: ' + JSON.stringify(e));
1570  }
1571  ```
1572
1573### on<sup>12+</sup>
1574
1575on(type: 'switching', callback: Callback&lt;OsAccountSwitchEventData&gt;): void
1576
1577Subscribes to the switchover between a foreground system account and a background system account in progress. This API uses an asynchronous callback to return the result.
1578
1579**System API**: This is a system API.
1580
1581**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1582
1583**System capability**: SystemCapability.Account.OsAccount
1584
1585**Parameters**
1586
1587| Name  | Type                      | Mandatory| Description                                                        |
1588| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1589| type     | 'switching'                 | Yes  | Event type. The value **switching** indicates that the switchover between a foreground system account and a background account is being performed.|
1590| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | Yes  | Callback used to return the system account IDs before and after the switchover.   |
1591
1592**Error codes**
1593
1594| ID| Error Message      |
1595| -------- | ------------- |
1596| 201 | Permission denied.|
1597| 202 | Not system application.|
1598| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1599| 12300001 | The system service works abnormally. |
1600| 12300002 | Invalid type. |
1601
1602**Example**
1603
1604  ```ts
1605  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1606  function onSwitchingCallback(eventData: osAccount.OsAccountSwitchEventData){
1607    console.log('receive eventData:' + JSON.stringify(eventData));
1608  }
1609  try {
1610    accountManager.on('switching', onSwitchingCallback);
1611  } catch (e) {
1612    console.log('receive eventData exception: ' + JSON.stringify(e));
1613  }
1614  ```
1615
1616### off<sup>12+</sup>
1617
1618off(type: 'switching', callback?: Callback&lt;OsAccountSwitchEventData&gt;): void
1619
1620Unsubscribes from the switchover between a foreground system account and a background system account in progress. This API uses an asynchronous callback to return the result.
1621
1622**System API**: This is a system API.
1623
1624**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1625
1626**System capability**: SystemCapability.Account.OsAccount
1627
1628**Parameters**
1629
1630| Name  | Type                      | Mandatory| Description                                                        |
1631| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1632| type     | 'switching'                 | Yes  | Event type. The value **switching** indicates that the switchover between a foreground system account and a background account is being performed.|
1633| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | No  | Callback to unregister. By default, this parameter is left empty, which unregisters all callbacks for the **switching** event.                     |
1634
1635**Error codes**
1636
1637| ID| Error Message      |
1638| -------- | ------------- |
1639| 201 | Permission denied.|
1640| 202 | Not system application.|
1641| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1642| 12300001 | The system service works abnormally. |
1643| 12300002 | Invalid type. |
1644
1645**Example**
1646
1647  ```ts
1648  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1649  try {
1650    accountManager.off('switching');
1651  } catch (e) {
1652    console.log('off exception: ' + JSON.stringify(e));
1653  }
1654  ```
1655
1656### on<sup>12+</sup>
1657
1658on(type: 'switched', callback: Callback&lt;OsAccountSwitchEventData&gt;): void
1659
1660Subscribes to the end of a switchover between a foreground system account and a background system account. This API uses an asynchronous callback to return the result.
1661
1662**System API**: This is a system API.
1663
1664**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1665
1666**System capability**: SystemCapability.Account.OsAccount
1667
1668**Parameters**
1669
1670| Name  | Type                      | Mandatory| Description                                                        |
1671| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1672| type     | 'switched'                 | Yes  | Event type. The value **switched** indicates that the switchover between a foreground system account and a background system account is complete.|
1673| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | Yes  | Callback used to return the system account IDs before and after the switchover.   |
1674
1675**Error codes**
1676
1677| ID| Error Message      |
1678| -------- | ------------- |
1679| 201 | Permission denied.|
1680| 202 | Not system application.|
1681| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1682| 12300001 | The system service works abnormally. |
1683| 12300002 | Invalid type. |
1684
1685**Example**
1686
1687  ```ts
1688  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1689  function onSwitchedCallback(eventData: osAccount.OsAccountSwitchEventData){
1690    console.log('receive eventData:' + JSON.stringify(eventData));
1691  }
1692  try {
1693    accountManager.on('switched', onSwitchedCallback);
1694  } catch (e) {
1695    console.log('receive eventData exception: ' + JSON.stringify(e));
1696  }
1697  ```
1698
1699### off<sup>12+</sup>
1700
1701off(type: 'switched', callback?: Callback&lt;OsAccountSwitchEventData&gt;): void
1702
1703Unsubscribes from the end of a switchover between a foreground system account and a background system account. This API uses an asynchronous callback to return the result.
1704
1705**System API**: This is a system API.
1706
1707**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1708
1709**System capability**: SystemCapability.Account.OsAccount
1710
1711**Parameters**
1712
1713| Name  | Type                      | Mandatory| Description                                                        |
1714| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1715| type     | 'switched'                 | Yes  | Event type. The value **switched** indicates that the switchover between a foreground system account and a background system account is complete.|
1716| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | No  | Callback to unregister. By default, this parameter is left empty, which unregisters all callbacks for the **switched** event.                     |
1717
1718**Error codes**
1719
1720| ID| Error Message      |
1721| -------- | ------------- |
1722| 201 | Permission denied.|
1723| 202 | Not system application.|
1724| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1725| 12300001 | The system service works abnormally. |
1726| 12300002 | Invalid type. |
1727
1728**Example**
1729
1730  ```ts
1731  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1732  try {
1733    accountManager.off('switched');
1734  } catch (e) {
1735    console.log('off exception: ' + JSON.stringify(e));
1736  }
1737  ```
1738
1739### getBundleIdForUid<sup>9+</sup>
1740
1741getBundleIdForUid(uid: number, callback: AsyncCallback&lt;number&gt;): void
1742
1743Obtains the bundle ID based on the UID. This API uses an asynchronous callback to return the result.
1744
1745**System API**: This is a system API.
1746
1747**System capability**: SystemCapability.Account.OsAccount
1748
1749**Parameters**
1750
1751| Name  | Type                      | Mandatory| Description                                                                       |
1752| -------- | --------------------------- | ---- | ------------------------------------------------------------------------ |
1753| uid      | number                      | Yes  | Process UID.                                                                |
1754| callback | AsyncCallback&lt;number&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the bundle ID obtained. Otherwise, **data** is an error object.|
1755
1756**Error codes**
1757
1758| ID| Error Message      |
1759| -------- | ------------- |
1760| 202 | Not system application.|
1761| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1762| 12300001 | The system service works abnormally. |
1763| 12300002 | Invalid uid. |
1764
1765**Example**
1766
1767  ```ts
1768  import { BusinessError } from '@kit.BasicServicesKit';
1769  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1770  let testUid: number = 1000000;
1771  try {
1772    accountManager.getBundleIdForUid(testUid, (err: BusinessError, bundleId: number) => {
1773      console.info('getBundleIdForUid errInfo:' + JSON.stringify(err));
1774      console.info('getBundleIdForUid bundleId:' + JSON.stringify(bundleId));
1775    });
1776  } catch (e) {
1777    console.info('getBundleIdForUid exception: ' + JSON.stringify(e));
1778  }
1779  ```
1780
1781### getBundleIdForUid<sup>9+</sup>
1782
1783getBundleIdForUid(uid: number): Promise&lt;number&gt;
1784
1785Obtains the bundle ID based on the UID. This API uses a promise to return the result.
1786
1787**System API**: This is a system API.
1788
1789**System capability**: SystemCapability.Account.OsAccount
1790
1791**Parameters**
1792
1793| Name | Type  | Mandatory| Description        |
1794| ------- | ------ | ---- | ------------ |
1795| uid     | number | Yes  |  Process UID.|
1796
1797**Return value**
1798
1799| Type                 | Description                                 |
1800| --------------------- | ------------------------------------ |
1801| Promise&lt;number&gt; | Promise used to return the bundle ID obtained.|
1802
1803**Error codes**
1804
1805| ID| Error Message      |
1806| -------- | ------------- |
1807| 202 | Not system application.|
1808| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1809| 12300001 | The system service works abnormally. |
1810| 12300002 | Invalid uid. |
1811
1812**Example**
1813
1814  ```ts
1815  import { BusinessError } from '@kit.BasicServicesKit';
1816  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1817  let testUid: number = 1000000;
1818  try {
1819    accountManager.getBundleIdForUid(testUid).then((result: number) => {
1820      console.info('getBundleIdForUid bundleId:' + JSON.stringify(result));
1821    }).catch((err: BusinessError) => {
1822      console.info('getBundleIdForUid errInfo:' + JSON.stringify(err));
1823    });
1824  } catch (e) {
1825    console.info('getBundleIdForUid exception: ' + JSON.stringify(e));
1826  }
1827  ```
1828
1829### getBundleIdForUidSync<sup>10+</sup>
1830
1831getBundleIdForUidSync(uid: number): number
1832
1833Obtains the bundle ID based on the specified UID. The API returns the result synchronously.
1834
1835**System API**: This is a system API.
1836
1837**System capability**: SystemCapability.Account.OsAccount
1838
1839**Parameters**
1840
1841| Name | Type  | Mandatory| Description        |
1842| ------- | ------ | ---- | ------------ |
1843| uid     | number | Yes  |  Process UID.|
1844
1845**Return value**
1846
1847| Type  | Description                    |
1848| ------ | ------------------------ |
1849| number | Bundle ID obtained.|
1850
1851**Error codes**
1852
1853| ID| Error Message      |
1854| -------- | ------------- |
1855| 202 | Not system application.|
1856| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1857| 12300002 | Invalid uid. |
1858
1859**Example**
1860
1861  ```ts
1862  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1863  let testUid: number = 1000000;
1864  try {
1865    let bundleId : number = accountManager.getBundleIdForUidSync(testUid);
1866    console.info('getBundleIdForUidSync bundleId:' + bundleId);
1867  } catch (e) {
1868    console.info('getBundleIdForUidSync exception: ' + JSON.stringify(e));
1869  }
1870  ```
1871
1872### isMainOsAccount<sup>9+</sup>
1873
1874isMainOsAccount(callback: AsyncCallback&lt;boolean&gt;): void
1875
1876Checks whether the current process belongs to the main system account. This API uses an asynchronous callback to return the result.
1877
1878**System API**: This is a system API.
1879
1880**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1881
1882**System capability**: SystemCapability.Account.OsAccount
1883
1884**Parameters**
1885
1886| Name  | Type                         | Mandatory| Description                                                              |
1887| -------- | ---------------------------- | ---- | ----------------------------------------------------------------- |
1888| callback | AsyncCallback&lt;boolean&gt; | Yes  | Callback used to return the result. If **true** is returned, the current process belongs to the main system account. If **false** is returned, the current process does not belong to the main system account.|
1889
1890**Error codes**
1891
1892| ID| Error Message      |
1893| -------- | ------------- |
1894| 201 | Permission denied.|
1895| 202 | Not system application.|
1896| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1897| 12300001 | The system service works abnormally. |
1898
1899**Example**
1900
1901  ```ts
1902  import { BusinessError } from '@kit.BasicServicesKit';
1903  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1904  try {
1905    accountManager.isMainOsAccount((err: BusinessError,result: boolean)=>{
1906      console.info('isMainOsAccount errInfo:' + JSON.stringify(err));
1907      console.info('isMainOsAccount result:' + JSON.stringify(result));
1908    });
1909  } catch (e) {
1910    console.info('isMainOsAccount exception: ' + JSON.stringify(e));
1911  }
1912  ```
1913
1914### isMainOsAccount<sup>9+</sup>
1915
1916isMainOsAccount(): Promise&lt;boolean&gt;;
1917
1918Checks whether the current process belongs to the main system account. This API uses a promise to return the result.
1919
1920**System API**: This is a system API.
1921
1922**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1923
1924**System capability**: SystemCapability.Account.OsAccount
1925
1926**Return value**
1927
1928| Type                  | Description                                                                 |
1929| ---------------------- | --------------------------------------------------------------------- |
1930| Promise&lt;boolean&gt; | Promise used to return the result. If **true** is returned, the current process belongs to the main system account. If **false** is returned, the current process does not belong to the main system account.|
1931
1932**Error codes**
1933
1934| ID| Error Message      |
1935| -------- | ------------- |
1936| 201 | Permission denied.|
1937| 202 | Not system application.|
1938| 12300001 | The system service works abnormally. |
1939
1940**Example**
1941
1942  ```ts
1943  import { BusinessError } from '@kit.BasicServicesKit';
1944  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1945  try {
1946    accountManager.isMainOsAccount().then((result: boolean) => {
1947      console.info('isMainOsAccount result:' + JSON.stringify(result));
1948    }).catch((err: BusinessError) => {
1949      console.info('isMainOsAccount errInfo:' + JSON.stringify(err));
1950    });
1951  } catch (e) {
1952    console.info('isMainOsAccount exception: ' + JSON.stringify(e));
1953  }
1954  ```
1955
1956### getOsAccountConstraintSourceTypes<sup>9+</sup>
1957
1958getOsAccountConstraintSourceTypes(localId: number, constraint: string, callback: AsyncCallback&lt;Array&lt;ConstraintSourceTypeInfo&gt;&gt;): void
1959
1960Obtains the constraint source information of a system account. This API uses an asynchronous callback to return the result.
1961
1962**System API**: This is a system API.
1963
1964**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
1965
1966**System capability**: SystemCapability.Account.OsAccount
1967
1968**Parameters**
1969
1970| Name  | Type                      | Mandatory| Description                                                        |
1971| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1972| localId     | number | Yes  |  ID of the target system account.|
1973| constraint     | string | Yes  |  [Constraint](js-apis-osAccount.md#constraints) whose source information is to be obtained.|
1974| callback | AsyncCallback&lt;Array&lt;[ConstraintSourceTypeInfo](#constraintsourcetypeinfo9)&gt;&gt;     | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the [constraint](js-apis-osAccount.md#constraints) source information obtained. Otherwise, **err** is an error object.                     |
1975
1976**Error codes**
1977
1978| ID| Error Message      |
1979| -------- | ------------- |
1980| 201 | Permission denied.|
1981| 202 | Not system application.|
1982| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1983| 12300001 | The system service works abnormally. |
1984| 12300002 | Invalid name or constraint. |
1985| 12300003 | Account not found. |
1986
1987**Example**
1988
1989  ```ts
1990  import { BusinessError } from '@kit.BasicServicesKit';
1991  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1992  try {
1993    accountManager.getOsAccountConstraintSourceTypes(100, 'constraint.wifi',
1994      (err: BusinessError,sourceTypeInfos: osAccount.ConstraintSourceTypeInfo[])=>{
1995      console.info('getOsAccountConstraintSourceTypes errInfo:' + JSON.stringify(err));
1996      console.info('getOsAccountConstraintSourceTypes sourceTypeInfos:' + JSON.stringify(sourceTypeInfos));
1997    });
1998  } catch (e) {
1999    console.info('getOsAccountConstraintSourceTypes exception: ' + JSON.stringify(e));
2000  }
2001  ```
2002
2003### getOsAccountConstraintSourceTypes<sup>9+</sup>
2004
2005getOsAccountConstraintSourceTypes(localId: number, constraint: string): Promise&lt;Array&lt;ConstraintSourceTypeInfo&gt;&gt;;
2006
2007Obtains the constraint source information of a system account. This API uses a promise to return the result.
2008
2009**System API**: This is a system API.
2010
2011**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
2012
2013**System capability**: SystemCapability.Account.OsAccount
2014
2015**Parameters**
2016
2017| Name | Type  | Mandatory| Description        |
2018| ------- | ------ | ---- | ------------ |
2019| localId     | number | Yes  |  ID of the target system account.|
2020| constraint     | string | Yes  |  [Constraint](js-apis-osAccount.md#constraints) whose source information is to be obtained.|
2021
2022**Return value**
2023
2024| Type                 | Description                                                        |
2025| --------------------- | ------------------------------------------------------------ |
2026| Promise&lt;Array&lt;[ConstraintSourceTypeInfo](#constraintsourcetypeinfo9)&gt;&gt; | Promise used to return the source information of the specified [constraint](js-apis-osAccount.md#constraints).|
2027
2028**Error codes**
2029
2030| ID| Error Message      |
2031| -------- | ------------- |
2032| 201 | Permission denied.|
2033| 202 | Not system application.|
2034| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2035| 12300001 | The system service works abnormally. |
2036| 12300002 | Invalid name or constraint. |
2037| 12300003 | Account not found. |
2038
2039**Example**
2040
2041  ```ts
2042  import { BusinessError } from '@kit.BasicServicesKit';
2043  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2044  try {
2045    accountManager.getOsAccountConstraintSourceTypes(100, 'constraint.wifi').then(
2046      (result: osAccount.ConstraintSourceTypeInfo[]) => {
2047      console.info('getOsAccountConstraintSourceTypes sourceTypeInfos:' + JSON.stringify(result));
2048    }).catch((err: BusinessError) => {
2049      console.info('getOsAccountConstraintSourceTypes errInfo:' + JSON.stringify(err));
2050    });
2051  } catch (e) {
2052    console.info('getOsAccountConstraintSourceTypes exception: ' + JSON.stringify(e));
2053  }
2054  ```
2055
2056### getOsAccountType<sup>12+</sup>
2057
2058getOsAccountType(localId: number): Promise&lt;OsAccountType&gt;;
2059
2060Obtains the type of a system account. This API uses a promise to return the result.
2061
2062**System API**: This is a system API.
2063
2064**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
2065
2066**System capability**: SystemCapability.Account.OsAccount
2067
2068**Parameters**
2069
2070| Name | Type  | Mandatory| Description        |
2071| ------- | ------ | ---- | ------------ |
2072| localId     | number | Yes  |  ID of the target system account.|
2073
2074**Return value**
2075
2076| Type                 | Description                                                        |
2077| --------------------- | ------------------------------------------------------------ |
2078| Promise&lt;[OsAccountType](js-apis-osAccount.md#osaccounttype)&gt; | Promise used to return the type of the system account obtained.|
2079
2080**Error codes**
2081
2082| ID| Error Message      |
2083| -------- | ------------- |
2084| 201 | Permission denied.|
2085| 202 | Not system application.|
2086| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2087| 12300001 | The system service works abnormally. |
2088| 12300003 | Account not found. |
2089
2090**Example**
2091
2092  ```ts
2093  import { BusinessError } from '@kit.BasicServicesKit';
2094  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2095  try {
2096    let localId: number = 100;
2097    accountManager.getOsAccountType(localId).then((type: osAccount.OsAccountType) => {
2098      console.info('getOsAccountType Type:' + type);
2099    }).catch((err: BusinessError) => {
2100      console.info('getOsAccountType errInfo:' + JSON.stringify(err));
2101    });
2102  } catch (e) {
2103    console.info('getOsAccountType exception: ' + JSON.stringify(e));
2104  }
2105  ```
2106
2107## UserAuth<sup>8+</sup>
2108
2109Provides APIs for user authentication.
2110
2111**System API**: This is a system API.
2112
2113### constructor<sup>8+</sup>
2114
2115constructor()
2116
2117A constructor used to create an instance for user authentication.
2118
2119**System API**: This is a system API.
2120
2121**System capability**: SystemCapability.Account.OsAccount
2122
2123**Error codes**
2124
2125| ID| Error Message      |
2126| -------- | ------------- |
2127| 202 | Not system application.|
2128
2129**Example**
2130  ```ts
2131  let userAuth = new osAccount.UserAuth();
2132  ```
2133
2134### getVersion<sup>8+</sup>
2135
2136getVersion(): number;
2137
2138Obtains version information.
2139
2140**System API**: This is a system API.
2141
2142**System capability**: SystemCapability.Account.OsAccount
2143
2144**Return value**
2145
2146| Type  | Description        |
2147| :----- | :----------- |
2148| number | Version information obtained.|
2149
2150**Error codes**
2151
2152| ID| Error Message      |
2153| -------- | ------------- |
2154| 202 | Not system application.|
2155
2156**Example**
2157  ```ts
2158  let userAuth = new osAccount.UserAuth();
2159  let version: number = userAuth.getVersion();
2160  console.log('getVersion version = ' + version);
2161  ```
2162
2163### getAvailableStatus<sup>8+</sup>
2164
2165getAvailableStatus(authType: AuthType, authTrustLevel: AuthTrustLevel): number;
2166
2167Obtains the available status of the authentication capability corresponding to the specified authentication type and trust level.
2168
2169**System API**: This is a system API.
2170
2171**System capability**: SystemCapability.Account.OsAccount
2172
2173**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2174
2175**Parameters**
2176
2177| Name          | Type                              | Mandatory| Description                      |
2178| --------------- | -----------------------------------| ---- | ------------------------- |
2179| authType        | [AuthType](#authtype8)             | Yes  | Authentication credential type.    |
2180| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8) | Yes  | Trust level of the authentication.|
2181
2182**Return value**
2183
2184| Type  | Description                          |
2185| ------ | ----------------------------- |
2186| number | Available status of the authentication capability.|
2187
2188**Error codes**
2189
2190| ID| Error Message                    |
2191| -------- | --------------------------- |
2192| 201 | Permission denied.|
2193| 202 | Not system application.|
2194| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2195| 12300001 | The system service works abnormally. |
2196| 12300002 | Invalid authType or authTrustLevel. |
2197
2198**Example**
2199  ```ts
2200  let userAuth = new osAccount.UserAuth();
2201  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2202  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2203  try {
2204    let status: number = userAuth.getAvailableStatus(authType, authTrustLevel);
2205    console.log('getAvailableStatus status = ' + status);
2206  } catch (e) {
2207    console.log('getAvailableStatus exception = ' + JSON.stringify(e));
2208  }
2209  ```
2210
2211### getProperty<sup>8+</sup>
2212
2213getProperty(request: GetPropertyRequest, callback: AsyncCallback&lt;ExecutorProperty&gt;): void
2214
2215Obtains the executor property based on the request. This API uses an asynchronous callback to return the result.
2216
2217**System API**: This is a system API.
2218
2219**System capability**: SystemCapability.Account.OsAccount
2220
2221**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2222
2223**Parameters**
2224
2225| Name   | Type                                                                   | Mandatory| Description                               |
2226| -------- | ----------------------------------------------------------- | ---- | ------------------------------------------------------ |
2227| request  | [GetPropertyRequest](#getpropertyrequest8)                  | Yes  | Request information, including the authentication credential type and property list.|
2228| callback | AsyncCallback&lt;[ExecutorProperty](#executorproperty8)&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the executor property information obtained. Otherwise, **err** is an error object.|
2229
2230**Error codes**
2231
2232| ID| Error Message                    |
2233| -------- | --------------------------- |
2234| 201 | Permission denied.|
2235| 202 | Not system application.|
2236| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2237| 12300001 | The system service works abnormally. |
2238| 12300002 | Invalid request. |
2239| 12300003 | Account not found. |
2240
2241**Example**
2242  ```ts
2243  import { BusinessError } from '@kit.BasicServicesKit';
2244  let userAuth = new osAccount.UserAuth();
2245  let keys: Array<osAccount.GetPropertyType>  = [
2246    osAccount.GetPropertyType.AUTH_SUB_TYPE,
2247    osAccount.GetPropertyType.REMAIN_TIMES,
2248    osAccount.GetPropertyType.FREEZING_TIME
2249  ];
2250  let request: osAccount.GetPropertyRequest = {
2251    authType: osAccount.AuthType.PIN,
2252    keys: keys
2253  };
2254  try {
2255    userAuth.getProperty(request, (err: BusinessError, result: osAccount.ExecutorProperty) => {
2256      console.log('getProperty err = ' + JSON.stringify(err));
2257      console.log('getProperty result = ' + JSON.stringify(result));
2258    });
2259  } catch (e) {
2260    console.log('getProperty exception = ' + JSON.stringify(e));
2261  }
2262  ```
2263
2264### getProperty<sup>8+</sup>
2265
2266getProperty(request: GetPropertyRequest): Promise&lt;ExecutorProperty&gt;;
2267
2268Obtains the executor property based on the request. This API uses a promise to return the result.
2269
2270**System API**: This is a system API.
2271
2272**System capability**: SystemCapability.Account.OsAccount
2273
2274**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2275
2276**Parameters**
2277
2278| Name   | Type                                                  | Mandatory| Description                               |
2279| -------- | ------------------------------------------------------ | ---- | ---------------------------------- |
2280| request  | [GetPropertyRequest](#getpropertyrequest8) | Yes  | Request information, including the authentication credential type and property list.|
2281
2282**Return value**
2283
2284| Type                                                             | Description                                                |
2285| :---------------------------------------------------------------- | :-------------------------------------------------- |
2286| Promise&lt;[ExecutorProperty](#executorproperty8)&gt; | Promise used to return the executor property information obtained.|
2287
2288**Error codes**
2289
2290| ID| Error Message                    |
2291| -------- | --------------------------- |
2292| 201 | Permission denied.|
2293| 202 | Not system application.|
2294| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2295| 12300001 | The system service works abnormally. |
2296| 12300002 | Invalid request. |
2297| 12300003 | Account not found. |
2298
2299**Example**
2300  ```ts
2301  import { BusinessError } from '@kit.BasicServicesKit';
2302  let userAuth = new osAccount.UserAuth();
2303  let keys: Array<osAccount.GetPropertyType> = [
2304    osAccount.GetPropertyType.AUTH_SUB_TYPE,
2305    osAccount.GetPropertyType.REMAIN_TIMES,
2306    osAccount.GetPropertyType.FREEZING_TIME
2307  ];
2308  let request: osAccount.GetPropertyRequest = {
2309    authType: osAccount.AuthType.PIN,
2310    keys: keys
2311  };
2312  try {
2313    userAuth.getProperty(request).then((result: osAccount.ExecutorProperty) => {
2314      console.log('getProperty result = ' + JSON.stringify(result));
2315    }).catch((err: BusinessError) => {
2316      console.log('getProperty error = ' + JSON.stringify(err));
2317    });
2318  } catch (e) {
2319    console.log('getProperty exception = ' + JSON.stringify(e));
2320  }
2321  ```
2322
2323### getPropertyByCredentialId<sup>14+</sup>
2324
2325getPropertyByCredentialId(credentialId: Uint8Array, keys: Array&lt;GetPropertyType&gt;): Promise&lt;ExecutorProperty&gt;;
2326
2327Obtains the specified property information of the associated executor based on the credential ID. This API uses a promise to return the result.
2328
2329**System API**: This is a system API.
2330
2331**System capability**: SystemCapability.Account.OsAccount
2332
2333**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2334
2335**Parameters**
2336
2337| Name   | Type                                                  | Mandatory| Description                               |
2338| -------- | ------------------------------------------------------ | ---- | ---------------------------------- |
2339| credentialId  | Uint8Array | Yes  | Credential ID.|
2340| keys     | Array&lt;[GetPropertyType](#getpropertytype8)&gt; | Yes   | Property type array to be queried.|
2341
2342**Return value**
2343
2344| Type                                                             | Description                                                |
2345| :---------------------------------------------------------------- | :-------------------------------------------------- |
2346| Promise&lt;[ExecutorProperty](#executorproperty8)&gt; | Promise used to return the executor attributes.|
2347
2348**Error codes**
2349
2350| ID| Error Message                    |
2351| -------- | --------------------------- |
2352| 201 | Permission denied.|
2353| 202 | Not system application.|
2354| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2355| 12300001 | The system service works abnormally. |
2356| 12300002 | Invalid keys. |
2357| 12300102 | The credential does not exist. |
2358
2359**Example**
2360  ```ts
2361  import { BusinessError } from '@kit.BasicServicesKit';
2362  let userIDM = new osAccount.UserIdentityManager();
2363  let credInfo: osAccount.EnrolledCredInfo[] = [];
2364  try {
2365    credInfo = await userIDM.getAuthInfo(osAccount.AuthType.PRIVATE_PIN);
2366  } catch (e) {
2367    console.log('getAuthInfo exception = ' + JSON.stringify(e));
2368    return;
2369  }
2370  if (credInfo.length == 0) {
2371    console.log('no credential infos');
2372    return;
2373  }
2374  let testCredentialId: Uint8Array = credInfo[0].credentialId;
2375  let keys: Array<osAccount.GetPropertyType> = [
2376    osAccount.GetPropertyType.AUTH_SUB_TYPE,
2377    osAccount.GetPropertyType.REMAIN_TIMES,
2378    osAccount.GetPropertyType.FREEZING_TIME
2379  ];
2380  try {
2381    let userAuth = new osAccount.UserAuth();
2382    userAuth.getPropertyByCredentialId(testCredentialId, keys).then((result: osAccount.ExecutorProperty) => {
2383      console.log('getPropertyByCredentialId result = ' + JSON.stringify(result));
2384    }).catch((err: BusinessError) => {
2385      console.log('getPropertyByCredentialId error = ' + JSON.stringify(err));
2386    });
2387  } catch (e) {
2388    console.log('getPropertyByCredentialId exception = ' + JSON.stringify(e));
2389  }
2390  ```
2391
2392### setProperty<sup>8+</sup>
2393
2394setProperty(request: SetPropertyRequest, callback: AsyncCallback&lt;void&gt;): void
2395
2396Sets the property for the initialization algorithm. This API uses an asynchronous callback to return the result.
2397
2398**System API**: This is a system API.
2399
2400**System capability**: SystemCapability.Account.OsAccount
2401
2402**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2403
2404**Parameters**
2405
2406| Name   | Type                                                 | Mandatory| Description                                                                   |
2407| -------- | ----------------------------------------------------- | ---- | ---------------------------------------------------------------------- |
2408| request  | [SetPropertyRequest](#setpropertyrequest8)| Yes  | Request information, including the authentication credential type and the key value to set.                                  |
2409| callback | AsyncCallback&lt;void&gt;                           | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, **err** is an error object.|
2410
2411**Error codes**
2412
2413| ID| Error Message                    |
2414| -------- | --------------------------- |
2415| 201 | Permission denied.|
2416| 202 | Not system application.|
2417| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2418| 12300001 | The system service works abnormally. |
2419| 12300002 | Invalid request. |
2420
2421**Example**
2422  ```ts
2423  import { BusinessError } from '@kit.BasicServicesKit';
2424  let userAuth = new osAccount.UserAuth();
2425  let request: osAccount.SetPropertyRequest = {
2426    authType: osAccount.AuthType.PIN,
2427    key: osAccount.SetPropertyType.INIT_ALGORITHM,
2428    setInfo: new Uint8Array([0])
2429  };
2430  try {
2431    userAuth.setProperty(request, (err: BusinessError) => {
2432      if (err) {
2433        console.log('setProperty failed, error = ' + JSON.stringify(err));
2434      } else {
2435        console.log('setProperty successfully');
2436      }
2437    });
2438  } catch (e) {
2439    console.log('setProperty exception = ' + JSON.stringify(e));
2440  }
2441  ```
2442
2443### setProperty<sup>8+</sup>
2444
2445setProperty(request: SetPropertyRequest): Promise&lt;void&gt;;
2446
2447Sets the property for the initialization algorithm. This API uses a promise to return the result.
2448
2449**System API**: This is a system API.
2450
2451**System capability**: SystemCapability.Account.OsAccount
2452
2453**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2454
2455**Parameters**
2456
2457| Name   | Type                                      | Mandatory| Description                                     |
2458| -------- | ------------------------------------------ | ---- | ---------------------------------------- |
2459| request  | [SetPropertyRequest](#setpropertyrequest8) | Yes  | Request information, including the authentication credential type and the key value to set.|
2460
2461**Return value**
2462
2463| Type                 | Description                                                          |
2464| :-------------------- | :------------------------------------------------------------ |
2465| Promise&lt;void&gt; | Promise that returns no value.|
2466
2467**Error codes**
2468
2469| ID| Error Message                    |
2470| -------- | --------------------------- |
2471| 201 | Permission denied.|
2472| 202 | Not system application.|
2473| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2474| 12300001 | The system service works abnormally. |
2475| 12300002 | Invalid request. |
2476
2477**Example**
2478  ```ts
2479  import { BusinessError } from '@kit.BasicServicesKit';
2480  let userAuth = new osAccount.UserAuth();
2481  let request: osAccount.SetPropertyRequest = {
2482    authType: osAccount.AuthType.PIN,
2483    key: osAccount.SetPropertyType.INIT_ALGORITHM,
2484    setInfo: new Uint8Array([0])
2485  };
2486  try {
2487    userAuth.setProperty(request).then(() => {
2488      console.log('setProperty successfully');
2489    }).catch((err: BusinessError) => {
2490      console.log('setProperty failed, error = ' + JSON.stringify(err));
2491    });
2492  } catch (e) {
2493    console.log('setProperty exception = ' + JSON.stringify(e));
2494  }
2495  ```
2496
2497### prepareRemoteAuth<sup>12+</sup>
2498
2499prepareRemoteAuth(remoteNetworkId: string): Promise&lt;void&gt;;
2500
2501Prepares for remote authentication. This API uses a promise to return the result.
2502
2503**System API**: This is a system API.
2504
2505**System capability**: SystemCapability.Account.OsAccount
2506
2507**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2508
2509**Parameters**
2510
2511| Name           | Type  | Mandatory| Description            |
2512| --------         | ------ | ---- | --------------- |
2513| remoteNetworkId  | string | Yes  | Remote network ID. |
2514
2515**Return value**
2516
2517| Type                 | Description                                                          |
2518| :-------------------- | :------------------------------------------------------------ |
2519| Promise&lt;void&gt; | Promise that returns no value.|
2520
2521**Error codes**
2522
2523| ID| Error Message                    |
2524| -------- | --------------------------- |
2525| 201 | Permission denied.|
2526| 202 | Not system application.|
2527| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2528| 12300001 | System service exception. |
2529| 12300002 | Invalid remoteNetworkId. |
2530
2531**Example**
2532  ```ts
2533  import { distributedDeviceManager } from '@kit.DistributedServiceKit';
2534  import { BusinessError } from '@kit.BasicServicesKit';
2535
2536  let userAuth = new osAccount.UserAuth();
2537  let distributedDeviceMgr = distributedDeviceManager.createDeviceManager("com.example.bundleName");
2538  distributedDeviceMgr.getAvailableDeviceList().then((data: Array<distributedDeviceManager.DeviceBasicInfo>) => {
2539      try {
2540        if (data.length > 0 && data[0].networkId != null) {
2541          userAuth.prepareRemoteAuth(data[0].networkId).then(() => {
2542            console.log('prepareRemoteAuth successfully');
2543          }).catch((err: BusinessError) => {
2544            console.log('prepareRemoteAuth failed, error = ' + JSON.stringify(err));
2545          });
2546        }
2547      } catch (e) {
2548        console.log('prepareRemoteAuth exception = ' + JSON.stringify(e));
2549      }
2550    }
2551  )
2552  ```
2553
2554### auth<sup>8+</sup>
2555
2556auth(challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, callback: IUserAuthCallback): Uint8Array;
2557
2558Performs authentication of the current user. This API uses an asynchronous callback to return the result.
2559
2560**System API**: This is a system API.
2561
2562**System capability**: SystemCapability.Account.OsAccount
2563
2564**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2565
2566**Parameters**
2567
2568| Name          | Type                                    | Mandatory| Description                               |
2569| --------------- | ---------------------------------------- | --- | ------------------------------------ |
2570| challenge       | Uint8Array                               | Yes | Challenge value, which is a random number used to improve security.|
2571| authType        | [AuthType](#authtype8)                   | Yes | Authentication credential type.                       |
2572| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | Yes | Trust level of the authentication result.              |
2573| callback        | [IUserAuthCallback](#iuserauthcallback8) | Yes | Callback used to return the authentication result. |
2574
2575**Return value**
2576
2577| Type       | Description              |
2578| ---------- | ------------------ |
2579| Uint8Array | ID of the context for canceling the authentication.|
2580
2581**Error codes**
2582
2583| ID| Error Message         |
2584| -------- | --------------------- |
2585| 201 | Permission denied.|
2586| 202 | Not system application.|
2587| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2588| 12300001 | The system service works abnormally. |
2589| 12300002 | Invalid challenge, authType or authTrustLevel. |
2590| 12300013 | Network exception. |
2591| 12300101 | The credential is incorrect. |
2592| 12300102 | The credential does not exist. |
2593| 12300105 | The trust level is not supported. |
2594| 12300106 | The authentication type is not supported. |
2595| 12300109 | The authentication, enrollment, or update operation is canceled. |
2596| 12300110 | The authentication is locked. |
2597| 12300111 | The authentication time out. |
2598| 12300112 | The authentication service is busy. |
2599| 12300113 | The authentication service does not exist. |
2600| 12300114 | The authentication service works abnormally. |
2601| 12300117 | PIN is expired. |
2602| 12300211 | Server unreachable. |
2603
2604**Example**
2605  ```ts
2606  let userAuth = new osAccount.UserAuth();
2607  let challenge: Uint8Array = new Uint8Array([0]);
2608  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2609  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2610  try {
2611    userAuth.auth(challenge, authType, authTrustLevel, {
2612      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2613          console.log('auth result = ' + result);
2614          console.log('auth extraInfo = ' + JSON.stringify(extraInfo));
2615      }
2616    });
2617  } catch (e) {
2618    console.log('auth exception = ' + JSON.stringify(e));
2619  }
2620  ```
2621
2622### auth<sup>12+</sup>
2623
2624auth(challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, options: AuthOptions, callback: IUserAuthCallback): Uint8Array
2625
2626Starts user authentication based on the specified challenge value, authentication type (PIN, facial, or fingerprint authentication), authentication trust level, and optional parameters (such as the account ID and authentication intent). This API uses an asynchronous callback to return the result.
2627
2628**System API**: This is a system API.
2629
2630**System capability**: SystemCapability.Account.OsAccount
2631
2632**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2633
2634**Parameters**
2635
2636| Name          | Type                                    | Mandatory| Description                               |
2637| --------------- | ---------------------------------------- | --- | ------------------------------------ |
2638| challenge       | Uint8Array                               | Yes | Challenge value, which is a random number used to prevent replay attacks and improve security.|
2639| authType        | [AuthType](#authtype8)                   | Yes | Authentication credential type.                       |
2640| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | Yes | Trust level of the authentication result.              |
2641| options         | [AuthOptions](#authoptions12) | Yes| Optional parameters for the authentication.|
2642| callback        | [IUserAuthCallback](#iuserauthcallback8) | Yes | Callback used to return the authentication result. |
2643
2644**Return value**
2645
2646| Type       | Description              |
2647| ---------- | ------------------ |
2648| Uint8Array | ID of the context for canceling the authentication.|
2649
2650**Error codes**
2651
2652| ID| Error Message         |
2653| -------- | --------------------- |
2654| 201 | Permission denied.|
2655| 202 | Not system application.|
2656| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2657| 12300001 | The system service works abnormally. |
2658| 12300002 | Invalid challenge, authType, authTrustLevel or options. |
2659| 12300003 | Account not found. |
2660| 12300013 | Network exception. |
2661| 12300101 | The credential is incorrect. |
2662| 12300102 | The credential does not exist. |
2663| 12300105 | The trust level is not supported. |
2664| 12300106 | The authentication type is not supported. |
2665| 12300109 | The authentication, enrollment, or update operation is canceled. |
2666| 12300110 | The authentication is locked. |
2667| 12300111 | The authentication time out. |
2668| 12300112 | The authentication service is busy. |
2669| 12300113 | The authentication service does not exist. |
2670| 12300114 | The authentication service works abnormally. |
2671| 12300117 | PIN is expired. |
2672| 12300211 | Server unreachable. |
2673
2674**Example**
2675  ```ts
2676  let userAuth = new osAccount.UserAuth();
2677  let challenge: Uint8Array = new Uint8Array([0]);
2678  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2679  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2680  let options: osAccount.AuthOptions = {
2681    accountId: 100
2682  };
2683  try {
2684    userAuth.auth(challenge, authType, authTrustLevel, options, {
2685      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2686          console.log('auth result = ' + result);
2687          console.log('auth extraInfo = ' + JSON.stringify(extraInfo));
2688      }
2689    });
2690  } catch (e) {
2691    console.log('auth exception = ' + JSON.stringify(e));
2692  }
2693  ```
2694
2695### authUser<sup>8+</sup>
2696
2697authUser(userId: number, challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, callback: IUserAuthCallback): Uint8Array;
2698
2699Performs authentication of the specified user. This API uses an asynchronous callback to return the result.
2700
2701**System API**: This is a system API.
2702
2703**System capability**: SystemCapability.Account.OsAccount
2704
2705**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2706
2707**Parameters**
2708
2709| Name          | Type                                                | Mandatory| Description                               |
2710| --------------- | ---------------------------------------------------- | --- | ------------------------------------ |
2711| userId          | number                                               | Yes | User ID.                       |
2712| challenge       | Uint8Array                                           | Yes | Challenge value, which is a random number used to improve security.                         |
2713| authType        | [AuthType](#authtype8)                   | Yes | Authentication credential type.                       |
2714| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | Yes | Trust level of the authentication result.              |
2715| callback        | [IUserAuthCallback](#iuserauthcallback8) | Yes | Callback used to return the authentication result. |
2716
2717**Return value**
2718
2719| Type       | Description              |
2720| ---------- | ------------------ |
2721| Uint8Array | ID of the context for canceling the authentication.|
2722
2723**Error codes**
2724
2725| ID| Error Message         |
2726| -------- | --------------------- |
2727| 201 | Permission denied.|
2728| 202 | Not system application.|
2729| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2730| 12300001 | The system service works abnormally. |
2731| 12300002 | Invalid challenge, authType or authTrustLevel. |
2732| 12300003 | Account not found. |
2733| 12300013 | Network exception. |
2734| 12300101 | The credential is incorrect. |
2735| 12300102 | The credential does not exist. |
2736| 12300105 | The trust level is not supported. |
2737| 12300106 | The authentication type is not supported. |
2738| 12300109 | The authentication, enrollment, or update operation is canceled. |
2739| 12300110 | The authentication is locked. |
2740| 12300111 | The authentication time out. |
2741| 12300112 | The authentication service is busy. |
2742| 12300113 | The authentication service does not exist. |
2743| 12300114 | The authentication service works abnormally. |
2744| 12300117 | PIN is expired. |
2745| 12300211 | Server unreachable. |
2746
2747**Example**
2748  ```ts
2749  let userAuth = new osAccount.UserAuth();
2750  let userID: number = 100;
2751  let challenge: Uint8Array = new Uint8Array([0]);
2752  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2753  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2754  try {
2755    userAuth.authUser(userID, challenge, authType, authTrustLevel, {
2756      onResult: (result,extraInfo) => {
2757        console.log('authUser result = ' + result);
2758        console.log('authUser extraInfo = ' + JSON.stringify(extraInfo));
2759      }
2760    });
2761  } catch (e) {
2762    console.log('authUser exception = ' + JSON.stringify(e));
2763  }
2764  ```
2765
2766### cancelAuth<sup>8+</sup>
2767
2768cancelAuth(contextID: Uint8Array): void
2769
2770Cancels an authentication.
2771
2772**System API**: This is a system API.
2773
2774**System capability**: SystemCapability.Account.OsAccount
2775
2776**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
2777
2778**Parameters**
2779
2780| Name   | Type      | Mandatory | Description                                       |
2781| ----------| ---------- | ---- | ------------------------------------------ |
2782| contextId | Uint8Array | Yes  | ID of the authentication context. The context ID is dynamically generated.|
2783
2784**Error codes**
2785
2786| ID| Error Message           |
2787| -------- | ------------------ |
2788| 201 | Permission denied.|
2789| 202 | Not system application.|
2790| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2791| 12300001 | The system service works abnormally. |
2792| 12300002 | Invalid contextId. |
2793
2794**Example**
2795  ```ts
2796  let userAuth = new osAccount.UserAuth();
2797  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
2798  let challenge = new Uint8Array([0]);
2799  let contextId: Uint8Array = userAuth.auth(challenge, osAccount.AuthType.PIN, osAccount.AuthTrustLevel.ATL1, {
2800    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2801      console.log('auth result = ' + result);
2802      console.log('auth extraInfo = ' + JSON.stringify(extraInfo));
2803    }
2804  });
2805  try {
2806    userAuth.cancelAuth(contextId);
2807  } catch (e) {
2808    console.log('cancelAuth exception = ' + JSON.stringify(e));
2809  }
2810  ```
2811
2812## PINAuth<sup>8+</sup>
2813
2814Provides APIs for PIN authentication.
2815
2816**System API**: This is a system API.
2817
2818### constructor<sup>8+</sup>
2819
2820constructor()
2821
2822Creates a PIN authentication instance.
2823
2824**System API**: This is a system API.
2825
2826**System capability**: SystemCapability.Account.OsAccount
2827
2828**Error codes**
2829
2830| ID| Error Message      |
2831| -------- | ------------- |
2832| 202 | Not system application.|
2833
2834**Example**
2835  ```ts
2836  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
2837  ```
2838
2839### registerInputer<sup>8+</sup>
2840
2841registerInputer(inputer: IInputer): void
2842
2843Registers a PIN inputer.
2844
2845**System API**: This is a system API.
2846
2847**System capability**: SystemCapability.Account.OsAccount
2848
2849**Required permissions**: ohos.permission.ACCESS_PIN_AUTH
2850
2851**Parameters**
2852
2853| Name   | Type                    | Mandatory| Description                     |
2854| ----------| ----------------------- | --- | -------------------------- |
2855| inputer   | [IInputer](#iinputer8)  | Yes | PIN inputer, which is used to obtain the PIN.|
2856
2857**Error codes**
2858
2859| ID| Error Message                    |
2860| -------- | --------------------------- |
2861| 201 | Permission denied.|
2862| 202 | Not system application.|
2863| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2864| 12300001 | The system service works abnormally. |
2865| 12300002 | Invalid inputer. |
2866| 12300103 | The credential inputer already exists. |
2867
2868**Example**
2869  ```ts
2870  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
2871  let password = new Uint8Array([0, 0, 0, 0, 0]);
2872  try {
2873    pinAuth.registerInputer({
2874        onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
2875          callback.onSetData(authSubType, password);
2876        }
2877    });
2878    console.log('registerInputer success.');
2879  } catch (e) {
2880    console.log('registerInputer exception = ' + JSON.stringify(e));
2881  }
2882  ```
2883
2884### unregisterInputer<sup>8+</sup>
2885
2886unregisterInputer(): void
2887
2888Unregisters this PIN inputer.
2889
2890**System API**: This is a system API.
2891
2892**System capability**: SystemCapability.Account.OsAccount
2893
2894**Required permissions**: ohos.permission.ACCESS_PIN_AUTH
2895
2896**Error codes**
2897
2898| ID| Error Message                    |
2899| -------- | --------------------------- |
2900| 201 | Permission denied.|
2901| 202 | Not system application.|
2902
2903**Example**
2904  ```ts
2905  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
2906  pinAuth.unregisterInputer();
2907  ```
2908
2909## InputerManager <sup>9+</sup>
2910
2911Provides APIs for managing credential inputers.
2912
2913### registerInputer<sup>9+</sup>
2914
2915static registerInputer(authType: AuthType, inputer: IInputer): void
2916
2917Registers a credential inputer.
2918
2919**System API**: This is a system API.
2920
2921**System capability**: SystemCapability.Account.OsAccount
2922
2923**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL or ohos.permission.MANAGE_USER_IDM
2924
2925**Parameters**
2926
2927| Name   | Type                    | Mandatory| Description                     |
2928| ----------| ----------------------- | --- | -------------------------- |
2929| authType   | [AuthType](#authtype8)  | Yes | Authentication credential type.|
2930| inputer   | [IInputer](#iinputer8)  | Yes | Credential inputer to register.|
2931
2932**Error codes**
2933
2934| ID| Error Message                    |
2935| -------- | --------------------------- |
2936| 201 | Permission denied.|
2937| 202 | Not system application.|
2938| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2939| 12300001 | The system service works abnormally. |
2940| 12300002 | Invalid authType or inputer. |
2941| 12300103 | The credential inputer already exists. |
2942| 12300106 | The authentication type is not supported. |
2943
2944**Example**
2945  ```ts
2946  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
2947  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0]);
2948  try {
2949    osAccount.InputerManager.registerInputer(authType, {
2950        onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
2951          callback.onSetData(authSubType, password);
2952        }
2953    });
2954    console.log('registerInputer success.');
2955  } catch (e) {
2956    console.log('registerInputer exception = ' + JSON.stringify(e));
2957  }
2958  ```
2959
2960### unregisterInputer<sup>9+</sup>
2961
2962static unregisterInputer(authType: AuthType): void
2963
2964Unregisters this credential inputer.
2965
2966**System API**: This is a system API.
2967
2968**System capability**: SystemCapability.Account.OsAccount
2969
2970**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL or ohos.permission.MANAGE_USER_IDM
2971
2972**Parameters**
2973
2974| Name   | Type                    | Mandatory| Description                     |
2975| ----------| ----------------------- | --- | -------------------------- |
2976| authType   | [AuthType](#authtype8)  | Yes | Authentication credential type.|
2977
2978**Error codes**
2979
2980| ID| Error Message                    |
2981| -------- | --------------------------- |
2982| 201 | Permission denied.|
2983| 202 | Not system application.|
2984| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2985| 12300002  | Invalid authType. |
2986
2987**Example**
2988  ```ts
2989  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
2990  try {
2991    osAccount.InputerManager.unregisterInputer(authType);
2992    console.log('unregisterInputer success.');
2993  } catch(err) {
2994    console.log('unregisterInputer err:' + JSON.stringify(err));
2995  }
2996  ```
2997
2998## DomainPlugin<sup>9+</sup>
2999
3000Provides APIs for domain account authentication.
3001
3002**System API**: This is a system API.
3003
3004### auth<sup>9+</sup>
3005
3006auth(domainAccountInfo: DomainAccountInfo, credential: Uint8Array, callback: IUserAuthCallback): void
3007
3008Authenticates a domain account.
3009
3010**System API**: This is a system API.
3011
3012**System capability**: SystemCapability.Account.OsAccount
3013
3014**Parameters**
3015
3016| Name     | Type                                   | Mandatory| Description            |
3017| ---------- | --------------------------------------- | ---- | --------------- |
3018| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3019| credential   | Uint8Array  | Yes  | Credentials of the domain account.|
3020| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3021
3022**Example**
3023  ```ts
3024  import { AsyncCallback } from '@kit.BasicServicesKit';
3025  let plugin: osAccount.DomainPlugin = {
3026    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3027          callback: osAccount.IUserAuthCallback) => {
3028      // mock authentication
3029      // notify authentication result
3030      let result: osAccount.AuthResult = {
3031        token: new Uint8Array([0]),
3032        remainTimes: 5,
3033        freezingTime: 0
3034      };
3035      callback.onResult(0, result);
3036    },
3037    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3038                    callback: osAccount.IUserAuthCallback) => {},
3039    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3040                    callback: osAccount.IUserAuthCallback) => {},
3041    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3042                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3043    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3044                      callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3045    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3046                  callback: AsyncCallback<void>) => {},
3047    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3048    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3049                          callback: AsyncCallback<boolean>) => {},
3050    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3051  }
3052  osAccount.DomainAccountManager.registerPlugin(plugin);
3053  let userAuth = new osAccount.UserAuth();
3054  let challenge: Uint8Array = new Uint8Array([0]);
3055  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
3056  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
3057  try {
3058    userAuth.auth(challenge, authType, authTrustLevel, {
3059      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3060          console.log('auth resultCode = ' + resultCode);
3061          console.log('auth authResult = ' + JSON.stringify(authResult));
3062      }
3063    });
3064  } catch (err) {
3065    console.log('auth exception = ' + JSON.stringify(err));
3066  }
3067  ```
3068
3069### authWithPopup<sup>10+</sup>
3070
3071authWithPopup(domainAccountInfo: DomainAccountInfo, callback: IUserAuthCallback): void
3072
3073Authenticates a domain account in a pop-up window.
3074
3075**System API**: This is a system API.
3076
3077**System capability**: SystemCapability.Account.OsAccount
3078
3079**Parameters**
3080
3081| Name     | Type                                   | Mandatory| Description            |
3082| ---------- | --------------------------------------- | ---- | --------------- |
3083| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3084| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3085
3086**Example**
3087  ```ts
3088  import { AsyncCallback } from '@kit.BasicServicesKit';
3089  let plugin: osAccount.DomainPlugin = {
3090    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3091          callback: osAccount.IUserAuthCallback) => {},
3092    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3093                    callback: osAccount.IUserAuthCallback) => {
3094      // mock authentication
3095      // notify authentication result
3096      let result: osAccount.AuthResult = {
3097        token: new Uint8Array([0]),
3098        remainTimes: 5,
3099        freezingTime: 0
3100      };
3101      callback.onResult(0, result);
3102    },
3103    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3104                    callback: osAccount.IUserAuthCallback) => {},
3105    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3106                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3107    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3108                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3109    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3110                  callback: AsyncCallback<void>) => {},
3111    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3112    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3113                          callback: AsyncCallback<boolean>) => {},
3114    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3115  }
3116  osAccount.DomainAccountManager.registerPlugin(plugin)
3117  ```
3118
3119### authWithToken<sup>10+</sup>
3120
3121authWithToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: IUserAuthCallback): void
3122
3123Authenticates a domain account by the authorization token.
3124
3125**System API**: This is a system API.
3126
3127**System capability**: SystemCapability.Account.OsAccount
3128
3129**Parameters**
3130
3131| Name     | Type                                   | Mandatory| Description            |
3132| ---------- | --------------------------------------- | ---- | --------------- |
3133| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3134| token   | Uint8Array  | Yes  | Authorization token generated when the PIN or biometric authentication is successful.|
3135| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3136
3137**Example**
3138  ```ts
3139  import { AsyncCallback } from '@kit.BasicServicesKit';
3140  let plugin: osAccount.DomainPlugin = {
3141    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3142          callback: osAccount.IUserAuthCallback) => {},
3143    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3144                    callback: osAccount.IUserAuthCallback) => {},
3145    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3146                    callback: osAccount.IUserAuthCallback) => {
3147      // mock authentication
3148      // notify authentication result
3149      let result: osAccount.AuthResult = {
3150        token: new Uint8Array([0]),
3151        remainTimes: 5,
3152        freezingTime: 0
3153      };
3154      callback.onResult(0, result);
3155    },
3156    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3157                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3158    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3159                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3160    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3161                  callback: AsyncCallback<void>) => {},
3162    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3163    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3164                          callback: AsyncCallback<boolean>) => {},
3165    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3166  }
3167  osAccount.DomainAccountManager.registerPlugin(plugin)
3168  ```
3169
3170### getAccountInfo<sup>10+</sup>
3171
3172getAccountInfo(options: GetDomainAccountInfoPluginOptions, callback: AsyncCallback&lt;DomainAccountInfo&gt;): void
3173
3174Obtains information about a domain account.
3175
3176**System API**: This is a system API.
3177
3178**System capability**: SystemCapability.Account.OsAccount
3179
3180**Parameters**
3181
3182| Name     | Type                                   | Mandatory| Description            |
3183| ---------- | --------------------------------------- | ---- | --------------- |
3184| options   | [GetDomainAccountInfoPluginOptions](#getdomainaccountinfopluginoptions10)  | Yes  | Domain account information.|
3185| callback   | AsyncCallback&lt;[DomainAccountInfo](#domainaccountinfo8)&gt; | Yes  | Callback used to return the result.|
3186
3187**Example**
3188  ```ts
3189  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3190  let plugin: osAccount.DomainPlugin = {
3191    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3192          callback: osAccount.IUserAuthCallback) => {},
3193    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3194                    callback: osAccount.IUserAuthCallback) => {},
3195    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3196                    callback: osAccount.IUserAuthCallback) => {},
3197    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3198                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {
3199      // mock getting account information
3200      // notify result
3201      let code: BusinessError = {
3202        code: 0,
3203        name: "",
3204        message: ""
3205      };
3206      let accountInfo: osAccount.DomainAccountInfo = {
3207        domain: options.domain ? options.domain : "",
3208        accountName: options.accountName,
3209        accountId: 'xxxx'
3210      };
3211      callback(code, accountInfo);
3212    },
3213    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3214                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3215    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3216                  callback: AsyncCallback<void>) => {},
3217    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3218    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3219                          callback: AsyncCallback<boolean>) => {},
3220    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3221  }
3222  osAccount.DomainAccountManager.registerPlugin(plugin)
3223  ```
3224
3225### getAuthStatusInfo<sup>10+</sup>
3226
3227getAuthStatusInfo(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;AuthStatusInfo&gt;): void
3228
3229Obtains the authentication status of a domain account.
3230
3231**System API**: This is a system API.
3232
3233**System capability**: SystemCapability.Account.OsAccount
3234
3235**Parameters**
3236
3237| Name     | Type                                   | Mandatory| Description            |
3238| ---------- | --------------------------------------- | ---- | --------------- |
3239| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3240| callback   | AsyncCallback&lt;[AuthStatusInfo](#authstatusinfo10)&gt; | Yes  | Callback used to return the result.|
3241
3242**Example**
3243  ```ts
3244  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3245  let plugin: osAccount.DomainPlugin = {
3246    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3247          callback: osAccount.IUserAuthCallback) => {},
3248    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3249                    callback: osAccount.IUserAuthCallback) => {},
3250    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3251                    callback: osAccount.IUserAuthCallback) => {},
3252    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3253                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3254    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3255                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {
3256      let code: BusinessError = {
3257        code: 0,
3258        name: "",
3259        message: ""
3260      };
3261      let statusInfo: osAccount.AuthStatusInfo = {
3262        remainTimes: 5,
3263        freezingTime: 0
3264      };
3265      callback(code, statusInfo);
3266    },
3267    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3268                  callback: AsyncCallback<void>) => {},
3269    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3270    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3271                          callback: AsyncCallback<boolean>) => {},
3272    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3273  }
3274  osAccount.DomainAccountManager.registerPlugin(plugin)
3275  ```
3276
3277### bindAccount<sup>10+</sup>
3278
3279bindAccount(domainAccountInfo: DomainAccountInfo, localId: number, callback: AsyncCallback&lt;void&gt;): void
3280
3281Binds a domain account.
3282
3283**System API**: This is a system API.
3284
3285**System capability**: SystemCapability.Account.OsAccount
3286
3287**Parameters**
3288
3289| Name     | Type                                   | Mandatory| Description            |
3290| ---------- | --------------------------------------- | ---- | --------------- |
3291| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3292| callback   | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result.|
3293
3294**Example**
3295  ```ts
3296  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3297  let plugin: osAccount.DomainPlugin = {
3298    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3299          callback: osAccount.IUserAuthCallback) => {},
3300    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3301                    callback: osAccount.IUserAuthCallback) => {},
3302    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3303                    callback: osAccount.IUserAuthCallback) => {},
3304    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3305                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3306    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3307                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3308    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3309                  callback: AsyncCallback<void>) => {
3310      // mock unbinding operation
3311      // notify binding result
3312      let code: BusinessError = {
3313        code: 0,
3314        name: "",
3315        message: ""
3316      };
3317      callback(code);
3318    },
3319    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3320    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3321                          callback: AsyncCallback<boolean>) => {},
3322    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3323  }
3324  osAccount.DomainAccountManager.registerPlugin(plugin)
3325  ```
3326
3327### unbindAccount<sup>10+</sup>
3328
3329unbindAccount(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;void&gt;): void
3330
3331Unbinds a domain account.
3332
3333**System API**: This is a system API.
3334
3335**System capability**: SystemCapability.Account.OsAccount
3336
3337**Parameters**
3338
3339| Name     | Type                                   | Mandatory| Description            |
3340| ---------- | --------------------------------------- | ---- | --------------- |
3341| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3342| callback   | AsyncCallback&lt;void&gt; | Yes  | Callback used to return the result.|
3343
3344**Example**
3345  ```ts
3346  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3347  let plugin: osAccount.DomainPlugin = {
3348    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3349          callback: osAccount.IUserAuthCallback) => {},
3350    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3351                    callback: osAccount.IUserAuthCallback) => {},
3352    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3353                    callback: osAccount.IUserAuthCallback) => {},
3354    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3355                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3356    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3357                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3358    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3359                  callback: AsyncCallback<void>) => {},
3360    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {
3361      // mock unbinding operation
3362      // notify unbinding result
3363      let code: BusinessError = {
3364        code: 0,
3365        name: "",
3366        message: ""
3367      };
3368      callback(code);
3369    },
3370    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3371                          callback: AsyncCallback<boolean>) => {},
3372    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3373  }
3374  osAccount.DomainAccountManager.registerPlugin(plugin)
3375  ```
3376
3377### isAccountTokenValid<sup>10+</sup>
3378
3379isAccountTokenValid(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: AsyncCallback&lt;boolean&gt;): void
3380
3381Checks whether the specified domain account token is valid.
3382
3383**System API**: This is a system API.
3384
3385**System capability**: SystemCapability.Account.OsAccount
3386
3387**Parameters**
3388
3389| Name     | Type                                   | Mandatory| Description            |
3390| ---------- | --------------------------------------- | ---- | --------------- |
3391| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3392| token | Uint8Array | Yes| Domain account token to check.|
3393| callback   | AsyncCallback&lt;boolean&gt; | Yes  | Callback used to return the result.|
3394
3395**Example**
3396  ```ts
3397  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3398  let plugin: osAccount.DomainPlugin = {
3399    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3400          callback: osAccount.IUserAuthCallback) => {},
3401    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3402                    callback: osAccount.IUserAuthCallback) => {},
3403    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3404                    callback: osAccount.IUserAuthCallback) => {},
3405    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3406                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3407    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3408                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3409    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3410                  callback: AsyncCallback<void>) => {},
3411    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3412    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3413                          callback: AsyncCallback<boolean>) => {
3414      // mock checking operation
3415      // notify checking result
3416      let code: BusinessError = {
3417        code: 0,
3418        name: "",
3419        message: ""
3420      };
3421      callback(code, true);
3422    },
3423    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3424  }
3425  osAccount.DomainAccountManager.registerPlugin(plugin)
3426  ```
3427
3428### getAccessToken<sup>10+</sup>
3429
3430getAccessToken(options: GetDomainAccessTokenOptions, callback: AsyncCallback&lt;Uint8Array&gt;): void
3431
3432Obtains the domain access token based on the specified conditions.
3433
3434**System API**: This is a system API.
3435
3436**System capability**: SystemCapability.Account.OsAccount
3437
3438**Parameters**
3439
3440| Name     | Type                                   | Mandatory| Description            |
3441| ---------- | --------------------------------------- | ---- | --------------- |
3442| options | [GetDomainAccessTokenOptions](#getdomainaccesstokenoptions10)  | Yes  | Options specified for obtaining the domain access token.|
3443| callback   | AsyncCallback&lt;Uint8Array&gt; | Yes  | Callback used to return the result.|
3444
3445**Example**
3446  ```ts
3447  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3448  let plugin: osAccount.DomainPlugin = {
3449    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3450          callback: osAccount.IUserAuthCallback) => {},
3451    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3452                    callback: osAccount.IUserAuthCallback) => {},
3453    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3454                    callback: osAccount.IUserAuthCallback) => {},
3455    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3456                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3457    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3458                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3459    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3460                  callback: AsyncCallback<void>) => {},
3461    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3462    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3463                          callback: AsyncCallback<boolean>) => {},
3464    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {
3465      // mock getting operation
3466      // notify result
3467      let code: BusinessError = {
3468        code: 0,
3469        name: "",
3470        message: ""
3471      };
3472      let token: Uint8Array = new Uint8Array([0]);
3473      callback(code, token);
3474    }
3475  }
3476  osAccount.DomainAccountManager.registerPlugin(plugin)
3477  ```
3478
3479## DomainAccountManager <sup>9+</sup>
3480Provides APIs for domain account management.
3481
3482### registerPlugin<sup>9+</sup>
3483
3484static registerPlugin(plugin: DomainPlugin): void
3485
3486Registers a domain plug-in.
3487
3488**System API**: This is a system API.
3489
3490**System capability**: SystemCapability.Account.OsAccount
3491
3492**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3493
3494**Parameters**
3495
3496| Name   | Type                    | Mandatory| Description                     |
3497| ----------| ----------------------- | --- | -------------------------- |
3498| plugin   | [DomainPlugin](#domainplugin9)  | Yes | Domain plug-in to register.|
3499
3500**Error codes**
3501
3502| ID| Error Message                    |
3503| -------- | --------------------------- |
3504| 201 | Permission denied.|
3505| 202 | Not system application.|
3506| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3507| 12300201 | The domain plugin has been registered. |
3508
3509**Example**
3510  ```ts
3511  import { AsyncCallback } from '@kit.BasicServicesKit';
3512  let plugin: osAccount.DomainPlugin = {
3513    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3514         callback: osAccount.IUserAuthCallback) => {},
3515    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3516                  callback: osAccount.IUserAuthCallback) => {},
3517    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3518                  callback: osAccount.IUserAuthCallback) => {},
3519    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3520                   callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3521    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3522                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3523    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3524                  callback: AsyncCallback<void>) => {},
3525    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3526    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3527                        callback: AsyncCallback<boolean>) => {},
3528    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3529  }
3530  try {
3531    osAccount.DomainAccountManager.registerPlugin(plugin);
3532    console.log('registerPlugin success.');
3533  } catch(err) {
3534    console.log('registerPlugin err:' + JSON.stringify(err));
3535  }
3536  ```
3537
3538### unregisterPlugin<sup>9+</sup>
3539
3540static unregisterPlugin(): void
3541
3542Unregisters this domain plug-in.
3543
3544**System API**: This is a system API.
3545
3546**System capability**: SystemCapability.Account.OsAccount
3547
3548**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3549
3550**Error codes**
3551
3552| ID| Error Message                    |
3553| -------- | --------------------------- |
3554| 201 | Permission denied.|
3555| 202 | Not system application.|
3556
3557**Example**
3558  ```ts
3559  try {
3560    osAccount.DomainAccountManager.unregisterPlugin();
3561    console.log('unregisterPlugin success.');
3562  } catch(err) {
3563    console.log('unregisterPlugin err:' + JSON.stringify(err));
3564  }
3565  ```
3566
3567### auth<sup>10+</sup>
3568
3569auth(domainAccountInfo: DomainAccountInfo, credential: Uint8Array, callback: IUserAuthCallback): void
3570
3571Authenticates a domain account.
3572
3573**System API**: This is a system API.
3574
3575**System capability**: SystemCapability.Account.OsAccount
3576
3577**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
3578
3579**Parameters**
3580
3581| Name     | Type                                   | Mandatory| Description            |
3582| ---------- | --------------------------------------- | ---- | --------------- |
3583| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3584| credential   | Uint8Array  | Yes  | Credentials of the domain account.|
3585| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3586
3587**Error codes**
3588
3589| ID| Error Message                    |
3590| -------- | --------------------------- |
3591| 201 | Permission denied.|
3592| 202 | Not system application.|
3593| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3594| 801 | Capability not supported.|
3595| 12300001 | The system service works abnormally. |
3596| 12300002 | Invalid domainAccountInfo or credential. |
3597| 12300003 | Domain account does not exist. |
3598| 12300013 | Network exception. |
3599| 12300101 | Authentication failed. |
3600| 12300109 | The authentication, enrollment, or update operation is canceled. |
3601| 12300110 | The authentication is locked. |
3602| 12300111 | The authentication time out. |
3603| 12300112 | The authentication service is busy. |
3604| 12300113 | The account authentication service does not exist. |
3605| 12300114 | The account authentication service works abnormally. |
3606| 12300211 | Server unreachable. |
3607
3608**Example**
3609  ```ts
3610  let domainAccountInfo: osAccount.DomainAccountInfo = {
3611    domain: 'CHINA',
3612    accountName: 'zhangsan'
3613  }
3614  let credential = new Uint8Array([0])
3615  try {
3616    osAccount.DomainAccountManager.auth(domainAccountInfo, credential, {
3617      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3618        console.log('auth resultCode = ' + resultCode);
3619        console.log('auth authResult = ' + JSON.stringify(authResult));
3620      }
3621    });
3622  } catch (err) {
3623    console.log('auth exception = ' + JSON.stringify(err));
3624  }
3625  ```
3626
3627### authWithPopup<sup>10+</sup>
3628
3629authWithPopup(callback: IUserAuthCallback): void
3630
3631Authenticates this domain account with a dialog box.
3632
3633**System API**: This is a system API.
3634
3635**System capability**: SystemCapability.Account.OsAccount
3636
3637**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
3638
3639No permission is required since API version 11. Use the SDK of the latest version.
3640
3641**Parameters**
3642
3643| Name     | Type                                   | Mandatory| Description            |
3644| ---------- | --------------------------------------- | ---- | --------------- |
3645| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3646
3647**Error codes**
3648
3649| ID| Error Message                    |
3650| -------- | --------------------------- |
3651| 201 | Permission denied.|
3652| 202 | Not system application.|
3653| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3654| 801 | Capability not supported.|
3655| 12300001 | The system service works abnormally. |
3656| 12300003 | No domain account is bound. |
3657| 12300013 | Network exception. |
3658| 12300101 | Authentication failed. |
3659| 12300109 | The authentication, enrollment, or update operation is canceled. |
3660| 12300110 | The authentication is locked. |
3661| 12300111 | The authentication time out. |
3662| 12300112 | The authentication service is busy. |
3663| 12300113 | The account authentication service does not exist. |
3664| 12300114 | The account authentication service works abnormally. |
3665| 12300211 | Server unreachable. |
3666
3667**Example**
3668  ```ts
3669  try {
3670    osAccount.DomainAccountManager.authWithPopup({
3671      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3672        console.log('auth resultCode = ' + resultCode);
3673        console.log('auth authResult = ' + JSON.stringify(authResult));
3674      }
3675    })
3676  } catch (err) {
3677    console.log('auth exception = ' + JSON.stringify(err));
3678  }
3679  ```
3680
3681### authWithPopup<sup>10+</sup>
3682
3683authWithPopup(localId: number, callback: IUserAuthCallback): void
3684
3685Authenticates this domain account with a dialog box.
3686
3687**System API**: This is a system API.
3688
3689**System capability**: SystemCapability.Account.OsAccount
3690
3691**Required permissions**: ohos.permission.ACCESS_USER_AUTH_INTERNAL
3692
3693No permission is required since API version 11. Use the SDK of the latest version.
3694
3695**Parameters**
3696
3697| Name     | Type                                   | Mandatory| Description            |
3698| ---------- | --------------------------------------- | ---- | --------------- |
3699| localId   | number  | Yes  | Local ID of the system account bound to the domain account.|
3700| callback   | [IUserAuthCallback](#iuserauthcallback8)  | Yes  | Callback used to return the authentication result.|
3701
3702**Error codes**
3703
3704| ID| Error Message                    |
3705| -------- | --------------------------- |
3706| 201 | Permission denied.|
3707| 202 | Not system application.|
3708| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3709| 801 | Capability not supported.|
3710| 12300001 | The system service works abnormally. |
3711| 12300002 | Invalid localId. |
3712| 12300003 | No domain account is bound. |
3713| 12300013 | Network exception. |
3714| 12300101 | Authentication failed. |
3715| 12300109 | The authentication, enrollment, or update operation is canceled. |
3716| 12300110 | The authentication is locked. |
3717| 12300111 | The authentication time out. |
3718| 12300112 | The authentication service is busy. |
3719| 12300113 | The account authentication service does not exist. |
3720| 12300114 | The account authentication service works abnormally. |
3721| 12300211 | Server unreachable. |
3722
3723**Example**
3724  ```ts
3725  try {
3726    osAccount.DomainAccountManager.authWithPopup(100, {
3727      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3728        console.log('authWithPopup resultCode = ' + resultCode);
3729        console.log('authWithPopup authResult = ' + JSON.stringify(authResult));
3730      }
3731    })
3732  } catch (err) {
3733    console.log('authWithPopup exception = ' + JSON.stringify(err));
3734  }
3735  ```
3736
3737### hasAccount<sup>10+</sup>
3738
3739hasAccount(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;boolean&gt;): void
3740
3741Checks whether a domain account exists.
3742
3743**System API**: This is a system API.
3744
3745**System capability**: SystemCapability.Account.OsAccount
3746
3747**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3748
3749**Parameters**
3750
3751| Name     | Type                                   | Mandatory| Description            |
3752| ---------- | --------------------------------------- | ---- | --------------- |
3753| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3754| callback   | AsyncCallback&lt;boolean&gt;  | Yes  | Callback used to return the result. |
3755
3756**Error codes**
3757
3758| ID| Error Message                    |
3759| -------- | --------------------------- |
3760| 201 | Permission denied.|
3761| 202 | Not system application.|
3762| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3763| 801 | Capability not supported.|
3764| 12300001 | The system service works abnormally. |
3765| 12300002 | Invalid domainAccountInfo. |
3766| 12300013 | Network exception. |
3767| 12300014 | Not authenticated. |
3768| 12300111 | The operation time out. |
3769| 12300114 | The authentication service works abnormally. |
3770| 12300211 | Server unreachable. |
3771
3772**Example**
3773  ```ts
3774  import { BusinessError } from '@kit.BasicServicesKit';
3775  let domainAccountInfo: osAccount.DomainAccountInfo = {
3776    domain: 'CHINA',
3777    accountName: 'zhangsan'
3778  }
3779  try {
3780    osAccount.DomainAccountManager.hasAccount(domainAccountInfo, (err: BusinessError, result: boolean) => {
3781      if (err) {
3782        console.log('call hasAccount failed, error: ' + JSON.stringify(err));
3783      } else {
3784        console.log('hasAccount result: ' + result);
3785      }
3786    });
3787  } catch (err) {
3788    console.log('hasAccount exception = ' + JSON.stringify(err));
3789  }
3790  ```
3791
3792### hasAccount<sup>10+</sup>
3793
3794hasAccount(domainAccountInfo: DomainAccountInfo): Promise&lt;boolean&gt;
3795
3796Checks whether a domain account exists.
3797
3798**System API**: This is a system API.
3799
3800**System capability**: SystemCapability.Account.OsAccount
3801
3802**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3803
3804**Parameters**
3805
3806| Name     | Type                                   | Mandatory| Description            |
3807| ---------- | --------------------------------------- | ---- | --------------- |
3808| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3809
3810**Return value**
3811
3812| Type                     | Description                    |
3813| :------------------------ | ----------------------- |
3814| Promise&lt;boolean&gt; | Promise used to return the result.|
3815
3816**Error codes**
3817
3818| ID| Error Message                    |
3819| -------- | --------------------------- |
3820| 201 | Permission denied.|
3821| 202 | Not system application.|
3822| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3823| 801 | Capability not supported.|
3824| 12300001 | The system service works abnormally. |
3825| 12300002 | Invalid domainAccountInfo. |
3826| 12300013 | Network exception. |
3827| 12300014 | Not authenticated. |
3828| 12300111 | The operation time out. |
3829| 12300114 | The authentication service works abnormally. |
3830| 12300211 | Server unreachable. |
3831
3832**Example**
3833  ```ts
3834  import { BusinessError } from '@kit.BasicServicesKit';
3835  let domainAccountInfo: osAccount.DomainAccountInfo = {
3836    domain: 'CHINA',
3837    accountName: 'zhangsan'
3838  }
3839  try {
3840    osAccount.DomainAccountManager.hasAccount(domainAccountInfo).then((result: boolean) => {
3841      console.log('hasAccount result: ' + result);
3842    }).catch((err: BusinessError) => {
3843        console.log('call hasAccount failed, error: ' + JSON.stringify(err));
3844    });
3845  } catch (err) {
3846    console.log('hasAccount exception = ' + JSON.stringify(err));
3847  }
3848  ```
3849
3850### updateAccountToken<sup>10+</sup>
3851
3852updateAccountToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: AsyncCallback&lt;void&gt;): void
3853
3854Updates the token of a domain account. An empty token means an invalid token. This API uses an asynchronous callback to return the result.
3855
3856**System API**: This is a system API.
3857
3858**System capability**: SystemCapability.Account.OsAccount
3859
3860**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3861
3862**Parameters**
3863
3864| Name     | Type                                   | Mandatory| Description            |
3865| ---------- | --------------------------------------- | ---- | --------------- |
3866| domainAccountInfo | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3867| token | Uint8Array  | Yes  | New domain account token.|
3868| callback | AsyncCallback&lt;void&gt; | Yes| Callback used to return the result. If the token is successfully updated, **err** is **null**. Otherwise, **err** is an error object.|
3869
3870**Error codes**
3871
3872| ID| Error Message                    |
3873| -------- | --------------------------- |
3874| 201 | Permission denied.|
3875| 202 | Not system application.|
3876| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3877| 12300001 | The system service works abnormally. |
3878| 12300002 | Invalid token. |
3879| 12300003 | Account not found. |
3880
3881**Example**
3882  ```ts
3883  import { BusinessError } from '@kit.BasicServicesKit';
3884  let domainAccountInfo: osAccount.DomainAccountInfo = {
3885    domain: 'CHINA',
3886    accountName: 'zhangsan',
3887    accountId: '123456'
3888  }
3889  let token = new Uint8Array([0])
3890  try {
3891    osAccount.DomainAccountManager.updateAccountToken(domainAccountInfo, token, (err: BusinessError) => {
3892      if (err != null) {
3893        console.log('updateAccountToken failed, error: ' + JSON.stringify(err));
3894      } else {
3895        console.log('updateAccountToken successfully');
3896      }
3897    })
3898  } catch (err) {
3899    console.log('updateAccountToken exception = ' + JSON.stringify(err));
3900  }
3901  ```
3902
3903### updateAccountToken<sup>10+</sup>
3904
3905updateAccountToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array): Promise&lt;void&gt;
3906
3907Updates the token of a domain account. An empty token means an invalid token. This API uses a promise to return the result.
3908
3909**System API**: This is a system API.
3910
3911**System capability**: SystemCapability.Account.OsAccount
3912
3913**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3914
3915**Parameters**
3916
3917| Name     | Type                                   | Mandatory| Description            |
3918| ---------- | --------------------------------------- | ---- | --------------- |
3919| domainAccountInfo | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
3920| token | Uint8Array  | Yes  | New domain account token.|
3921
3922**Return value**
3923
3924| Type                     | Description                    |
3925| :------------------------ | ----------------------- |
3926| Promise&lt;void&gt; | Promise that returns no value.|
3927
3928**Error codes**
3929
3930| ID| Error Message                    |
3931| -------- | --------------------------- |
3932| 201 | Permission denied.|
3933| 202 | Not system application.|
3934| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3935| 12300001 | The system service works abnormally. |
3936| 12300002 | Invalid token. |
3937| 12300003 | Account not found. |
3938
3939**Example**
3940  ```ts
3941  import { BusinessError } from '@kit.BasicServicesKit';
3942  let domainAccountInfo: osAccount.DomainAccountInfo = {
3943    domain: 'CHINA',
3944    accountName: 'zhangsan',
3945    accountId: '123456'
3946  }
3947  let token = new Uint8Array([0])
3948  try {
3949    osAccount.DomainAccountManager.updateAccountToken(domainAccountInfo, token).then(() => {
3950      console.log('updateAccountToken successfully');
3951    }).catch((err: BusinessError) => {
3952        console.log('updateAccountToken failed, error: ' + JSON.stringify(err));
3953    });
3954  } catch (err) {
3955    console.log('updateAccountToken exception = ' + JSON.stringify(err));
3956  }
3957  ```
3958### updateAccountInfo<sup>12+</sup>
3959
3960updateAccountInfo(oldAccountInfo: DomainAccountInfo, newAccountInfo: DomainAccountInfo): Promise&lt;void&gt;
3961
3962Updates information about the specified domain account. This API uses a promise to return the result.
3963
3964**System API**: This is a system API.
3965
3966**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS
3967
3968**System capability**: SystemCapability.Account.OsAccount
3969
3970**Parameters**
3971
3972| Name     | Type                                   | Mandatory| Description            |
3973| ---------- | --------------------------------------- | ---- | --------------- |
3974| oldAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes   | Domain account information. |
3975| newAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes   | New domain account information. |
3976
3977**Error codes**
3978
3979| ID| Error Message                    |
3980| -------- | --------------------------- |
3981| 201 | Permission denied.|
3982| 202 | Not system application.|
3983| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3984| 801 | Capability not supported.|
3985| 12300001 | The system service works abnormally. |
3986| 12300002 | The new account info is invalid. |
3987| 12300003 | The old account not found. |
3988| 12300004 | The new account already exists. |
3989
3990**Example**
3991  ```ts
3992  import { BusinessError } from '@kit.BasicServicesKit';
3993  let oldDomainInfo: osAccount.DomainAccountInfo =
3994    {domain: 'testDomain', accountName: 'oldtestAccountName'};
3995  let newDomainInfo: osAccount.DomainAccountInfo =
3996    {domain: 'testDomain', accountName: 'newtestAccountName'};
3997  try {
3998    osAccount.DomainAccountManager.updateAccountInfo(oldDomainInfo, newDomainInfo).then(() => {
3999      console.log('updateAccountInfo, success');
4000    }).catch((err: BusinessError) => {
4001      console.log('updateAccountInfo err: ' + err);
4002    });
4003  } catch (e) {
4004    console.log('updateAccountInfo exception: ' + e);
4005  }
4006  ```
4007
4008### getAccountInfo<sup>10+</sup>
4009
4010getAccountInfo(options: GetDomainAccountInfoOptions, callback: AsyncCallback&lt;DomainAccountInfo&gt;): void
4011
4012Obtains information about the specified domain account. This API uses an asynchronous callback to return the result.
4013
4014**System API**: This is a system API.
4015
4016**System capability**: SystemCapability.Account.OsAccount
4017
4018**Required permissions**: ohos.permission.GET_DOMAIN_ACCOUNTS
4019
4020**Parameters**
4021
4022| Name     | Type                                   | Mandatory| Description            |
4023| ---------- | --------------------------------------- | ---- | --------------- |
4024| options   | [GetDomainAccountInfoOptions](#getdomainaccountinfooptions10)  | Yes  | Domain account information.|
4025| callback   | AsyncCallback&lt;DomainAccountInfo&gt;  | Yes  | Callback used to return the result.|
4026
4027**Error codes**
4028
4029| ID| Error Message                    |
4030| -------- | --------------------------- |
4031| 201 | Permission denied.|
4032| 202 | Not system application.|
4033| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4034| 801 | Capability not supported.|
4035| 12300001 | The system service works abnormally. |
4036| 12300003 | Account not found. |
4037| 12300013 | Network exception. |
4038| 12300014 | Not authenticated. |
4039| 12300111 | The operation time out. |
4040| 12300114 | The authentication service works abnormally. |
4041| 12300211 | Server unreachable. |
4042
4043**Example**
4044  ```ts
4045  import { BusinessError } from '@kit.BasicServicesKit';
4046  let domainAccountInfo: osAccount.GetDomainAccountInfoOptions = {
4047    domain: 'CHINA',
4048    accountName: 'zhangsan'
4049  }
4050  try {
4051    osAccount.DomainAccountManager.getAccountInfo(domainAccountInfo,
4052      (err: BusinessError, result: osAccount.DomainAccountInfo) => {
4053      if (err) {
4054        console.log('call getAccountInfo failed, error: ' + JSON.stringify(err));
4055      } else {
4056        console.log('getAccountInfo result: ' + result);
4057      }
4058    });
4059  } catch (err) {
4060    console.log('getAccountInfo exception = ' + JSON.stringify(err));
4061  }
4062  ```
4063
4064### getAccountInfo<sup>10+</sup>
4065
4066getAccountInfo(options: GetDomainAccountInfoOptions): Promise&lt;DomainAccountInfo&gt;
4067
4068Obtains information about the specified domain account. This API uses a promise to return the result.
4069
4070**System API**: This is a system API.
4071
4072**System capability**: SystemCapability.Account.OsAccount
4073
4074**Required permissions**: ohos.permission.GET_DOMAIN_ACCOUNTS
4075
4076**Parameters**
4077
4078| Name     | Type                                   | Mandatory| Description            |
4079| ---------- | --------------------------------------- | ---- | --------------- |
4080| options   | [GetDomainAccountInfoOptions](#getdomainaccountinfooptions10)  | Yes  | Domain account information.|
4081
4082**Return value**
4083
4084| Type                     | Description                    |
4085| :------------------------ | ----------------------- |
4086| Promise&lt;DomainAccountInfo&gt; | Promise used to return the domain account information obtained.|
4087
4088**Error codes**
4089
4090| ID| Error Message                    |
4091| -------- | --------------------------- |
4092| 201 | Permission denied.|
4093| 202 | Not system application.|
4094| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4095| 801 | Capability not supported.|
4096| 12300001 | The system service works abnormally. |
4097| 12300003 | Account not found. |
4098| 12300013 | Network exception. |
4099| 12300014 | Not authenticated. |
4100| 12300111 | The operation time out. |
4101| 12300114 | The authentication service works abnormally. |
4102| 12300211 | Server unreachable. |
4103
4104**Example**
4105  ```ts
4106  import { BusinessError } from '@kit.BasicServicesKit';
4107  let domainAccountInfo: osAccount.GetDomainAccountInfoOptions = {
4108    domain: 'CHINA',
4109    accountName: 'zhangsan'
4110  }
4111  try {
4112    osAccount.DomainAccountManager.getAccountInfo(domainAccountInfo)
4113      .then((result: osAccount.DomainAccountInfo) => {
4114      console.log('getAccountInfo result: ' + result);
4115    }).catch((err: BusinessError) => {
4116      console.log('call getAccountInfo failed, error: ' + JSON.stringify(err));
4117    });
4118  } catch (err) {
4119    console.log('getAccountInfo exception = ' + JSON.stringify(err));
4120  }
4121  ```
4122
4123### getAccessToken<sup>11+</sup>
4124
4125getAccessToken(businessParams: Record<string, Object>, callback: AsyncCallback&lt;Uint8Array&gt;): void
4126
4127Obtains the service access token of this domain account. This API uses an asynchronous callback to return the result.
4128
4129**System API**: This is a system API.
4130
4131**System capability**: SystemCapability.Account.OsAccount
4132
4133**Parameters**
4134
4135| Name     | Type                                   | Mandatory| Description            |
4136| ---------- | --------------------------------------- | ---- | --------------- |
4137| businessParams | Record<string, Object>  | Yes  | Service parameters. The specific formats vary depending on the domain plug-in.|
4138| callback | AsyncCallback&lt;Uint8Array&gt;  | Yes  | Callback used to return the result. If the operation is successful, **err** is **null**. Otherwise, an error object is returned.|
4139
4140**Error codes**
4141
4142| ID| Error Message                    |
4143| -------- | --------------------------- |
4144| 202 | Not system application.|
4145| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4146| 801 | Capability not supported.|
4147| 12300001 | The system service works abnormally. |
4148| 12300002 | Invalid business parameters. |
4149| 12300003 | Domain account not found. |
4150| 12300013 | Network exception. |
4151| 12300014 | The domain account is not authenticated. |
4152| 12300111 | The operation time out. |
4153| 12300114 | The authentication service works abnormally. |
4154| 12300211 | Server unreachable. |
4155
4156**Example**
4157  ```ts
4158  import { BusinessError } from '@kit.BasicServicesKit';
4159  let businessParams: Record<string, Object> = {
4160    'clientId': 'xxx',
4161    'secretId': 'yyy'
4162  };  // depends on the implementation of the domain plugin
4163  try {
4164    osAccount.DomainAccountManager.getAccessToken(businessParams,
4165      (err: BusinessError, result: Uint8Array) => {
4166      if (err) {
4167        console.log('getAccessToken failed, error: ' + JSON.stringify(err));
4168      } else {
4169        console.log('getAccessToken result: ' + result);
4170      }
4171    });
4172  } catch (err) {
4173    console.log('getAccessToken exception = ' + JSON.stringify(err));
4174  }
4175  ```
4176
4177### getAccessToken<sup>11+</sup>
4178
4179getAccessToken(businessParams: Record<string, Object>): Promise&lt;Uint8Array&gt;
4180
4181Obtains the service access token of this domain account. This API uses a promise to return the result.
4182
4183**System API**: This is a system API.
4184
4185**System capability**: SystemCapability.Account.OsAccount
4186
4187**Parameters**
4188
4189| Name     | Type                                   | Mandatory| Description            |
4190| ---------- | --------------------------------------- | ---- | --------------- |
4191| businessParams | Record<string, Object> | Yes  | Service parameters. The specific formats vary depending on the domain plug-in.|
4192
4193**Return value**
4194
4195| Type                     | Description                    |
4196| :------------------------ | ----------------------- |
4197| Promise&lt;Uint8Array&gt; | Promise used to return the service access token obtained.|
4198
4199**Error codes**
4200
4201| ID| Error Message                    |
4202| -------- | --------------------------- |
4203| 202 | Not system application.|
4204| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4205| 801 | Capability not supported.|
4206| 12300001 | The system service works abnormally. |
4207| 12300002 | Invalid business parameters. |
4208| 12300003 | Domain account not found. |
4209| 12300013 | Network exception. |
4210| 12300014 | The domain account is not authenticated. |
4211| 12300111 | The operation time out. |
4212| 12300114 | The authentication service works abnormally. |
4213| 12300211 | Server unreachable. |
4214
4215**Example**
4216  ```ts
4217  import { BusinessError } from '@kit.BasicServicesKit';
4218  let businessParams: Record<string, Object> = {
4219    'clientId': 'xxx',
4220    'secretId': 'yyy'
4221  };  // depends on the implementation of the domain plugin
4222  try {
4223    osAccount.DomainAccountManager.getAccessToken(businessParams)
4224      .then((result: Uint8Array) => {
4225      console.log('getAccessToken result: ' + result);
4226    }).catch((err: BusinessError) => {
4227      console.log('getAccessToken failed, error: ' + JSON.stringify(err));
4228    });
4229  } catch (err) {
4230    console.log('getAccessToken exception = ' + JSON.stringify(err));
4231  }
4232  ```
4233
4234### isAuthenticationExpired<sup>12+</sup>
4235
4236isAuthenticationExpired(domainAccountInfo: DomainAccountInfo): Promise&lt;boolean&gt;;
4237
4238Checks whether the authentication of a domain account has expired. This API uses a promise to return the result.
4239
4240**System API**: This is a system API.
4241
4242**Required permissions**: ohos.permission.MANAGE_LOCAL_ACCOUNTS or ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
4243
4244**System capability**: SystemCapability.Account.OsAccount
4245
4246**Parameters**
4247
4248| Name     | Type                                   | Mandatory| Description            |
4249| ---------- | --------------------------------------- | ---- | --------------- |
4250| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | Yes  | Domain account information.|
4251
4252**Return value**
4253
4254| Type                     | Description                    |
4255| :------------------------ | ----------------------- |
4256| Promise&lt;boolean&gt; | Promise used to return the result.|
4257
4258**Error codes**
4259
4260| ID| Error Message                    |
4261| -------- | --------------------------- |
4262| 201 | Permission denied.|
4263| 202 | Not system application.|
4264| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4265| 801 | Capability not supported.|
4266| 12300001 | The system service works abnormally. |
4267| 12300003 | Domain account not found. |
4268
4269**Example**
4270  ```ts
4271  import { BusinessError } from '@kit.BasicServicesKit';
4272  let domainInfo: osAccount.DomainAccountInfo =
4273    {domain: 'testDomain', accountName: 'testAccountName'};
4274  try {
4275    osAccount.DomainAccountManager.isAuthenticationExpired(domainInfo).then((result: boolean) => {
4276      console.log('isAuthenticationExpired, result: ' + result);
4277    }).catch((err: BusinessError) => {
4278      console.log('isAuthenticationExpired err: ' + err);
4279    });
4280  } catch (e) {
4281    console.log('isAuthenticationExpired exception: ' + e);
4282  }
4283  ```
4284
4285## UserIdentityManager<sup>8+</sup>
4286
4287Provides APIs for user IDM.
4288
4289**System API**: This is a system API.
4290
4291### constructor<sup>8+</sup>
4292
4293A **constructor()** used to create an instance for user IDM.
4294
4295**System API**: This is a system API.
4296
4297**System capability**: SystemCapability.Account.OsAccount
4298
4299**Error codes**
4300
4301| ID| Error Message                    |
4302| -------- | --------------------------- |
4303| 202 | Not system application.|
4304
4305**Example**
4306  ```ts
4307  let userIDM = new osAccount.UserIdentityManager();
4308  ```
4309
4310### openSession<sup>8+</sup>
4311
4312openSession(callback: AsyncCallback&lt;Uint8Array&gt;): void
4313
4314Opens a session to obtain the challenge value. This API uses an asynchronous callback to return the result.
4315
4316**System API**: This is a system API.
4317
4318**System capability**: SystemCapability.Account.OsAccount
4319
4320**Required permissions**: ohos.permission.MANAGE_USER_IDM
4321
4322**Parameters**
4323
4324| Name   | Type                            | Mandatory| Description                                                           |
4325| -------- | -------------------------------- | ---- | -------------------------------------------------------------- |
4326| callback | AsyncCallback&lt;Uint8Array&gt;  | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the challenge value obtained. Otherwise, **err** is an error object.|
4327
4328**Error codes**
4329
4330| ID| Error Message                    |
4331| -------- | --------------------------- |
4332| 201 | Permission denied.|
4333| 202 | Not system application.|
4334| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4335| 12300001 | The system service works abnormally. |
4336
4337**Example**
4338  ```ts
4339  import { BusinessError } from '@kit.BasicServicesKit';
4340  let userIDM = new osAccount.UserIdentityManager();
4341  try {
4342    userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4343        console.log('openSession error = ' + JSON.stringify(err));
4344        console.log('openSession challenge = ' + JSON.stringify(challenge));
4345    });
4346  } catch (e) {
4347    console.log('openSession exception = ' + JSON.stringify(e));
4348  }
4349  ```
4350
4351### openSession<sup>8+</sup>
4352
4353openSession(accountId?: number): Promise&lt;Uint8Array&gt;
4354
4355Opens a session. This API returns a challenge value, which can be used to determine whether the subsequent identity authentication is in this session. This can prevent replay attacks. This API uses a promise to return the result.
4356
4357**System API**: This is a system API.
4358
4359**System capability**: SystemCapability.Account.OsAccount
4360
4361**Required permissions**: ohos.permission.MANAGE_USER_IDM
4362
4363**Parameters**
4364
4365| Name    | Type   | Mandatory| Description       |
4366| --------- | ------- | ---- | ----------- |
4367| accountId<sup>12+</sup> | number  | No  | System account ID, which is left blank by default.|
4368
4369**Return value**
4370
4371| Type                     | Description                    |
4372| :------------------------ | ----------------------- |
4373| Promise&lt;Uint8Array&gt; | Promise used to return the challenge value obtained.|
4374
4375**Error codes**
4376
4377| ID| Error Message                    |
4378| -------- | --------------------------- |
4379| 201 | Permission denied.|
4380| 202 | Not system application.|
4381| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4382| 12300001 | The system service works abnormally. |
4383| 12300003 | Account not found. |
4384| 12300008 | Restricted account. |
4385
4386**Example**
4387  ```ts
4388  import { BusinessError } from '@kit.BasicServicesKit';
4389  let userIDM = new osAccount.UserIdentityManager();
4390  let accountId = 100;
4391  try {
4392    userIDM.openSession(accountId).then((challenge: Uint8Array) => {
4393        console.info('openSession challenge = ' + JSON.stringify(challenge));
4394    }).catch((err: BusinessError) => {
4395        console.info('openSession error = ' + JSON.stringify(err));
4396    });
4397  } catch (e) {
4398    console.log('openSession exception = ' + JSON.stringify(e));
4399  }
4400  ```
4401
4402### addCredential<sup>8+</sup>
4403
4404addCredential(credentialInfo: CredentialInfo, callback: IIdmCallback): void
4405
4406Adds credential information, including the credential type, subtype, and token (if a non-PIN credential is added).
4407
4408**System API**: This is a system API.
4409
4410**System capability**: SystemCapability.Account.OsAccount
4411
4412**Required permissions**: ohos.permission.MANAGE_USER_IDM
4413
4414**Parameters**
4415
4416| Name          | Type                                | Mandatory| Description                       |
4417| --------------- | ------------------------------------ | --- | ---------------------------- |
4418| credentialInfo  | [CredentialInfo](#credentialinfo8)   | Yes | Credential information to add.               |
4419| callback        | [IIdmCallback](#iidmcallback8)       | Yes | Callback used to return the result. |
4420
4421**Error codes**
4422
4423| ID| Error Message                    |
4424| -------- | ------------------- |
4425| 201 | Permission denied.|
4426| 202 | Not system application.|
4427| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4428| 12300001 | The system service works abnormally. |
4429| 12300002 | Invalid credentialInfo, i.e. authType or authSubType. |
4430| 12300003 | Account not found. |
4431| 12300008 | Restricted account. |
4432| 12300101 | The token is invalid. |
4433| 12300106 | The authentication type is not supported. |
4434| 12300109 | The authentication, enrollment, or update operation is canceled. |
4435| 12300111 | The operation time out. |
4436| 12300115 | The number of credentials reaches the upper limit. |
4437| 12300116 | Credential complexity verification failed. |
4438
4439**Example**
4440  ```ts
4441  import { BusinessError } from '@kit.BasicServicesKit';
4442  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
4443  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
4444  pinAuth.registerInputer({
4445    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
4446      callback.onSetData(authSubType, password);
4447    }
4448  });
4449  let credentialInfo: osAccount.CredentialInfo = {
4450    credType: osAccount.AuthType.PIN,
4451    credSubType: osAccount.AuthSubType.PIN_SIX,
4452    token: new Uint8Array([]),
4453  };
4454  let userIDM = new osAccount.UserIdentityManager();
4455  userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4456    try {
4457    userIDM.addCredential(credentialInfo, {
4458      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4459        console.log('addCredential result = ' + result);
4460        console.log('addCredential extraInfo = ' + extraInfo);
4461      }
4462    });
4463    } catch (e) {
4464      console.log('addCredential exception = ' + JSON.stringify(e));
4465    }
4466  });
4467  ```
4468
4469### updateCredential<sup>8+</sup>
4470
4471updateCredential(credentialInfo: CredentialInfo, callback: IIdmCallback): void
4472
4473Updates credential information. This API uses an asynchronous callback to return the result.
4474
4475**System API**: This is a system API.
4476
4477**System capability**: SystemCapability.Account.OsAccount
4478
4479**Required permissions**: ohos.permission.MANAGE_USER_IDM
4480
4481**Parameters**
4482
4483| Name          | Type                                 | Mandatory| Description                    |
4484| --------------- | ------------------------------------- | --- | ------------------------- |
4485| credentialInfo  | [CredentialInfo](#credentialinfo8)    | Yes | Credential information to add.            |
4486| callback        | [IIdmCallback](#iidmcallback8)        | Yes | Callback used to return the result.|
4487
4488**Error codes**
4489
4490| ID| Error Message                    |
4491| -------- | ------------------- |
4492| 201 | Permission denied.|
4493| 202 | Not system application.|
4494| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4495| 12300001 | The system service works abnormally. |
4496| 12300002 | Invalid credentialInfo, i.e. authType or authSubType. |
4497| 12300003 | Account not found. |
4498| 12300101 | The token is invalid. |
4499| 12300102 | The credential does not exist. |
4500| 12300106 | The authentication type is not supported. |
4501| 12300109 | The authentication, enrollment, or update operation is canceled. |
4502| 12300111 | The operation time out. |
4503| 12300116 | Credential complexity verification failed. |
4504
4505**Example**
4506  ```ts
4507  import { BusinessError } from '@kit.BasicServicesKit';
4508  let userIDM = new osAccount.UserIdentityManager();
4509  let userAuth: osAccount.UserAuth = new osAccount.UserAuth();
4510  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
4511  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
4512  let credentialInfo: osAccount.CredentialInfo = {
4513    credType: osAccount.AuthType.PIN,
4514    credSubType: osAccount.AuthSubType.PIN_SIX,
4515    token: new Uint8Array([]),
4516  };
4517  pinAuth.registerInputer({
4518    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
4519      callback.onSetData(authSubType, password);
4520    }
4521  });
4522  userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4523    userAuth.auth(challenge, credentialInfo.credType, osAccount.AuthTrustLevel.ATL1, {
4524      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
4525        if (result != osAccount.ResultCode.SUCCESS) {
4526          return;
4527        }
4528        if (extraInfo.token != null) {
4529          credentialInfo.token = extraInfo.token;
4530        }
4531        try {
4532          userIDM.updateCredential(credentialInfo, {
4533            onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4534                console.log('updateCredential result = ' + result);
4535                console.log('updateCredential extraInfo = ' + extraInfo);
4536            }
4537          });
4538        } catch (e) {
4539          console.log('updateCredential exception = ' + JSON.stringify(e));
4540        }
4541      }
4542    });
4543  });
4544  ```
4545
4546### closeSession<sup>8+</sup>
4547
4548closeSession(accountId?: number): void
4549
4550Closes this session to terminate IDM.
4551
4552**System API**: This is a system API.
4553
4554**System capability**: SystemCapability.Account.OsAccount
4555
4556**Required permissions**: ohos.permission.MANAGE_USER_IDM
4557
4558**Parameters**
4559
4560| Name    | Type   | Mandatory| Description       |
4561| --------- | ------- | ---- | ----------- |
4562| accountId<sup>12+</sup> | number  | No  | System account ID, which is left blank by default.|
4563
4564**Error codes**
4565
4566| ID| Error Message                    |
4567| -------- | --------------------------- |
4568| 201 | Permission denied.|
4569| 202 | Not system application.|
4570| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4571| 12300001 | The system service works abnormally. |
4572| 12300003 | Account not found. |
4573| 12300008 | Restricted account. |
4574
4575**Example**
4576  ```ts
4577  let userIDM = new osAccount.UserIdentityManager();
4578  let accountId = 100;
4579  userIDM.closeSession(accountId);
4580  ```
4581
4582### cancel<sup>8+</sup>
4583
4584cancel(challenge: Uint8Array): void
4585
4586Cancels an entry based on the challenge value.
4587
4588**System API**: This is a system API.
4589
4590**System capability**: SystemCapability.Account.OsAccount
4591
4592**Required permissions**: ohos.permission.MANAGE_USER_IDM
4593
4594**Parameters**
4595
4596| Name   | Type       | Mandatory| Description  |
4597| -------- | ----------- | ---- | ----- |
4598| challenge | Uint8Array | Yes  | Challenge value.|
4599
4600**Error codes**
4601
4602| ID| Error Message           |
4603| -------- | ------------------- |
4604| 201 | Permission denied.|
4605| 202 | Not system application.|
4606| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4607| 12300001 | The system service works abnormally. |
4608| 12300002 | Invalid challenge. |
4609
4610**Example**
4611  ```ts
4612  let userIDM = new osAccount.UserIdentityManager();
4613  let challenge: Uint8Array = new Uint8Array([0]);
4614  try {
4615    userIDM.cancel(challenge);
4616  } catch(err) {
4617    console.log('cancel err:' + JSON.stringify(err));
4618  }
4619  ```
4620
4621### delUser<sup>8+</sup>
4622
4623delUser(token: Uint8Array, callback: IIdmCallback): void
4624
4625Deletes a user based on the authentication token. This API uses a callback to return the result.
4626
4627**System API**: This is a system API.
4628
4629**System capability**: SystemCapability.Account.OsAccount
4630
4631**Required permissions**: ohos.permission.MANAGE_USER_IDM
4632
4633**Parameters**
4634
4635| Name   | Type                          | Mandatory| Description                     |
4636| -------- | ------------------------------ | --- | ------------------------- |
4637| token    | Uint8Array                     | Yes | Authentication token.            |
4638| callback | [IIdmCallback](#iidmcallback8) | Yes | Callback used to return the result.|
4639
4640**Error codes**
4641
4642| ID| Error Message       |
4643| -------- | ------------------- |
4644| 201 | Permission denied.|
4645| 202 | Not system application.|
4646| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4647| 12300001 | The system service works abnormally. |
4648| 12300101 | The token is invalid. |
4649
4650**Example**
4651  ```ts
4652  let userIDM = new osAccount.UserIdentityManager();
4653  let token: Uint8Array = new Uint8Array([0]);
4654  try {
4655    userIDM.delUser(token, {
4656      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4657        console.log('delUser result = ' + result);
4658        console.log('delUser extraInfo = ' + JSON.stringify(extraInfo));
4659      }
4660    });
4661  } catch (e) {
4662    console.log('delUser exception = ' + JSON.stringify(e));
4663  }
4664  ```
4665
4666### delCred<sup>8+</sup>
4667
4668delCred(credentialId: Uint8Array, token: Uint8Array, callback: IIdmCallback): void
4669
4670Deletes user credential information.
4671
4672**System API**: This is a system API.
4673
4674**System capability**: SystemCapability.Account.OsAccount
4675
4676**Required permissions**: ohos.permission.MANAGE_USER_IDM
4677
4678**Parameters**
4679
4680| Name          | Type                                           | Mandatory| Description                     |
4681| --------------- | ----------------------------------- | --- | ---------------------------|
4682| credentialId    | Uint8Array                          | Yes | Credential ID.                 |
4683| token           | Uint8Array                          | Yes | Authentication token.              |
4684| callback        | [IIdmCallback](#iidmcallback8)      | Yes | Callback used to return the result.|
4685
4686**Error codes**
4687
4688| ID| Error Message            |
4689| -------- | ------------------- |
4690| 201 | Permission denied.|
4691| 202 | Not system application.|
4692| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4693| 12300001 | The system service works abnormally. |
4694| 12300002 | Invalid credentialId. |
4695| 12300101 | The token is invalid. |
4696| 12300102 | The credential does not exist. |
4697
4698**Example**
4699  ```ts
4700  let userIDM = new osAccount.UserIdentityManager();
4701  let credentialId: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0]);
4702  let token: Uint8Array = new Uint8Array([0]);
4703  try {
4704    userIDM.delCred(credentialId, token, {
4705      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4706          console.log('delCred result = ' + result);
4707          console.log('delCred extraInfo = ' + JSON.stringify(extraInfo));
4708      }
4709    });
4710  } catch (e) {
4711    console.log('delCred exception = ' + JSON.stringify(e));
4712  }
4713  ```
4714
4715### getAuthInfo<sup>8+</sup>
4716
4717getAuthInfo(callback: AsyncCallback&lt;Array&lt;EnrolledCredInfo&gt;&gt;): void
4718
4719Obtains authentication information. This API uses an asynchronous callback to return the result.
4720
4721**System API**: This is a system API.
4722
4723**System capability**: SystemCapability.Account.OsAccount
4724
4725**Required permissions**: ohos.permission.USE_USER_IDM
4726
4727**Parameters**
4728
4729| Name   | Type                                                                    | Mandatory| Description                                                |
4730| -------- | ------------------------------------------------------------------------ | ---- | --------------------------------------------- |
4731| callback | AsyncCallback&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is information about all registered credentials of the user. Otherwise, **err** is an error object.|
4732
4733**Error codes**
4734
4735| ID| Error Message              |
4736| -------- | --------------------- |
4737| 201 | Permission denied.|
4738| 202 | Not system application.|
4739| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4740| 12300001 | The system service works abnormally. |
4741
4742**Example**
4743  ```ts
4744  import { BusinessError } from '@kit.BasicServicesKit';
4745  let userIDM = new osAccount.UserIdentityManager();
4746  try {
4747    userIDM.getAuthInfo((err: BusinessError, result: osAccount.EnrolledCredInfo[]) => {
4748      console.log('getAuthInfo err = ' + JSON.stringify(err));
4749      console.log('getAuthInfo result = ' + JSON.stringify(result));
4750    });
4751  } catch (e) {
4752    console.log('getAuthInfo exception = ' + JSON.stringify(e));
4753  }
4754  ```
4755
4756### getAuthInfo<sup>8+</sup>
4757
4758getAuthInfo(authType: AuthType, callback: AsyncCallback&lt;Array&lt;EnrolledCredInfo&gt;&gt;): void
4759
4760Obtains authentication information of the specified type. This API uses an asynchronous callback to return the result.
4761
4762**System API**: This is a system API.
4763
4764**System capability**: SystemCapability.Account.OsAccount
4765
4766**Required permissions**: ohos.permission.USE_USER_IDM
4767
4768**Parameters**
4769
4770| Name   | Type                                              | Mandatory| Description                                               |
4771| -------- | -------------------------------------------------- | ---- | -------------------------------------------------- |
4772| authType | [AuthType](#authtype8) | Yes  | Authentication credential type.                                         |
4773| callback | AsyncCallback&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Yes  | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the information about all enrolled credentials of the specified type. Otherwise, **err** is an error object.|
4774
4775**Error codes**
4776
4777| ID| Error Message              |
4778| -------- | ------------------- |
4779| 201 | Permission denied.|
4780| 202 | Not system application.|
4781| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4782| 12300001 | The system service works abnormally. |
4783| 12300002 | Invalid authType. |
4784
4785**Example**
4786  ```ts
4787  import { BusinessError } from '@kit.BasicServicesKit';
4788  let userIDM = new osAccount.UserIdentityManager();
4789  try {
4790    userIDM.getAuthInfo(osAccount.AuthType.PIN,
4791      (err: BusinessError, result: osAccount.EnrolledCredInfo[]) => {
4792      console.log('getAuthInfo err = ' + JSON.stringify(err));
4793      console.log('getAuthInfo result = ' + JSON.stringify(result));
4794    });
4795  } catch (e) {
4796    console.log('getAuthInfo exception = ' + JSON.stringify(e));
4797  }
4798  ```
4799
4800### getAuthInfo<sup>8+</sup>
4801
4802getAuthInfo(authType?: AuthType): Promise&lt;Array&lt;EnrolledCredInfo&gt;&gt;;
4803
4804Obtains authentication information. This API uses a promise to return the result.
4805
4806**System API**: This is a system API.
4807
4808**System capability**: SystemCapability.Account.OsAccount
4809
4810**Required permissions**: ohos.permission.USE_USER_IDM
4811
4812**Parameters**
4813
4814| Name   | Type                               | Mandatory| Description     |
4815| -------- | ----------------------------------- | ---- | -------- |
4816| authType | [AuthType](#authtype8)              | No  | Authentication type. By default, this parameter is left blank, which means to obtain information about all authentication types.|
4817
4818**Return value**
4819
4820| Type                                        | Description                                                                    |
4821| :------------------------------------------- | :----------------------------------------------------------------------- |
4822| Promise&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Promise used to return the information about all the enrolled credentials of the specified type.|
4823
4824**Error codes**
4825
4826| ID| Error Message              |
4827| -------- | ------------------- |
4828| 201 | Permission denied.|
4829| 202 | Not system application.|
4830| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4831| 12300001 | The system service works abnormally. |
4832| 12300002 | Invalid authType. |
4833
4834**Example**
4835  ```ts
4836  import { BusinessError } from '@kit.BasicServicesKit';
4837  let userIDM = new osAccount.UserIdentityManager();
4838  try {
4839    userIDM.getAuthInfo(osAccount.AuthType.PIN).then((result: osAccount.EnrolledCredInfo[]) => {
4840      console.log('getAuthInfo result = ' + JSON.stringify(result))
4841    }).catch((err: BusinessError) => {
4842      console.log('getAuthInfo error = ' + JSON.stringify(err));
4843    });
4844  } catch (e) {
4845    console.log('getAuthInfo exception = ' + JSON.stringify(e));
4846  }
4847  ```
4848
4849### getAuthInfo<sup>12+</sup>
4850
4851getAuthInfo(options?: GetAuthInfoOptions): Promise&lt;Array&lt;EnrolledCredInfo&gt;&gt;
4852
4853Obtains authentication information. This API uses a promise to return the result.
4854
4855**System API**: This is a system API.
4856
4857**System capability**: SystemCapability.Account.OsAccount
4858
4859**Required permissions**: ohos.permission.USE_USER_IDM
4860
4861**Parameters**
4862
4863| Name   | Type                               | Mandatory| Description     |
4864| -------- | ----------------------------------- | ---- | -------- |
4865| options | [GetAuthInfoOptions](#getauthinfooptions12)          | No  | Optional parameters for obtaining authentication information.|
4866
4867**Return value**
4868
4869| Type                                        | Description                                                                    |
4870| :------------------------------------------- | :----------------------------------------------------------------------- |
4871| Promise&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Promise used to return the information about all the enrolled credentials of the specified type.|
4872
4873**Error codes**
4874
4875| ID| Error Message              |
4876| -------- | ------------------- |
4877| 201 | Permission denied.|
4878| 202 | Not system application.|
4879| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4880| 12300001 | The system service works abnormally. |
4881| 12300002 | Invalid options. |
4882| 12300003 | Account not found. |
4883
4884**Example**
4885  ```ts
4886  import { BusinessError } from '@kit.BasicServicesKit';
4887  let userIDM = new osAccount.UserIdentityManager();
4888  let options: osAccount.GetAuthInfoOptions = {
4889    authType: osAccount.AuthType.PIN,
4890    accountId: 100,
4891  };
4892  try {
4893    userIDM.getAuthInfo(options).then((result: osAccount.EnrolledCredInfo[]) => {
4894      console.log('getAuthInfo result = ' + JSON.stringify(result))
4895    }).catch((err: BusinessError) => {
4896      console.log('getAuthInfo error = ' + JSON.stringify(err));
4897    });
4898  } catch (e) {
4899    console.log('getAuthInfo exception = ' + JSON.stringify(e));
4900  }
4901  ```
4902
4903### getEnrolledId<sup>12+</sup>
4904
4905getEnrolledId(authType: AuthType, accountId?: number): Promise&lt;Uint8Array&gt;
4906
4907Obtains the ID of the enrolled credential based on the credential type and account ID (optional). This API uses a promise to return the result.
4908
4909**System API**: This is a system API.
4910
4911**System capability**: SystemCapability.Account.OsAccount
4912
4913**Required permissions**: ohos.permission.USE_USER_IDM
4914
4915**Parameters**
4916
4917| Name    | Type                  | Mandatory| Description     |
4918| --------  | ---------------------- | ---- | -------- |
4919| authType  | [AuthType](#authtype8) | Yes  | Credential type.|
4920| accountId | number                 | No  | System account ID, which is left blank by default.|
4921
4922**Return value**
4923
4924| Type                      | Description                                                                    |
4925| :------------------------ | :----------------------------------------------------------------------- |
4926| Promise&lt;Uint8Array&gt; | Promise used to return the credential ID obtained.|
4927
4928**Error codes**
4929
4930| ID| Error Message              |
4931| -------- | ------------------- |
4932| 201 | Permission denied.|
4933| 202 | Not system application.|
4934| 401      | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified; 2. Incorrect parameter types. |
4935| 12300001 | The system service works abnormally. |
4936| 12300002 | Invalid authType. |
4937| 12300003 | Account not found. |
4938| 12300102 | The credential does not exist. |
4939| 12300106 | The authentication type is not supported. |
4940
4941**Example**
4942  ```ts
4943  import { BusinessError } from '@kit.BasicServicesKit';
4944  let userIDM = new osAccount.UserIdentityManager();
4945  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
4946  let accountId = 100;
4947  try {
4948    userIDM.getEnrolledId(authType, accountId).then((enrolledId: Uint8Array) => {
4949        console.info('getEnrolledId enrolledId = ' + JSON.stringify(enrolledId));
4950    }).catch((err: BusinessError) => {
4951        console.info('getEnrolledId error = ' + JSON.stringify(err));
4952    });
4953  } catch (e) {
4954    console.log('getEnrolledId exception = ' + JSON.stringify(e));
4955  }
4956  ```
4957
4958## IInputData<sup>8+</sup>
4959
4960Provides callbacks for PIN operations.
4961
4962**System API**: This is a system API.
4963
4964### onSetData<sup>8+</sup>
4965
4966onSetData: (authSubType: AuthSubType, data: Uint8Array) => void;
4967
4968**System API**: This is a system API.
4969
4970Called to notify the caller the data is set.
4971
4972**System capability**: SystemCapability.Account.OsAccount
4973
4974**Parameters**
4975
4976| Name     | Type                                    | Mandatory| Description                                           |
4977| ---------- | ---------------------------------------- | ---- | ----------------------------------------------- |
4978| authSubType | [AuthSubType](#authsubtype8)             | Yes  | Credential subtype.                           |
4979| data       | Uint8Array                               | Yes  | Data (credential) to set. The data is used for authentication and operations for adding and modifying credentials.|
4980
4981**Error codes**
4982
4983| ID| Error Message              |
4984| -------- | ------------------- |
4985| 202 | Not system application.|
4986| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4987| 12300002 | Invalid pinSubType. |
4988
4989**Example**
4990  ```ts
4991  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
4992  let passwordNumber: Uint8Array = new Uint8Array([1, 2, 3, 4]);
4993  let inputer: osAccount.IInputer = {
4994    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
4995        if (authSubType == osAccount.AuthSubType.PIN_NUMBER) {
4996          callback.onSetData(authSubType, passwordNumber);
4997        } else {
4998          callback.onSetData(authSubType, password);
4999        }
5000    }
5001  };
5002  ```
5003
5004## IInputer<sup>8+</sup>
5005
5006Provides callbacks for credential inputers.
5007
5008**System API**: This is a system API.
5009
5010### onGetData<sup>8+</sup>
5011
5012onGetData: (authSubType: AuthSubType, callback: IInputData, options: GetInputDataOptions) => void;
5013
5014Called to notify the caller that data is obtained.
5015
5016**System API**: This is a system API.
5017
5018**System capability**: SystemCapability.Account.OsAccount
5019
5020**Parameters**
5021
5022| Name     | Type                                   | Mandatory| Description            |
5023| ---------- | --------------------------------------- | ---- | --------------- |
5024| authSubType | [AuthSubType](#authsubtype8) | Yes| Authentication credential subtype.|
5025| callback   | [IInputData](#iinputdata8)  | Yes  | Callback used to return the PIN data.|
5026| options | [GetInputDataOptions](#getinputdataoptions-12) | Yes| Optional parameters for the callback function.|
5027
5028**Example**
5029  ```ts
5030  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
5031  let passwordNumber: Uint8Array = new Uint8Array([1, 2, 3, 4]);
5032  let inputer: osAccount.IInputer = {
5033    onGetData: (authSubType: osAccount.AuthSubType,
5034      callback: osAccount.IInputData, options: osAccount.GetInputDataOptions) => {
5035        if (authSubType == osAccount.AuthSubType.PIN_NUMBER) {
5036          callback.onSetData(authSubType, passwordNumber);
5037        } else {
5038          callback.onSetData(authSubType, password);
5039        }
5040    }
5041  };
5042  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
5043  let result = pinAuth.registerInputer(inputer);
5044  console.log('registerInputer result: ' + result);
5045  ```
5046
5047## IUserAuthCallback<sup>8+</sup>
5048
5049Provides callbacks for user authentication.
5050
5051**System API**: This is a system API.
5052
5053### onResult<sup>8+</sup>
5054
5055onResult: (result: number, extraInfo: AuthResult) => void;
5056
5057Called to return the result code and authentication result.
5058
5059**System API**: This is a system API.
5060
5061**System capability**: SystemCapability.Account.OsAccount
5062
5063**Parameters**
5064
5065| Name    | Type                                   | Mandatory| Description                |
5066| --------- | --------------------------------------- | ---- | ------------------- |
5067| result    | number                                   | Yes  | Authentication result code.|
5068| extraInfo | [AuthResult](#authresult8)  | Yes  | Specific authentication result information. If the authentication is successful, the authentication token is returned in **extrainfo**. If the authentication fails, the remaining authentication time is returned. If the authentication executor is locked, the freezing time is returned.|
5069
5070**Example**
5071  ```ts
5072  let authCallback: osAccount.IUserAuthCallback = {
5073    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
5074      console.log('auth result = ' + result);
5075      console.log('auth extraInfo = ' + JSON.stringify(extraInfo));
5076    }
5077  };
5078  ```
5079
5080### onAcquireInfo?<sup>8+</sup>
5081
5082onAcquireInfo?: (module: number, acquire: number, extraInfo: Uint8Array) => void;
5083
5084Called to acquire identity authentication information.
5085
5086**System API**: This is a system API.
5087
5088**System capability**: SystemCapability.Account.OsAccount
5089
5090**Parameters**
5091
5092| Name   | Type    | Mandatory| Description                          |
5093| --------- | ------- | ---- | ----------------------------- |
5094| module    | number  | Yes  | Type of authentication executor.  |
5095| acquire   | number  | Yes  | Tip code of the authentication executor.|
5096| extraInfo | Uint8Array     | Yes  | Reserved.                    |
5097
5098**Example**
5099  ```ts
5100  let authCallback: osAccount.IUserAuthCallback = {
5101    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
5102      console.log('auth result = ' + result)
5103      console.log('auth extraInfo = ' + JSON.stringify(extraInfo));
5104    },
5105    onAcquireInfo: (module: number, acquire: number, extraInfo: Uint8Array) => {
5106      console.log('auth module = ' + module);
5107      console.log('auth acquire = ' + acquire);
5108      console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
5109    }
5110  };
5111  ```
5112
5113## IIdmCallback<sup>8+</sup>
5114
5115Provides callbacks for IDM.
5116
5117**System API**: This is a system API.
5118
5119### onResult<sup>8+</sup>
5120
5121onResult: (result: number, extraInfo: RequestResult) => void;
5122
5123Called to return the result code and request result information.
5124
5125**System API**: This is a system API.
5126
5127**System capability**: SystemCapability.Account.OsAccount
5128
5129**Parameters**
5130
5131| Name    | Type                                   | Mandatory| Description                    |
5132| --------- | --------------------------------------- | ---- | ----------------------- |
5133| result    | number                                  | Yes  | Authentication result code.   |
5134| extraInfo | [RequestResult](#requestresult8)  | Yes  | Specific information to be transferred.|
5135
5136**Example**
5137  ```ts
5138  let idmCallback: osAccount.IIdmCallback = {
5139    onResult: (result: number, extraInfo: osAccount.RequestResult) => {
5140      console.log('callback result = ' + result)
5141      console.info('callback extraInfo = ' + JSON.stringify(extraInfo));
5142    }
5143  };
5144  ```
5145
5146### onAcquireInfo?<sup>8+</sup>
5147
5148onAcquireInfo?: (module: number, acquire: number, extraInfo: Uint8Array) => void;
5149
5150Called to acquire IDM information.
5151
5152**System API**: This is a system API.
5153
5154**System capability**: SystemCapability.Account.OsAccount
5155
5156**Parameters**
5157
5158| Name   | Type    | Mandatory| Description                          |
5159| --------- | ------- | ---- | ----------------------------- |
5160| module    | number  | Yes  | Type of authentication executor.  |
5161| acquire   | number  | Yes  | Tip code of the authentication executor.|
5162| extraInfo | Uint8Array | Yes  | Reserved.                    |
5163
5164**Example**
5165  ```ts
5166  let idmCallback: osAccount.IIdmCallback = {
5167    onResult: (result: number, extraInfo: Object) => {
5168      console.log('callback result = ' + result)
5169      console.log('callback onResult = ' + JSON.stringify(extraInfo));
5170    },
5171    onAcquireInfo: (module: number, acquire: number, extraInfo: Uint8Array) => {
5172      console.log('callback module = ' + module);
5173      console.log('callback acquire = ' + acquire);
5174      console.log('callback onacquireinfo = ' + JSON.stringify(extraInfo));
5175    }
5176  };
5177  ```
5178
5179## GetPropertyRequest<sup>8+</sup>
5180
5181Defines the request for obtaining property information.
5182
5183**System API**: This is a system API.
5184
5185**System capability**: SystemCapability.Account.OsAccount
5186
5187| Name   | Type                                                         | Mandatory  | Description                  |
5188| -------- | ------------------------------------------------------------- | ----- | ----------------------- |
5189| authType | [AuthType](#authtype8)                            | Yes   | Authentication credential type.       |
5190| keys     | Array&lt;[GetPropertyType](#getpropertytype8)&gt; | Yes   | An array of the types of the properties to obtain.|
5191| accountId<sup>12+</sup> | number | No| System account ID, which is **undefined** by default.|
5192
5193## SetPropertyRequest<sup>8+</sup>
5194
5195Defines the request for setting property information.
5196
5197**System API**: This is a system API.
5198
5199**System capability**: SystemCapability.Account.OsAccount
5200
5201| Name   | Type                                            | Mandatory  | Description                |
5202| -------- | ------------------------------------------------ | ----- | -------------------- |
5203| authType | [AuthType](#authtype8)               | Yes   | Authentication credential type.    |
5204| key     | [SetPropertyType](#setpropertytype8) | Yes   | Type of the property to set.|
5205| setInfo  | Uint8Array                                       | Yes   | Information to set.    |
5206
5207## ExecutorProperty<sup>8+</sup>
5208
5209Defines the executor property.
5210
5211**System API**: This is a system API.
5212
5213**System capability**: SystemCapability.Account.OsAccount
5214
5215| Name        | Type                        |  Readable| Writable| Description             |
5216| ------------ | ---------------------------- | ----- | -----|----------------- |
5217| result       | number                       | Yes   | Yes  | Result.        |
5218| authSubType  | [AuthSubType](#authsubtype8) | Yes   | Yes  | Authentication credential subtype.|
5219| remainTimes  | number                       | Yes   | Yes  | Number of remaining authentication times.    |
5220| freezingTime | number                       | Yes   | Yes  | Freezing time.    |
5221| enrollmentProgress<sup>10+</sup> | string   | Yes   | Yes  | Enrollment progress. By default, no value is passed in.|
5222| sensorInfo<sup>10+</sup> | string           | Yes   | Yes  | Sensor information. By default, no value is passed in.|
5223| nextPhaseFreezingTime<sup>12+</sup> | number | Yes   | Yes  | Next freezing time, which is **undefined** by default.|
5224
5225## AuthResult<sup>8+</sup>
5226
5227Defines the authentication result information.
5228
5229**System API**: This is a system API.
5230
5231**System capability**: SystemCapability.Account.OsAccount
5232
5233| Name       | Type       | Mandatory  | Description             |
5234| ------------ | ----------- | ----- | ----------------- |
5235| token        | Uint8Array  | No   | Authentication token. By default, no value is passed in.     |
5236| remainTimes  | number      | No   | Number of remaining authentication times. By default, no value is passed in.     |
5237| freezingTime | number      | No   | Freezing time. By default, no value is passed in.     |
5238| nextPhaseFreezingTime<sup>12+</sup> | number | No   | Next freezing time, which is **undefined** by default.|
5239| credentialId<sup>12+</sup> | Uint8Array  | No   | Credential ID, which is left blank by default.|
5240| accountId<sup>12+</sup>         | number | No   | System account ID, which is **undefined** by default.|
5241| pinValidityPeriod<sup>12+</sup> | number | No   | Authentication validity period, which is **undefined** by default.|
5242
5243## CredentialInfo<sup>8+</sup>
5244
5245Defines the credential information.
5246
5247**System API**: This is a system API.
5248
5249**System capability**: SystemCapability.Account.OsAccount
5250
5251| Name       | Type                                    | Mandatory  | Description             |
5252| ------------ | ---------------------------------------- | ----- | ----------------- |
5253| credType     | [AuthType](#authtype8)       | Yes   | Authentication credential type.    |
5254| credSubType  | [AuthSubType](#authsubtype8) | Yes   | Authentication credential subtype.  |
5255| token        | Uint8Array                           | Yes   | Authentication token.    |
5256| accountId<sup>12+</sup>    | number | No   | System account ID, which is **undefined** by default.|
5257
5258## RequestResult<sup>8+</sup>
5259
5260Defines the request result information.
5261
5262**System API**: This is a system API.
5263
5264**System capability**: SystemCapability.Account.OsAccount
5265
5266| Name       | Type       | Mandatory  | Description             |
5267| ------------ | ----------- | ----- | ----------------- |
5268| credentialId | Uint8Array  | No   | Credential ID. By default, no value is passed in.     |
5269
5270## EnrolledCredInfo<sup>8+</sup>
5271
5272Defines enrolled credential information.
5273
5274**System API**: This is a system API.
5275
5276**System capability**: SystemCapability.Account.OsAccount
5277
5278| Name       | Type                                    | Mandatory  | Description             |
5279| ------------ | ---------------------------------------- | ----- | ------------------- |
5280| credentialId | Uint8Array                               | Yes   | Credential ID.      |
5281| authType     | [AuthType](#authtype8)       | Yes   | Authentication credential type.  |
5282| authSubType  | [AuthSubType](#authsubtype8) | Yes   | Credential subtype.|
5283| templateId   | Uint8Array                               | Yes   | Authentication credential template ID.    |
5284
5285## GetPropertyType<sup>8+</sup>
5286
5287Enumerates the types of properties to obtain.
5288
5289**System API**: This is a system API.
5290
5291**System capability**: SystemCapability.Account.OsAccount
5292
5293| Name          | Value| Description     |
5294| ------------- | ------ | --------- |
5295| AUTH_SUB_TYPE | 1      | Authentication credential subtype.|
5296| REMAIN_TIMES  | 2      | Number of remaining times.  |
5297| FREEZING_TIME | 3      | Freezing time.  |
5298| ENROLLMENT_PROGRESS<sup>10+</sup> | 4      | Enrollment progress.  |
5299| SENSOR_INFO<sup>10+</sup> | 5      | Sensor information.  |
5300| NEXT_PHASE_FREEZING_TIME<sup>12+</sup> | 6 | Next freezing time.|
5301
5302## SetPropertyType<sup>8+</sup>
5303
5304Enumerates the types of properties to set.
5305
5306**System API**: This is a system API.
5307
5308**System capability**: SystemCapability.Account.OsAccount
5309
5310| Name          | Value| Description       |
5311| -------------- | ----- | ----------- |
5312| INIT_ALGORITHM | 1     | Initialization algorithm.|
5313
5314## AuthType<sup>8+</sup>
5315
5316Enumerates the authentication credential types.
5317
5318**System API**: This is a system API.
5319
5320**System capability**: SystemCapability.Account.OsAccount
5321
5322| Name | Value| Description            |
5323| ----- | ----- | ---------------- |
5324| PIN   | 1     | PIN authentication.|
5325| FACE  | 2     | Facial authentication.|
5326| FINGERPRINT<sup>10+</sup>   | 4     | Fingerprint authentication.|
5327| RECOVERY_KEY<sup>12+</sup> | 8 | Key recovery type.|
5328| PRIVATE_PIN<sup>14+</sup> | 16 | Private PIN type.|
5329| DOMAIN<sup>9+</sup>  | 1024     | Domain authentication.|
5330
5331## AuthSubType<sup>8+</sup>
5332
5333Enumerates the authentication credential subtypes.
5334
5335**System API**: This is a system API.
5336
5337**System capability**: SystemCapability.Account.OsAccount
5338
5339| Name      | Value| Description              |
5340| ---------- | ----- | ------------------ |
5341| PIN_SIX    | 10000 | Six-digit PIN.      |
5342| PIN_NUMBER | 10001 | Custom PIN.|
5343| PIN_MIXED  | 10002 | Custom mixed credentials.|
5344| PIN_FOUR<sup>12+</sup>   | 10003 | 4-digit credential.|
5345| PIN_PATTERN<sup>12+</sup>  | 10004 | Pattern credential.|
5346| PIN_QUESTION<sup>14+</sup>  | 10005 | Security question credential.|
5347| FACE_2D    | 20000 | 2D face credential.  |
5348| FACE_3D    | 20001 | 3D face credential.  |
5349| FINGERPRINT_CAPACITIVE<sup>10+</sup>    | 30000 | Capacitive fingerprint.  |
5350| FINGERPRINT_OPTICAL<sup>10+</sup>    | 30001 | Optical fingerprint.  |
5351| FINGERPRINT_ULTRASONIC<sup>10+</sup>    | 30002 | Ultrasonic fingerprint.  |
5352| DOMAIN_MIXED<sup>9+</sup>    | 10240001 | Mixed domain authentication credentials.  |
5353
5354## AuthTrustLevel<sup>8+</sup>
5355
5356Enumerates the trust levels of the authentication result.
5357
5358**System API**: This is a system API.
5359
5360**System capability**: SystemCapability.Account.OsAccount
5361
5362| Name | Value| Description       |
5363| ---- | ------ | ----------- |
5364| ATL1 | 10000  | Trust level 1.|
5365| ATL2 | 20000  | Trust level 2.|
5366| ATL3 | 30000  | Trust level 3.|
5367| ATL4 | 40000  | Trust level 4.|
5368
5369## Module<sup>8+</sup>
5370
5371Enumerates the modules from which information is obtained.
5372
5373**System API**: This is a system API.
5374
5375**System capability**: SystemCapability.Account.OsAccount
5376
5377| Name      | Value| Description                    |
5378| --------- | ------ | ------------------------ |
5379| FACE_AUTH | 1      | Facial authentication module.|
5380
5381## ResultCode<sup>8+</sup>
5382
5383Enumerates the authentication result codes.
5384
5385**System API**: This is a system API.
5386
5387**System capability**: SystemCapability.Account.OsAccount
5388
5389| Name                   | Value| Description                                    |
5390| ----------------------- | ----- | ---------------------------------------- |
5391| SUCCESS                 | 0     | The authentication is successful or the authentication feature is supported.            |
5392| FAIL                    | 1     | The authentication executor failed to identify the user.                  |
5393| GENERAL_ERROR           | 2     | Other errors.                           |
5394| CANCELED                | 3     | The authentication is canceled.                      |
5395| TIMEOUT                 | 4     | The authentication timed out.                      |
5396| TYPE_NOT_SUPPORT        | 5     | The authentication credential type is not supported.                |
5397| TRUST_LEVEL_NOT_SUPPORT | 6     | The authentication trust level is not supported.              |
5398| BUSY                    | 7     | The authentication executor is busy. Try again after a few seconds.|
5399| INVALID_PARAMETERS      | 8     | Incorrect parameters are detected.                         |
5400| LOCKED                  | 9     | The authentication executor is locked.                    |
5401| NOT_ENROLLED            | 10    | The authentication executor is not enrolled.                  |
5402
5403## FaceTipsCode<sup>8+</sup>
5404
5405Enumerates the tip codes for facial authentication.
5406
5407**System API**: This is a system API.
5408
5409**System capability**: SystemCapability.Account.OsAccount
5410
5411| Name                         | Value| Description                                    |
5412| ----------------------------- | ----- | ---------------------------------------- |
5413| FACE_AUTH_TIP_TOO_BRIGHT      | 1     | The obtained face image is too bright.        |
5414| FACE_AUTH_TIP_TOO_DARK        | 2     | The obtained face image is too dark.      |
5415| FACE_AUTH_TIP_TOO_CLOSE       | 3     | The face is too close to the device.                      |
5416| FACE_AUTH_TIP_TOO_FAR         | 4     | The face is too far away from the device.                      |
5417| FACE_AUTH_TIP_TOO_HIGH        | 5     | Only the upper part of the face is captured because the device is angled too high.             |
5418| FACE_AUTH_TIP_TOO_LOW         | 6     | Only the lower part of the face is captured because the device is angled too low.             |
5419| FACE_AUTH_TIP_TOO_RIGHT       | 7     | Only the right part of the face is captured because the device is angled too much to the right.|
5420| FACE_AUTH_TIP_TOO_LEFT        | 8     | Only the left part of the face is captured because the device is angled too much to the left.|
5421| FACE_AUTH_TIP_TOO_MUCH_MOTION | 9     | The face moves too fast during facial information collection.        |
5422| FACE_AUTH_TIP_POOR_GAZE       | 10    | The face is not facing the device.                        |
5423| FACE_AUTH_TIP_NOT_DETECTED    | 11    | No face is detected.                        |
5424
5425## FingerprintTips<sup>8+</sup>
5426
5427Enumerates the tip codes for fingerprint authentication.
5428
5429**System API**: This is a system API.
5430
5431**System capability**: SystemCapability.Account.OsAccount
5432
5433| Name                         | Value| Description                                           |
5434| ----------------------------- | ----- | ----------------------------------------------- |
5435| FINGERPRINT_TIP_GOOD          | 0     | The captured image is clear.                             |
5436| FINGERPRINT_TIP_IMAGER_DIRTY  | 1     | The fingerprint image has big noise due to dirt on the sensor.|
5437| FINGERPRINT_TIP_INSUFFICIENT  | 2     | Failed to process the fingerprint image due to big noise.  |
5438| FINGERPRINT_TIP_PARTIAL       | 3     | Only part of the fingerprint image is detected.                        |
5439| FINGERPRINT_TIP_TOO_FAST      | 4     | The fingerprint image is incomplete due to quick motion.                 |
5440| FINGERPRINT_TIP_TOO_SLOW      | 5     | Failed to read the fingerprint image due to lack of motion.               |
5441| FINGERPRINT_TIP_FINGER_DOWN<sup>10+</sup>   | 6     | Press your finger.                 |
5442| FINGERPRINT_TIP_FINGER_UP<sup>10+</sup>     | 7     | Lift your finger.               |
5443
5444## OsAccountInfo
5445
5446Represents the system account information.
5447
5448**System capability**: SystemCapability.Account.OsAccount
5449
5450| Name     | Type  | Mandatory| Description      |
5451| ----------- | ------ | ---- | ---------- |
5452| shortName<sup>12+</sup> | string | No  | Short name of the system account.<br>**System API**: This is a system API and is left blank by default.|
5453| isLoggedIn<sup>12+</sup> | boolean | No  | Whether the system account is logged in.<br>**System API**: This is a system API. The default value is **false**.|
5454
5455## OsAccountType
5456
5457Enumerates the system account types.
5458
5459**System capability**: SystemCapability.Account.OsAccount
5460
5461| Name  | Value| Description        |
5462| ------ | ------ | ----------- |
5463| PRIVATE<sup>12+</sup> | 1024  | Privacy account. Only one privacy account is allowed.<br>**System API**: This is a system API.  |
5464
5465## DomainAccountInfo<sup>8+</sup>
5466
5467Represents domain account information.
5468
5469**System capability**: SystemCapability.Account.OsAccount
5470
5471| Name     | Type  | Mandatory| Description      |
5472| ----------- | ------ | ---- | ---------- |
5473| accountId<sup>10+</sup> | string | No  | Domain account ID.<br>**System API**: This is a system API and is **undefined** by default.|
5474| isAuthenticated<sup>11+</sup>| boolean | No| Whether the domain account has been authenticated.<br>**System API**: This is a system API. The default value is **false**.|
5475
5476## ConstraintSourceTypeInfo<sup>9+</sup>
5477
5478Defines the constraint source type.
5479
5480**System API**: This is a system API.
5481
5482**System capability**: SystemCapability.Account.OsAccount
5483
5484| Name     | Type  | Mandatory| Description      |
5485| ----------- | ------ | ---- | ---------- |
5486| localId      | number | Yes  | ID of the target system account.    |
5487| type | [ConstraintSourceType](#constraintsourcetype9) | Yes  | Type of the constrain source.|
5488
5489## ConstraintSourceType<sup>9+</sup>
5490
5491Enumerates the constraint sources.
5492
5493**System API**: This is a system API.
5494
5495**System capability**: SystemCapability.Account.OsAccount
5496
5497| Name  | Value| Description        |
5498| ------ | ------ | ------------ |
5499| CONSTRAINT_NOT_EXIST  | 0      | The constraint does not exist.|
5500| CONSTRAINT_TYPE_BASE | 1      | Constraint from system settings.  |
5501| CONSTRAINT_TYPE_DEVICE_OWNER  | 2   | Constraint from the device owners' settings.  |
5502| CONSTRAINT_TYPE_PROFILE_OWNER  | 3  | Constraint from the profile owners' settings.  |
5503
5504## AuthStatusInfo<sup>10+</sup>
5505
5506Presents the authentication status information.
5507
5508**System API**: This is a system API.
5509
5510**System capability**: SystemCapability.Account.OsAccount
5511
5512| Name     | Type  | Mandatory| Description      |
5513| ----------- | ------ | ---- | ---------- |
5514| remainTimes  | number | Yes  | Number of remaining times.  |
5515| freezingTime | number | Yes  | Freezing time.|
5516
5517## GetDomainAccessTokenOptions<sup>10+</sup>
5518
5519Defines the options for obtaining a domain access token.
5520
5521**System API**: This is a system API.
5522
5523**System capability**: SystemCapability.Account.OsAccount
5524
5525| Name     | Type  | Mandatory| Description      |
5526| ----------- | ------ | ---- | ---------- |
5527| domainAccountInfo  | [DomainAccountInfo](#domainaccountinfo8) | Yes  | Domain account information.  |
5528| domainAccountToken | Uint8Array | Yes  | Token of the domain account.|
5529| businessParams | Record<string, Object> | Yes  | Service parameters customized by the service party based on the request protocol.|
5530| callerUid | number | Yes  | Unique identifier of the caller.|
5531
5532## GetDomainAccountInfoOptions<sup>10+</sup>
5533
5534Defines the options for obtaining domain account information.
5535
5536**System API**: This is a system API.
5537
5538**System capability**: SystemCapability.Account.OsAccount
5539
5540| Name     | Type  | Mandatory| Description      |
5541| ----------- | ------ | ---- | ---------- |
5542| accountName | string | Yes  | Domain account name.|
5543| domain      | string | No  | Domain name, which is **undefined** by default.|
5544| serverConfigId<sup>12+</sup>| string | No| ID of the server to which the domain account belongs, which is **undefined** by default.|
5545
5546## GetDomainAccountInfoPluginOptions<sup>10+</sup>
5547
5548Defines the options for the domain plug-in to obtain the domain account information. The **GetDomainAccountInfoPluginOptions** class inherits from [**GetDomainAccountInfoOptions**](#getdomainaccountinfooptions10).
5549
5550**System API**: This is a system API.
5551
5552**System capability**: SystemCapability.Account.OsAccount
5553
5554| Name     | Type  | Mandatory| Description      |
5555| ----------- | ------ | ---- | ---------- |
5556| callerUid | number | Yes  | Unique identifier of the caller.|
5557
5558## OsAccountSwitchEventData<sup>12+</sup>
5559
5560Defines the event that indicates the start or end of a foreground-background system account switchover.
5561
5562**System API**: This is a system API.
5563
5564**System capability**: SystemCapability.Account.OsAccount
5565
5566| Name     | Type  | Mandatory| Description      |
5567| ----------- | ------ | ---- | ---------- |
5568| fromAccountId | number | Yes  | System account ID before the switchover.|
5569| toAccountId | number | Yes  | System account ID after the switchover.|
5570
5571## CreateOsAccountOptions<sup>12+</sup>
5572
5573Represents the optional parameter used to create a system account.
5574
5575**System API**: This is a system API.
5576
5577**System capability**: SystemCapability.Account.OsAccount
5578
5579| Name     | Type  | Mandatory| Description      |
5580| ----------- | ------ | ---- | ---------- |
5581| shortName | string | Yes  | Short name of the account (used as the name of the personal folder).<br>**The short name cannot**:<br>Contain any of the following characters: \< \>\| : " * ? / \\<br>Contain any of the following: . or ..<br>Exceed 255 characters. |
5582
5583## CreateOsAccountForDomainOptions<sup>12+</sup>
5584
5585Represents a set of optional parameters for creating a system account bound to the specified domain account. It inherits from [CreateOsAccountOptions](#createosaccountoptions12).
5586
5587**System API**: This is a system API.
5588
5589**System capability**: SystemCapability.Account.OsAccount
5590
5591| Name     | Type  | Mandatory| Description      |
5592| ----------- | ------ | ---- | ---------- |
5593| shortName | string | Yes  | Short name of the account (used as the name of the personal folder).<br>**The short name cannot**:<br>Contain any of the following characters: \< \>\| : " * ? / \\<br>Contain any of the following: . or ..<br>Exceed 255 characters. |
5594
5595## GetAuthInfoOptions<sup>12+</sup>
5596
5597Represents a set of optional parameters for [GetAuthInfo](#getauthinfo12).
5598
5599**System API**: This is a system API.
5600
5601**System capability**: SystemCapability.Account.OsAccount
5602
5603| Name     | Type                   | Mandatory| Description      |
5604| --------- | ---------------------- | ---- | ---------- |
5605| authType  | [AuthType](#authtype8) | No  | Authentication type, which is **undefined** by default.|
5606| accountId | number                 | No  | System account ID, which is **undefined** by default.|
5607
5608## AuthIntent<sup>12+</sup>
5609
5610Enumerates the authentication intents.
5611
5612**System API**: This is a system API.
5613
5614**System capability**: SystemCapability.Account.OsAccount
5615
5616| Name    | Value  | Description      |
5617| -------- | --- | ---------- |
5618| UNLOCK   | 1   | Unlock.|
5619| SILENT_AUTH<sup>14+</sup>  | 2   | Silent authentication.|
5620| QUESTION_AUTH<sup>14+</sup>   | 3   | Security question authentication.|
5621
5622## RemoteAuthOptions<sup>12+</sup>
5623
5624Represents a set of optional parameters for remote authentication.
5625
5626**System API**: This is a system API.
5627
5628**System capability**: SystemCapability.Account.OsAccount
5629
5630| Name              | Type   | Mandatory| Description      |
5631| ------------------ | ------ | ---- | ---------- |
5632| verifierNetworkId  | string | No  | Network ID of the credential verifier, which is left blank by default.|
5633| collectorNetworkId | string | No  | Network ID of the credential collector, which is left blank by default.|
5634| collectorTokenId   | number | No  | Token ID of the credential collector, which is **undefined** by default.|
5635
5636## AuthOptions<sup>12+</sup>
5637
5638Represents a set of optional parameters for [auth](#auth12).
5639
5640**System API**: This is a system API.
5641
5642**System capability**: SystemCapability.Account.OsAccount
5643
5644| Name              | Type   | Mandatory| Description      |
5645| ------------------ | ------ | ---- | ---------- |
5646| accountId          | number | No  | System account ID, which is **undefined** by default.|
5647| authIntent         | [AuthIntent](#authintent12) | No  | Authentication intent, which is **undefined** by default.|
5648| remoteAuthOptions  | [RemoteAuthOptions](#remoteauthoptions12) | No  | Remote authentication options, which is **undefined** by default.|
5649
5650## GetInputDataOptions <sup>12+</sup>
5651
5652Represents a set of optional parameters for [onGetData](#ongetdata8).
5653
5654**System API**: This is a system API.
5655
5656**System capability**: SystemCapability.Account.OsAccount
5657
5658| Name              | Type   | Mandatory| Description      |
5659| ------------------ | ------ | ---- | ---------- |
5660| challenge          | Uint8Array | No  | Challenge value, which is **undefined** by default.|
5661