• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2024 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 "switch_subscriber_handler.h"
17 
18 #include <parameters.h>
19 
20 #include "dfx_hisysevent.h"
21 #include "input_event_data_transformation.h"
22 #include "input_event_handler.h"
23 #include "util_ex.h"
24 #undef MMI_LOG_DOMAIN
25 #define MMI_LOG_DOMAIN MMI_LOG_HANDLER
26 #undef MMI_LOG_TAG
27 #define MMI_LOG_TAG "SwitchSubscriberHandler"
28 
29 namespace OHOS {
30 namespace MMI {
31 #ifdef OHOS_BUILD_ENABLE_KEYBOARD
HandleKeyEvent(const std::shared_ptr<KeyEvent> keyEvent)32 void SwitchSubscriberHandler::HandleKeyEvent(const std::shared_ptr<KeyEvent> keyEvent)
33 {
34     CHKPV(keyEvent);
35     CHKPV(nextHandler_);
36     nextHandler_->HandleKeyEvent(keyEvent);
37 }
38 #endif // OHOS_BUILD_ENABLE_KEYBOARD
39 
40 #ifdef OHOS_BUILD_ENABLE_POINTER
HandlePointerEvent(const std::shared_ptr<PointerEvent> pointerEvent)41 void SwitchSubscriberHandler::HandlePointerEvent(const std::shared_ptr<PointerEvent> pointerEvent)
42 {
43     CHKPV(pointerEvent);
44     CHKPV(nextHandler_);
45     nextHandler_->HandlePointerEvent(pointerEvent);
46 }
47 #endif // OHOS_BUILD_ENABLE_POINTER
48 
49 #ifdef OHOS_BUILD_ENABLE_TOUCH
HandleTouchEvent(const std::shared_ptr<PointerEvent> pointerEvent)50 void SwitchSubscriberHandler::HandleTouchEvent(const std::shared_ptr<PointerEvent> pointerEvent)
51 {
52     CHKPV(pointerEvent);
53     CHKPV(nextHandler_);
54     nextHandler_->HandleTouchEvent(pointerEvent);
55 }
56 #endif // OHOS_BUILD_ENABLE_TOUCH
57 
58 #ifdef OHOS_BUILD_ENABLE_SWITCH
HandleSwitchEvent(const std::shared_ptr<SwitchEvent> switchEvent)59 void SwitchSubscriberHandler::HandleSwitchEvent(const std::shared_ptr<SwitchEvent> switchEvent)
60 {
61     CHKPV(switchEvent);
62     UpdateSwitchState(switchEvent);
63     if (OnSubscribeSwitchEvent(switchEvent)) {
64         MMI_HILOGI("Subscribe switchEvent filter success. switchValue:%{public}d", switchEvent->GetSwitchValue());
65         return;
66     }
67     CHKPV(nextHandler_);
68     nextHandler_->HandleSwitchEvent(switchEvent);
69 }
70 #endif // OHOS_BUILD_ENABLE_SWITCH
71 
SubscribeSwitchEvent(SessionPtr sess,int32_t subscribeId,int32_t switchType)72 int32_t SwitchSubscriberHandler::SubscribeSwitchEvent(SessionPtr sess, int32_t subscribeId, int32_t switchType)
73 {
74     CALL_INFO_TRACE;
75     if (subscribeId < 0) {
76         MMI_HILOGE("Invalid subscribeId");
77         return RET_ERR;
78     }
79     if (switchType < SwitchEvent::SwitchType::SWITCH_DEFAULT) {
80         MMI_HILOGE("Invalid switchType");
81         return RET_ERR;
82     }
83     CHKPR(sess, ERROR_NULL_POINTER);
84 
85     MMI_HILOGD("subscribeId:%{public}d switchType:%{public}d", subscribeId, switchType);
86     auto subscriber = std::make_shared<Subscriber>(subscribeId, sess, switchType);
87     InsertSubScriber(std::move(subscriber));
88     InitSessionDeleteCallback();
89     return RET_OK;
90 }
91 
UnsubscribeSwitchEvent(SessionPtr sess,int32_t subscribeId)92 int32_t SwitchSubscriberHandler::UnsubscribeSwitchEvent(SessionPtr sess, int32_t subscribeId)
93 {
94     CALL_INFO_TRACE;
95     MMI_HILOGD("subscribeId:%{public}d", subscribeId);
96     for (auto it = subscribers_.begin(); it != subscribers_.end(); ++it) {
97         if ((*it)->id_ == subscribeId && (*it)->sess_ == sess) {
98             subscribers_.erase(it);
99             return RET_OK;
100         }
101     }
102     MMI_HILOGE("UnsubscribeSwitchEvent failed with %{public}d", subscribeId);
103     return RET_ERR;
104 }
105 
OnSubscribeSwitchEvent(std::shared_ptr<SwitchEvent> switchEvent)106 bool SwitchSubscriberHandler::OnSubscribeSwitchEvent(std::shared_ptr<SwitchEvent> switchEvent)
107 {
108     CHKPF(switchEvent);
109     MMI_HILOGI("The switchValue:%{public}d", switchEvent->GetSwitchValue());
110     if (switchEvent->GetSwitchType() == SwitchEvent::SwitchType::SWITCH_LID) {
111         DfxHisysevent::OnLidSwitchChanged(switchEvent->GetSwitchValue());
112     }
113 
114     bool handled = false;
115     for (const auto &subscriber : subscribers_) {
116         if (subscriber->switchType_ == switchEvent->GetSwitchType() ||
117             (subscriber->switchType_ == SwitchEvent::SwitchType::SWITCH_DEFAULT &&
118                 switchEvent->GetSwitchType() == SwitchEvent::SwitchType::SWITCH_LID)) {
119             CHKPC(subscriber->sess_);
120             MMI_HILOGI("The subscriber:%{public}d", subscriber->sess_->GetPid());
121             NotifySubscriber(switchEvent, subscriber);
122             handled = true;
123         }
124     }
125     if (switchEvent->GetSwitchType() == SwitchEvent::SwitchType::SWITCH_PRIVACY) {
126         std::string value = OHOS::system::GetParameter(SUPER_PRIVACY_SWITCH, "");
127         if (value.empty() || value == "false") {
128             OHOS::system::SetParameter(SUPER_PRIVACY_SWITCH, "true");
129         } else {
130             OHOS::system::SetParameter(SUPER_PRIVACY_SWITCH, "false");
131         }
132     }
133     MMI_HILOGD("%{public}s", handled ? "true" : "false");
134     MMI_HILOGD("SUPER_PRIVACY_SWITCH:%{public}s", OHOS::system::GetParameter(SUPER_PRIVACY_SWITCH, "").c_str());
135     return handled;
136 }
137 
InsertSubScriber(std::shared_ptr<Subscriber> subs)138 void SwitchSubscriberHandler::InsertSubScriber(std::shared_ptr<Subscriber> subs)
139 {
140     CALL_DEBUG_ENTER;
141     CHKPV(subs);
142     for (auto it = subscribers_.begin(); it != subscribers_.end(); ++it) {
143         if (subs->sess_ != nullptr && (*it)->id_ == subs->id_ && (*it)->sess_ == subs->sess_) {
144             MMI_HILOGW("Repeat registration id:%{public}d, desc:%{public}s",
145                 subs->id_, subs->sess_->GetDescript().c_str());
146             return;
147         }
148     }
149     subscribers_.push_back(subs);
150 }
151 
OnSessionDelete(SessionPtr sess)152 void SwitchSubscriberHandler::OnSessionDelete(SessionPtr sess)
153 {
154     CALL_DEBUG_ENTER;
155     CHKPV(sess);
156     for (auto it = subscribers_.begin(); it != subscribers_.end();) {
157         if ((*it)->sess_ == sess) {
158             subscribers_.erase(it++);
159             continue;
160         }
161         ++it;
162     }
163 }
164 
NotifySubscriber(std::shared_ptr<SwitchEvent> switchEvent,const std::shared_ptr<Subscriber> & subscriber)165 void SwitchSubscriberHandler::NotifySubscriber(std::shared_ptr<SwitchEvent> switchEvent,
166                                                const std::shared_ptr<Subscriber> &subscriber)
167 {
168     CALL_DEBUG_ENTER;
169     CHKPV(switchEvent);
170     CHKPV(subscriber);
171     auto udsServerPtr = InputHandler->GetUDSServer();
172     CHKPV(udsServerPtr);
173     NetPacket pkt(MmiMessageId::ON_SUBSCRIBE_SWITCH);
174     InputEventDataTransformation::SwitchEventToNetPacket(switchEvent, pkt);
175     if (subscriber->sess_ == nullptr) {
176         MMI_HILOGE("Subscriber's sess is null");
177         return;
178     }
179     int32_t fd = subscriber->sess_->GetFd();
180     pkt << fd << subscriber->id_;
181     MMI_HILOGI("Notify subscriber id:%{public}d, switchValue:%{public}d, pid:%{public}d",
182         subscriber->id_, switchEvent->GetSwitchValue(), subscriber->sess_->GetPid());
183     if (pkt.ChkRWError()) {
184         MMI_HILOGE("Packet write dispatch subscriber failed");
185         return;
186     }
187     if (!udsServerPtr->SendMsg(fd, pkt)) {
188         MMI_HILOGE("Leave, server dispatch subscriber failed");
189     }
190 }
191 
InitSessionDeleteCallback()192 bool SwitchSubscriberHandler::InitSessionDeleteCallback()
193 {
194     CALL_DEBUG_ENTER;
195     if (callbackInitialized_) {
196         MMI_HILOGD("Session delete callback has already been initialized");
197         return true;
198     }
199     auto udsServerPtr = InputHandler->GetUDSServer();
200     CHKPF(udsServerPtr);
201     std::function<void(SessionPtr)> callback =
202         [this] (SessionPtr sess) { return this->OnSessionDelete(sess); };
203     udsServerPtr->AddSessionDeletedCallback(callback);
204     callbackInitialized_ = true;
205     return true;
206 }
207 
Dump(int32_t fd,const std::vector<std::string> & args)208 void SwitchSubscriberHandler::Dump(int32_t fd, const std::vector<std::string> &args)
209 {
210     CALL_DEBUG_ENTER;
211     mprintf(fd, "Subscriber information:\t");
212     mprintf(fd, "subscribers: count=%zu", subscribers_.size());
213     for (const auto &item : subscribers_) {
214         std::shared_ptr<Subscriber> subscriber = item;
215         CHKPV(subscriber);
216         SessionPtr session = item->sess_;
217         CHKPV(session);
218         mprintf(fd, "subscriber id:%d | Pid:%d | Uid:%d | Fd:%d\t",
219                 subscriber->id_, session->GetPid(), session->GetUid(), session->GetFd());
220     }
221 }
222 
UpdateSwitchState(const std::shared_ptr<SwitchEvent> switchEvent)223 bool SwitchSubscriberHandler::UpdateSwitchState(const std::shared_ptr<SwitchEvent> switchEvent)
224 {
225     CALL_DEBUG_ENTER;
226     CHKPF(switchEvent);
227     switchStateRecord_[switchEvent->GetSwitchType()] = switchEvent->GetSwitchValue();
228     return true;
229 }
230 
QuerySwitchStatus(int32_t switchType,int32_t & state)231 int32_t SwitchSubscriberHandler::QuerySwitchStatus(int32_t switchType, int32_t& state)
232 {
233     CALL_INFO_TRACE;
234     MMI_HILOGD("QuerySwitchStatus");
235     if (switchStateRecord_.find(switchType) != switchStateRecord_.end()) {
236         if (switchStateRecord_[switchType] == SwitchEvent::SWITCH_ON) {
237             state = SwitchEvent::STATE_ON;
238         } else {
239             state = SwitchEvent::STATE_OFF;
240         }
241         return RET_OK;
242     }
243     state = SwitchEvent::STATE_UNKNOW;
244     MMI_HILOGI("No info about switch %{public}d", switchType);
245     return RET_ERR;
246 }
247 } // namespace MMI
248 } // namespace OHOS
249