1# bundlemanager_ecological_rule_manager
2
3### 简介
4生态规则管控服务提供一种系统的扩展能力,设备厂商可以在定制设备上(2B合作项目等),对应用的行为(跳转、添加桌面卡片、免安装元服务)进行管控,从而定制出满足厂商管控要求的用户体验。
5
6
7### 软件架构
8![image](figures/architecture_zh.jpg)
9
10以下是对于上图关键字段的描述信息:
11
12- `App`:App,在打开元服务时会受到生态规则服务的管控。
13- `AbilityManagerService`:元能力管理服务,用于协调各Ability运行关系、及对生命周期进行调度的系统服务。
14- `FormManagerService`:卡片管理服务,管理卡片的生命周期,并维护卡片信息以及卡片事件的调度。
15- `BundleManagerService`:包管理服务,负责应用安装包的管理,提供安装包的信息查询、安装、更新、卸载和包信息存储等能力。
16- `EcologicalRuleManagerService`:生态规则管控服务,对元服务的拉起,加桌等行为进行管控。
17
18
19### 目录结构
20
21```shell
22/foundation/bundlemanager/ecological_rule_mgr       # 生态规则管控服务业务代码
23├── etc
24│   └── init                                        # SA启动配置文件
25├── interfaces                                      # 接口代码
26│   └── innerkits                                   # 内部接口
27├── profile                                         # 服务配置文件
28├── services                                        # 服务代码
29├── LICENSE                                         # 证书文件
30├── tests                                           # 开发者测试
31└── utils                                           # 工具类
32```
33### 编译构建
34
35在OpenHarmony源码根目录下,调用以下指令,单独编译ecological_rule_manager。
36```shell
37./build.sh --product-name rk3568 --ccache --build-target ecological_rule_manager
38```
39> **说明:**
40--product-name:产品名称,例如Hi3516DV300、rk3568等。
41--ccache:编译时使用缓存功能。
42--build-target: 编译的部件名称。
43
44### 接口使用说明
45生态规则管控服务只对系统服务开放内部接口,系统根据实际需要进行接口功能扩展。
46|接口|说明|
47|---|---|
48|QueryStartExperience(const Want &want, const CallerInfo &callerInfo, ExperienceRule &rule):int32_t|提供给AbilityManagerService使用,在元服务打开时调用。ExperienceRule为返回值,返回是否允许打开;不允许时可以返回具体的体验Want。|
49|QueryFreeInstallExperience(const Want &want, const CallerInfo &callerInfo ExperienceRule &rule):int32_t|提供给BundleManagerService使用,在元服务免安装时调用。用于判断是否允许免安装,不允许时可以返回具体的体验Want。|
50|IsSupportPublishForm(const vector<AAFwk::Want> &wants, const CallerInfo &callerInfo, bool &bSupport):int32_t|提供给FormManagerService使用,在卡片加桌时调用。用于判断是否允许加桌|
51|EvaluateResolveInfos(const Want &want, const CallerInfo &callerInfo, int32_t type,std::vector<AbilityInfo> &abilityInfos):int32_t|提供给AbilityManagerService使用,支持过滤掉禁止出现的提供者|
52
53