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 
26 namespace OHOS {
27 namespace HDI {
28 namespace Sensor {
29 namespace V2_0 {
30 
31 using GroupIdCallBackMap = std::unordered_map<int32_t, std::vector<sptr<ISensorCallback>>>;
32 
33 class SensorIfService : public ISensorInterface {
34 public:
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 DisableSensor(int32_t sensorId, uint32_t serviceId);
42     int32_t SetBatch(int32_t sensorId, int64_t samplingInterval, int64_t reportInterval) override;
43     int32_t SetBatchSenior(int32_t serviceId, int32_t sensorId, int32_t mode, int64_t samplingInterval,
44                            int64_t reportInterval);
45     int32_t SetMode(int32_t sensorId, int32_t mode) override;
46     int32_t SetOption(int32_t sensorId, uint32_t option) override;
47     int32_t Register(int32_t groupId, const sptr<ISensorCallback> &callbackObj) override;
48     int32_t Unregister(int32_t groupId, const sptr<ISensorCallback> &callbackObj) override;
49     int32_t ReadData(int32_t sensorId, std::vector<HdfSensorEvents> &event) override;
50     int32_t SetSdcSensor(int32_t sensorId, bool enabled, int32_t rateLevel) override;
51     int32_t GetSdcSensorInfo(std::vector<SdcSensorInfo>& sdcSensorInfo) override;
52     int32_t GetSensorVdiImpl();
53     void OnRemoteDied(const wptr<IRemoteObject> &object);
54     std::mutex sensorServiceMutex_;
55 private:
56     int32_t AddSensorDeathRecipient(const sptr<ISensorCallback> &callbackObj);
57     int32_t RemoveSensorDeathRecipient(const sptr<ISensorCallback> &callbackObj);
58     void  RemoveDeathNotice(int32_t sensorType);
59     int32_t AddCallbackMap(int32_t groupId, const sptr<ISensorCallback> &callbackObj);
60     int32_t RemoveCallbackMap(int32_t groupId, int serviceId, const sptr<ISensorCallback> &callbackObj);
61     sptr<SensorCallbackVdi> GetSensorCb(int32_t groupId, const sptr<ISensorCallback> &callbackObj, bool cbFlag);
62     void RegisteDumpHost();
63     OHOS::HDI::Sensor::V1_1::ISensorInterfaceVdi *sensorVdiImpl_ = nullptr;
64     struct HdfVdiObject *vdi_ = nullptr;
65     GroupIdCallBackMap callbackMap = {};
66     sptr<SensorCallbackVdi> traditionalCb = nullptr;
67     sptr<SensorCallbackVdi> medicalCb = nullptr;
68     std::vector<HdfSensorInformation> hdfSensorInformations;
69     int32_t SetDelay(int32_t sensorId, int64_t &samplingInterval, int64_t &reportInterval);
70 };
71 } // V2_0
72 } // Sensor
73 } // HDI
74 } // OHOS
75 
76 #endif // HDI_SENSOR_IF_SERVICE_H
77