LibWeb: Set Cookie header on <img> and <object> resource requests

This required passing a reference to the owning HTML*Element to
ImageLoader, the same way that CSSLoader has a reference to its owner.
This commit is contained in:
Timothy Flynn 2021-04-14 10:39:12 -04:00 committed by Andreas Kling
parent 347838a240
commit 0cacc52990
4 changed files with 12 additions and 5 deletions

View file

@ -38,6 +38,7 @@ namespace Web::HTML {
HTMLImageElement::HTMLImageElement(DOM::Document& document, QualifiedName qualified_name) HTMLImageElement::HTMLImageElement(DOM::Document& document, QualifiedName qualified_name)
: HTMLElement(document, move(qualified_name)) : HTMLElement(document, move(qualified_name))
, m_image_loader(*this)
{ {
m_image_loader.on_load = [this] { m_image_loader.on_load = [this] {
this->document().update_layout(); this->document().update_layout();

View file

@ -36,6 +36,7 @@ namespace Web::HTML {
HTMLObjectElement::HTMLObjectElement(DOM::Document& document, QualifiedName qualified_name) HTMLObjectElement::HTMLObjectElement(DOM::Document& document, QualifiedName qualified_name)
: HTMLElement(document, move(qualified_name)) : HTMLElement(document, move(qualified_name))
, m_image_loader(*this)
{ {
m_image_loader.on_load = [this] { m_image_loader.on_load = [this] {
m_should_show_fallback_content = false; m_should_show_fallback_content = false;

View file

@ -27,21 +27,24 @@
#include <AK/Debug.h> #include <AK/Debug.h>
#include <LibCore/Timer.h> #include <LibCore/Timer.h>
#include <LibGfx/Bitmap.h> #include <LibGfx/Bitmap.h>
#include <LibWeb/DOM/Document.h>
#include <LibWeb/DOM/Element.h>
#include <LibWeb/Loader/ImageLoader.h> #include <LibWeb/Loader/ImageLoader.h>
#include <LibWeb/Loader/ResourceLoader.h> #include <LibWeb/Loader/ResourceLoader.h>
namespace Web { namespace Web {
ImageLoader::ImageLoader() ImageLoader::ImageLoader(DOM::Element& owner_element)
: m_timer(Core::Timer::construct()) : m_owner_element(owner_element)
, m_timer(Core::Timer::construct())
{ {
} }
void ImageLoader::load(const URL& url) void ImageLoader::load(const URL& url)
{ {
m_loading_state = LoadingState::Loading; m_loading_state = LoadingState::Loading;
LoadRequest request;
request.set_url(url); auto request = LoadRequest::create_for_url_on_page(url, m_owner_element.document().page());
set_resource(ResourceLoader::the().load_resource(Resource::Type::Image, request)); set_resource(ResourceLoader::the().load_resource(Resource::Type::Image, request));
} }

View file

@ -34,7 +34,7 @@ namespace Web {
class ImageLoader : public ImageResourceClient { class ImageLoader : public ImageResourceClient {
public: public:
ImageLoader(); ImageLoader(DOM::Element& owner_element);
void load(const URL&); void load(const URL&);
@ -69,6 +69,8 @@ private:
Failed, Failed,
}; };
DOM::Element& m_owner_element;
mutable bool m_visible_in_viewport { false }; mutable bool m_visible_in_viewport { false };
size_t m_current_frame_index { 0 }; size_t m_current_frame_index { 0 };