1 /*
2 * Copyright (c) 2021-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 #include "dcamera_source_callback.h"
17
18 #include "anonymous_string.h"
19 #include "distributed_camera_errno.h"
20 #include "distributed_hardware_log.h"
21
22 namespace OHOS {
23 namespace DistributedHardware {
~DCameraSourceCallback()24 DCameraSourceCallback::~DCameraSourceCallback()
25 {
26 regCallbacks_.clear();
27 unregCallbacks_.clear();
28 }
29
OnNotifyRegResult(const std::string & devId,const std::string & dhId,const std::string & reqId,int32_t status,std::string & data)30 int32_t DCameraSourceCallback::OnNotifyRegResult(const std::string& devId, const std::string& dhId,
31 const std::string& reqId, int32_t status, std::string& data)
32 {
33 DHLOGI("DCameraSourceCallback OnNotifyRegResult devId: %{public}s dhId: %{public}s",
34 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str());
35 std::lock_guard<std::mutex> lock(mapMutex_);
36 auto iter = regCallbacks_.find(reqId);
37 if (iter == regCallbacks_.end()) {
38 DHLOGE("DCameraSourceCallback OnNotifyRegResult not found devId: %{public}s dhId: %{public}s",
39 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str());
40 return DCAMERA_NOT_FOUND;
41 }
42 int32_t ret = iter->second->OnRegisterResult(devId, dhId, status, data);
43 if (ret != DCAMERA_OK) {
44 DHLOGE("DCameraSourceCallback OnNotifyRegResult failed, devId: %{public}s dhId: %{public}s ret: %{public}d",
45 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str(), ret);
46 }
47 regCallbacks_.erase(iter);
48 return ret;
49 }
50
OnNotifyUnregResult(const std::string & devId,const std::string & dhId,const std::string & reqId,int32_t status,std::string & data)51 int32_t DCameraSourceCallback::OnNotifyUnregResult(const std::string& devId, const std::string& dhId,
52 const std::string& reqId, int32_t status, std::string& data)
53 {
54 DHLOGI("DCameraSourceCallback OnNotifyUnregResult devId: %{public}s dhId: %{public}s",
55 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str());
56 std::lock_guard<std::mutex> lock(mapMutex_);
57 auto iter = unregCallbacks_.find(reqId);
58 if (iter == unregCallbacks_.end()) {
59 DHLOGE("DCameraSourceCallback OnNotifyUnregResult not found devId: %{public}s dhId: %{public}s",
60 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str());
61 return DCAMERA_NOT_FOUND;
62 }
63 int32_t ret = iter->second->OnUnregisterResult(devId, dhId, status, data);
64 if (ret != DCAMERA_OK) {
65 DHLOGE("DCameraSourceCallback OnNotifyUnregResult failed, devId: %{public}s dhId: %{public}s ret: %{public}d",
66 GetAnonyString(devId).c_str(), GetAnonyString(dhId).c_str(), ret);
67 }
68 unregCallbacks_.erase(iter);
69 return ret;
70 }
71
OnHardwareStateChanged(const std::string & devId,const std::string & dhId,int32_t status)72 int32_t DCameraSourceCallback::OnHardwareStateChanged(const std::string &devId, const std::string &dhId,
73 int32_t status)
74 {
75 DHLOGI("On hardware state changed, devId: %{public}s, dhId: %{public}s, status: %{public}d",
76 GetAnonyString(devId).c_str(), dhId.c_str(), status);
77 std::lock_guard<std::mutex> stateLck(stateListenerMtx_);
78 if (stateListener_ == nullptr) {
79 DHLOGE("State listener is null.");
80 return DCAMERA_BAD_VALUE;
81 }
82 if (devId.empty() || devId.size() > DID_MAX_SIZE || dhId.empty() || dhId.size() > DID_MAX_SIZE) {
83 DHLOGE("devId or dhId is invalid");
84 return DCAMERA_BAD_VALUE;
85 }
86 if (status < 0) {
87 DHLOGE("status in invalid.");
88 return DCAMERA_BAD_VALUE;
89 }
90 BusinessState currentState = static_cast<BusinessState>(status);
91 stateListener_->OnStateChanged(devId, dhId, currentState);
92 return DCAMERA_OK;
93 }
94
OnDataSyncTrigger(const std::string & devId)95 int32_t DCameraSourceCallback::OnDataSyncTrigger(const std::string &devId)
96 {
97 DHLOGI("On data sync trigger, devId: %{public}s", GetAnonyString(devId).c_str());
98 std::lock_guard<std::mutex> triggerLck(triggerListenerMtx_);
99 if (devId.empty() || devId.size() > DID_MAX_SIZE) {
100 DHLOGE("devId is invalid");
101 return DCAMERA_BAD_VALUE;
102 }
103 if (triggerListener_ == nullptr) {
104 DHLOGE("Trigger listener is null.");
105 return DCAMERA_BAD_VALUE;
106 }
107 triggerListener_->OnDataSyncTrigger(devId);
108 return DCAMERA_OK;
109 }
110
PushRegCallback(std::string & reqId,std::shared_ptr<RegisterCallback> & callback)111 void DCameraSourceCallback::PushRegCallback(std::string& reqId, std::shared_ptr<RegisterCallback>& callback)
112 {
113 std::lock_guard<std::mutex> lock(mapMutex_);
114 regCallbacks_.emplace(reqId, callback);
115 }
116
PopRegCallback(std::string & reqId)117 void DCameraSourceCallback::PopRegCallback(std::string& reqId)
118 {
119 std::lock_guard<std::mutex> lock(mapMutex_);
120 regCallbacks_.erase(reqId);
121 }
122
PushUnregCallback(std::string & reqId,std::shared_ptr<UnregisterCallback> & callback)123 void DCameraSourceCallback::PushUnregCallback(std::string& reqId, std::shared_ptr<UnregisterCallback>& callback)
124 {
125 std::lock_guard<std::mutex> lock(mapMutex_);
126 unregCallbacks_.emplace(reqId, callback);
127 }
128
PopUnregCallback(std::string & reqId)129 void DCameraSourceCallback::PopUnregCallback(std::string& reqId)
130 {
131 std::lock_guard<std::mutex> lock(mapMutex_);
132 unregCallbacks_.erase(reqId);
133 }
134
RegisterStateListener(const std::shared_ptr<DistributedHardwareStateListener> listener)135 void DCameraSourceCallback::RegisterStateListener(const std::shared_ptr<DistributedHardwareStateListener> listener)
136 {
137 DHLOGD("Register state listener.");
138 std::lock_guard<std::mutex> stateLck(stateListenerMtx_);
139 stateListener_ = listener;
140 }
141
UnRegisterStateListener()142 void DCameraSourceCallback::UnRegisterStateListener()
143 {
144 DHLOGD("UnRegister state listener.");
145 std::lock_guard<std::mutex> stateLck(stateListenerMtx_);
146 stateListener_ = nullptr;
147 }
148
RegisterTriggerListener(const std::shared_ptr<DataSyncTriggerListener> listener)149 void DCameraSourceCallback::RegisterTriggerListener(const std::shared_ptr<DataSyncTriggerListener> listener)
150 {
151 DHLOGD("Register trigger listener.");
152 std::lock_guard<std::mutex> triggerLck(triggerListenerMtx_);
153 triggerListener_ = listener;
154 }
155
UnRegisterTriggerListener()156 void DCameraSourceCallback::UnRegisterTriggerListener()
157 {
158 DHLOGD("UnRegister trigger listener.");
159 std::lock_guard<std::mutex> triggerLck(triggerListenerMtx_);
160 triggerListener_ = nullptr;
161 }
162 } // namespace DistributedHardware
163 } // namespace OHOS
164