RequestClient.cpp 3.5 KB

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