1 /*
2 * Copyright (c) 2021-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 "ethernet_service.h"
17
18 #include <new>
19 #include <sys/time.h>
20
21 #include "ethernet_management.h"
22 #include "mac_address_info.h"
23 #include "interface_configuration.h"
24 #include "iremote_object.h"
25 #include "net_ethernet_base_service.h"
26 #include "net_manager_center.h"
27 #include "net_manager_constants.h"
28 #include "netmanager_base_permission.h"
29 #include "netmgr_ext_log_wrapper.h"
30 #include "netsys_controller.h"
31 #include "system_ability_definition.h"
32
33 namespace OHOS {
34 namespace NetManagerStandard {
35 namespace {
36 constexpr uint16_t DEPENDENT_SERVICE_NET_CONN_MANAGER = 0x0001;
37 constexpr uint16_t DEPENDENT_SERVICE_COMMON_EVENT = 0x0002;
38 constexpr uint16_t DEPENDENT_SERVICE_All = 0x0003;
39 constexpr const char *NET_ACTIVATE_WORK_THREAD = "POLICY_CALLBACK_WORK_THREAD";
40 const bool REGISTER_LOCAL_RESULT_ETH =
41 SystemAbility::MakeAndRegisterAbility(DelayedSingleton<EthernetService>::GetInstance().get());
42 } // namespace
43
EthernetService()44 EthernetService::EthernetService() : SystemAbility(COMM_ETHERNET_MANAGER_SYS_ABILITY_ID, true) {}
45
46 EthernetService::~EthernetService() = default;
47
OnStart()48 void EthernetService::OnStart()
49 {
50 struct timeval tv;
51 gettimeofday(&tv, nullptr);
52 NETMGR_EXT_LOG_D("EthernetService::OnStart begin");
53 if (state_ == STATE_RUNNING) {
54 NETMGR_EXT_LOG_D("EthernetService the state is already running");
55 return;
56 }
57 if (!Init()) {
58 NETMGR_EXT_LOG_E("EthernetService init failed");
59 return;
60 }
61 state_ = STATE_RUNNING;
62 gettimeofday(&tv, nullptr);
63 NETMGR_EXT_LOG_D("EthernetService::OnStart end");
64 }
65
OnStop()66 void EthernetService::OnStop()
67 {
68 state_ = STATE_STOPPED;
69 registerToService_ = false;
70 ethernetServiceFfrtQueue_.reset();
71 }
72
Dump(int32_t fd,const std::vector<std::u16string> & args)73 int32_t EthernetService::Dump(int32_t fd, const std::vector<std::u16string> &args)
74 {
75 NETMGR_EXT_LOG_D("Start Dump, fd: %{public}d", fd);
76 std::string result;
77 ethManagement_.GetDumpInfo(result);
78 int32_t ret = dprintf(fd, "%s\n", result.c_str());
79 return ret < 0 ? NETMANAGER_EXT_ERR_LOCAL_PTR_NULL : NETMANAGER_EXT_SUCCESS;
80 }
81
OnAddSystemAbility(int32_t systemAbilityId,const std::string & deviceId)82 void EthernetService::OnAddSystemAbility(int32_t systemAbilityId, const std::string &deviceId)
83 {
84 switch (systemAbilityId) {
85 case COMM_NET_CONN_MANAGER_SYS_ABILITY_ID:
86 NETMGR_EXT_LOG_D("EthernetService::OnAddSystemAbility Conn");
87 dependentServiceState_ |= DEPENDENT_SERVICE_NET_CONN_MANAGER;
88 break;
89 case COMMON_EVENT_SERVICE_ID:
90 NETMGR_EXT_LOG_D("EthernetService::OnAddSystemAbility CES");
91 dependentServiceState_ |= DEPENDENT_SERVICE_COMMON_EVENT;
92 break;
93 default:
94 NETMGR_EXT_LOG_D("EthernetService::OnAddSystemAbility unhandled sysabilityId:%{public}d", systemAbilityId);
95 break;
96 }
97 if (dependentServiceState_ == DEPENDENT_SERVICE_All) {
98 InitManagement();
99 }
100 }
101
Init()102 bool EthernetService::Init()
103 {
104 if (!REGISTER_LOCAL_RESULT_ETH) {
105 NETMGR_EXT_LOG_E("EthernetService Register to local sa manager failed");
106 return false;
107 }
108 if (!registerToService_) {
109 if (!Publish(DelayedSingleton<EthernetService>::GetInstance().get())) {
110 NETMGR_EXT_LOG_E("EthernetService Register to sa manager failed");
111 return false;
112 }
113 registerToService_ = true;
114 }
115 AddSystemAbilityListener(COMM_NET_CONN_MANAGER_SYS_ABILITY_ID);
116 AddSystemAbilityListener(COMMON_EVENT_SERVICE_ID);
117 interfaceStateCallback_ = new (std::nothrow) GlobalInterfaceStateCallback(*this);
118 if (interfaceStateCallback_ == nullptr) {
119 NETMGR_EXT_LOG_E("allInterfaceStateCallback_ is nullptr");
120 return false;
121 }
122 NetsysController::GetInstance().RegisterCallback(interfaceStateCallback_);
123 serviceComm_ = new (std::nothrow) EthernetServiceCommon();
124 if (serviceComm_ == nullptr) {
125 NETMGR_EXT_LOG_E("serviceComm_ is nullptr");
126 return false;
127 }
128 NetManagerCenter::GetInstance().RegisterEthernetService(serviceComm_);
129 ethernetServiceFfrtQueue_ = std::make_shared<ffrt::queue>("EthernetService");
130 return true;
131 }
132
InitManagement()133 void EthernetService::InitManagement()
134 {
135 NETMGR_EXT_LOG_D("EthernetService::InitManagement Enter");
136 ethManagement_.Init();
137 }
138
OnInterfaceAddressUpdated(const std::string & addr,const std::string & ifName,int flags,int scope)139 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceAddressUpdated(const std::string &addr,
140 const std::string &ifName, int flags,
141 int scope)
142 {
143 return 0;
144 }
145
OnInterfaceAddressRemoved(const std::string & addr,const std::string & ifName,int flags,int scope)146 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceAddressRemoved(const std::string &addr,
147 const std::string &ifName, int flags,
148 int scope)
149 {
150 return 0;
151 }
152
OnInterfaceAdded(const std::string & iface)153 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceAdded(const std::string &iface)
154 {
155 NETMGR_EXT_LOG_D("iface: %{public}s, added", iface.c_str());
156 ethernetService_.NotifyMonitorIfaceCallbackAsync(
157 [=](const sptr<InterfaceStateCallback> &callback) { callback->OnInterfaceAdded(iface); });
158 return 0;
159 }
160
OnInterfaceRemoved(const std::string & iface)161 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceRemoved(const std::string &iface)
162 {
163 NETMGR_EXT_LOG_D("iface: %{public}s, removed", iface.c_str());
164 ethernetService_.NotifyMonitorIfaceCallbackAsync(
165 [=](const sptr<InterfaceStateCallback> &callback) { callback->OnInterfaceRemoved(iface); });
166 return 0;
167 }
168
OnInterfaceChanged(const std::string & iface,bool up)169 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceChanged(const std::string &iface, bool up)
170 {
171 return 0;
172 }
173
OnInterfaceLinkStateChanged(const std::string & ifName,bool up)174 int32_t EthernetService::GlobalInterfaceStateCallback::OnInterfaceLinkStateChanged(const std::string &ifName, bool up)
175 {
176 NETMGR_EXT_LOG_D("iface: %{public}s, up: %{public}d", ifName.c_str(), up);
177 ethernetService_.NotifyMonitorIfaceCallbackAsync(
178 [=](const sptr<InterfaceStateCallback> &callback) { callback->OnInterfaceChanged(ifName, up); });
179 return 0;
180 }
181
OnRouteChanged(bool updated,const std::string & route,const std::string & gateway,const std::string & ifName)182 int32_t EthernetService::GlobalInterfaceStateCallback::OnRouteChanged(bool updated, const std::string &route,
183 const std::string &gateway,
184 const std::string &ifName)
185 {
186 return 0;
187 }
188
OnDhcpSuccess(NetsysControllerCallback::DhcpResult & dhcpResult)189 int32_t EthernetService::GlobalInterfaceStateCallback::OnDhcpSuccess(NetsysControllerCallback::DhcpResult &dhcpResult)
190 {
191 return 0;
192 }
193
OnBandwidthReachedLimit(const std::string & limitName,const std::string & iface)194 int32_t EthernetService::GlobalInterfaceStateCallback::OnBandwidthReachedLimit(const std::string &limitName,
195 const std::string &iface)
196 {
197 return 0;
198 }
199
GetMacAddress(std::vector<MacAddressInfo> & macAddrList)200 int32_t EthernetService::GetMacAddress(std::vector<MacAddressInfo> &macAddrList)
201 {
202 NETMGR_EXT_LOG_I("EthernetService GetMacAddress enter");
203 if (!NetManagerPermission::CheckPermission(Permission::GET_ETHERNET_LOCAL_MAC)) {
204 NETMGR_EXT_LOG_E("EthernetService GetMacAddress no js permission");
205 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
206 }
207
208 return ethManagement_.GetMacAddress(macAddrList);
209 }
210
SetIfaceConfig(const std::string & iface,sptr<InterfaceConfiguration> & ic)211 int32_t EthernetService::SetIfaceConfig(const std::string &iface, sptr<InterfaceConfiguration> &ic)
212 {
213 NETMGR_EXT_LOG_D("Set iface: %{public}s config", iface.c_str());
214 if (!NetManagerPermission::IsSystemCaller()) {
215 NETMGR_EXT_LOG_E("Caller not have sys permission");
216 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
217 }
218 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
219 NETMGR_EXT_LOG_E("EthernetService SetIfaceConfig no js permission");
220 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
221 }
222
223 return ethManagement_.UpdateDevInterfaceCfg(iface, ic);
224 }
225
GetIfaceConfig(const std::string & iface,sptr<InterfaceConfiguration> & ifaceConfig)226 int32_t EthernetService::GetIfaceConfig(const std::string &iface, sptr<InterfaceConfiguration> &ifaceConfig)
227 {
228 NETMGR_EXT_LOG_D("Get iface: %{public}s config", iface.c_str());
229 if (!NetManagerPermission::IsSystemCaller()) {
230 NETMGR_EXT_LOG_E("Caller not have sys permission");
231 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
232 }
233 if (!NetManagerPermission::CheckPermission(Permission::GET_NETWORK_INFO)) {
234 NETMGR_EXT_LOG_E("EthernetService GetIfaceConfig no js permission");
235 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
236 }
237
238 return ethManagement_.GetDevInterfaceCfg(iface, ifaceConfig);
239 }
240
IsIfaceActive(const std::string & iface,int32_t & activeStatus)241 int32_t EthernetService::IsIfaceActive(const std::string &iface, int32_t &activeStatus)
242 {
243 NETMGR_EXT_LOG_D("Get iface: %{public}s is active", iface.c_str());
244 if (!NetManagerPermission::IsSystemCaller()) {
245 NETMGR_EXT_LOG_E("Caller not have sys permission");
246 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
247 }
248 if (!NetManagerPermission::CheckPermission(Permission::GET_NETWORK_INFO)) {
249 NETMGR_EXT_LOG_E("EthernetService IsIfaceActive no js permission");
250 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
251 }
252
253 return ethManagement_.IsIfaceActive(iface, activeStatus);
254 }
255
GetAllActiveIfaces(std::vector<std::string> & activeIfaces)256 int32_t EthernetService::GetAllActiveIfaces(std::vector<std::string> &activeIfaces)
257 {
258 if (!NetManagerPermission::IsSystemCaller()) {
259 NETMGR_EXT_LOG_E("Caller not have sys permission");
260 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
261 }
262 if (!NetManagerPermission::CheckPermission(Permission::GET_NETWORK_INFO)) {
263 NETMGR_EXT_LOG_E("EthernetService GetAllActiveIfaces no js permission");
264 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
265 }
266
267 return ethManagement_.GetAllActiveIfaces(activeIfaces);
268 }
269
ResetFactory()270 int32_t EthernetService::ResetFactory()
271 {
272 if (!NetManagerPermission::IsSystemCaller()) {
273 NETMGR_EXT_LOG_E("Caller not have sys permission");
274 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
275 }
276 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
277 NETMGR_EXT_LOG_E("EthernetService GetAllActiveIfaces no js permission");
278 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
279 }
280
281 return ethManagement_.ResetFactory();
282 }
283
RegisterIfacesStateChanged(const sptr<InterfaceStateCallback> & callback)284 int32_t EthernetService::RegisterIfacesStateChanged(const sptr<InterfaceStateCallback> &callback)
285 {
286 if (callback == nullptr) {
287 NETMGR_EXT_LOG_E("Register interface callback failed");
288 return NETMANAGER_EXT_ERR_PARAMETER_ERROR;
289 }
290 if (!NetManagerPermission::IsSystemCaller()) {
291 NETMGR_EXT_LOG_E("Caller not have sys permission");
292 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
293 }
294 if (!NetManagerPermission::CheckPermission(Permission::GET_NETWORK_INFO)) {
295 NETMGR_EXT_LOG_E("RegisterIfacesStateChanged no permission");
296 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
297 }
298 return RegisterMonitorIfaceCallbackAsync(callback);
299 }
300
UnregisterIfacesStateChanged(const sptr<InterfaceStateCallback> & callback)301 int32_t EthernetService::UnregisterIfacesStateChanged(const sptr<InterfaceStateCallback> &callback)
302 {
303 if (callback == nullptr) {
304 NETMGR_EXT_LOG_E("Unregister interface callback failed");
305 return NETMANAGER_EXT_ERR_PARAMETER_ERROR;
306 }
307 if (!NetManagerPermission::IsSystemCaller()) {
308 NETMGR_EXT_LOG_E("Caller not have sys permission");
309 return NETMANAGER_EXT_ERR_NOT_SYSTEM_CALL;
310 }
311 if (!NetManagerPermission::CheckPermission(Permission::GET_NETWORK_INFO)) {
312 NETMGR_EXT_LOG_E("RegisterIfacesStateChanged no permission");
313 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
314 }
315 return UnregisterMonitorIfaceCallbackAsync(callback);
316 }
317
SetInterfaceUp(const std::string & iface)318 int32_t EthernetService::SetInterfaceUp(const std::string &iface)
319 {
320 NETMGR_EXT_LOG_D("Set interface: %{public}s up", iface.c_str());
321 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
322 NETMGR_EXT_LOG_E("EthernetService SetInterfaceUp no permission");
323 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
324 }
325 return NetsysController::GetInstance().SetInterfaceUp(iface);
326 }
327
SetInterfaceDown(const std::string & iface)328 int32_t EthernetService::SetInterfaceDown(const std::string &iface)
329 {
330 NETMGR_EXT_LOG_D("Set interface: %{public}s down", iface.c_str());
331 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
332 NETMGR_EXT_LOG_E("EthernetService SetInterfaceDown no permission");
333 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
334 }
335 return NetsysController::GetInstance().SetInterfaceDown(iface);
336 }
337
GetInterfaceConfig(const std::string & iface,OHOS::nmd::InterfaceConfigurationParcel & config)338 int32_t EthernetService::GetInterfaceConfig(const std::string &iface, OHOS::nmd::InterfaceConfigurationParcel &config)
339 {
340 NETMGR_EXT_LOG_D("Get interface: %{public}s config", iface.c_str());
341 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
342 NETMGR_EXT_LOG_E("EthernetService GetInterfaceConfig no permission");
343 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
344 }
345 config.ifName = iface;
346 return NetsysController::GetInstance().GetInterfaceConfig(config);
347 }
348
SetInterfaceConfig(const std::string & iface,OHOS::nmd::InterfaceConfigurationParcel & cfg)349 int32_t EthernetService::SetInterfaceConfig(const std::string &iface, OHOS::nmd::InterfaceConfigurationParcel &cfg)
350 {
351 NETMGR_EXT_LOG_D("Set interface: %{public}s config", iface.c_str());
352 if (!NetManagerPermission::CheckPermission(Permission::CONNECTIVITY_INTERNAL)) {
353 NETMGR_EXT_LOG_E("EthernetService SetInterfaceConfig no permission");
354 return NETMANAGER_EXT_ERR_PERMISSION_DENIED;
355 }
356 cfg.ifName = iface;
357 return NetsysController::GetInstance().SetInterfaceConfig(cfg);
358 }
359
RegisterMonitorIfaceCallbackAsync(const sptr<InterfaceStateCallback> & callback)360 int32_t EthernetService::RegisterMonitorIfaceCallbackAsync(const sptr<InterfaceStateCallback> &callback)
361 {
362 int32_t ret = NETMANAGER_EXT_ERR_OPERATION_FAILED;
363 if (!ethernetServiceFfrtQueue_) {
364 NETMGR_EXT_LOG_E("FFRT Init Fail");
365 return ret;
366 }
367 ffrt::task_handle RegisterMonitorIfaceTask = ethernetServiceFfrtQueue_->submit_h([this, &callback, &ret]() {
368 for (auto iterCb = monitorIfaceCallbacks_.begin(); iterCb != monitorIfaceCallbacks_.end(); iterCb++) {
369 if ((*iterCb)->AsObject().GetRefPtr() == callback->AsObject().GetRefPtr()) {
370 NETMGR_EXT_LOG_D("Register interface callback failed, callback already exists");
371 ret = NETMANAGER_EXT_ERR_OPERATION_FAILED;
372 return;
373 }
374 }
375 monitorIfaceCallbacks_.push_back(callback);
376 NETMGR_EXT_LOG_D("Register interface callback success");
377 ret = NETMANAGER_EXT_SUCCESS;
378 }, ffrt::task_attr().name("RegisterMonitorIfaceCallbackAsync"));
379 ethernetServiceFfrtQueue_->wait(RegisterMonitorIfaceTask);
380 return ret;
381 }
382
UnregisterMonitorIfaceCallbackAsync(const sptr<InterfaceStateCallback> & callback)383 int32_t EthernetService::UnregisterMonitorIfaceCallbackAsync(const sptr<InterfaceStateCallback> &callback)
384 {
385 int32_t ret = NETMANAGER_EXT_ERR_OPERATION_FAILED;
386 if (!ethernetServiceFfrtQueue_) {
387 NETMGR_EXT_LOG_E("FFRT Init Fail");
388 return ret;
389 }
390 ffrt::task_handle UnregisterMonitorIfaceTask = ethernetServiceFfrtQueue_->submit_h([this, &callback, &ret]() {
391 for (auto iterCb = monitorIfaceCallbacks_.begin(); iterCb != monitorIfaceCallbacks_.end(); iterCb++) {
392 if ((*iterCb)->AsObject().GetRefPtr() == callback->AsObject().GetRefPtr()) {
393 monitorIfaceCallbacks_.erase(iterCb);
394 NETMGR_EXT_LOG_D("Unregister interface callback success.");
395 ret = NETMANAGER_EXT_SUCCESS;
396 return;
397 }
398 }
399 NETMGR_EXT_LOG_E("Unregister interface callback is doesnot exist.");
400 ret = NETMANAGER_EXT_ERR_OPERATION_FAILED;
401 }, ffrt::task_attr().name("UnregisterMonitorIfaceCallbackAsync"));
402 ethernetServiceFfrtQueue_->wait(UnregisterMonitorIfaceTask);
403 return ret;
404 }
405
NotifyMonitorIfaceCallbackAsync(OnFunctionT onFunction)406 void EthernetService::NotifyMonitorIfaceCallbackAsync(OnFunctionT onFunction)
407 {
408 if (!ethernetServiceFfrtQueue_) {
409 NETMGR_EXT_LOG_E("FFRT Init Fail");
410 return;
411 }
412 ffrt::task_handle NotifyMonitorIfaceTask_ = ethernetServiceFfrtQueue_->submit_h([this, &onFunction]() {
413 std::for_each(monitorIfaceCallbacks_.begin(), monitorIfaceCallbacks_.end(), onFunction);
414 }, ffrt::task_attr().name("NotifyMonitorIfaceCallbackAsync"));
415 ethernetServiceFfrtQueue_->wait(NotifyMonitorIfaceTask_);
416 }
417 } // namespace NetManagerStandard
418 } // namespace OHOS
419