123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- /*
- * Copyright (c) 2020, the SerenityOS developers.
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #include "ConnectionCache.h"
- #include <LibCore/EventLoop.h>
- #include <LibGemini/GeminiJob.h>
- #include <LibGemini/GeminiResponse.h>
- #include <RequestServer/GeminiRequest.h>
- namespace RequestServer {
- GeminiRequest::GeminiRequest(ClientConnection& client, NonnullRefPtr<Gemini::GeminiJob> job, NonnullOwnPtr<OutputFileStream>&& output_stream)
- : Request(client, move(output_stream))
- , m_job(job)
- {
- m_job->on_finish = [this](bool success) {
- Core::deferred_invoke([url = m_job->url(), socket = m_job->socket()] {
- ConnectionCache::request_did_finish(url, socket);
- });
- if (auto* response = m_job->response()) {
- set_downloaded_size(this->output_stream().size());
- if (!response->meta().is_empty()) {
- HashMap<String, String, CaseInsensitiveStringTraits> headers;
- headers.set("meta", response->meta());
- // Note: We're setting content-type to meta only on status==SUCCESS
- // we should perhaps have a better mechanism for this, since we
- // are already shoehorning the concept of "headers" here
- if (response->status() >= 20 && response->status() < 30) {
- headers.set("content-type", response->meta());
- }
- set_response_headers(headers);
- }
- }
- // signal 100% request progress so any listeners can react
- // appropriately
- did_progress(downloaded_size(), downloaded_size());
- did_finish(success);
- };
- m_job->on_progress = [this](Optional<u32> total, u32 current) {
- did_progress(total, current);
- };
- m_job->on_certificate_requested = [this](auto&) {
- did_request_certificates();
- };
- }
- void GeminiRequest::set_certificate(String certificate, String key)
- {
- m_job->set_certificate(move(certificate), move(key));
- }
- GeminiRequest::~GeminiRequest()
- {
- m_job->on_finish = nullptr;
- m_job->on_progress = nullptr;
- m_job->shutdown();
- }
- NonnullOwnPtr<GeminiRequest> GeminiRequest::create_with_job(Badge<GeminiProtocol>, ClientConnection& client, NonnullRefPtr<Gemini::GeminiJob> job, NonnullOwnPtr<OutputFileStream>&& output_stream)
- {
- return adopt_own(*new GeminiRequest(client, move(job), move(output_stream)));
- }
- }
|