| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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_JOB_WRAPPER_H_ | 5 #ifndef CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_WRAPPER_H_ |
| 6 #define CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_WRAPPER_H_ | 6 #define CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_WRAPPER_H_ |
| 7 | 7 |
| 8 #include "base/macros.h" | 8 #include "base/macros.h" |
| 9 #include "base/memory/weak_ptr.h" |
| 10 #include "content/browser/loader/url_loader_request_handler.h" |
| 11 #include "content/browser/service_worker/service_worker_response_type.h" |
| 9 #include "content/browser/service_worker/service_worker_url_request_job.h" | 12 #include "content/browser/service_worker/service_worker_url_request_job.h" |
| 10 | 13 |
| 11 namespace content { | 14 namespace content { |
| 12 | 15 |
| 13 // TODO(scottmg): Not yet implemented. See https://crbug.com/715640. | |
| 14 class ServiceWorkerControlleeURLLoader; | |
| 15 | |
| 16 // This class is a helper to support having | 16 // This class is a helper to support having |
| 17 // ServiceWorkerControlleeRequestHandler work with both URLRequestJobs and | 17 // ServiceWorkerControlleeRequestHandler work with both URLRequestJobs and |
| 18 // mojom::URLLoaderFactorys (that is, both with and without | 18 // mojom::URLLoaderFactorys (that is, both with and without |
| 19 // --enable-network-service). It wraps either a ServiceWorkerURLRequestJob or a | 19 // --enable-network-service). It wraps either a ServiceWorkerURLRequestJob or a |
| 20 // ServiceWorkerControlleeRequestHandler and forwards to the underlying | 20 // callback for URLLoaderFactory and forwards to the underlying implementation. |
| 21 // implementation. | |
| 22 class ServiceWorkerURLJobWrapper { | 21 class ServiceWorkerURLJobWrapper { |
| 23 public: | 22 public: |
| 24 // Non-network service case. | 23 // Non-network service case. |
| 25 explicit ServiceWorkerURLJobWrapper( | 24 explicit ServiceWorkerURLJobWrapper( |
| 26 base::WeakPtr<ServiceWorkerURLRequestJob> url_request_job); | 25 base::WeakPtr<ServiceWorkerURLRequestJob> url_request_job); |
| 27 | 26 |
| 28 // With --enable-network-service. | 27 // With --enable-network-service. |
| 29 explicit ServiceWorkerURLJobWrapper( | 28 // TODO(kinuko): Implement this as a separate job class rather |
| 30 ServiceWorkerControlleeURLLoader* url_loader); | 29 // than in a wrapper. |
| 30 ServiceWorkerURLJobWrapper(LoaderFactoryCallback loader_factory_callback); |
| 31 | 31 |
| 32 ~ServiceWorkerURLJobWrapper(); | 32 ~ServiceWorkerURLJobWrapper(); |
| 33 | 33 |
| 34 // Sets the response type. | 34 // Sets the response type. |
| 35 void FallbackToNetwork(); | 35 void FallbackToNetwork(); |
| 36 void FallbackToNetworkOrRenderer(); | 36 void FallbackToNetworkOrRenderer(); |
| 37 void ForwardToServiceWorker(); | 37 void ForwardToServiceWorker(); |
| 38 | 38 |
| 39 // Returns true if this job should not be handled by a service worker, but | 39 // Returns true if this job should not be handled by a service worker, but |
| 40 // instead should fallback to the network. | 40 // instead should fallback to the network. |
| 41 bool ShouldFallbackToNetwork(); | 41 bool ShouldFallbackToNetwork(); |
| 42 | 42 |
| 43 // Tells the job to abort with a start error. Currently this is only called | 43 // Tells the job to abort with a start error. Currently this is only called |
| 44 // because the controller was lost. This function could be made more generic | 44 // because the controller was lost. This function could be made more generic |
| 45 // if needed later. | 45 // if needed later. |
| 46 void FailDueToLostController(); | 46 void FailDueToLostController(); |
| 47 | 47 |
| 48 // Determines from the ResourceRequestInfo (or similar) the type of page | 48 // Determines from the ResourceRequestInfo (or similar) the type of page |
| 49 // transition used (for metrics purposes). | 49 // transition used (for metrics purposes). |
| 50 ui::PageTransition GetPageTransition(); | 50 ui::PageTransition GetPageTransition(); |
| 51 | 51 |
| 52 // Determines the number of redirects used to handle the job (for metrics | 52 // Determines the number of redirects used to handle the job (for metrics |
| 53 // purposes). | 53 // purposes). |
| 54 size_t GetURLChainSize() const; | 54 size_t GetURLChainSize() const; |
| 55 | 55 |
| 56 // Returns true if the underlying job has been canceled or destroyed. | 56 // Returns true if the underlying job has been canceled or destroyed. |
| 57 bool WasCanceled() const; | 57 bool WasCanceled() const; |
| 58 | 58 |
| 59 private: | 59 private: |
| 60 enum class JobType { kURLRequest, kURLLoader }; |
| 61 |
| 62 // Used only for URLLoader case. |
| 63 // TODO(kinuko): Implement this in a separate job class rather |
| 64 // than in a wrapper. |
| 65 void StartRequest(); |
| 66 |
| 67 JobType job_type_; |
| 68 |
| 69 ServiceWorkerResponseType response_type_ = NOT_DETERMINED; |
| 70 LoaderFactoryCallback loader_factory_callback_; |
| 71 |
| 60 base::WeakPtr<ServiceWorkerURLRequestJob> url_request_job_; | 72 base::WeakPtr<ServiceWorkerURLRequestJob> url_request_job_; |
| 61 ServiceWorkerControlleeURLLoader* url_loader_; | 73 |
| 74 base::WeakPtrFactory<ServiceWorkerURLJobWrapper> weak_factory_; |
| 62 | 75 |
| 63 DISALLOW_COPY_AND_ASSIGN(ServiceWorkerURLJobWrapper); | 76 DISALLOW_COPY_AND_ASSIGN(ServiceWorkerURLJobWrapper); |
| 64 }; | 77 }; |
| 65 | 78 |
| 66 } // namespace content | 79 } // namespace content |
| 67 | 80 |
| 68 #endif // CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_WRAPPER_H_ | 81 #endif // CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_WRAPPER_H_ |
| OLD | NEW |