1 /*
2 * Copyright (c) 2021-2022 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_sink_service_ipc.h"
17
18 #include "if_system_ability_manager.h"
19 #include "iservice_registry.h"
20
21 #include "anonymous_string.h"
22 #include "distributed_camera_constants.h"
23 #include "distributed_camera_errno.h"
24 #include "distributed_hardware_log.h"
25
26 namespace OHOS {
27 namespace DistributedHardware {
DCameraSinkServiceIpc()28 DCameraSinkServiceIpc::DCameraSinkServiceIpc() : isInit_(false)
29 {
30 DHLOGI("DCameraSinkServiceIpc Create");
31 }
32
~DCameraSinkServiceIpc()33 DCameraSinkServiceIpc::~DCameraSinkServiceIpc()
34 {
35 DHLOGI("DCameraSinkServiceIpc Delete");
36 UnInit();
37 }
38
39 IMPLEMENT_SINGLE_INSTANCE(DCameraSinkServiceIpc);
40
Init()41 void DCameraSinkServiceIpc::Init()
42 {
43 std::lock_guard<std::mutex> autoLock(initCamSrvLock_);
44 DHLOGI("DCameraSinkServiceIpc Init Start");
45 if (isInit_) {
46 DHLOGI("DCameraSinkServiceIpc has already init");
47 return;
48 }
49 sourceRemoteRecipient_ = sptr<SourceRemoteRecipient>(new SourceRemoteRecipient());
50 isInit_ = true;
51 DHLOGI("DCameraSinkServiceIpc Init End");
52 }
53
UnInit()54 void DCameraSinkServiceIpc::UnInit()
55 {
56 std::lock_guard<std::mutex> autoLock(initCamSrvLock_);
57 DHLOGI("DCameraSinkServiceIpc UnInit Start");
58 if (!isInit_) {
59 DHLOGI("DCameraSinkServiceIpc has already UnInit");
60 return;
61 }
62 ClearSourceRemoteCamSrv();
63 DHLOGI("DCameraSinkServiceIpc Start free recipient");
64 sourceRemoteRecipient_ = nullptr;
65 isInit_ = false;
66 DHLOGI("DCameraSinkServiceIpc UnInit End");
67 }
68
GetSourceRemoteCamSrv(const std::string & deviceId)69 sptr<IDistributedCameraSource> DCameraSinkServiceIpc::GetSourceRemoteCamSrv(const std::string& deviceId)
70 {
71 if (deviceId.empty()) {
72 DHLOGE("GetSourceRemoteCamSrv deviceId is empty");
73 return nullptr;
74 }
75 {
76 std::lock_guard<std::mutex> autoLock(sourceRemoteCamSrvLock_);
77 auto iter = remoteSources_.find(deviceId);
78 if (iter != remoteSources_.end()) {
79 auto object = iter->second;
80 if (object != nullptr) {
81 DHLOGI("DCameraSinkServiceIpc GetSourceRemoteCamSrv from cache devId: %{public}s",
82 GetAnonyString(deviceId).c_str());
83 return object;
84 }
85 }
86 }
87 DHLOGI("GetSourceRemoteCamSrv remote deviceid is %{public}s", GetAnonyString(deviceId).c_str());
88 auto samgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
89 if (samgr == nullptr) {
90 DHLOGE("GetSourceRemoteCamSrv failed to connect to systemAbilityMgr!");
91 return nullptr;
92 }
93
94 auto object = samgr->CheckSystemAbility(DISTRIBUTED_HARDWARE_CAMERA_SOURCE_SA_ID, deviceId);
95 if (object == nullptr) {
96 DHLOGE("GetSourceRemoteCamSrv failed get remote CamSrv %{public}s", GetAnonyString(deviceId).c_str());
97 return nullptr;
98 }
99 int32_t ret = object->AddDeathRecipient(sourceRemoteRecipient_);
100 sptr<IDistributedCameraSource> remoteCamSrvObj = iface_cast<IDistributedCameraSource>(object);
101 if (remoteCamSrvObj == nullptr) {
102 DHLOGI("GetSourceRemoteCamSrv failed, remoteCamSrvObj is null ret: %{public}d", ret);
103 return nullptr;
104 }
105 {
106 std::lock_guard<std::mutex> autoLock(sourceRemoteCamSrvLock_);
107 auto iter = remoteSources_.find(deviceId);
108 if (iter != remoteSources_.end()) {
109 iter->second->AsObject()->RemoveDeathRecipient(sourceRemoteRecipient_);
110 }
111 remoteSources_[deviceId] = remoteCamSrvObj;
112 }
113 DHLOGI("GetSourceRemoteCamSrv success, AddDeathRecipient ret: %{public}d", ret);
114 return remoteCamSrvObj;
115 }
116
DeleteSourceRemoteCamSrv(const std::string & deviceId)117 void DCameraSinkServiceIpc::DeleteSourceRemoteCamSrv(const std::string& deviceId)
118 {
119 DHLOGI("DeleteSourceRemoteCamSrv devId: %{public}s", GetAnonyString(deviceId).c_str());
120 std::lock_guard<std::mutex> autoLock(sourceRemoteCamSrvLock_);
121 auto item = remoteSources_.find(deviceId);
122 if (item == remoteSources_.end()) {
123 DHLOGI("DeleteSourceRemoteCamSrv not found device: %{public}s", GetAnonyString(deviceId).c_str());
124 return;
125 }
126
127 if (item->second != nullptr) {
128 item->second->AsObject()->RemoveDeathRecipient(sourceRemoteRecipient_);
129 }
130 remoteSources_.erase(item);
131 }
132
ClearSourceRemoteCamSrv()133 void DCameraSinkServiceIpc::ClearSourceRemoteCamSrv()
134 {
135 DHLOGI("ClearSourceRemoteCamSrv Start");
136 std::lock_guard<std::mutex> autoLock(sourceRemoteCamSrvLock_);
137 for (auto iter = remoteSources_.begin(); iter != remoteSources_.end(); iter++) {
138 if (iter->second != nullptr) {
139 iter->second->AsObject()->RemoveDeathRecipient(sourceRemoteRecipient_);
140 }
141 }
142 remoteSources_.clear();
143 DHLOGI("ClearSourceRemoteCamSrv end");
144 }
145
OnRemoteDied(const wptr<IRemoteObject> & remote)146 void DCameraSinkServiceIpc::SourceRemoteRecipient::OnRemoteDied(const wptr<IRemoteObject>& remote)
147 {
148 DHLOGI("SourceRemoteRecipient OnRemoteDied received died notify!");
149 DCameraSinkServiceIpc::GetInstance().OnSourceRemoteCamSrvDied(remote);
150 }
151
OnSourceRemoteCamSrvDied(const wptr<IRemoteObject> & remote)152 void DCameraSinkServiceIpc::OnSourceRemoteCamSrvDied(const wptr<IRemoteObject>& remote)
153 {
154 DHLOGI("OnSourceRemoteCamSrvDied delete diedRemoted");
155 std::lock_guard<std::mutex> autoLock(sourceRemoteCamSrvLock_);
156 sptr<IRemoteObject> diedRemoted = remote.promote();
157 if (diedRemoted == nullptr) {
158 DHLOGE("OnSourceRemoteCamSrvDied promote failed!");
159 return;
160 }
161 auto iter = std::find_if(remoteSources_.begin(), remoteSources_.end(), [&](
162 const std::pair<std::string, sptr<IDistributedCameraSource>> &item)->bool {
163 return item.second->AsObject() == diedRemoted;
164 });
165 if (iter == remoteSources_.end()) {
166 DHLOGI("OnSourceRemoteCamSrvDied not found remote object");
167 return;
168 }
169 DHLOGI("OnSourceRemoteCamSrvDied remote.devId: %{public}s", GetAnonyString(iter->first).c_str());
170 if (iter->second != nullptr) {
171 iter->second->AsObject()->RemoveDeathRecipient(sourceRemoteRecipient_);
172 }
173 remoteSources_.erase(iter);
174 }
175 } // namespace DistributedHardware
176 } // namespace OHOS
177