1 /*
2 * Copyright (c) 2025 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 <stdatomic.h>
17 #include <securec.h>
18
19 #include "anonymizer.h"
20 #include "bus_center_manager.h"
21 #include "cJSON.h"
22 #include "g_enhance_adapter_func_pack.h"
23 #include "lnn_local_net_ledger.h"
24 #include "lnn_log.h"
25 #include "lnn_distributed_net_ledger_common.h"
26 #include "lnn_sle_capability.h"
27 #include "softbus_adapter_mem.h"
28 #include "softbus_adapter_sle_common_struct.h"
29 #include "softbus_json_utils.h"
30 #include "softbus_error_code.h"
31
32 static void SleStateChangeEventHandler(int32_t state);
33
34 const SoftBusSleStateListener g_sleStateChangedListener = {
35 .onSleStateChanged = SleStateChangeEventHandler,
36 };
37
38 static int32_t g_sleStateListenerId = -1;
39 static int32_t g_sleRangeCap = 0;
40 static char g_sleMacAddr[MAC_LEN];
41
SetSleRangeCapToLocalLedger(void)42 int32_t SetSleRangeCapToLocalLedger(void)
43 {
44 g_sleRangeCap = GetSleRangeCapacityPacked();
45 int32_t sleCapCache = 0;
46 int32_t ret = LnnGetLocalNumInfo(NUM_KEY_SLE_RANGE_CAP, &sleCapCache);
47 if (ret != SOFTBUS_OK) {
48 LNN_LOGE(LNN_LEDGER, "LnnGetLocalNumInfo fail, ret=%{public}d", ret);
49 }
50 if (sleCapCache == g_sleRangeCap) {
51 LNN_LOGW(LNN_LEDGER, "slecap is consistent, not fix");
52 return SOFTBUS_OK;
53 }
54 ret = LnnUpdateSleCapacityAndVersion(g_sleRangeCap);
55 if (ret != SOFTBUS_OK) {
56 LNN_LOGE(LNN_LEDGER, "LnnSetLocalNumInfo fail, ret=%{public}d", ret);
57 return ret;
58 }
59 LNN_LOGI(LNN_LEDGER, "LnnSetLocalNumInfo set sle range cap %{public}d", g_sleRangeCap);
60 return SOFTBUS_OK;
61 }
62
SetSleAddrToLocalLedger(void)63 int32_t SetSleAddrToLocalLedger(void)
64 {
65 if (!IsSleEnabledPacked()) {
66 LNN_LOGI(LNN_LEDGER, "SLE not enabled!");
67 return SOFTBUS_SLE_RANGING_NOT_ENABLE;
68 }
69 int32_t ret = GetLocalSleAddrPacked(g_sleMacAddr, MAC_LEN);
70 if (ret != SOFTBUS_OK) {
71 LNN_LOGE(LNN_LEDGER, "GetLocalSleAddr fail, ret=%{public}d", ret);
72 return ret;
73 }
74 ret = LnnSetLocalStrInfo(STRING_KEY_SLE_ADDR, g_sleMacAddr);
75 if (ret != SOFTBUS_OK) {
76 LNN_LOGE(LNN_LEDGER, "LnnSetLocalStrInfo fail, ret=%{public}d", ret);
77 return ret;
78 }
79 char *anonySleMac = NULL;
80 Anonymize(g_sleMacAddr, &anonySleMac);
81 LNN_LOGI(LNN_LEDGER, "LnnSetLocalStrInfo set sle mac %{public}s", AnonymizeWrapper(anonySleMac));
82 AnonymizeFree(anonySleMac);
83 return SOFTBUS_OK;
84 }
85
LnnSendSleInfoForAllNode(void)86 void LnnSendSleInfoForAllNode(void)
87 {
88 cJSON *json = cJSON_CreateObject();
89 if (json == NULL) {
90 LNN_LOGE(LNN_LEDGER, "json object create failed");
91 return;
92 }
93 if (!AddNumberToJsonObject(json, JSON_KEY_SLE_CAP, g_sleRangeCap) ||
94 !AddStringToJsonObject(json, JSON_KEY_SLE_MAC, g_sleMacAddr)) {
95 cJSON_Delete(json);
96 LNN_LOGE(LNN_LEDGER, "json object add failed");
97 return;
98 }
99 char *data = cJSON_PrintUnformatted(json);
100 cJSON_Delete(json);
101 if (data == NULL) {
102 LNN_LOGE(LNN_LEDGER, "json print failed");
103 return;
104 }
105 NodeBasicInfo *info = NULL;
106 int32_t infoNum = 0;
107 if (LnnGetAllOnlineNodeInfo(&info, &infoNum) != SOFTBUS_OK) {
108 LNN_LOGE(LNN_LEDGER, "get all online node info fail");
109 cJSON_free(data);
110 return;
111 }
112 if (info == NULL || infoNum == 0) {
113 cJSON_free(data);
114 LNN_LOGE(LNN_LEDGER, "online node is zero");
115 return;
116 }
117 LNN_LOGI(LNN_BUILDER, "online nodes count=%{public}d", infoNum);
118 for (int32_t i = 0; i < infoNum; ++i) {
119 if (LnnIsLSANode(&info[i])) {
120 continue;
121 }
122 char *anonyNetworkId = NULL;
123 Anonymize(info[i].networkId, &anonyNetworkId);
124 LNN_LOGI(LNN_BUILDER, "sync slecap and slemac to networkId=%{public}s", AnonymizeWrapper(anonyNetworkId));
125 if (LnnSendSyncInfoMsg(LNN_INFO_TYPE_SLE_MAC, info[i].networkId,
126 (const uint8_t *)data, strlen(data) + 1, NULL) != SOFTBUS_OK) {
127 LNN_LOGE(LNN_BUILDER, "sync slecap and slemac failed. networkId=%{public}s",
128 AnonymizeWrapper(anonyNetworkId));
129 }
130 AnonymizeFree(anonyNetworkId);
131 }
132 cJSON_free(data);
133 SoftBusFree(info);
134 }
135
SleStateChangeEventHandler(int32_t state)136 static void SleStateChangeEventHandler(int32_t state)
137 {
138 LNN_LOGE(LNN_LEDGER, "SleStateChangeEventHandler enter!");
139 if (state != SOFTBUS_SLE_STATE_TURN_ON) {
140 LNN_LOGI(LNN_LEDGER, "event is not sle turn on, ignore");
141 return;
142 }
143 (void)SetSleRangeCapToLocalLedger();
144 (void)SetSleAddrToLocalLedger();
145 (void)LnnSendSleInfoForAllNode();
146 }
147
LocalLedgerInitSleCapacity(NodeInfo * nodeInfo)148 int32_t LocalLedgerInitSleCapacity(NodeInfo* nodeInfo)
149 {
150 if (nodeInfo == NULL) {
151 LNN_LOGE(LNN_LEDGER, "NodeInfo is NULL");
152 return SOFTBUS_ERR;
153 }
154 int32_t sleCapacity = GetSleRangeCapacityPacked();
155 char sleMacAddr[MAC_LEN] = { 0 };
156 int32_t ret = GetLocalSleAddrPacked(sleMacAddr, MAC_LEN);
157 if (ret != SOFTBUS_OK) {
158 LNN_LOGE(LNN_LEDGER, "GetLocalSleAddr fail, init pass, ret=%{public}d", ret);
159 }
160 nodeInfo->sleRangeCapacity = sleCapacity;
161 memcpy_s(nodeInfo->connectInfo.sleMacAddr, MAC_LEN, sleMacAddr, MAC_LEN);
162 ret = SoftBusAddSleStateListenerPacked(&g_sleStateChangedListener, &g_sleStateListenerId);
163 if (ret != SOFTBUS_OK) {
164 LNN_LOGE(LNN_LEDGER, "Add sle state listener failed.");
165 return ret;
166 }
167 return SOFTBUS_OK;
168 }
169
OnReceiveSleMacChangedMsg(LnnSyncInfoType type,const char * networkId,const uint8_t * msg,uint32_t size)170 void OnReceiveSleMacChangedMsg(LnnSyncInfoType type, const char *networkId, const uint8_t *msg, uint32_t size)
171 {
172 if (type != LNN_INFO_TYPE_SLE_MAC) {
173 LNN_LOGE(LNN_LEDGER, "not sle mac type");
174 return;
175 }
176 if (networkId == NULL || msg == NULL) {
177 LNN_LOGE(LNN_LEDGER, "networkId or msg is null");
178 return;
179 }
180 uint32_t addrLen = (uint32_t)strnlen((const char *)msg, size);
181 if (size == 0 || addrLen != size - 1 || addrLen == 0) {
182 LNN_LOGE(LNN_LEDGER, "invalid msg");
183 return;
184 }
185 char *anonyNetworkId = NULL;
186 Anonymize(networkId, &anonyNetworkId);
187 LNN_LOGI(LNN_LEDGER, "OnReceiveSleMacChangedMsg networkId=%{public}s", AnonymizeWrapper(anonyNetworkId));
188 AnonymizeFree(anonyNetworkId);
189 char sleMacSync [MAC_LEN];
190 int32_t sleCapSync = 0;
191 cJSON *json = cJSON_Parse((char *)msg);
192 if (json == NULL) {
193 LNN_LOGE(LNN_LEDGER, "json parse failed");
194 return;
195 }
196 if (!GetJsonObjectStringItem(json, JSON_KEY_SLE_MAC, sleMacSync, MAC_LEN) ||
197 !GetJsonObjectNumberItem(json, JSON_KEY_SLE_CAP, &sleCapSync)) {
198 LNN_LOGE(LNN_BUILDER, "parse sle mac and sle cap");
199 cJSON_Delete(json);
200 return;
201 }
202 cJSON_Delete(json);
203 if (LnnSetDLSleRangeInfo(networkId, CATEGORY_NETWORK_ID, sleCapSync, sleMacSync) != SOFTBUS_OK) {
204 return;
205 }
206 char *anonySleMac = NULL;
207 Anonymize(networkId, &anonySleMac);
208 LNN_LOGI(LNN_LEDGER, "slecap and slemac sync succ, slecap %{public}d sle mac %{public}s", sleCapSync,
209 AnonymizeWrapper(anonySleMac));
210 AnonymizeFree(anonySleMac);
211 }
212
LnnInitSleInfo(void)213 int32_t LnnInitSleInfo(void)
214 {
215 int32_t ret = LnnRegSyncInfoHandler(LNN_INFO_TYPE_SLE_MAC, OnReceiveSleMacChangedMsg);
216 if (ret != SOFTBUS_OK) {
217 LNN_LOGE(LNN_LEDGER, "Add handler for sle mac changed");
218 return ret;
219 }
220 return SOFTBUS_OK;
221 }
222
LnnDeinitSleInfo(void)223 void LnnDeinitSleInfo(void)
224 {
225 (void)LnnUnregSyncInfoHandler(LNN_INFO_TYPE_SLE_MAC, OnReceiveSleMacChangedMsg);
226 }
227
LocalLedgerDeinitSleCapacity(void)228 void LocalLedgerDeinitSleCapacity(void)
229 {
230 SoftBusRemoveSleStateListenerPacked(g_sleStateListenerId);
231 g_sleStateListenerId = -1;
232 }
233