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