# @ohos.bundle.appControl (appControl) The **appControl** module provides APIs for setting, obtaining, and deleting the disposed status of an application. An application in the disposed status is forbidden to run. When a user clicks the application icon on the home screen, the corresponding page is displayed based on the disposal intent. > **NOTE** > > The initial APIs of this module are supported since API version 9. Newly added APIs will be marked with a superscript to indicate their earliest API version. > > The APIs provided by this module are system APIs. ## Modules to Import ``` ts import appControl from '@ohos.bundle.appControl' ``` ## appControl.setDisposedStatus setDisposedStatus(appId: string, disposedWant: Want): Promise\ Sets the disposed status for an application. This API uses a promise to return the result. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | | disposedWant | Want | Yes| Disposal intent of the application.| **Return value** | Type | Description | | ------------------------- | ------------------ | | Promise\ | Promise that returns no value.| **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import { BusinessError } from '@ohos.base'; import Want from '@ohos.app.ability.Want'; import appControl from '@ohos.bundle.appControl'; let appId = "com.example.myapplication_xxxxx"; let want:Want = {bundleName: 'com.example.myapplication'}; try { appControl.setDisposedStatus(appId, want) .then(() => { console.info('setDisposedStatus success'); }).catch((error: BusinessError) => { let message = (error as BusinessError).message; console.error('setDisposedStatus failed ' + message); }); } catch (error) { let message = (error as BusinessError).message; console.error('setDisposedStatus failed ' + message); } ``` ## appControl.setDisposedStatus setDisposedStatus(appId: string, disposedWant: Want, callback: AsyncCallback\): void; Sets the disposed status for an application. This API uses an asynchronous callback to return the result. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------------------------------- | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | | disposedWant | Want | Yes| Disposal intent of the application.| | callback | AsyncCallback\ | Yes | Callback used to return the result. If the operation is successful, **err** is **null**; otherwise, **err** is an error object.| **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; import Want from '@ohos.app.ability.Want'; let appId = "com.example.myapplication_xxxxx"; let want: Want = {bundleName: 'com.example.myapplication'}; try { appControl.setDisposedStatus(appId, want, (error: BusinessError, data) => { if (error) { let message = (error as BusinessError).message; console.error('setDisposedStatus failed ' + message); return; } console.info('setDisposedStatus success'); }); } catch (error) { let message = (error as BusinessError).message; console.error('setDisposedStatus failed ' + message); } ``` ## appControl.setDisposedStatusSync10+ setDisposedStatusSync(appId: string, disposedWant: Want): void; Sets the disposed status for an application. This API is a synchronous API. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------------------------------- | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | | disposedWant | Want | Yes| Disposal intent of the application.| **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; import Want from '@ohos.app.ability.Want'; let appId: string = "com.example.myapplication_xxxxx"; let want: Want = {bundleName: 'com.example.myapplication'}; try { appControl.setDisposedStatusSync(appId, want); } catch (error) { let message = (error as BusinessError).message; console.error('setDisposedStatusSync failed ' + message); } ``` ## appControl.getDisposedStatus getDisposedStatus(appId: string): Promise\; Obtains the disposed status of an application. This API uses a promise to return the result. If the operation is successful, the disposed status of the application is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | **Return value** | Type | Description | | ------------------------- | ------------------ | | Promise\ | Promise used to return the disposed status.| **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; let appId = "com.example.myapplication_xxxxx"; try { appControl.getDisposedStatus(appId) .then((data) => { console.info('getDisposedStatus success. DisposedStatus: ' + JSON.stringify(data)); }).catch((error: BusinessError) => { let message = (error as BusinessError).message; console.error('getDisposedStatus failed ' + message); }); } catch (error) { let message = (error as BusinessError).message; console.error('getDisposedStatus failed ' + message); } ``` ## appControl.getDisposedStatus getDisposedStatus(appId: string, callback: AsyncCallback\): void; Obtains the disposed status of an application. This API uses an asynchronous callback to return the result. If the operation is successful, the disposed status of the application is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | | callback | AsyncCallback\ | Yes | Callback used to return the result. If the operation is successful, **err** is **null** and **data** is the disposed status obtained; otherwise, **err** is an error object. | **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; let appId = "com.example.myapplication_xxxxx"; try { appControl.getDisposedStatus(appId, (error, data) => { if (error) { let message = (error as BusinessError).message; console.error('getDisposedStatus failed ' + message); return; } console.info('getDisposedStatus success. DisposedStatus: ' + JSON.stringify(data)); }); } catch (error) { let message = (error as BusinessError).message; console.error('getDisposedStatus failed ' + message); } ``` ## appControl.getDisposedStatusSync10+ getDisposedStatusSync(appId: string): Want; Obtains the disposed status of an application. This API is a synchronous API. If the operation is successful, the disposed status of the application is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | **Return value** | Type | Description | | ------------------------- | ------------------ | | Want | Disposed status. | **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; import Want from '@ohos.app.ability.Want'; let appId: string = "com.example.myapplication_xxxxx"; let want: Want; try { want = appControl.getDisposedStatusSync(appId); } catch (error) { let message = (error as BusinessError).message; console.error('getDisposedStatusSync failed ' + message); } ``` ## appControl.deleteDisposedStatus deleteDisposedStatus(appId: string): Promise\ Deletes the disposed status for an application. This API uses a promise to return the result. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | **Return value** | Type | Description | | ------------------------- | ------------------ | | Promise\ | Promise that returns no value.| **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; let appId = "com.example.myapplication_xxxxx"; try { appControl.deleteDisposedStatus(appId) .then(() => { console.info('deleteDisposedStatus success'); }).catch((error: BusinessError) => { let message = (error as BusinessError).message; console.error('deleteDisposedStatus failed ' + message); }); } catch (error) { let message = (error as BusinessError).message; console.error('deleteDisposedStatus failed ' + message); } ``` ## appControl.deleteDisposedStatus deleteDisposedStatus(appId: string, callback: AsyncCallback\) : void Deletes the disposed status for an application. This API uses an asynchronous callback to return the result. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | | callback | AsyncCallback\ | Yes | Callback used to return the result. If the operation is successful, **err** is **null**; otherwise, **err** is an error object. | **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; let appId = "com.example.myapplication_xxxxx"; try { appControl.deleteDisposedStatus(appId, (error: BusinessError, data) => { if (error) { console.error('deleteDisposedStatus failed ' + error.message); return; } console.info('deleteDisposedStatus success'); }); } catch (error) { let message = (error as BusinessError).message; console.error('deleteDisposedStatus failed ' + message); } ``` ## appControl.deleteDisposedStatusSync10+ deleteDisposedStatusSync(appId: string) : void Deletes the disposed status for an application. This API is a synchronous API. If the operation is successful, **null** is returned. If the operation fails, an error message is returned. **Required permissions**: ohos.permission.MANAGE_DISPOSED_APP_STATUS **System capability**: SystemCapability.BundleManager.BundleFramework.AppControl **System API**: This is a system API. **Parameters** | Name | Type | Mandatory | Description | | ----------- | ------ | ---- | --------------------------------------- | | appId | string | Yes | ID of the target application.
**appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. For details about how to obtain **appId**, see [Obtaining appId of an Application](#obtaining-appid-of-an-application). | **Error codes** For details about the error codes, see [Bundle Error Codes](../errorcodes/errorcode-bundle.md). | ID| Error Message | | ------ | -------------------------------------- | | 17700005 | The specified app ID is empty string. | **Example** ```ts import appControl from '@ohos.bundle.appControl'; import { BusinessError } from '@ohos.base'; let appId: string = "com.example.myapplication_xxxxx"; try { appControl.deleteDisposedStatusSync(appId); } catch (error) { let message = (error as BusinessError).message; console.error('deleteDisposedStatusSync failed ' + message); } ``` ## Obtaining appId of an Application **appId** is the unique identifier of an application and is determined by the bundle name and signature information of the application. It can be obtained by calling [getBundleInfo](js-apis-bundleManager.md#bundlemanagergetbundleinfo). **Example** ```ts import bundleManager from '@ohos.bundle.bundleManager'; import { BusinessError } from '@ohos.base'; let bundleName = 'com.example.myapplication'; let appId: string; try { bundleManager.getBundleInfo(bundleName, bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_SIGNATURE_INFO) .then((data) => { appId = data.signatureInfo.appId; console.info("appId is " + appId); }).catch((error: BusinessError) => { let message = (error as BusinessError).message; console.error("getBundleInfo failed " + message); }); } catch (error) { let message = (error as BusinessError).message; console.error("getBundleInfo failed " + message); } ```