RequestClient.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /*
  2. * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibProtocol/Request.h>
  7. #include <LibProtocol/RequestClient.h>
  8. namespace Protocol {
  9. RequestClient::RequestClient(NonnullOwnPtr<Core::LocalSocket> socket)
  10. : IPC::ConnectionToServer<RequestClientEndpoint, RequestServerEndpoint>(*this, move(socket))
  11. {
  12. }
  13. void RequestClient::ensure_connection(URL const& url, ::RequestServer::CacheLevel cache_level)
  14. {
  15. async_ensure_connection(url, cache_level);
  16. }
  17. template<typename RequestHashMapTraits>
  18. RefPtr<Request> RequestClient::start_request(ByteString const& method, URL const& url, HashMap<ByteString, ByteString, RequestHashMapTraits> const& request_headers, ReadonlyBytes request_body, Core::ProxyData const& proxy_data)
  19. {
  20. auto headers_or_error = request_headers.template clone<Traits<ByteString>>();
  21. if (headers_or_error.is_error())
  22. return nullptr;
  23. auto body_result = ByteBuffer::copy(request_body);
  24. if (body_result.is_error())
  25. return nullptr;
  26. auto maybe_response = IPCProxy::try_start_request(method, url, headers_or_error.release_value(), body_result.release_value(), proxy_data);
  27. if (maybe_response.is_error())
  28. return nullptr;
  29. auto response = maybe_response.release_value();
  30. auto request_id = response.request_id();
  31. if (request_id < 0 || !response.response_fd().has_value())
  32. return nullptr;
  33. auto response_fd = response.response_fd().value().take_fd();
  34. auto request = Request::create_from_id({}, *this, request_id);
  35. request->set_request_fd({}, response_fd);
  36. m_requests.set(request_id, request);
  37. return request;
  38. }
  39. bool RequestClient::stop_request(Badge<Request>, Request& request)
  40. {
  41. if (!m_requests.contains(request.id()))
  42. return false;
  43. return IPCProxy::stop_request(request.id());
  44. }
  45. bool RequestClient::set_certificate(Badge<Request>, Request& request, ByteString certificate, ByteString key)
  46. {
  47. if (!m_requests.contains(request.id()))
  48. return false;
  49. return IPCProxy::set_certificate(request.id(), move(certificate), move(key));
  50. }
  51. void RequestClient::request_finished(i32 request_id, bool success, u64 total_size)
  52. {
  53. RefPtr<Request> request;
  54. if ((request = m_requests.get(request_id).value_or(nullptr))) {
  55. request->did_finish({}, success, total_size);
  56. }
  57. m_requests.remove(request_id);
  58. }
  59. void RequestClient::request_progress(i32 request_id, Optional<u64> const& total_size, u64 downloaded_size)
  60. {
  61. if (auto request = const_cast<Request*>(m_requests.get(request_id).value_or(nullptr))) {
  62. request->did_progress({}, total_size, downloaded_size);
  63. }
  64. }
  65. void RequestClient::headers_became_available(i32 request_id, HashMap<ByteString, ByteString, CaseInsensitiveStringTraits> const& response_headers, Optional<u32> const& status_code)
  66. {
  67. auto request = const_cast<Request*>(m_requests.get(request_id).value_or(nullptr));
  68. if (!request) {
  69. warnln("Received headers for non-existent request {}", request_id);
  70. return;
  71. }
  72. auto response_headers_clone_or_error = response_headers.clone();
  73. if (response_headers_clone_or_error.is_error()) {
  74. warnln("Error while receiving headers for request {}: {}", request_id, response_headers_clone_or_error.error());
  75. return;
  76. }
  77. request->did_receive_headers({}, response_headers_clone_or_error.release_value(), status_code);
  78. }
  79. void RequestClient::certificate_requested(i32 request_id)
  80. {
  81. if (auto request = const_cast<Request*>(m_requests.get(request_id).value_or(nullptr))) {
  82. request->did_request_certificates({});
  83. }
  84. }
  85. }
  86. template RefPtr<Protocol::Request> Protocol::RequestClient::start_request(ByteString const& method, URL const&, HashMap<ByteString, ByteString> const& request_headers, ReadonlyBytes request_body, Core::ProxyData const&);
  87. template RefPtr<Protocol::Request> Protocol::RequestClient::start_request(ByteString const& method, URL const&, HashMap<ByteString, ByteString, CaseInsensitiveStringTraits> const& request_headers, ReadonlyBytes request_body, Core::ProxyData const&);