OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2017 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef CONTENT_BROWSER_APPCACHE_APPCACHE_NETWORK_SERVICE_HANDLER_ |
| 6 #define CONTENT_BROWSER_APPCACHE_APPCACHE_NETWORK_SERVICE_HANDLER_ |
| 7 |
| 8 #include <memory> |
| 9 |
| 10 #include "base/macros.h" |
| 11 #include "content/browser/appcache/appcache_service_impl.h" |
| 12 #include "content/browser/appcache/appcache_storage.h" |
| 13 #include "content/common/content_export.h" |
| 14 #include "content/common/url_loader_factory.mojom.h" |
| 15 #include "content/public/common/resource_type.h" |
| 16 |
| 17 namespace content { |
| 18 class AppCacheEntry; |
| 19 class AppCacheHost; |
| 20 class AppCacheNavigationHandleCore; |
| 21 class AppCacheStorage; |
| 22 class ResourceContext; |
| 23 struct ResourceRequest; |
| 24 |
| 25 // This class is instantiated during navigation, to check if the URL being |
| 26 // navigated to can be served out of the AppCache. |
| 27 // The AppCacheRequestHandler class provides this functionality as well. |
| 28 // However it is tightly coupled with the underlying job and the lifetime |
| 29 // of that class gets a touch complicated. The AppCacheRequestHandler is |
| 30 // generally associated with a request and it dies when the request goes away. |
| 31 // For this case, we are just checking if the URL can be served out of the |
| 32 // cache. If yes, then the plan is to create a URLLoaderFactory which can serve |
| 33 // URL requests from the cache. |
| 34 // TODO(ananta) |
| 35 // Look into whether we can get rid of this class when the overall picture of |
| 36 // how AppCache interacts with the network service gets clearer. |
| 37 class CONTENT_EXPORT AppCacheNetworkServiceHandler |
| 38 : public AppCacheStorage::Delegate { |
| 39 public: |
| 40 AppCacheNetworkServiceHandler( |
| 41 std::unique_ptr<ResourceRequest> resource_request, |
| 42 AppCacheNavigationHandleCore* navigation_handle_core, |
| 43 base::Callback<void(mojom::URLLoaderFactoryPtrInfo, |
| 44 std::unique_ptr<ResourceRequest>)> callback); |
| 45 |
| 46 ~AppCacheNetworkServiceHandler() override; |
| 47 |
| 48 // Called to start the process of looking up the URL in the AppCache |
| 49 // database, |
| 50 void Start(); |
| 51 |
| 52 // AppCacheStorage::Delegate methods |
| 53 // The AppCacheNetworkServiceHandler instance is deleted on return from this |
| 54 // function. |
| 55 void OnMainResponseFound(const GURL& url, |
| 56 const AppCacheEntry& entry, |
| 57 const GURL& fallback_url, |
| 58 const AppCacheEntry& fallback_entry, |
| 59 int64_t cache_id, |
| 60 int64_t group_id, |
| 61 const GURL& mainfest_url) override; |
| 62 |
| 63 private: |
| 64 std::unique_ptr<ResourceRequest> resource_request_; |
| 65 |
| 66 // Callback to invoke when we make a determination on whether the request is |
| 67 // to be served from the cache or network. |
| 68 base::Callback<void(mojom::URLLoaderFactoryPtrInfo, |
| 69 std::unique_ptr<ResourceRequest>)> callback_; |
| 70 |
| 71 AppCacheStorage* storage_; |
| 72 |
| 73 // The precreated host pointer from the AppCacheNavigationHandleCore class. |
| 74 // The ownership of this pointer stays with the AppCacheNavigationHandleCore |
| 75 // class. |
| 76 AppCacheHost* host_; |
| 77 |
| 78 DISALLOW_COPY_AND_ASSIGN(AppCacheNetworkServiceHandler); |
| 79 }; |
| 80 |
| 81 } // namespace content |
| 82 |
| 83 #endif // CONTENT_BROWSER_APPCACHE_APPCACHE_NETWORK_SERVICE_HANDLER_ |
OLD | NEW |