Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1159)

Side by Side Diff: content/browser/service_worker/service_worker_request_handler.h

Issue 2886843006: servificied service worker interception
Patch Set: Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_ 5 #ifndef CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_
6 #define CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_ 6 #define CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/callback_forward.h" 10 #include "base/callback_forward.h"
(...skipping 16 matching lines...) Expand all
27 class URLRequestInterceptor; 27 class URLRequestInterceptor;
28 } 28 }
29 29
30 namespace storage { 30 namespace storage {
31 class BlobStorageContext; 31 class BlobStorageContext;
32 } 32 }
33 33
34 namespace content { 34 namespace content {
35 35
36 class ResourceContext; 36 class ResourceContext;
37 struct ResourceRequest;
37 class ResourceRequestBodyImpl; 38 class ResourceRequestBodyImpl;
38 class ServiceWorkerContextCore; 39 class ServiceWorkerContextCore;
39 class ServiceWorkerContextWrapper; 40 class ServiceWorkerContextWrapper;
40 class ServiceWorkerNavigationHandleCore; 41 class ServiceWorkerNavigationHandleCore;
41 class ServiceWorkerProviderHost; 42 class ServiceWorkerProviderHost;
42 class WebContents; 43 class WebContents;
43 44
44 // Abstract base class for routing network requests to ServiceWorkers. 45 // Abstract base class for routing network requests to ServiceWorkers.
45 // Created one per URLRequest and attached to each request. 46 // Created one per URLRequest and attached to each request.
46 class CONTENT_EXPORT ServiceWorkerRequestHandler 47 class CONTENT_EXPORT ServiceWorkerRequestHandler
47 : public base::SupportsUserData::Data { 48 : public base::SupportsUserData::Data {
48 public: 49 public:
49 // PlzNavigate 50 // PlzNavigate
50 // Attaches a newly created handler if the given |request| needs to be handled 51 // Attaches a newly created handler if the given |request| needs to be handled
51 // by ServiceWorker. 52 // by ServiceWorker.
52 static void InitializeForNavigation( 53 static void InitializeForNavigation(
53 net::URLRequest* request, 54 net::URLRequest* url_request,
54 ServiceWorkerNavigationHandleCore* navigation_handle_core, 55 ServiceWorkerNavigationHandleCore* navigation_handle_core,
55 storage::BlobStorageContext* blob_storage_context, 56 storage::BlobStorageContext* blob_storage_context,
56 bool skip_service_worker, 57 bool skip_service_worker,
57 ResourceType resource_type, 58 ResourceType resource_type,
58 RequestContextType request_context_type, 59 RequestContextType request_context_type,
59 RequestContextFrameType frame_type, 60 RequestContextFrameType frame_type,
60 bool is_parent_frame_secure, 61 bool is_parent_frame_secure,
61 scoped_refptr<ResourceRequestBodyImpl> body, 62 scoped_refptr<ResourceRequestBodyImpl> body,
62 const base::Callback<WebContents*(void)>& web_contents_getter); 63 const base::Callback<WebContents*(void)>& web_contents_getter);
63 64
64 // PlzNavigate and --enable-network-service. 65 // PlzNavigate and --enable-network-service.
65 // Same as InitializeForNavigation() but instead of attaching to a URLRequest, 66 // Same as InitializeForNavigation() but instead of attaching to a URLRequest,
66 // returns a URLLoaderFactoryPtrInfo if the request needs to be handled. 67 // TODO(falken): is comment wrong?
67 static mojom::URLLoaderFactoryPtr InitializeForNavigationNetworkService( 68 static mojom::URLLoaderFactoryPtr InitializeForNavigationNetworkService(
68 const ResourceRequest& resource_request, 69 const ResourceRequest& resource_request,
69 ResourceContext* resource_context, 70 ResourceContext* resource_context,
70 ServiceWorkerNavigationHandleCore* navigation_handle_core, 71 ServiceWorkerNavigationHandleCore* navigation_handle_core,
71 storage::BlobStorageContext* blob_storage_context, 72 storage::BlobStorageContext* blob_storage_context,
72 bool skip_service_worker, 73 bool skip_service_worker,
73 ResourceType resource_type, 74 ResourceType resource_type,
74 RequestContextType request_context_type, 75 RequestContextType request_context_type,
75 RequestContextFrameType frame_type, 76 RequestContextFrameType frame_type,
76 bool is_parent_frame_secure, 77 bool is_parent_frame_secure,
77 scoped_refptr<ResourceRequestBodyImpl> body, 78 scoped_refptr<ResourceRequestBodyImpl> body,
79 #if 0
80 const base::Callback<WebContents*(void)>& web_contents_getter,
81 NetworkFallbackCallback network_fallback_callback);
82 #endif
78 const base::Callback<WebContents*(void)>& web_contents_getter); 83 const base::Callback<WebContents*(void)>& web_contents_getter);
79 84
80 // Attaches a newly created handler if the given |request| needs to 85 // Attaches a newly created handler if the given |request| needs to
81 // be handled by ServiceWorker. 86 // be handled by ServiceWorker.
82 // TODO(kinuko): While utilizing UserData to attach data to URLRequest 87 // TODO(kinuko): While utilizing UserData to attach data to URLRequest
83 // has some precedence, it might be better to attach this handler in a more 88 // has some precedence, it might be better to attach this handler in a more
84 // explicit way within content layer, e.g. have ResourceRequestInfoImpl 89 // explicit way within content layer, e.g. have ResourceRequestInfoImpl
85 // own it. 90 // own it.
86 static void InitializeHandler( 91 static void InitializeHandler(
87 net::URLRequest* request, 92 net::URLRequest* request,
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
119 const net::URLRequest* request); 124 const net::URLRequest* request);
120 125
121 ~ServiceWorkerRequestHandler() override; 126 ~ServiceWorkerRequestHandler() override;
122 127
123 // Called via custom URLRequestJobFactory. 128 // Called via custom URLRequestJobFactory.
124 virtual net::URLRequestJob* MaybeCreateJob( 129 virtual net::URLRequestJob* MaybeCreateJob(
125 net::URLRequest* request, 130 net::URLRequest* request,
126 net::NetworkDelegate* network_delegate, 131 net::NetworkDelegate* network_delegate,
127 ResourceContext* context) = 0; 132 ResourceContext* context) = 0;
128 133
134 virtual mojom::URLLoaderFactoryPtr MaybeGetURLLoaderFactory(
135 const ResourceRequest& resource_request,
136 ResourceContext* resource_context,
137 std::unique_ptr<ServiceWorkerRequestHandler> request_handler);
138
129 // Methods to support cross site navigations. 139 // Methods to support cross site navigations.
130 void PrepareForCrossSiteTransfer(int old_process_id); 140 void PrepareForCrossSiteTransfer(int old_process_id);
131 void CompleteCrossSiteTransfer(int new_process_id, 141 void CompleteCrossSiteTransfer(int new_process_id,
132 int new_provider_id); 142 int new_provider_id);
133 void MaybeCompleteCrossSiteTransferInOldProcess( 143 void MaybeCompleteCrossSiteTransferInOldProcess(
134 int old_process_id); 144 int old_process_id);
135 145
136 // Useful for detecting storage partition mismatches in the context of cross 146 // Useful for detecting storage partition mismatches in the context of cross
137 // site transfer navigations. 147 // site transfer navigations.
138 bool SanityCheckIsSameContext(ServiceWorkerContextWrapper* wrapper); 148 bool SanityCheckIsSameContext(ServiceWorkerContextWrapper* wrapper);
139 149
140 protected: 150 protected:
141 ServiceWorkerRequestHandler( 151 ServiceWorkerRequestHandler(
142 base::WeakPtr<ServiceWorkerContextCore> context, 152 base::WeakPtr<ServiceWorkerContextCore> context,
143 base::WeakPtr<ServiceWorkerProviderHost> provider_host, 153 base::WeakPtr<ServiceWorkerProviderHost> provider_host,
144 base::WeakPtr<storage::BlobStorageContext> blob_storage_context, 154 base::WeakPtr<storage::BlobStorageContext> blob_storage_context,
145 ResourceType resource_type); 155 ResourceType resource_type);
146 156
147 base::WeakPtr<ServiceWorkerContextCore> context_; 157 base::WeakPtr<ServiceWorkerContextCore> context_;
148 base::WeakPtr<ServiceWorkerProviderHost> provider_host_; 158 base::WeakPtr<ServiceWorkerProviderHost> provider_host_;
149 base::WeakPtr<storage::BlobStorageContext> blob_storage_context_; 159 base::WeakPtr<storage::BlobStorageContext> blob_storage_context_;
150 ResourceType resource_type_; 160 ResourceType resource_type_;
151 161
152 private: 162 private:
163 static std::unique_ptr<ServiceWorkerRequestHandler>
164 InitializeForNavigationInternal(
165 const GURL& url,
166 ServiceWorkerNavigationHandleCore* navigation_handle_core,
167 storage::BlobStorageContext* blob_storage_context,
168 bool skip_service_worker,
169 ResourceType resource_type,
170 RequestContextType request_context_type,
171 RequestContextFrameType frame_type,
172 bool is_parent_frame_secure,
173 scoped_refptr<ResourceRequestBodyImpl> body,
174 #if 0
175 const base::Callback<WebContents*(void)>& web_contents_getter,
176 NetworkFallbackCallback network_fallback_callback);
177 #endif
178 const base::Callback<WebContents*(void)>& web_contents_getter);
179
153 std::unique_ptr<ServiceWorkerProviderHost> host_for_cross_site_transfer_; 180 std::unique_ptr<ServiceWorkerProviderHost> host_for_cross_site_transfer_;
154 int old_process_id_; 181 int old_process_id_;
155 int old_provider_id_; 182 int old_provider_id_;
156 183
157 DISALLOW_COPY_AND_ASSIGN(ServiceWorkerRequestHandler); 184 DISALLOW_COPY_AND_ASSIGN(ServiceWorkerRequestHandler);
158 }; 185 };
159 186
160 } // namespace content 187 } // namespace content
161 188
162 #endif // CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_ 189 #endif // CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_REQUEST_HANDLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698