2011-07-03 09:50:11 +08:00
|
|
|
/**
|
2012-10-08 23:02:04 -04:00
|
|
|
* FreeRDP: A Remote Desktop Protocol Implementation
|
2011-07-03 09:50:11 +08:00
|
|
|
* Network Transport Layer
|
|
|
|
|
*
|
|
|
|
|
* Copyright 2011 Vic Lee
|
|
|
|
|
*
|
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-06-06 14:01:41 +02:00
|
|
|
#ifndef FREERDP_LIB_CORE_TRANSPORT_H
|
|
|
|
|
#define FREERDP_LIB_CORE_TRANSPORT_H
|
2011-07-03 09:50:11 +08:00
|
|
|
|
2011-07-10 15:34:43 -04:00
|
|
|
typedef enum
|
|
|
|
|
{
|
|
|
|
|
TRANSPORT_LAYER_TCP,
|
2011-08-25 13:30:17 +08:00
|
|
|
TRANSPORT_LAYER_TLS,
|
2023-09-22 22:13:54 +02:00
|
|
|
TRANSPORT_LAYER_NAMEDPIPE,
|
2012-03-26 12:20:38 -04:00
|
|
|
TRANSPORT_LAYER_TSG,
|
2013-10-11 06:12:50 -04:00
|
|
|
TRANSPORT_LAYER_TSG_TLS,
|
2011-08-25 13:30:17 +08:00
|
|
|
TRANSPORT_LAYER_CLOSED
|
2011-07-10 15:34:43 -04:00
|
|
|
} TRANSPORT_LAYER;
|
|
|
|
|
|
2011-07-03 15:34:15 -04:00
|
|
|
#include "tcp.h"
|
2012-11-14 21:19:17 -05:00
|
|
|
#include "nla.h"
|
2023-03-07 11:58:28 +01:00
|
|
|
#include "rdstls.h"
|
2012-05-04 19:48:53 -04:00
|
|
|
|
2012-12-12 23:18:20 -05:00
|
|
|
#include "gateway/tsg.h"
|
|
|
|
|
|
2012-05-04 19:48:53 -04:00
|
|
|
#include <winpr/sspi.h>
|
2013-10-08 23:43:57 -04:00
|
|
|
#include <winpr/wlog.h>
|
2013-03-27 13:03:41 -04:00
|
|
|
#include <winpr/synch.h>
|
|
|
|
|
#include <winpr/thread.h>
|
|
|
|
|
#include <winpr/stream.h>
|
2012-12-21 15:36:10 -05:00
|
|
|
#include <winpr/collections.h>
|
|
|
|
|
|
2016-08-10 09:12:55 +02:00
|
|
|
#include <freerdp/api.h>
|
2011-07-03 15:34:15 -04:00
|
|
|
|
2011-07-03 12:42:35 -04:00
|
|
|
#include <time.h>
|
2011-07-07 13:37:48 -04:00
|
|
|
#include <freerdp/types.h>
|
2011-07-05 23:18:00 -04:00
|
|
|
#include <freerdp/settings.h>
|
2020-09-02 11:37:04 +00:00
|
|
|
#include <freerdp/transport_io.h>
|
2013-03-21 16:45:25 -04:00
|
|
|
|
2022-11-11 12:26:28 +01:00
|
|
|
#include "state.h"
|
|
|
|
|
|
|
|
|
|
typedef state_run_t (*TransportRecv)(rdpTransport* transport, wStream* stream, void* extra);
|
2011-07-03 09:50:11 +08:00
|
|
|
|
2026-01-26 13:08:35 +01:00
|
|
|
WINPR_ATTR_MALLOC(Stream_Release, 1)
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-03 08:00:24 +02:00
|
|
|
FREERDP_LOCAL wStream* transport_send_stream_init(rdpTransport* transport, size_t size);
|
2026-01-26 13:08:35 +01:00
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2019-11-06 15:24:51 +01:00
|
|
|
FREERDP_LOCAL BOOL transport_connect(rdpTransport* transport, const char* hostname, UINT16 port,
|
2020-06-17 08:41:21 +02:00
|
|
|
DWORD timeout);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2023-09-22 22:13:54 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_childsession(rdpTransport* transport);
|
2024-02-23 10:42:18 +01:00
|
|
|
|
|
|
|
|
/**! \brief Attach a socket to the transport layer
|
|
|
|
|
*
|
|
|
|
|
* The ownership of the socket provided by \b sockfd is taken if and only if the function is
|
|
|
|
|
* successful. In such a case the caller must no longer close or otherwise use the socket. If the
|
|
|
|
|
* function fails it is up to the caller to close the socket.
|
|
|
|
|
*
|
|
|
|
|
* The implementation can be overridden by
|
|
|
|
|
* transport_set_io_callbacks(rdpTransportIo::TransportAttach)
|
|
|
|
|
*
|
|
|
|
|
* \param transport The transport instance to attach the socket to
|
|
|
|
|
* \param sockfd The socket to attach to the transport
|
|
|
|
|
*
|
|
|
|
|
* \return \b TRUE in case of success, \b FALSE otherwise.
|
|
|
|
|
*/
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_attach(rdpTransport* transport, int sockfd);
|
2024-09-05 20:59:21 +08:00
|
|
|
|
|
|
|
|
/**! \brief Attach a transport layer
|
|
|
|
|
*
|
|
|
|
|
* The ownership of the transport layer provided by \b layer is taken if and only if the function is
|
|
|
|
|
* successful. In such a case the caller must no longer free or otherwise use the layer. If the
|
|
|
|
|
* function fails it is up to the caller to free the layer.
|
|
|
|
|
*
|
|
|
|
|
* The implementation can be overridden by
|
|
|
|
|
* transport_set_io_callbacks(rdpTransportIo::AttachLayer)
|
|
|
|
|
*
|
|
|
|
|
* \param transport The transport instance to attach the socket to
|
|
|
|
|
* \param layer The layer to attach to the transport
|
|
|
|
|
*
|
|
|
|
|
* \return \b TRUE in case of success, \b FALSE otherwise.
|
|
|
|
|
*/
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2024-09-05 20:59:21 +08:00
|
|
|
FREERDP_LOCAL BOOL transport_attach_layer(rdpTransport* transport, rdpTransportLayer* layer);
|
|
|
|
|
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_disconnect(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_rdp(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_tls(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2023-06-23 00:49:27 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_nla(rdpTransport* transport, BOOL earlyUserAuth);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2023-03-07 11:58:28 +01:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_rdstls(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2023-03-07 20:06:47 -05:00
|
|
|
FREERDP_LOCAL BOOL transport_connect_aad(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_accept_rdp(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_accept_tls(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_accept_nla(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2023-03-07 11:58:28 +01:00
|
|
|
FREERDP_LOCAL BOOL transport_accept_rdstls(rdpTransport* transport);
|
2018-08-22 13:40:41 +02:00
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL int transport_read_pdu(rdpTransport* transport, wStream* s);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL int transport_write(rdpTransport* transport, wStream* s);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2024-01-03 00:00:14 +08:00
|
|
|
FREERDP_LOCAL BOOL transport_get_public_key(rdpTransport* transport, const BYTE** data,
|
|
|
|
|
DWORD* length);
|
|
|
|
|
|
2021-08-24 15:04:58 +02:00
|
|
|
#if defined(WITH_FREERDP_DEPRECATED)
|
2019-11-06 15:24:51 +01:00
|
|
|
FREERDP_LOCAL void transport_get_fds(rdpTransport* transport, void** rfds, int* rcount);
|
2021-08-24 15:04:58 +02:00
|
|
|
#endif
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL int transport_check_fds(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2019-11-06 15:24:51 +01:00
|
|
|
FREERDP_LOCAL DWORD transport_get_event_handles(rdpTransport* transport, HANDLE* events,
|
|
|
|
|
DWORD nCount);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL HANDLE transport_get_front_bio(rdpTransport* transport);
|
2016-08-10 09:12:55 +02:00
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2019-11-06 15:24:51 +01:00
|
|
|
FREERDP_LOCAL BOOL transport_set_blocking_mode(rdpTransport* transport, BOOL blocking);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
2019-11-06 15:24:51 +01:00
|
|
|
FREERDP_LOCAL void transport_set_gateway_enabled(rdpTransport* transport, BOOL GatewayEnabled);
|
|
|
|
|
FREERDP_LOCAL void transport_set_nla_mode(rdpTransport* transport, BOOL NlaMode);
|
2023-03-07 11:58:28 +01:00
|
|
|
FREERDP_LOCAL void transport_set_rdstls_mode(rdpTransport* transport, BOOL RdstlsMode);
|
2023-03-07 20:06:47 -05:00
|
|
|
FREERDP_LOCAL void transport_set_aad_mode(rdpTransport* transport, BOOL AadMode);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_is_write_blocked(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL int transport_drain_output_buffer(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2022-11-15 15:04:13 +01:00
|
|
|
FREERDP_LOCAL BOOL transport_io_callback_set_event(rdpTransport* transport, BOOL set);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2025-09-26 10:54:46 +02:00
|
|
|
FREERDP_LOCAL const rdpTransportIo* transport_get_io_callbacks(const rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2020-09-02 11:37:04 +00:00
|
|
|
FREERDP_LOCAL BOOL transport_set_io_callbacks(rdpTransport* transport,
|
|
|
|
|
const rdpTransportIo* io_callbacks);
|
2021-09-06 11:01:36 +02:00
|
|
|
|
|
|
|
|
FREERDP_LOCAL BOOL transport_set_nla(rdpTransport* transport, rdpNla* nla);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL rdpNla* transport_get_nla(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_tls(rdpTransport* transport, rdpTls* tls);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL rdpTls* transport_get_tls(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_tsg(rdpTransport* transport, rdpTsg* tsg);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL rdpTsg* transport_get_tsg(rdpTransport* transport);
|
|
|
|
|
|
2026-01-26 13:08:35 +01:00
|
|
|
WINPR_ATTR_MALLOC(Stream_Release, 1)
|
|
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL wStream* transport_take_from_pool(rdpTransport* transport, size_t size);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2025-03-19 18:26:28 +08:00
|
|
|
FREERDP_LOCAL UINT64 transport_get_bytes_sent(rdpTransport* transport, BOOL resetCount);
|
2021-09-06 11:01:36 +02:00
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_have_more_bytes_to_read(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL TRANSPORT_LAYER transport_get_layer(rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_layer(rdpTransport* transport, TRANSPORT_LAYER layer);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2025-09-26 10:54:46 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_get_blocking(const rdpTransport* transport);
|
2026-02-24 11:28:38 +01:00
|
|
|
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_blocking(rdpTransport* transport, BOOL blocking);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_connected_event(rdpTransport* transport);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-06 11:01:36 +02:00
|
|
|
FREERDP_LOCAL BOOL transport_set_recv_callbacks(rdpTransport* transport, TransportRecv recv,
|
|
|
|
|
void* extra);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2021-09-08 15:47:03 +02:00
|
|
|
FREERDP_LOCAL int transport_tcp_connect(rdpTransport* transport, const char* hostname, int port,
|
|
|
|
|
DWORD timeout);
|
2021-09-06 11:01:36 +02:00
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2024-09-05 20:59:21 +08:00
|
|
|
FREERDP_LOCAL rdpTransportLayer*
|
|
|
|
|
transport_connect_layer(rdpTransport* transport, const char* hostname, int port, DWORD timeout);
|
|
|
|
|
|
2016-08-10 09:12:55 +02:00
|
|
|
FREERDP_LOCAL void transport_free(rdpTransport* transport);
|
2011-07-03 09:50:11 +08:00
|
|
|
|
2024-01-26 13:09:00 +01:00
|
|
|
WINPR_ATTR_MALLOC(transport_free, 1)
|
2026-01-26 13:08:35 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2024-01-26 13:09:00 +01:00
|
|
|
FREERDP_LOCAL rdpTransport* transport_new(rdpContext* context);
|
|
|
|
|
|
2023-06-23 00:49:27 +02:00
|
|
|
FREERDP_LOCAL void transport_set_early_user_auth_mode(rdpTransport* transport, BOOL EUAMode);
|
|
|
|
|
|
2026-02-24 11:28:38 +01:00
|
|
|
WINPR_ATTR_NODISCARD
|
2024-09-05 20:59:21 +08:00
|
|
|
FREERDP_LOCAL BIO_METHOD* BIO_s_transport_layer(void);
|
|
|
|
|
|
2017-06-06 14:01:41 +02:00
|
|
|
#endif /* FREERDP_LIB_CORE_TRANSPORT_H */
|