Resource.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/ByteBuffer.h>
  8. #include <AK/HashMap.h>
  9. #include <AK/HashTable.h>
  10. #include <AK/Noncopyable.h>
  11. #include <AK/RefCounted.h>
  12. #include <AK/URL.h>
  13. #include <AK/WeakPtr.h>
  14. #include <AK/Weakable.h>
  15. #include <LibGfx/Forward.h>
  16. #include <LibWeb/Forward.h>
  17. #include <LibWeb/Loader/LoadRequest.h>
  18. namespace Web {
  19. class ResourceClient;
  20. class Resource : public RefCounted<Resource> {
  21. AK_MAKE_NONCOPYABLE(Resource);
  22. AK_MAKE_NONMOVABLE(Resource);
  23. public:
  24. enum class Type {
  25. Generic,
  26. Image,
  27. };
  28. static NonnullRefPtr<Resource> create(Badge<ResourceLoader>, Type, const LoadRequest&);
  29. virtual ~Resource();
  30. Type type() const { return m_type; }
  31. bool is_loaded() const { return m_loaded; }
  32. bool is_failed() const { return m_failed; }
  33. const String& error() const { return m_error; }
  34. bool has_encoded_data() const { return !m_encoded_data.is_empty(); }
  35. const AK::URL& url() const { return m_request.url(); }
  36. const ByteBuffer& encoded_data() const { return m_encoded_data; }
  37. const HashMap<String, String, CaseInsensitiveStringTraits>& response_headers() const { return m_response_headers; }
  38. [[nodiscard]] Optional<u32> status_code() const { return m_status_code; }
  39. void register_client(Badge<ResourceClient>, ResourceClient&);
  40. void unregister_client(Badge<ResourceClient>, ResourceClient&);
  41. bool has_encoding() const { return m_encoding.has_value(); }
  42. const Optional<String>& encoding() const { return m_encoding; }
  43. const String& mime_type() const { return m_mime_type; }
  44. void for_each_client(Function<void(ResourceClient&)>);
  45. void did_load(Badge<ResourceLoader>, ReadonlyBytes data, const HashMap<String, String, CaseInsensitiveStringTraits>& headers, Optional<u32> status_code);
  46. void did_fail(Badge<ResourceLoader>, const String& error, Optional<u32> status_code);
  47. protected:
  48. explicit Resource(Type, const LoadRequest&);
  49. Resource(Type, Resource&);
  50. private:
  51. LoadRequest m_request;
  52. ByteBuffer m_encoded_data;
  53. Type m_type { Type::Generic };
  54. bool m_loaded { false };
  55. bool m_failed { false };
  56. String m_error;
  57. Optional<String> m_encoding;
  58. String m_mime_type;
  59. HashMap<String, String, CaseInsensitiveStringTraits> m_response_headers;
  60. Optional<u32> m_status_code;
  61. HashTable<ResourceClient*> m_clients;
  62. };
  63. class ResourceClient : public Weakable<ResourceClient> {
  64. public:
  65. virtual ~ResourceClient();
  66. virtual void resource_did_load() { }
  67. virtual void resource_did_fail() { }
  68. protected:
  69. virtual Resource::Type client_type() const { return Resource::Type::Generic; }
  70. Resource* resource() { return m_resource; }
  71. const Resource* resource() const { return m_resource; }
  72. void set_resource(Resource*);
  73. private:
  74. RefPtr<Resource> m_resource;
  75. };
  76. }