1# EnterpriseAdminExtensionAbility Development 2 3## Introduction to EnterpriseAdminExtensionAbility 4 5EnterpriseAdminExtensionAbility is a mandatory component for Mobile Device Management (MDM) applications. When developing MDM applications for enterprises, you need to inherit EnterpriseAdminExtensionAbility and implement MDM service logic in the EnterpriseAdminExtensionAbility instance. EnterpriseAdminExtensionAbility implements notifications of system management status changes and defines the callbacks for when a device administrator application is enabled or disabled or an application is installed or uninstalled. 6 7## Constraints 8 9EnterpriseAdminExtensionAbility is applicable only to enterprise administrator applications. 10 11## Observing Activation/Deactivation of a Device Administrator Application and Installation/Removal of an Application 12 13### Overview 14 15**onAdminEnabled**: When an enterprise administrator or employee deploys an MDM application and activates the device administrator application, this callback is invoked to notify the MDM application that the DeviceAdmin permission is activated. The initialization policy of the MDM application can set in **onAdminEnabled**. 16 17**onAdminDisabled**: When the device administrator application is deactivated, the callback is invoked to notify the MDM application that the DeviceAdmin permission is deactivated. 18 19**onBundleAdded**: The enterprise administrator can subscribe to application installation and uninstallation events. When an application is installed on an enterprise device, the MDM application reports the event in this callback to notify the enterprise administrator. 20 21**onBundleRemoved**: When an application is removed from an enterprise device, the MDM application reports the event in this callback to notify the enterprise administrator. 22 23### Available APIs 24 25| Class | API | Description | 26| ------------------------------ | ----------------------------------------- | ---------------------------- | 27| EnterpriseAdminExtensionAbility | onAdminEnabled(): void | Called when a device administrator application is activated. | 28| EnterpriseAdminExtensionAbility | onAdminDisabled(): void | Called when a device administrator application is deactivated.| 29| EnterpriseAdminExtensionAbility | onBundleAdded(bundleName: string): void | Called when an application is installed on a device. | 30| EnterpriseAdminExtensionAbility | onBundleRemoved(bundleName: string): void | Called when an application is removed from a device. | 31 32### How to Develop 33 34To implement EnterpriseAdminExtensionAbility, you need to activate the device administrator application and create **ExtensionAbility** in the code directory of the device administrator application. The procedure is as follows: 35 361. In the **ets** directory of the target module, right-click and choose **New > Directory** to create a directory named **EnterpriseExtAbility**. 372. Right-click the **EnterpriseExtAbility** directory, and choose **New > TypeScript File** to create a file named **EnterpriseExtAbility.ts**. 383. Open the **EnterpriseExtAbility.ts** file and import the **EnterpriseAdminExtensionAbility** module. Inherit the **EnterpriseAdminExtensionAbility** module to the custom class and add application notification callbacks, such as **onAdminEnabled()** and **onAdminDisabled()**. When the device administrator application is activated or deactivated, the device administrator can receive notifications. 39 40 ```ts 41 import EnterpriseAdminExtensionAbility from '@ohos.enterprise.EnterpriseAdminExtensionAbility'; 42 43 export default class EnterpriseAdminAbility extends EnterpriseAdminExtensionAbility { 44 45 onAdminEnabled() { 46 console.info("onAdminEnabled"); 47 } 48 49 onAdminDisabled() { 50 console.info("onAdminDisabled"); 51 } 52 53 onBundleAdded(bundleName: string) { 54 console.info("EnterpriseAdminAbility onBundleAdded bundleName:" + bundleName) 55 } 56 57 onBundleRemoved(bundleName: string) { 58 console.info("EnterpriseAdminAbility onBundleRemoved bundleName" + bundleName) 59 } 60 }; 61 ``` 62 634. Register **ServiceExtensionAbility** in the [**module.json5**](../quick-start/module-configuration-file.md) file corresponding to the project module. Set **type** to **enterpriseAdmin** and **srcEntry** to the path of the ExtensionAbility code. 64 65 ```ts 66 "extensionAbilities": [ 67 { 68 "name": "ohos.samples.enterprise_admin_ext_ability", 69 "type": "enterpriseAdmin", 70 "exported": true, 71 "srcEntry": "./ets/enterpriseextability/EnterpriseAdminAbility.ts" 72 } 73 ] 74 ``` 75 76## Example 77 78Use **subscribeManagedEvent** in the **@ohos.enterprise.adminManager** module to subscribe to application installation and removal events. When an application is installed or removed, the MDM application is notified of the event. Then, the MDM application reports the event in the callback to notify the enterprise administrator. To unsubscribe from events, use **unsubscribeManagedEvent**. 79 80```ts 81 @State managedEvents: Array<adminManager.ManagedEvent> = [0,1] 82 @State subscribeManagedEventMsg: string = "" 83 @State unsubscribeManagedEventMsg: string = "" 84 85 async subscribeManagedEventCallback() { 86 await adminManager.subscribeManagedEvent(this.admin, 87 [adminManager.ManagedEvent.MANAGED_EVENT_BUNDLE_ADDED, 88 adminManager.ManagedEvent.MANAGED_EVENT_BUNDLE_REMOVED], (error) => { 89 if (error) { 90 this.subscribeManagedEventMsg = 'subscribeManagedEvent Callback::errorCode: ' + error.code + ' errorMessage: ' + error.message 91 } else { 92 this.subscribeManagedEventMsg = 'subscribeManagedEvent Callback::success' 93 } 94 }) 95 } 96 97 async unsubscribeManagedEventPromise() { 98 await adminManager.unsubscribeManagedEvent(this.admin, 99 [adminManager.ManagedEvent.MANAGED_EVENT_BUNDLE_ADDED, 100 adminManager.ManagedEvent.MANAGED_EVENT_BUNDLE_REMOVED]).then(() => { 101 this.unsubscribeManagedEventMsg = 'unsubscribeManagedEvent Promise::success' 102 }).catch((error) => { 103 this.unsubscribeManagedEventMsg = 'unsubscribeManagedEvent Promise::errorCode: ' + error.code + ' errorMessage: ' + error.message 104 }) 105 } 106``` 107 108