• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 &params)
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