Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
19253bd3
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
19253bd3
编写于
3月 10, 2023
作者:
N
ningning
提交者:
Gitee
3月 10, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add zh-cn/application-dev/application-models/enterprise-extensionAbility.md.
Signed-off-by:
N
ningning
<
3248127340@qq.com
>
上级
5e7d3c8b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
118 addition
and
0 deletion
+118
-0
zh-cn/application-dev/application-models/enterprise-extensionAbility.md
...ion-dev/application-models/enterprise-extensionAbility.md
+118
-0
未找到文件。
zh-cn/application-dev/application-models/enterprise-extensionAbility.md
0 → 100644
浏览文件 @
19253bd3
# EnterpriseAdminExtensionAbility开发指南
## EnterpriseAdminExtensionAbility简介
企业设备管理扩展能力,是MDM应用必备组件。当开发者为企业开发MDM(Mobile Device Management)应用时,需继承EnterpriseAdminExtensionAbility,在EnterpriseAdminExtensionAbility实例中实现MDM业务逻辑,EnterpriseAdminExtensionAbility实现了系统管理状态变化通知功能,并定义了管理应用激活、去激活、应用安装、卸载事件等回调接口。
## 约束与限制
-
**_功能限制_**
仅支持设备管理员应用使用。
## 场景:监听设备管理器激活、去激活、应用安装、卸载事件
### 概述
onAdminEnabled:由企业管理员或者员工部署MDM应用,激活设备管理器,系统通知MDM应用已激活DeviceAdmin权限。MDM应用可在onAdminEnabled回调函数中进行初始化策略设置。
onAdminDisabled:由系统或者员工去激活设备管理器,通知去激活DeviceAdmin权限,应用可以通知企业管理员设备已脱管。
onBundleAdded: 企业应用管理场景下,企业管理员订阅应用安装卸载事件,端侧应用安装和卸载事件通知MDM应用,MDM应用可以在回调函数中进行事件上报,通知企业管理员。
onBundleRemoved: 企业应用管理场景下,企业管理员取消订阅应用安装卸载事件。
### 接口说明
| 类名 | 接口名称 | 描述 |
| :------------------------------ | ----------------------------------------- | ---------------------------- |
| EnterpriseAdminExtensionAbility | onAdminDisabled(): void | 设备管理器应用去激活回调方法 |
| EnterpriseAdminExtensionAbility | onBundleAdded(bundleName: string): void | 应用安装回调方法 |
| EnterpriseAdminExtensionAbility | onAdminEnabled(): void | 设备管理器应用激活回调方法 |
| EnterpriseAdminExtensionAbility | onBundleRemoved(bundleName: string): void | 应用卸载回调方法 |
### 开发步骤
开发者在实现EnterpriseAdminExtensionAbility的时候,需先激活设备管理员应用,并在设备管理员应用的代码目录下新建ExtensionAbility,具体步骤如下。
1.
在工程Module对应的ets目录下,右键选择“New > Directory”,新建一个目录并命名为EnterpriseExtAbility。
2.
在EnterpriseExtAbility目录,右键选择“New > TypeScript File”,新建一个TypeScript文件并命名为EnterpriseExtAbility.ts。
3.
打开EnterpriseExtAbility.ts文件,导入EnterpriseAdminExtensionAbility模块,自定义类继承EnterpriseAdminExtensionAbility并加上需要的应用通知回调方法,如onAdminEnabled()、onAdminDisabled()等回调方法。当设备管理员应用被激活或者去激活时,则可以在对应回调方法中接受系统发送通知。
```
ts
import
EnterpriseAdminExtensionAbility
from
'
@ohos.enterprise.EnterpriseAdminExtensionAbility
'
;
export
default
class
EnterpriseAdminAbility
extends
EnterpriseAdminExtensionAbility
{
onAdminEnabled
()
{
console
.
info
(
"
onAdminEnabled
"
);
}
onAdminDisabled
()
{
console
.
info
(
"
onAdminDisabled
"
);
}
onBundleAdded
(
bundleName
:
string
)
{
console
.
info
(
"
EnterpriseAdminAbility onBundleAdded bundleName:
"
+
bundleName
)
}
onBundleRemoved
(
bundleName
:
string
)
{
console
.
info
(
"
EnterpriseAdminAbility onBundleRemoved bundleName
"
+
bundleName
)
}
};
```
4.在工程Module对应的
[
module.json5
](
../quick-start/module-configuration-file.md
)
配置文件中注册ServiceExtensionAbility,type标签需要设置为“enterpriseAdmin”,srcEntrance标签表示当前ExtensionAbility组件所对应的代码路径。
```
ts
"
extensionAbilities
"
:
[
{
"
name
"
:
"
ohos.samples.enterprise_admin_ext_ability
"
,
"
type
"
:
"
enterpriseAdmin
"
,
"
visible
"
:
true
,
"
srcEntrance
"
:
"
./ets/enterpriseextability/EnterpriseAdminAbility.ts
"
}
]
```
## 使用示例
通过@ohos.enterprise.adminManager模块中的subscribeManagedEvent接口和unsubscribeManagedEvent接口进行企业设备管理事件的订阅,订阅应用安装、卸载事件。当订阅成功后,端侧应用安装和卸载事件通知MDM应用,MDM应用可以在回调函数中进行事件上报,通知企业管理员。
```
ts
@
State
managedEvents
:
Array
<
adminManager
.
ManagedEvent
>
=
[
0
,
1
]
@
State
subscribeManagedEventMsg
:
string
=
""
@
State
unsubscribeManagedEventMsg
:
string
=
""
async
subscribeManagedEventCallback
()
{
await
adminManager
.
subscribeManagedEvent
(
this
.
admin
,
[
adminManager
.
ManagedEvent
.
MANAGED_EVENT_BUNDLE_ADDED
,
adminManager
.
ManagedEvent
.
MANAGED_EVENT_BUNDLE_REMOVED
],
(
error
)
=>
{
if
(
error
)
{
this
.
subscribeManagedEventMsg
=
'
subscribeManagedEvent Callback::errorCode:
'
+
error
.
code
+
'
errorMessage:
'
+
error
.
message
}
else
{
this
.
subscribeManagedEventMsg
=
'
subscribeManagedEvent Callback::success
'
}
})
}
async
unsubscribeManagedEventPromise
()
{
await
adminManager
.
unsubscribeManagedEvent
(
this
.
admin
,
[
adminManager
.
ManagedEvent
.
MANAGED_EVENT_BUNDLE_ADDED
,
adminManager
.
ManagedEvent
.
MANAGED_EVENT_BUNDLE_REMOVED
]).
then
(()
=>
{
this
.
unsubscribeManagedEventMsg
=
'
unsubscribeManagedEvent Promise::success
'
}).
catch
((
error
)
=>
{
this
.
unsubscribeManagedEventMsg
=
'
unsubscribeManagedEvent Promise::errorCode:
'
+
error
.
code
+
'
errorMessage:
'
+
error
.
message
})
}
```
## 相关实例
针对EnterpriseAdminExtensionAbility开发,有以下相关示例可供参考:
[
EnterpriseAdminExtensionAbility:EnterpriseAdminExtensionAbility的创建与使用(ArkTS) (API9)
](
https://gitee.com/openharmony/applications_app_samples/tree/master/customization/EnterpriseAdminExtensionAbility
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录