1 /*
2 * Copyright (c) 2025-2026 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 <arpa/inet.h>
17 #include <sys/socket.h>
18
19 #include "errors.h"
20 #include "ipc_object_stub.h"
21 #include "ipc_types.h"
22 #include "message_parcel.h"
23 #include "netmgr_ext_log_wrapper.h"
24 #include "networkslice_ipc_interface_code.h"
25 #include "networkslice_service.h"
26 #include "net_manager_constants.h"
27 #include "networkslice_stub.h"
28
29 namespace OHOS {
30 namespace NetManagerStandard {
31 constexpr int32_t BUFFER_MAX = 65535;
NetworkSliceStub()32 NetworkSliceStub::NetworkSliceStub()
33 {
34 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::SET_NETWORKSLICE_UEPOLICY)] =
35 &NetworkSliceStub::OnSetNetworkSlicePolicy;
36 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_INIT_UEPOLICY)] =
37 &NetworkSliceStub::OnNetworkSliceInitUePolicy;
38 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_ALLOWEDNSSAI_RPT)] =
39 &NetworkSliceStub::OnNetworkSliceAllowedNssaiRpt;
40 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_EHPLMN_RPT)] =
41 &NetworkSliceStub::OnNetworkSliceEhplmnRpt;
42 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_GETRSDBYDNN)] =
43 &NetworkSliceStub::OnGetRouteSelectionDescriptorByDNN;
44 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_GETRSDBYNETCAP)] =
45 &NetworkSliceStub::OnGetRSDByNetCap;
46 memberFuncMap_[static_cast<uint32_t>(NetworkSliceInterfaceCode::NETWORKSLICE_SETSASTATE)] =
47 &NetworkSliceStub::OnSetSaState;
48 }
49
OnRemoteRequest(uint32_t code,MessageParcel & data,MessageParcel & reply,MessageOption & option)50 int32_t NetworkSliceStub::OnRemoteRequest(uint32_t code, MessageParcel &data, MessageParcel &reply,
51 MessageOption &option)
52 {
53 std::u16string myDescripter = NetworkSliceStub::GetDescriptor();
54 std::u16string remoteDescripter = data.ReadInterfaceToken();
55 if (myDescripter != remoteDescripter) {
56 NETMGR_EXT_LOG_E("descriptor checked fail");
57 return NETMANAGER_EXT_ERR_DESCRIPTOR_MISMATCH;
58 }
59 auto itFunc = memberFuncMap_.find(code);
60 if (itFunc != memberFuncMap_.end()) {
61 auto requestFunc = itFunc->second;
62 if (requestFunc != nullptr) {
63 return (this->*requestFunc)(data, reply);
64 }
65 }
66 return IPCObjectStub::OnRemoteRequest(code, data, reply, option);
67 }
68
OnSetNetworkSlicePolicy(MessageParcel & data,MessageParcel & reply)69 int32_t NetworkSliceStub::OnSetNetworkSlicePolicy(MessageParcel &data, MessageParcel &reply)
70 {
71 NETMGR_EXT_LOG_I("NetworkSliceStub::OnSetNetworkSlicePolicy");
72 int32_t buffersize = data.ReadInt32();
73 if (buffersize <= 0 || buffersize > BUFFER_MAX) {
74 NETMGR_EXT_LOG_E("buffer length is invalid: %{public}d", buffersize);
75 return NETMANAGER_EXT_ERR_INVALID_PARAMETER;
76 }
77 std::vector<uint8_t> buffer;
78 for (int32_t i = 0; i < buffersize; ++i) {
79 buffer.push_back(data.ReadUint8());
80 }
81 int32_t ret = NetworkSliceService::GetInstance().SetNetworkSliceUePolicy(buffer);
82 return NETMANAGER_EXT_SUCCESS;
83 }
84
OnNetworkSliceAllowedNssaiRpt(MessageParcel & data,MessageParcel & reply)85 int32_t NetworkSliceStub::OnNetworkSliceAllowedNssaiRpt(MessageParcel &data, MessageParcel &reply)
86 {
87 NETMGR_EXT_LOG_I("NetworkSliceStub::OnNetworkSliceAllowedNssaiRpt");
88 int32_t buffersize = data.ReadInt32();
89 if (buffersize <= 0 || buffersize > BUFFER_MAX) {
90 NETMGR_EXT_LOG_E("buffer length is invalid: %{public}d", buffersize);
91 return NETMANAGER_EXT_ERR_INVALID_PARAMETER;
92 }
93 std::vector<uint8_t> buffer;
94 for (int i = 0; i < buffersize; ++i) {
95 buffer.push_back(data.ReadUint8());
96 }
97 int32_t ret = NetworkSliceService::GetInstance().NetworkSliceAllowedNssaiRpt(buffer);
98 return NETMANAGER_EXT_SUCCESS;
99 }
100
OnNetworkSliceEhplmnRpt(MessageParcel & data,MessageParcel & reply)101 int32_t NetworkSliceStub::OnNetworkSliceEhplmnRpt(MessageParcel &data, MessageParcel &reply)
102 {
103 NETMGR_EXT_LOG_I("NetworkSliceStub::OnNetworkSliceEhplmnRpt");
104 int32_t buffersize = data.ReadInt32();
105 if (buffersize <= 0 || buffersize > BUFFER_MAX) {
106 NETMGR_EXT_LOG_E("buffer length is invalid: %{public}d", buffersize);
107 return NETMANAGER_EXT_ERR_INVALID_PARAMETER;
108 }
109 std::vector<uint8_t> buffer;
110 for (int i = 0; i < buffersize; ++i) {
111 buffer.push_back(data.ReadUint8());
112 }
113 int32_t ret = NetworkSliceService::GetInstance().NetworkSliceEhplmnRpt(buffer);
114 return NETMANAGER_EXT_SUCCESS;
115 }
116
OnNetworkSliceInitUePolicy(MessageParcel & data,MessageParcel & reply)117 int32_t NetworkSliceStub::OnNetworkSliceInitUePolicy(MessageParcel &data, MessageParcel &reply)
118 {
119 NETMGR_EXT_LOG_I("NetworkSliceStub::OnNetworkSliceInitUePolicy");
120 int32_t ret = NetworkSliceService::GetInstance().NetworkSliceInitUePolicy();
121 return NETMANAGER_EXT_SUCCESS;
122 }
123
OnGetRouteSelectionDescriptorByDNN(MessageParcel & data,MessageParcel & reply)124 int32_t NetworkSliceStub::OnGetRouteSelectionDescriptorByDNN(MessageParcel &data, MessageParcel &reply)
125 {
126 NETMGR_EXT_LOG_I("NetworkSliceStub::OnGetRouteSelectionDescriptorByDNN");
127 std::string dnn = data.ReadString();
128 std::string snssai;
129 uint8_t sscmode;
130 int32_t ret = NetworkSliceService::GetInstance().GetRouteSelectionDescriptorByDNN(dnn, snssai, sscmode);
131 reply.WriteString(snssai);
132 reply.WriteUint8(sscmode);
133 return NETMANAGER_EXT_SUCCESS;
134 }
135
OnGetRSDByNetCap(MessageParcel & data,MessageParcel & reply)136 int32_t NetworkSliceStub::OnGetRSDByNetCap(MessageParcel &data, MessageParcel &reply)
137 {
138 NETMGR_EXT_LOG_I("NetworkSliceStub::OnGetRSDByNetCap");
139 int32_t netcap = data.ReadInt32();
140 std::map<std::string, std::string> networkSliceParas;
141 int32_t ret = NetworkSliceService::GetInstance().GetRSDByNetCap(netcap, networkSliceParas);
142 if (networkSliceParas.find("dnn") != networkSliceParas.end() && !networkSliceParas["dnn"].empty()) {
143 reply.WriteString(networkSliceParas["dnn"]);
144 } else {
145 reply.WriteString("Invalid");
146 }
147 if (networkSliceParas.find("snssai") != networkSliceParas.end() && !networkSliceParas["snssai"].empty()) {
148 reply.WriteString(networkSliceParas["snssai"]);
149 } else {
150 reply.WriteString("Invalid");
151 }
152 if (networkSliceParas.find("sscmode") != networkSliceParas.end() && !networkSliceParas["sscmode"].empty()) {
153 reply.WriteString(networkSliceParas["sscmode"]);
154 } else {
155 reply.WriteString("0");
156 }
157 if (networkSliceParas.find("pdusessiontype") != networkSliceParas.end() &&
158 !networkSliceParas["pdusessiontype"].empty()) {
159 reply.WriteString(networkSliceParas["pdusessiontype"]);
160 } else {
161 reply.WriteString("0");
162 }
163 if (networkSliceParas.find("routebitmap") != networkSliceParas.end() && !networkSliceParas["routebitmap"].empty()) {
164 reply.WriteString(networkSliceParas["routebitmap"]);
165 } else {
166 reply.WriteString("0");
167 }
168 return ret;
169 }
170
OnSetSaState(MessageParcel & data,MessageParcel & reply)171 int32_t NetworkSliceStub::OnSetSaState(MessageParcel &data, MessageParcel &reply)
172 {
173 NETMGR_EXT_LOG_I("NetworkSliceStub::OnSetSaState");
174 bool isSaState = data.ReadBool();
175 int32_t ret = NetworkSliceService::GetInstance().SetSaState(isSaState);
176 return NETMANAGER_EXT_SUCCESS;
177 }
178 } // namespace NetManagerStandard
179 } // namespace OHOS
180