1 /*
2 * Copyright (c) 2021-2025 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 #include "dcamera_source_handler.h"
17
18 #include "anonymous_string.h"
19 #include "dcamera_hdf_operate.h"
20 #include "dcamera_hisysevent_adapter.h"
21 #include "dcamera_radar.h"
22 #include "dcamera_source_callback.h"
23 #include "dcamera_source_handler_ipc.h"
24 #include "dcamera_source_load_callback.h"
25 #include "distributed_camera_constants.h"
26 #include "distributed_camera_errno.h"
27 #include "distributed_hardware_log.h"
28 #include "if_system_ability_manager.h"
29 #include "iservice_registry.h"
30
31 namespace OHOS {
32 namespace DistributedHardware {
33 IMPLEMENT_SINGLE_INSTANCE(DCameraSourceHandler);
34
DCameraSourceHandler()35 DCameraSourceHandler::DCameraSourceHandler()
36 {
37 DHLOGI("DCameraSourceHandler construct.");
38 callback_ = sptr<DCameraSourceCallback>(new DCameraSourceCallback());
39 }
40
~DCameraSourceHandler()41 DCameraSourceHandler::~DCameraSourceHandler()
42 {
43 DHLOGI("~DCameraSourceHandler");
44 }
45
InitSource(const std::string & params)46 int32_t DCameraSourceHandler::InitSource(const std::string& params)
47 {
48 DHLOGI("Start");
49 {
50 std::lock_guard<std::mutex> autoLock(producerMutex_);
51 if (state_ == DCAMERA_SA_STATE_START) {
52 return DCAMERA_OK;
53 }
54 }
55 sptr<ISystemAbilityManager> sm = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
56 if (sm == nullptr) {
57 DHLOGE("GetSourceLocalCamSrv GetSystemAbilityManager failed");
58 return DCAMERA_INIT_ERR;
59 }
60 ReportSaEvent(INIT_SA_EVENT, DISTRIBUTED_HARDWARE_CAMERA_SOURCE_SA_ID, "init source sa event.");
61 sptr<DCameraSourceLoadCallback> loadCallback(new DCameraSourceLoadCallback(params));
62 int32_t ret = sm->LoadSystemAbility(DISTRIBUTED_HARDWARE_CAMERA_SOURCE_SA_ID, loadCallback);
63 DcameraRadar::GetInstance().ReportDcameraInit("LoadSystemAbility", CameraInit::SERVICE_INIT,
64 BizState::BIZ_STATE_START, ret);
65 if (ret != ERR_OK) {
66 DHLOGE("systemAbilityId: %{public}d load failed, result code: %{public}d.",
67 DISTRIBUTED_HARDWARE_CAMERA_SOURCE_SA_ID, ret);
68 return DCAMERA_INIT_ERR;
69 }
70 {
71 uint32_t interval = 1;
72 std::unique_lock<std::mutex> lock(producerMutex_);
73 producerCon_.wait_for(lock, std::chrono::minutes(interval), [this] {
74 return (this->state_ == DCAMERA_SA_STATE_START);
75 });
76 if (state_ == DCAMERA_SA_STATE_STOP) {
77 DHLOGE("SourceSA Start failed!");
78 return DCAMERA_INIT_ERR;
79 }
80 }
81 DHLOGI("end, result: %{public}d", ret);
82 return DCAMERA_OK;
83 }
84
FinishStartSA(const std::string & params)85 void DCameraSourceHandler::FinishStartSA(const std::string ¶ms)
86 {
87 DCameraSourceHandlerIpc::GetInstance().Init();
88 sptr<IDistributedCameraSource> dCameraSourceSrv = DCameraSourceHandlerIpc::GetInstance().GetSourceLocalCamSrv();
89 if (dCameraSourceSrv == nullptr) {
90 DHLOGE("get Service failed");
91 return;
92 }
93
94 DcameraRadar::GetInstance().ReportDcameraInitProgress("InitSource", CameraInit::SOURCE_CAMERA_INIT, DCAMERA_OK);
95 dCameraSourceSrv->InitSource(params, callback_);
96 std::lock_guard<std::mutex> lock(producerMutex_);
97 state_ = DCAMERA_SA_STATE_START;
98 producerCon_.notify_one();
99 }
100
FinishStartSAFailed(const int32_t systemAbilityId)101 void DCameraSourceHandler::FinishStartSAFailed(const int32_t systemAbilityId)
102 {
103 DHLOGE("SourceSA Start failed, systemAbilityId: %{public}d.", systemAbilityId);
104 std::unique_lock<std::mutex> lock(producerMutex_);
105 state_ = DCAMERA_SA_STATE_STOP;
106 producerCon_.notify_one();
107 }
108
ReleaseSource()109 int32_t DCameraSourceHandler::ReleaseSource()
110 {
111 DHLOGI("Start");
112 sptr<IDistributedCameraSource> dCameraSourceSrv = DCameraSourceHandlerIpc::GetInstance().GetSourceLocalCamSrv();
113 if (dCameraSourceSrv == nullptr) {
114 DHLOGE("get Service failed");
115 return DCAMERA_INIT_ERR;
116 }
117 ReportSaEvent(RELEASE_SA_EVENT, DISTRIBUTED_HARDWARE_CAMERA_SOURCE_SA_ID, "release source sa event.");
118 dCameraSourceSrv->ReleaseSource();
119 DCameraSourceHandlerIpc::GetInstance().UnInit();
120 std::unique_lock<std::mutex> lock(producerMutex_);
121 state_ = DCAMERA_SA_STATE_STOP;
122 DHLOGI("end");
123 return DCAMERA_OK;
124 }
125
RegisterDistributedHardware(const std::string & devId,const std::string & dhId,const EnableParam & param,std::shared_ptr<RegisterCallback> callback)126 int32_t DCameraSourceHandler::RegisterDistributedHardware(const std::string& devId, const std::string& dhId,
127 const EnableParam& param, std::shared_ptr<RegisterCallback> callback)
128 {
129 DHLOGI("devId: %{public}s dhId: %{public}s", GetAnonyString(devId).c_str(),
130 GetAnonyString(dhId).c_str());
131 if (callback == nullptr) {
132 DHLOGI("RegisterCallback is null.");
133 return DCAMERA_BAD_VALUE;
134 }
135 sptr<IDistributedCameraSource> dCameraSourceSrv = DCameraSourceHandlerIpc::GetInstance().GetSourceLocalCamSrv();
136 if (dCameraSourceSrv == nullptr) {
137 DHLOGE("get Service failed");
138 return DCAMERA_BAD_VALUE;
139 }
140
141 std::string reqId = GetRandomID();
142 std::lock_guard<std::mutex> autoLock(optLock_);
143
144 CHECK_AND_RETURN_RET_LOG(callback_ == nullptr, DCAMERA_BAD_VALUE, "ipc callback is null.");
145 callback_->PushRegCallback(reqId, callback);
146 int32_t ret = dCameraSourceSrv->RegisterDistributedHardware(devId, dhId, reqId, param);
147 if (ret != DCAMERA_OK) {
148 callback_->PopRegCallback(reqId);
149 }
150 DHLOGI("end, ret: %{public}d devId: %{public}s dhId: %{public}s version: %{public}s",
151 ret, GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str(), param.sinkVersion.c_str());
152 return ret;
153 }
154
UnregisterDistributedHardware(const std::string & devId,const std::string & dhId,std::shared_ptr<UnregisterCallback> callback)155 int32_t DCameraSourceHandler::UnregisterDistributedHardware(const std::string& devId, const std::string& dhId,
156 std::shared_ptr<UnregisterCallback> callback)
157 {
158 DHLOGI("devId: %{public}s dhId: %{public}s", GetAnonyString(devId).c_str(),
159 GetAnonyString(dhId).c_str());
160 if (callback == nullptr) {
161 DHLOGI("UnregisterCallback is null.");
162 return DCAMERA_BAD_VALUE;
163 }
164 sptr<IDistributedCameraSource> dCameraSourceSrv = DCameraSourceHandlerIpc::GetInstance().GetSourceLocalCamSrv();
165 if (dCameraSourceSrv == nullptr) {
166 DHLOGE("get Service failed");
167 return DCAMERA_BAD_VALUE;
168 }
169
170 std::string reqId = GetRandomID();
171 std::lock_guard<std::mutex> autoLock(optLock_);
172
173 CHECK_AND_RETURN_RET_LOG(callback_ == nullptr, DCAMERA_BAD_VALUE, "ipc callback is null.");
174 callback_->PushUnregCallback(reqId, callback);
175 int32_t ret = dCameraSourceSrv->UnregisterDistributedHardware(devId, dhId, reqId);
176 if (ret != DCAMERA_OK) {
177 callback_->PopUnregCallback(reqId);
178 }
179 DHLOGI("end, ret: %{public}d devId: %{public}s dhId: %{public}s", ret,
180 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str());
181 return ret;
182 }
183
ConfigDistributedHardware(const std::string & devId,const std::string & dhId,const std::string & key,const std::string & value)184 int32_t DCameraSourceHandler::ConfigDistributedHardware(const std::string& devId, const std::string& dhId,
185 const std::string& key, const std::string& value)
186 {
187 return DCAMERA_OK;
188 }
189
RegisterDistributedHardwareStateListener(std::shared_ptr<DistributedHardwareStateListener> listener)190 void DCameraSourceHandler::RegisterDistributedHardwareStateListener(
191 std::shared_ptr<DistributedHardwareStateListener> listener)
192 {
193 CHECK_AND_RETURN_LOG(callback_ == nullptr, "%{public}s", "ipc callback is null.");
194 callback_->RegisterStateListener(listener);
195 }
196
UnregisterDistributedHardwareStateListener()197 void DCameraSourceHandler::UnregisterDistributedHardwareStateListener()
198 {
199 CHECK_AND_RETURN_LOG(callback_ == nullptr, "%{public}s", "ipc callback is null.");
200 callback_->UnRegisterStateListener();
201 }
202
RegisterDataSyncTriggerListener(std::shared_ptr<DataSyncTriggerListener> listener)203 void DCameraSourceHandler::RegisterDataSyncTriggerListener(std::shared_ptr<DataSyncTriggerListener> listener)
204 {
205 CHECK_AND_RETURN_LOG(callback_ == nullptr, "%{public}s", "ipc callback is null.");
206 callback_->RegisterTriggerListener(listener);
207 }
208
UnregisterDataSyncTriggerListener()209 void DCameraSourceHandler::UnregisterDataSyncTriggerListener()
210 {
211 CHECK_AND_RETURN_LOG(callback_ == nullptr, "%{public}s", "ipc callback is null.");
212 callback_->UnRegisterTriggerListener();
213 }
214
LoadDistributedHDF(std::shared_ptr<HdfDeathCallback> callback)215 int32_t DCameraSourceHandler::LoadDistributedHDF(std::shared_ptr<HdfDeathCallback> callback)
216 {
217 return DCameraHdfOperate::GetInstance().LoadDcameraHDFImpl(callback);
218 }
219
UnLoadDistributedHDF()220 int32_t DCameraSourceHandler::UnLoadDistributedHDF()
221 {
222 return DCameraHdfOperate::GetInstance().UnLoadDcameraHDFImpl();
223 }
224
SetSAState()225 void DCameraSourceHandler::SetSAState()
226 {
227 std::unique_lock<std::mutex> lock(producerMutex_);
228 state_ = DCAMERA_SA_STATE_STOP;
229 }
230
GetSourceHardwareHandler()231 IDistributedHardwareSource *GetSourceHardwareHandler()
232 {
233 DHLOGI("DCameraSourceHandler GetSourceHardwareHandler Start");
234 return &DCameraSourceHandler::GetInstance();
235 }
236 } // namespace DistributedHardware
237 } // namespace OHOS
238