161847f8eSopenharmony_ci/*
261847f8eSopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
361847f8eSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
461847f8eSopenharmony_ci * you may not use this file except in compliance with the License.
561847f8eSopenharmony_ci * You may obtain a copy of the License at
661847f8eSopenharmony_ci *
761847f8eSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
861847f8eSopenharmony_ci *
961847f8eSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
1061847f8eSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
1161847f8eSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1261847f8eSopenharmony_ci * See the License for the specific language governing permissions and
1361847f8eSopenharmony_ci * limitations under the License.
1461847f8eSopenharmony_ci */
1561847f8eSopenharmony_ci
1661847f8eSopenharmony_ci/**
1761847f8eSopenharmony_ci * @file
1861847f8eSopenharmony_ci * @kit AbilityKit
1961847f8eSopenharmony_ci */
2061847f8eSopenharmony_ci
2161847f8eSopenharmony_ciimport type { AsyncCallback } from './@ohos.base';
2261847f8eSopenharmony_ciimport type * as _BusinessAbilityInfo from './application/BusinessAbilityInfo';
2361847f8eSopenharmony_ci
2461847f8eSopenharmony_ci/**
2561847f8eSopenharmony_ci * This module is used to obtain business ability information of various applications installed on the current device.
2661847f8eSopenharmony_ci *
2761847f8eSopenharmony_ci * @namespace businessAbilityRouter
2861847f8eSopenharmony_ci * @syscap SystemCapability.Ability.AbilityRuntime.Core
2961847f8eSopenharmony_ci * @systemapi
3061847f8eSopenharmony_ci * @since 10
3161847f8eSopenharmony_ci */
3261847f8eSopenharmony_cideclare namespace businessAbilityRouter {
3361847f8eSopenharmony_ci  /**
3461847f8eSopenharmony_ci   * This enumeration value is used to identify various types of business ability info
3561847f8eSopenharmony_ci   *
3661847f8eSopenharmony_ci   * @enum { number }
3761847f8eSopenharmony_ci   * @syscap SystemCapability.Ability.AbilityRuntime.Core
3861847f8eSopenharmony_ci   * @systemapi
3961847f8eSopenharmony_ci   * @since 10
4061847f8eSopenharmony_ci   */
4161847f8eSopenharmony_ci  export enum BusinessType {
4261847f8eSopenharmony_ci    /**
4361847f8eSopenharmony_ci     * Indicates business ability info with type of share
4461847f8eSopenharmony_ci     *
4561847f8eSopenharmony_ci     * @syscap SystemCapability.Ability.AbilityRuntime.Core
4661847f8eSopenharmony_ci     * @systemapi
4761847f8eSopenharmony_ci     * @since 10
4861847f8eSopenharmony_ci     */
4961847f8eSopenharmony_ci    SHARE = 0,
5061847f8eSopenharmony_ci
5161847f8eSopenharmony_ci    /**
5261847f8eSopenharmony_ci     * Indicates business ability info with type of unspecified
5361847f8eSopenharmony_ci     *
5461847f8eSopenharmony_ci     * @syscap SystemCapability.Ability.AbilityRuntime.Core
5561847f8eSopenharmony_ci     * @systemapi
5661847f8eSopenharmony_ci     * @since 10
5761847f8eSopenharmony_ci     */
5861847f8eSopenharmony_ci    UNSPECIFIED = 255
5961847f8eSopenharmony_ci  }
6061847f8eSopenharmony_ci
6161847f8eSopenharmony_ci  /**
6261847f8eSopenharmony_ci   * This filter value is used to filter business ability info
6361847f8eSopenharmony_ci   *
6461847f8eSopenharmony_ci   * @typedef BusinessAbilityFilter
6561847f8eSopenharmony_ci   * @syscap SystemCapability.Ability.AbilityRuntime.Core
6661847f8eSopenharmony_ci   * @systemapi
6761847f8eSopenharmony_ci   * @since 10
6861847f8eSopenharmony_ci   */
6961847f8eSopenharmony_ci  export interface BusinessAbilityFilter {
7061847f8eSopenharmony_ci    /**
7161847f8eSopenharmony_ci     * Indicates the type of business ability info
7261847f8eSopenharmony_ci     *
7361847f8eSopenharmony_ci     * @type { BusinessType }
7461847f8eSopenharmony_ci     * @syscap SystemCapability.Ability.AbilityRuntime.Core
7561847f8eSopenharmony_ci     * @systemapi
7661847f8eSopenharmony_ci     * @since 10
7761847f8eSopenharmony_ci     */
7861847f8eSopenharmony_ci    businessType: BusinessType;
7961847f8eSopenharmony_ci
8061847f8eSopenharmony_ci    /**
8161847f8eSopenharmony_ci     * Indicates the supported mime type of business ability info
8261847f8eSopenharmony_ci     *
8361847f8eSopenharmony_ci     * @type { ?string }
8461847f8eSopenharmony_ci     * @syscap SystemCapability.Ability.AbilityRuntime.Core
8561847f8eSopenharmony_ci     * @systemapi
8661847f8eSopenharmony_ci     * @since 10
8761847f8eSopenharmony_ci     */
8861847f8eSopenharmony_ci    mimeType?: string;
8961847f8eSopenharmony_ci
9061847f8eSopenharmony_ci    /**
9161847f8eSopenharmony_ci     * Indicates the supported uri of business ability info
9261847f8eSopenharmony_ci     *
9361847f8eSopenharmony_ci     * @type { ?string }
9461847f8eSopenharmony_ci     * @syscap SystemCapability.Ability.AbilityRuntime.Core
9561847f8eSopenharmony_ci     * @systemapi
9661847f8eSopenharmony_ci     * @since 10
9761847f8eSopenharmony_ci     */
9861847f8eSopenharmony_ci    uri?: string;
9961847f8eSopenharmony_ci  }
10061847f8eSopenharmony_ci
10161847f8eSopenharmony_ci  /**
10261847f8eSopenharmony_ci   * Query the business ability info of by the given filter. ohos.permission.GET_BUNDLE_INFO_PRIVILEGED is required
10361847f8eSopenharmony_ci   * for cross user access.
10461847f8eSopenharmony_ci   *
10561847f8eSopenharmony_ci   * @permission ohos.permission.GET_BUNDLE_INFO_PRIVILEGED
10661847f8eSopenharmony_ci   * @param { BusinessAbilityFilter } filter - Indicates the filter containing the business ability info to be queried.
10761847f8eSopenharmony_ci   * @param { AsyncCallback<Array<BusinessAbilityInfo>> } callback - The callback of querying business ability info
10861847f8eSopenharmony_ci   *                                                                 result.
10961847f8eSopenharmony_ci   * @throws { BusinessError } 201 - Permission denied.
11061847f8eSopenharmony_ci   * @throws { BusinessError } 202 - non-system app called system api.
11161847f8eSopenharmony_ci   * @throws { BusinessError } 401 - Parameter error. Possible causes: 1. Mandatory parameters are left unspecified;
11261847f8eSopenharmony_ci   * 2. Incorrect parameter types; 3. Parameter verification failed.
11361847f8eSopenharmony_ci   * @syscap SystemCapability.Ability.AbilityRuntime.Core
11461847f8eSopenharmony_ci   * @systemapi
11561847f8eSopenharmony_ci   * @since 10
11661847f8eSopenharmony_ci   */
11761847f8eSopenharmony_ci  function queryBusinessAbilityInfo(
11861847f8eSopenharmony_ci    filter: BusinessAbilityFilter,
11961847f8eSopenharmony_ci    callback: AsyncCallback<Array<BusinessAbilityInfo>>
12061847f8eSopenharmony_ci  ): void;
12161847f8eSopenharmony_ci
12261847f8eSopenharmony_ci  /**
12361847f8eSopenharmony_ci   * Query the business ability info of by the given filter. ohos.permission.GET_BUNDLE_INFO_PRIVILEGED is required
12461847f8eSopenharmony_ci   * for cross user access.
12561847f8eSopenharmony_ci   *
12661847f8eSopenharmony_ci   * @permission ohos.permission.GET_BUNDLE_INFO_PRIVILEGED
12761847f8eSopenharmony_ci   * @param { BusinessAbilityFilter } filter - Indicates the filter containing the business ability info to be queried.
12861847f8eSopenharmony_ci   * @returns { Promise<Array<BusinessAbilityInfo>> } Returns a list of business ability info objects.
12961847f8eSopenharmony_ci   * @throws { BusinessError } 201 - Permission denied.
13061847f8eSopenharmony_ci   * @throws { BusinessError } 202 - non-system app called system api.
13161847f8eSopenharmony_ci   * @throws { BusinessError } 401 - Parameter error. Possible causes: 1. Mandatory parameters are left unspecified;
13261847f8eSopenharmony_ci   * 2. Incorrect parameter types; 3. Parameter verification failed.
13361847f8eSopenharmony_ci   * @syscap SystemCapability.Ability.AbilityRuntime.Core
13461847f8eSopenharmony_ci   * @systemapi
13561847f8eSopenharmony_ci   * @since 10
13661847f8eSopenharmony_ci   */
13761847f8eSopenharmony_ci  function queryBusinessAbilityInfo(filter: BusinessAbilityFilter): Promise<Array<BusinessAbilityInfo>>;
13861847f8eSopenharmony_ci
13961847f8eSopenharmony_ci  /**
14061847f8eSopenharmony_ci   * Obtains business ability info.
14161847f8eSopenharmony_ci   *
14261847f8eSopenharmony_ci   * @typedef { _BusinessAbilityInfo.BusinessAbilityInfo }
14361847f8eSopenharmony_ci   * @syscap SystemCapability.Ability.AbilityRuntime.Core
14461847f8eSopenharmony_ci   * @systemapi
14561847f8eSopenharmony_ci   * @since 10
14661847f8eSopenharmony_ci   */
14761847f8eSopenharmony_ci  export type BusinessAbilityInfo = _BusinessAbilityInfo.BusinessAbilityInfo;
14861847f8eSopenharmony_ci}
14961847f8eSopenharmony_ci
15061847f8eSopenharmony_ciexport default businessAbilityRouter;
151