WebDriverConnection.cpp 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (c) 2022, Florent Castelli <florent.castelli@gmail.com>
  3. * Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org>
  4. * Copyright (c) 2022, Tobias Christiansen <tobyase@serenityos.org>
  5. * Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
  6. *
  7. * SPDX-License-Identifier: BSD-2-Clause
  8. */
  9. #include "WebDriverConnection.h"
  10. #include "BrowserWindow.h"
  11. #include <AK/Vector.h>
  12. #include <LibWeb/Cookie/Cookie.h>
  13. #include <LibWeb/Cookie/ParsedCookie.h>
  14. #include <LibWebView/WebContentClient.h>
  15. namespace Browser {
  16. WebDriverConnection::WebDriverConnection(NonnullOwnPtr<Core::Stream::LocalSocket> socket, NonnullRefPtr<BrowserWindow> browser_window)
  17. : IPC::ConnectionToServer<WebDriverSessionClientEndpoint, WebDriverSessionServerEndpoint>(*this, move(socket))
  18. , m_browser_window(move(browser_window))
  19. {
  20. }
  21. void WebDriverConnection::quit()
  22. {
  23. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: quit");
  24. if (auto browser_window = m_browser_window.strong_ref())
  25. browser_window->close();
  26. }
  27. Messages::WebDriverSessionClient::GetTitleResponse WebDriverConnection::get_title()
  28. {
  29. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: get_title");
  30. if (auto browser_window = m_browser_window.strong_ref())
  31. return { browser_window->active_tab().title() };
  32. return { "" };
  33. }
  34. void WebDriverConnection::refresh()
  35. {
  36. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: refresh");
  37. if (auto browser_window = m_browser_window.strong_ref())
  38. browser_window->active_tab().reload();
  39. }
  40. void WebDriverConnection::back()
  41. {
  42. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: back");
  43. if (auto browser_window = m_browser_window.strong_ref())
  44. browser_window->active_tab().go_back();
  45. }
  46. void WebDriverConnection::forward()
  47. {
  48. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: forward");
  49. if (auto browser_window = m_browser_window.strong_ref())
  50. browser_window->active_tab().go_forward();
  51. }
  52. Messages::WebDriverSessionClient::GetAllCookiesResponse WebDriverConnection::get_all_cookies()
  53. {
  54. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: get_cookies");
  55. if (auto browser_window = m_browser_window.strong_ref()) {
  56. if (browser_window->active_tab().on_get_cookies_entries) {
  57. return { browser_window->active_tab().on_get_cookies_entries() };
  58. }
  59. }
  60. return { {} };
  61. }
  62. void WebDriverConnection::add_cookie(Web::Cookie::ParsedCookie const& cookie)
  63. {
  64. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: add_cookie {}", cookie.name);
  65. if (auto browser_window = m_browser_window.strong_ref()) {
  66. auto& tab = browser_window->active_tab();
  67. if (tab.on_set_cookie) {
  68. // FIXME: The spec doesn't say anything about the source
  69. // but can we assume a cookie created through a HTTP-request to the WebDriver
  70. // to be (source) from an HTTP-API?
  71. tab.on_set_cookie(tab.url(), cookie, Web::Cookie::Source::Http);
  72. }
  73. }
  74. }
  75. void WebDriverConnection::update_cookie(Web::Cookie::Cookie const& cookie)
  76. {
  77. dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: update_cookie {}", cookie.name);
  78. if (auto browser_window = m_browser_window.strong_ref()) {
  79. auto& tab = browser_window->active_tab();
  80. if (tab.on_update_cookie) {
  81. tab.on_update_cookie(tab.url(), cookie);
  82. }
  83. }
  84. }
  85. }