mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 14:52:06 +00:00 
			
		
		
		
	 ff47223301
			
		
	
	
		ff47223301
		
	
	
	
	
		
			
			It used to take a plain `Socket` and cast it to a `BufferedSocketBase`, which can lead to unpleasant result when used with a non-buffered `Socket`.
		
			
				
	
	
		
			74 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  * Copyright (c) 2022, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Function.h>
 | |
| #include <AK/Stream.h>
 | |
| #include <LibCore/Forward.h>
 | |
| #include <LibCore/Object.h>
 | |
| 
 | |
| namespace Core {
 | |
| 
 | |
| class NetworkJob : public Object {
 | |
|     C_OBJECT_ABSTRACT(NetworkJob)
 | |
| public:
 | |
|     enum class Error {
 | |
|         None,
 | |
|         ConnectionFailed,
 | |
|         TransmissionFailed,
 | |
|         ProtocolFailed,
 | |
|         Cancelled,
 | |
|     };
 | |
|     virtual ~NetworkJob() override = default;
 | |
| 
 | |
|     // Could fire twice, after Headers and after Trailers!
 | |
|     Function<void(HashMap<DeprecatedString, DeprecatedString, CaseInsensitiveStringTraits> const& response_headers, Optional<u32> response_code)> on_headers_received;
 | |
|     Function<void(bool success)> on_finish;
 | |
|     Function<void(Optional<u64>, u64)> on_progress;
 | |
| 
 | |
|     bool is_cancelled() const { return m_error == Error::Cancelled; }
 | |
|     bool has_error() const { return m_error != Error::None; }
 | |
|     Error error() const { return m_error; }
 | |
|     NetworkResponse* response() { return m_response.ptr(); }
 | |
|     NetworkResponse const* response() const { return m_response.ptr(); }
 | |
| 
 | |
|     enum class ShutdownMode {
 | |
|         DetachFromSocket,
 | |
|         CloseSocket,
 | |
|     };
 | |
|     virtual void start(Core::BufferedSocketBase&) = 0;
 | |
|     virtual void shutdown(ShutdownMode) = 0;
 | |
|     virtual void fail(Error error) { did_fail(error); }
 | |
| 
 | |
|     void cancel()
 | |
|     {
 | |
|         shutdown(ShutdownMode::DetachFromSocket);
 | |
|         m_error = Error::Cancelled;
 | |
|     }
 | |
| 
 | |
| protected:
 | |
|     NetworkJob(Stream&);
 | |
|     void did_finish(NonnullRefPtr<NetworkResponse>&&);
 | |
|     void did_fail(Error);
 | |
|     void did_progress(Optional<u64> total_size, u64 downloaded);
 | |
| 
 | |
|     ErrorOr<size_t> do_write(ReadonlyBytes bytes) { return m_output_stream.write_some(bytes); }
 | |
| 
 | |
| private:
 | |
|     RefPtr<NetworkResponse> m_response;
 | |
|     Stream& m_output_stream;
 | |
|     Error m_error { Error::None };
 | |
| };
 | |
| 
 | |
| char const* to_string(NetworkJob::Error);
 | |
| 
 | |
| }
 | |
| 
 | |
| template<>
 | |
| struct AK::Formatter<Core::NetworkJob> : Formatter<Core::Object> {
 | |
| };
 |