1 /*
2 * Copyright (c) 2021 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 "client_trans_channel_manager.h"
17
18 #include "client_trans_auth_manager.h"
19 #include "client_trans_proxy_manager.h"
20 #include "client_trans_session_callback.h"
21 #include "client_trans_session_manager.h"
22 #include "client_trans_statistics.h"
23 #include "client_trans_tcp_direct_manager.h"
24 #include "client_trans_tcp_direct_message.h"
25 #include "client_trans_udp_manager.h"
26 #include "softbus_error_code.h"
27 #include "trans_log.h"
28
ClientTransChannelInit(void)29 int32_t ClientTransChannelInit(void)
30 {
31 IClientSessionCallBack *cb = GetClientSessionCb();
32 TRANS_CHECK_AND_RETURN_RET_LOGE(cb != NULL, SOFTBUS_NO_INIT, TRANS_SDK, "get client session Cb failed.");
33
34 int32_t ret = TransTdcManagerInit(cb);
35 TRANS_CHECK_AND_RETURN_RET_LOGE(ret == SOFTBUS_OK, ret, TRANS_SDK, "trans tcp manager init failed.");
36
37 ret = ClientTransAuthInit(cb);
38 TRANS_CHECK_AND_RETURN_RET_LOGE(ret == SOFTBUS_OK, ret, TRANS_SDK, "client trans auth init failed.");
39
40 ret = ClientTransStatisticsInit();
41 TRANS_CHECK_AND_RETURN_RET_LOGE(ret == SOFTBUS_OK, ret, TRANS_SDK, "client trans statistics init failed.");
42
43 ret = ClientTransProxyInit(cb);
44 TRANS_CHECK_AND_RETURN_RET_LOGE(ret == SOFTBUS_OK, ret, TRANS_SDK, "client trans proxy init failed.");
45
46 ret = ClientTransUdpMgrInit(cb);
47 TRANS_CHECK_AND_RETURN_RET_LOGE(ret == SOFTBUS_OK, ret, TRANS_SDK, "client trans udp mgr init failed.");
48 return SOFTBUS_OK;
49 }
50
ClientTransChannelDeinit(void)51 void ClientTransChannelDeinit(void)
52 {
53 TransTdcManagerDeinit();
54 ClientTransUdpMgrDeinit();
55 ClientTransProxyDeinit();
56 ClientTransStatisticsDeinit();
57 }
58
ClientTransCloseChannel(int32_t channelId,int32_t type)59 int32_t ClientTransCloseChannel(int32_t channelId, int32_t type)
60 {
61 if (channelId < 0) {
62 TRANS_LOGW(TRANS_SDK, "Invalid param");
63 return SOFTBUS_INVALID_PARAM;
64 }
65 DeleteSocketResourceByChannelId(channelId, type);
66 int32_t ret = SOFTBUS_OK;
67 switch (type) {
68 case CHANNEL_TYPE_PROXY:
69 ClientTransProxyCloseChannel(channelId);
70 break;
71 case CHANNEL_TYPE_TCP_DIRECT:
72 TransDelDataBufNode(channelId);
73 TransTdcCloseChannel(channelId);
74 break;
75 case CHANNEL_TYPE_UDP:
76 ret = ClientTransCloseUdpChannel(channelId, SHUTDOWN_REASON_LOCAL);
77 break;
78 case CHANNEL_TYPE_AUTH:
79 ClientTransAuthCloseChannel(channelId, SHUTDOWN_REASON_LOCAL);
80 break;
81 default:
82 TRANS_LOGE(TRANS_SDK, "Invalid type");
83 return SOFTBUS_TRANS_INVALID_CHANNEL_TYPE;
84 }
85 return ret;
86 }
87
ClientTransChannelSendBytes(int32_t channelId,int32_t channelType,const void * data,uint32_t len)88 int32_t ClientTransChannelSendBytes(int32_t channelId, int32_t channelType, const void *data, uint32_t len)
89 {
90 if ((data == NULL) || (len == 0)) {
91 TRANS_LOGW(TRANS_BYTES, "Invalid param");
92 return SOFTBUS_INVALID_PARAM;
93 }
94
95 bool needAck = false;
96 int32_t ret = GetSupportTlvAndNeedAckById(channelId, channelType, NULL, &needAck);
97 if (ret != SOFTBUS_OK) {
98 TRANS_LOGE(TRANS_SDK, "GetSupportTlvAndNeedAckById fail, channelId=%{public}d.", channelId);
99 return ret;
100 }
101 switch (channelType) {
102 case CHANNEL_TYPE_AUTH:
103 ret = TransAuthChannelSendBytes(channelId, data, len);
104 break;
105 case CHANNEL_TYPE_PROXY:
106 ret = TransProxyChannelSendBytes(channelId, data, len, needAck);
107 break;
108 case CHANNEL_TYPE_TCP_DIRECT:
109 ret = TransTdcSendBytes(channelId, data, len, needAck);
110 break;
111 default:
112 TRANS_LOGE(TRANS_SDK, "Invalid channelType=%{public}d", channelType);
113 return SOFTBUS_TRANS_INVALID_CHANNEL_TYPE;
114 }
115 return ret;
116 }
117
ClientTransChannelAsyncSendBytes(int32_t channelId,int32_t channelType,const void * data,uint32_t len,uint32_t dataSeq)118 int32_t ClientTransChannelAsyncSendBytes(int32_t channelId, int32_t channelType, const void *data, uint32_t len,
119 uint32_t dataSeq)
120 {
121 if ((data == NULL) || (len == 0)) {
122 TRANS_LOGW(TRANS_BYTES, "Invalid param");
123 return SOFTBUS_INVALID_PARAM;
124 }
125 int32_t ret = SOFTBUS_OK;
126 switch (channelType) {
127 case CHANNEL_TYPE_PROXY:
128 ret = TransProxyChannelAsyncSendBytes(channelId, data, len, dataSeq);
129 break;
130 case CHANNEL_TYPE_TCP_DIRECT:
131 ret = TransTdcAsyncSendBytes(channelId, data, len, dataSeq);
132 break;
133 default:
134 TRANS_LOGE(TRANS_SDK, "Invalid channelType=%{public}d", channelType);
135 return SOFTBUS_TRANS_INVALID_CHANNEL_TYPE;
136 }
137 return ret;
138 }
139
ClientTransChannelSendMessage(int32_t channelId,int32_t channelType,const void * data,uint32_t len)140 int32_t ClientTransChannelSendMessage(int32_t channelId, int32_t channelType, const void *data, uint32_t len)
141 {
142 if ((data == NULL) || (len == 0)) {
143 TRANS_LOGW(TRANS_MSG, "Invalid param.");
144 return SOFTBUS_INVALID_PARAM;
145 }
146
147 int32_t ret = SOFTBUS_OK;
148 switch (channelType) {
149 case CHANNEL_TYPE_AUTH:
150 ret = TransAuthChannelSendMessage(channelId, data, len);
151 break;
152 case CHANNEL_TYPE_PROXY:
153 ret = TransProxyChannelSendMessage(channelId, data, len);
154 break;
155 case CHANNEL_TYPE_TCP_DIRECT:
156 ret = TransTdcSendMessage(channelId, data, len);
157 break;
158 default:
159 TRANS_LOGE(TRANS_MSG, "Invalid channelType=%{public}d", channelType);
160 return SOFTBUS_TRANS_CHANNEL_TYPE_INVALID;
161 }
162 return ret;
163 }
164
ClientTransChannelSendStream(int32_t channelId,int32_t channelType,const StreamData * data,const StreamData * ext,const StreamFrameInfo * param)165 int32_t ClientTransChannelSendStream(int32_t channelId, int32_t channelType, const StreamData *data,
166 const StreamData *ext, const StreamFrameInfo *param)
167 {
168 if ((data == NULL) || (ext == NULL) || (param == NULL)) {
169 TRANS_LOGW(TRANS_STREAM, "Invalid param");
170 return SOFTBUS_INVALID_PARAM;
171 }
172
173 int32_t ret = SOFTBUS_OK;
174 switch (channelType) {
175 case CHANNEL_TYPE_UDP:
176 ret = TransUdpChannelSendStream(channelId, data, ext, param);
177 break;
178 default:
179 TRANS_LOGE(TRANS_STREAM, "unsupport channelType=%{public}d.", channelType);
180 return SOFTBUS_TRANS_CHANNEL_TYPE_INVALID;
181 }
182 return ret;
183 }
184
ClientTransChannelSendFile(int32_t channelId,int32_t channelType,const char * sFileList[],const char * dFileList[],uint32_t fileCnt)185 int32_t ClientTransChannelSendFile(int32_t channelId, int32_t channelType, const char *sFileList[],
186 const char *dFileList[], uint32_t fileCnt)
187 {
188 int32_t ret = SOFTBUS_OK;
189 switch (channelType) {
190 case CHANNEL_TYPE_UDP:
191 ret = TransUdpChannelSendFile(channelId, sFileList, dFileList, fileCnt);
192 break;
193 case CHANNEL_TYPE_PROXY:
194 ret = TransProxyChannelSendFile(channelId, sFileList, dFileList, fileCnt);
195 break;
196 default:
197 TRANS_LOGE(TRANS_FILE, "unsupport channelType=%{public}d.", channelType);
198 return SOFTBUS_TRANS_CHANNEL_TYPE_INVALID;
199 }
200 return ret;
201 }
202
DeleteFileListener(const char * sessionName)203 void DeleteFileListener(const char *sessionName)
204 {
205 TransUdpDeleteFileListener(sessionName);
206 }
207
ClientGetSessionKey(int32_t channelId,char * key,unsigned int len)208 int32_t ClientGetSessionKey(int32_t channelId, char *key, unsigned int len)
209 {
210 return TransTdcGetSessionKey(channelId, key, len);
211 }
212
ClientGetHandle(int32_t channelId,int * handle)213 int32_t ClientGetHandle(int32_t channelId, int *handle)
214 {
215 return TransTdcGetHandle(channelId, handle);
216 }
217
ClientDisableSessionListener(int32_t channelId)218 int32_t ClientDisableSessionListener(int32_t channelId)
219 {
220 return TransDisableSessionListener(channelId);
221 }