mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-24 18:24:45 -05:00
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).
43 lines
1.2 KiB
C++
43 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) 2020, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include "ConnectionCache.h"
|
|
#include <LibGemini/GeminiRequest.h>
|
|
#include <LibGemini/Job.h>
|
|
#include <RequestServer/GeminiProtocol.h>
|
|
#include <RequestServer/GeminiRequest.h>
|
|
|
|
namespace RequestServer {
|
|
|
|
GeminiProtocol::GeminiProtocol()
|
|
: Protocol("gemini")
|
|
{
|
|
}
|
|
|
|
GeminiProtocol::~GeminiProtocol()
|
|
{
|
|
}
|
|
|
|
OwnPtr<Request> GeminiProtocol::start_request(ClientConnection& client, const String&, const URL& url, const HashMap<String, String>&, ReadonlyBytes)
|
|
{
|
|
Gemini::GeminiRequest request;
|
|
request.set_url(url);
|
|
|
|
auto pipe_result = get_pipe_for_request();
|
|
if (pipe_result.is_error())
|
|
return {};
|
|
|
|
auto output_stream = MUST(Core::Stream::File::adopt_fd(pipe_result.value().write_fd, Core::Stream::OpenMode::Write));
|
|
auto job = Gemini::Job::construct(request, *output_stream);
|
|
auto protocol_request = GeminiRequest::create_with_job({}, client, *job, move(output_stream));
|
|
protocol_request->set_request_fd(pipe_result.value().read_fd);
|
|
|
|
ConnectionCache::get_or_create_connection(ConnectionCache::g_tls_connection_cache, url, *job);
|
|
|
|
return protocol_request;
|
|
}
|
|
|
|
}
|