mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 00:52:33 +00:00 
			
		
		
		
	 aafc451016
			
		
	
	
		aafc451016
		
	
	
	
	
		
			
			This commit converts TLS::TLSv12 to a Core::Stream object, and in the process allows TLS to now wrap other Core::Stream::Socket objects. As a large part of LibHTTP and LibGemini depend on LibTLS's interface, this also converts those to support Core::Stream, which leads to a simplification of LibHTTP (as there's no need to care about the underlying socket type anymore). Note that RequestServer now controls the TLS socket options, which is a better place anyway, as RS is the first receiver of the user-requested options (though this is currently not particularly useful).
		
			
				
	
	
		
			99 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Badge.h>
 | |
| #include <AK/ByteBuffer.h>
 | |
| #include <AK/FileStream.h>
 | |
| #include <AK/Function.h>
 | |
| #include <AK/MemoryStream.h>
 | |
| #include <AK/RefCounted.h>
 | |
| #include <AK/String.h>
 | |
| #include <AK/WeakPtr.h>
 | |
| #include <LibCore/Notifier.h>
 | |
| #include <LibCore/Stream.h>
 | |
| #include <LibIPC/Forward.h>
 | |
| 
 | |
| namespace Protocol {
 | |
| 
 | |
| class RequestClient;
 | |
| 
 | |
| class Request : public RefCounted<Request> {
 | |
| public:
 | |
|     struct CertificateAndKey {
 | |
|         String certificate;
 | |
|         String key;
 | |
|     };
 | |
| 
 | |
|     static NonnullRefPtr<Request> create_from_id(Badge<RequestClient>, RequestClient& client, i32 request_id)
 | |
|     {
 | |
|         return adopt_ref(*new Request(client, request_id));
 | |
|     }
 | |
| 
 | |
|     int id() const { return m_request_id; }
 | |
|     int fd() const { return m_fd; }
 | |
|     bool stop();
 | |
| 
 | |
|     void stream_into(OutputStream&);
 | |
|     void stream_into(Core::Stream::Stream&);
 | |
| 
 | |
|     bool should_buffer_all_input() const { return m_should_buffer_all_input; }
 | |
|     /// Note: Will override `on_finish', and `on_headers_received', and expects `on_buffered_request_finish' to be set!
 | |
|     void set_should_buffer_all_input(bool);
 | |
| 
 | |
|     /// Note: Must be set before `set_should_buffer_all_input(true)`.
 | |
|     Function<void(bool success, u32 total_size, const HashMap<String, String, CaseInsensitiveStringTraits>& response_headers, Optional<u32> response_code, ReadonlyBytes payload)> on_buffered_request_finish;
 | |
|     Function<void(bool success, u32 total_size)> on_finish;
 | |
|     Function<void(Optional<u32> total_size, u32 downloaded_size)> on_progress;
 | |
|     Function<void(const HashMap<String, String, CaseInsensitiveStringTraits>& response_headers, Optional<u32> response_code)> on_headers_received;
 | |
|     Function<CertificateAndKey()> on_certificate_requested;
 | |
| 
 | |
|     void did_finish(Badge<RequestClient>, bool success, u32 total_size);
 | |
|     void did_progress(Badge<RequestClient>, Optional<u32> total_size, u32 downloaded_size);
 | |
|     void did_receive_headers(Badge<RequestClient>, const HashMap<String, String, CaseInsensitiveStringTraits>& response_headers, Optional<u32> response_code);
 | |
|     void did_request_certificates(Badge<RequestClient>);
 | |
| 
 | |
|     RefPtr<Core::Notifier>& write_notifier(Badge<RequestClient>) { return m_write_notifier; }
 | |
|     void set_request_fd(Badge<RequestClient>, int fd) { m_fd = fd; }
 | |
| 
 | |
| private:
 | |
|     explicit Request(RequestClient&, i32 request_id);
 | |
|     template<typename T>
 | |
|     void stream_into_impl(T&);
 | |
| 
 | |
|     WeakPtr<RequestClient> m_client;
 | |
|     int m_request_id { -1 };
 | |
|     RefPtr<Core::Notifier> m_write_notifier;
 | |
|     int m_fd { -1 };
 | |
|     bool m_should_buffer_all_input { false };
 | |
| 
 | |
|     struct InternalBufferedData {
 | |
|         DuplexMemoryStream payload_stream;
 | |
|         HashMap<String, String, CaseInsensitiveStringTraits> response_headers;
 | |
|         Optional<u32> response_code;
 | |
|     };
 | |
| 
 | |
|     struct InternalStreamData {
 | |
|         InternalStreamData(NonnullOwnPtr<Core::Stream::Stream> stream)
 | |
|             : read_stream(move(stream))
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         NonnullOwnPtr<Core::Stream::Stream> read_stream;
 | |
|         RefPtr<Core::Notifier> read_notifier;
 | |
|         bool success;
 | |
|         u32 total_size { 0 };
 | |
|         bool request_done { false };
 | |
|         Function<void()> on_finish {};
 | |
|         bool user_finish_called { false };
 | |
|     };
 | |
| 
 | |
|     OwnPtr<InternalBufferedData> m_internal_buffered_data;
 | |
|     OwnPtr<InternalStreamData> m_internal_stream_data;
 | |
| };
 | |
| 
 | |
| }
 |