跳到主要内容

订阅阻断类事件

场景介绍

从6.0.0(20) 开始,新增提供统一的安全审计数据多客户端订阅/取消订阅、添加/删除过滤条件、阻断接口,应用可以获取设备上的安全审计数据(如下表),并按需进行订阅、过滤与阻断,以支撑审计相关业务。

审计事件ID说明
0x1C801100文件创建阻断事件。
0x1C801101文件打开阻断事件。
0x1C801102文件重命名阻断事件。
0x1C801103文件删除阻断事件。
0x1C801104文件设置扩展属性的阻断事件。
0x1C801105文件删除扩展属性的阻断事件。

约束与限制

  1. 当前能力仅支持2in1设备。
  2. 一个进程最大只允许创建2个客户端实例,当前设备最多只允许创建16个客户端实例。
  3. 一个客户端实例最大只允许设置256条正过滤的过滤value和256条反过滤的过滤value。

业务流程

流程说明:

  1. 开发者创建审计阻断类事件(以下统称为事件)订阅客户端实例,需要提供CallBack。

  2. 开发者使用步骤1中创建的实例订阅事件,需要提供想要订阅的事件id。

  3. 开发者使用步骤1中创建的实例设置事件过滤条件,需要提供事件id和过滤条件信息。

  4. 当事件发生时,审计服务先根据事件过滤条件过滤事件,当事件满足过滤条件时,触发回调通知订阅当前事件的客户端。

  5. 开发者根据审计数据制定阻断策略。

  6. 使用步骤1中创建的实例设置接收到的事件的阻断策略。

  7. 当业务结束时,开发者可以使用步骤1中创建的实例解除过滤条件,取消订阅事件。

  8. 当业务结束时,开发者可以删除步骤1中创建的实例。

    支持先设置过滤条件再订阅事件。

    删除实例后,被删除的实例所有的订阅以及过滤条件将被全部解除。

接口说明

更多接口及使用方法请参见API参考

接口名描述
int32_t HMS_SecurityAudit_NewAuthClient(SecurityAudit_AuthClient** client, SecurityAudit_Handler handler);创建审计阻断类事件管理对象AuthClient,AuthClient提供订阅、解订阅、增加事件过滤、移除事件过滤、阻断功能
int32_t HMS_SecurityAudit_DeleteAuthClient(SecurityAudit_AuthClient* client);删除审计阻断类事件管理对象
int32_t HMS_SecurityAudit_SubscribeAuthEvent(const SecurityAudit_AuthClient* client, const SecurityAudit_Auth_Event *events, uint64_t count);订阅审计阻断类事件
int32_t HMS_SecurityAudit_UnsubscribeAuthEvent(const SecurityAudit_AuthClient* client, const SecurityAudit_Auth_Event *events, uint64_t count);解订阅审计阻断类事件
int32_t HMS_SecurityAudit_AddAuthEventFilter(const SecurityAudit_AuthClient* client, SecurityAudit_Auth_Event event, const SecurityAudit_Filter *filter);添加审计阻断类事件过滤条件
int32_t HMS_SecurityAudit_RemoveAuthEventFilter(const SecurityAudit_AuthClient* client, SecurityAudit_Auth_Event event, const SecurityAudit_Filter *filter);移除审计阻断类事件过滤条件
int32_t HMS_SecurityAudit_Auth(const SecurityAudit_AuthClient* client, const SecurityAudit_Event *event, SecurityAudit_AuthResult authResult);设置审计阻断类事件的阻断结果

开发步骤

  • 在开发准备过程中,需要申请权限:ohos.permission.kernel.AUTH_AUDIT_EVENT。
  • 只允许清单内的企业类应用申请该权限,申请方式请参考:申请使用企业类应用可用权限
  1. 在CMakeLists.txt中导入安全审计共享库,并链接该库。

    find_library(dsm-lib libsecurityaudit_ndk.z.so)
    target_link_libraries(entry PUBLIC libace_napi.z.so ${dsm-lib})
  2. 导入安全审计的头文件。

    #include <DeviceSecurityKit/security_audit.h>
    #include <cstdio>
  3. 全局范围定义阻断类事件客户端以及携带阻断策略的回调函数。

    SecurityAudit_AuthClient *client = nullptr;
    void AuthAllowCb(const SecurityAudit_Event *events, uint64_t count)
    {
    if (events == nullptr) {
    printf("events nullptr");
    return;
    }
    if (client == nullptr) {
    printf("client nullptr");
    return;
    }
    for (uint64_t i = 0; i < count; i++) {
    printf("event metadata = %s \n", events[i].metadata);
    printf("event content = %s \n", events[i].content);
    printf("event id = %ld \n", events[i].eventId);
    const SecurityAudit_Event *singleEvent = &events[i];
    HMS_SecurityAudit_Auth(client, singleEvent, SECURITY_AUDIT_AUTH_RESULT_DENY);
    }
    }
  4. 创建审计阻断类事件客户端实例。

    SecurityAudit_Handler handler = AuthAllowCb;
    HMS_SecurityAudit_NewAuthClient(&client, handler);
    if (client == nullptr) {
    printf("client is null");
    return;
    }
  5. 订阅审计阻断类事件。

    SecurityAudit_Auth_Event event[1] = {};
    event[0] = SECURITY_AUDIT_AUTH_EVENT_FILE_CREATE;
    int ret = HMS_SecurityAudit_SubscribeAuthEvent(client, event, 1);
    if (ret != 0) {
    printf("subscribe fail");
    return;
    }
  6. 设置审计阻断类事件过滤条件。

    SecurityAudit_Filter filter = {};
    filter.type = PROCESS_NAME_PREFIX;
    const char* filterStr[1] = {};
    filterStr[0] = "1";
    filter.value = filterStr;
    filter.valueCount = 1;
    ret = HMS_SecurityAudit_AddAuthEventFilter(client, SECURITY_AUDIT_AUTH_EVENT_FILE_CREATE, &filter);
    if (ret != 0) {
    printf("addfilter fail");
    return;
    }
  7. 解除审计阻断类事件订阅。

    ret = HMS_SecurityAudit_UnsubscribeAuthEvent(client, event, 1);
    if (ret != 0) {
    printf("unsubscribe fail");
    return;
    }
  8. 解除审计阻断类事件过滤条件。

    ret = HMS_SecurityAudit_RemoveAuthEventFilter(client, SECURITY_AUDIT_AUTH_EVENT_FILE_CREATE, &filter);
    if (ret != 0) {
    printf("removefilter fail");
    return;
    }
  9. 删除审计阻断类事件客户端实例。

    ret = HMS_SecurityAudit_DeleteAuthClient(client);
    if (ret != 0) {
    printf("deleteclient fail");
    return;
    }