• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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