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