1/*
2 * Copyright (c) 2023 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 *     http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16#ifndef HDI_SENSOR_IF_SERVICE_H
17#define HDI_SENSOR_IF_SERVICE_H
18
19#include <map>
20#include "v2_0/isensor_interface.h"
21#include "isensor_interface_vdi.h"
22#include "sensor_callback_vdi.h"
23#include "sensor_client_info.h"
24#include "sensor_clients_manager.h"
25
26namespace OHOS {
27namespace HDI {
28namespace Sensor {
29namespace V2_0 {
30
31using GroupIdCallBackMap = std::unordered_map<int32_t, std::vector<sptr<ISensorCallback>>>;
32
33class SensorIfService : public ISensorInterface {
34public:
35    SensorIfService();
36    ~SensorIfService();
37    int32_t Init(void);
38    int32_t GetAllSensorInfo(std::vector<HdfSensorInformation> &info) override;
39    int32_t Enable(int32_t sensorId) override;
40    int32_t Disable(int32_t sensorId) override;
41    int32_t SetBatch(int32_t sensorId, int64_t samplingInterval, int64_t reportInterval) override;
42    int32_t SetBatchSenior(int32_t serviceId, int32_t sensorId, int32_t mode, int64_t samplingInterval,
43                           int64_t reportInterval);
44    int32_t SetMode(int32_t sensorId, int32_t mode) override;
45    int32_t SetOption(int32_t sensorId, uint32_t option) override;
46    int32_t Register(int32_t groupId, const sptr<ISensorCallback> &callbackObj) override;
47    int32_t Unregister(int32_t groupId, const sptr<ISensorCallback> &callbackObj) override;
48    int32_t ReadData(int32_t sensorId, std::vector<HdfSensorEvents> &event) override;
49    int32_t SetSdcSensor(int32_t sensorId, bool enabled, int32_t rateLevel) override;
50    int32_t GetSdcSensorInfo(std::vector<SdcSensorInfo>& sdcSensorInfo) override;
51    int32_t GetSensorVdiImpl();
52    void OnRemoteDied(const wptr<IRemoteObject> &object);
53    std::mutex sensorServiceMutex_;
54private:
55    int32_t AddSensorDeathRecipient(const sptr<ISensorCallback> &callbackObj);
56    int32_t RemoveSensorDeathRecipient(const sptr<ISensorCallback> &callbackObj);
57    void  RemoveDeathNotice(int32_t sensorType);
58    int32_t AddCallbackMap(int32_t groupId, const sptr<ISensorCallback> &callbackObj);
59    int32_t RemoveCallbackMap(int32_t groupId, int serviceId, const sptr<ISensorCallback> &callbackObj);
60    sptr<SensorCallbackVdi> GetSensorCb(int32_t groupId, const sptr<ISensorCallback> &callbackObj, bool cbFlag);
61    void RegisteDumpHost();
62    OHOS::HDI::Sensor::V1_1::ISensorInterfaceVdi *sensorVdiImpl_ = nullptr;
63    struct HdfVdiObject *vdi_ = nullptr;
64    GroupIdCallBackMap callbackMap = {};
65    sptr<SensorCallbackVdi> traditionalCb = nullptr;
66    sptr<SensorCallbackVdi> medicalCb = nullptr;
67    std::vector<HdfSensorInformation> hdfSensorInformations;
68    int32_t SetDelay(int32_t sensorId, int64_t &samplingInterval, int64_t &reportInterval);
69};
70} // V2_0
71} // Sensor
72} // HDI
73} // OHOS
74
75#endif // HDI_SENSOR_IF_SERVICE_H
76