mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 14:52:06 +00:00 
			
		
		
		
	 d5871f5717
			
		
	
	
		d5871f5717
		
	
	
	
	
		
			
			Similar to POSIX read, the basic read and write functions of AK::Stream do not have a lower limit of how much data they read or write (apart from "none at all"). Rename the functions to "read some [data]" and "write some [data]" (with "data" being omitted, since everything here is reading and writing data) to make them sufficiently distinct from the functions that ensure to use the entire buffer (which should be the go-to function for most usages). No functional changes, just a lot of new FIXMEs.
		
			
				
	
	
		
			64 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Ali Mohammad Pur <mpfard@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/OwnPtr.h>
 | |
| #include <LibCore/Proxy.h>
 | |
| #include <LibCore/Socket.h>
 | |
| 
 | |
| namespace Core {
 | |
| class SOCKSProxyClient final : public Socket {
 | |
| public:
 | |
|     enum class Version : u8 {
 | |
|         V4 = 0x04,
 | |
|         V5 = 0x05,
 | |
|     };
 | |
| 
 | |
|     struct UsernamePasswordAuthenticationData {
 | |
|         DeprecatedString username;
 | |
|         DeprecatedString password;
 | |
|     };
 | |
| 
 | |
|     enum class Command : u8 {
 | |
|         Connect = 0x01,
 | |
|         Bind = 0x02,
 | |
|         UDPAssociate = 0x03,
 | |
|     };
 | |
| 
 | |
|     using HostOrIPV4 = Variant<DeprecatedString, u32>;
 | |
| 
 | |
|     static ErrorOr<NonnullOwnPtr<SOCKSProxyClient>> connect(Socket& underlying, Version, HostOrIPV4 const& target, int target_port, Variant<UsernamePasswordAuthenticationData, Empty> const& auth_data = {}, Command = Command::Connect);
 | |
|     static ErrorOr<NonnullOwnPtr<SOCKSProxyClient>> connect(HostOrIPV4 const& server, int server_port, Version, HostOrIPV4 const& target, int target_port, Variant<UsernamePasswordAuthenticationData, Empty> const& auth_data = {}, Command = Command::Connect);
 | |
| 
 | |
|     virtual ~SOCKSProxyClient() override;
 | |
| 
 | |
|     // ^Stream::Stream
 | |
|     virtual ErrorOr<Bytes> read_some(Bytes bytes) override { return m_socket.read_some(bytes); }
 | |
|     virtual ErrorOr<size_t> write_some(ReadonlyBytes bytes) override { return m_socket.write_some(bytes); }
 | |
|     virtual bool is_eof() const override { return m_socket.is_eof(); }
 | |
|     virtual bool is_open() const override { return m_socket.is_open(); }
 | |
|     virtual void close() override { m_socket.close(); }
 | |
| 
 | |
|     // ^Stream::Socket
 | |
|     virtual ErrorOr<size_t> pending_bytes() const override { return m_socket.pending_bytes(); }
 | |
|     virtual ErrorOr<bool> can_read_without_blocking(int timeout = 0) const override { return m_socket.can_read_without_blocking(timeout); }
 | |
|     virtual ErrorOr<void> set_blocking(bool enabled) override { return m_socket.set_blocking(enabled); }
 | |
|     virtual ErrorOr<void> set_close_on_exec(bool enabled) override { return m_socket.set_close_on_exec(enabled); }
 | |
|     virtual void set_notifications_enabled(bool enabled) override { m_socket.set_notifications_enabled(enabled); }
 | |
| 
 | |
| private:
 | |
|     SOCKSProxyClient(Socket& socket, OwnPtr<Socket> own_socket)
 | |
|         : m_socket(socket)
 | |
|         , m_own_underlying_socket(move(own_socket))
 | |
|     {
 | |
|         m_socket.on_ready_to_read = [this] { on_ready_to_read(); };
 | |
|     }
 | |
| 
 | |
|     Socket& m_socket;
 | |
|     OwnPtr<Socket> m_own_underlying_socket;
 | |
| };
 | |
| }
 |