1bc2ed2b3Sopenharmony_ci/*
2bc2ed2b3Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3bc2ed2b3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4bc2ed2b3Sopenharmony_ci * you may not use this file except in compliance with the License.
5bc2ed2b3Sopenharmony_ci * You may obtain a copy of the License at
6bc2ed2b3Sopenharmony_ci *
7bc2ed2b3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8bc2ed2b3Sopenharmony_ci *
9bc2ed2b3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10bc2ed2b3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11bc2ed2b3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12bc2ed2b3Sopenharmony_ci * See the License for the specific language governing permissions and
13bc2ed2b3Sopenharmony_ci * limitations under the License.
14bc2ed2b3Sopenharmony_ci */
15bc2ed2b3Sopenharmony_ci
16bc2ed2b3Sopenharmony_ci#ifndef CARDEMULATION_H
17bc2ed2b3Sopenharmony_ci#define CARDEMULATION_H
18bc2ed2b3Sopenharmony_ci
19bc2ed2b3Sopenharmony_ci#include "nfc_sdk_common.h"
20bc2ed2b3Sopenharmony_ci
21bc2ed2b3Sopenharmony_cinamespace OHOS {
22bc2ed2b3Sopenharmony_cinamespace NFC {
23bc2ed2b3Sopenharmony_cinamespace KITS {
24bc2ed2b3Sopenharmony_ci
25bc2ed2b3Sopenharmony_ciclass CardEmulation final {
26bc2ed2b3Sopenharmony_cipublic:
27bc2ed2b3Sopenharmony_ci    explicit CardEmulation();
28bc2ed2b3Sopenharmony_ci    ~CardEmulation();
29bc2ed2b3Sopenharmony_ci
30bc2ed2b3Sopenharmony_ci    /**
31bc2ed2b3Sopenharmony_ci     * @Description Get an object of nfc cardEmulation.
32bc2ed2b3Sopenharmony_ci     * @param void
33bc2ed2b3Sopenharmony_ci     * @return an object of nfc cardEmulation
34bc2ed2b3Sopenharmony_ci     */
35bc2ed2b3Sopenharmony_ci    static CardEmulation &GetInstance();
36bc2ed2b3Sopenharmony_ci
37bc2ed2b3Sopenharmony_ci    /**
38bc2ed2b3Sopenharmony_ci     * Checks whether a specified type of card emulation is supported.
39bc2ed2b3Sopenharmony_ci     * @param feature Indicates the card emulation type, {@code HCE}, {@code UICC}, or {@code ESE}.
40bc2ed2b3Sopenharmony_ci     * @return Returns {@code true} if the specified type of card emulation is supported; returns
41bc2ed2b3Sopenharmony_ci     * {@code false} otherwise.
42bc2ed2b3Sopenharmony_ci     */
43bc2ed2b3Sopenharmony_ci    bool IsSupported(FeatureType feature);
44bc2ed2b3Sopenharmony_ci};
45bc2ed2b3Sopenharmony_ci} // namespace KITS
46bc2ed2b3Sopenharmony_ci} // namespace NFC
47bc2ed2b3Sopenharmony_ci} // namespace OHOS
48bc2ed2b3Sopenharmony_ci#endif // NFC_CONTROLLER_H