Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_COMMON_NAVIGATION_PARAMS_H_ | 5 #ifndef CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| 6 #define CONTENT_COMMON_NAVIGATION_PARAMS_H_ | 6 #define CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/time/time.h" | 11 #include "base/time/time.h" |
| 12 #include "content/common/content_export.h" | 12 #include "content/common/content_export.h" |
| 13 #include "content/common/frame_message_enums.h" | 13 #include "content/common/frame_message_enums.h" |
| 14 #include "content/common/service_worker/service_worker_types.h" | |
| 14 #include "content/public/common/page_state.h" | 15 #include "content/public/common/page_state.h" |
| 15 #include "content/public/common/referrer.h" | 16 #include "content/public/common/referrer.h" |
| 17 #include "content/public/common/request_context_frame_type.h" | |
| 18 #include "content/public/common/request_context_type.h" | |
| 16 #include "ui/base/page_transition_types.h" | 19 #include "ui/base/page_transition_types.h" |
| 17 #include "url/gurl.h" | 20 #include "url/gurl.h" |
| 18 | 21 |
| 19 namespace base { | 22 namespace base { |
| 20 class RefCountedMemory; | 23 class RefCountedMemory; |
| 21 } | 24 } |
| 22 | 25 |
| 23 namespace content { | 26 namespace content { |
| 24 | 27 |
| 25 // PlzNavigate | 28 // PlzNavigate |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 39 CommonNavigationParams(); | 42 CommonNavigationParams(); |
| 40 CommonNavigationParams(const GURL& url, | 43 CommonNavigationParams(const GURL& url, |
| 41 const Referrer& referrer, | 44 const Referrer& referrer, |
| 42 ui::PageTransition transition, | 45 ui::PageTransition transition, |
| 43 FrameMsg_Navigate_Type::Value navigation_type, | 46 FrameMsg_Navigate_Type::Value navigation_type, |
| 44 bool allow_download, | 47 bool allow_download, |
| 45 bool should_replace_current_entry, | 48 bool should_replace_current_entry, |
| 46 base::TimeTicks ui_timestamp, | 49 base::TimeTicks ui_timestamp, |
| 47 FrameMsg_UILoadMetricsReportType::Value report_type, | 50 FrameMsg_UILoadMetricsReportType::Value report_type, |
| 48 const GURL& base_url_for_data_url, | 51 const GURL& base_url_for_data_url, |
| 49 const GURL& history_url_for_data_url); | 52 const GURL& history_url_for_data_url, |
| 53 int service_worker_provider_id); | |
|
michaeln
2015/09/01 01:15:23
browser_initiated_nav_id
| |
| 50 ~CommonNavigationParams(); | 54 ~CommonNavigationParams(); |
| 51 | 55 |
| 52 // The URL to navigate to. | 56 // The URL to navigate to. |
| 53 // PlzNavigate: May be modified when the navigation is ready to commit. | 57 // PlzNavigate: May be modified when the navigation is ready to commit. |
| 54 GURL url; | 58 GURL url; |
| 55 | 59 |
| 56 // The URL to send in the "Referer" header field. Can be empty if there is | 60 // The URL to send in the "Referer" header field. Can be empty if there is |
| 57 // no referrer. | 61 // no referrer. |
| 58 Referrer referrer; | 62 Referrer referrer; |
| 59 | 63 |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 82 // The report type to be used when recording the metric using |ui_timestamp|. | 86 // The report type to be used when recording the metric using |ui_timestamp|. |
| 83 FrameMsg_UILoadMetricsReportType::Value report_type; | 87 FrameMsg_UILoadMetricsReportType::Value report_type; |
| 84 | 88 |
| 85 // Base URL for use in Blink's SubstituteData. | 89 // Base URL for use in Blink's SubstituteData. |
| 86 // Is only used with data: URLs. | 90 // Is only used with data: URLs. |
| 87 GURL base_url_for_data_url; | 91 GURL base_url_for_data_url; |
| 88 | 92 |
| 89 // History URL for use in Blink's SubstituteData. | 93 // History URL for use in Blink's SubstituteData. |
| 90 // Is only used with data: URLs. | 94 // Is only used with data: URLs. |
| 91 GURL history_url_for_data_url; | 95 GURL history_url_for_data_url; |
| 96 | |
| 97 // PlzNavigate | |
| 98 // The ServiceWorker provider ID associated with the navigation. | |
| 99 int service_worker_provider_id; | |
| 92 }; | 100 }; |
| 93 | 101 |
| 94 // Provided by the renderer ---------------------------------------------------- | 102 // Provided by the renderer ---------------------------------------------------- |
| 95 // | 103 // |
| 96 // This struct holds parameters sent by the renderer to the browser. It is only | 104 // This struct holds parameters sent by the renderer to the browser. It is only |
| 97 // used in PlzNavigate (since in the current architecture, the renderer does not | 105 // used in PlzNavigate (since in the current architecture, the renderer does not |
| 98 // inform the browser of navigations until they commit). | 106 // inform the browser of navigations until they commit). |
| 99 | 107 |
| 100 // This struct is not used outside of the PlzNavigate project. | 108 // This struct is not used outside of the PlzNavigate project. |
| 101 // PlzNavigate: parameters needed to start a navigation on the IO thread, | 109 // PlzNavigate: parameters needed to start a navigation on the IO thread, |
| 102 // following a renderer-initiated navigation request. | 110 // following a renderer-initiated navigation request. |
| 103 struct CONTENT_EXPORT BeginNavigationParams { | 111 struct CONTENT_EXPORT BeginNavigationParams { |
| 104 // TODO(clamy): See if it is possible to reuse this in | 112 // TODO(clamy): See if it is possible to reuse this in |
| 105 // ResourceMsg_Request_Params. | 113 // ResourceMsg_Request_Params. |
| 106 BeginNavigationParams(); | 114 BeginNavigationParams(); |
| 107 BeginNavigationParams(std::string method, | 115 BeginNavigationParams(std::string method, |
| 108 std::string headers, | 116 std::string headers, |
| 109 int load_flags, | 117 int load_flags, |
| 110 bool has_user_gesture); | 118 bool has_user_gesture, |
| 119 bool skip_service_worker, | |
| 120 FetchRequestMode fetch_request_mode, | |
|
nasko
2015/08/20 16:49:50
Can we skip adding some of these? For example, Fet
Fabrice (no longer in Chrome)
2015/08/26 13:23:24
I removed them and DCHEK'd them per clamy's sugges
| |
| 121 FetchCredentialsMode fetch_credentials_mode, | |
| 122 FetchRedirectMode fetch_redirect_mode, | |
| 123 RequestContextType request_context_type, | |
|
nasko
2015/08/20 16:49:50
This one can also be only one of two values, right
Fabrice (no longer in Chrome)
2015/08/26 13:23:24
I did some quick and dirty testing, these are the
| |
| 124 RequestContextFrameType frame_type); | |
| 111 | 125 |
| 112 // The request method: GET, POST, etc. | 126 // The request method: GET, POST, etc. |
| 113 std::string method; | 127 std::string method; |
| 114 | 128 |
| 115 // Additional HTTP request headers. | 129 // Additional HTTP request headers. |
| 116 std::string headers; | 130 std::string headers; |
| 117 | 131 |
| 118 // net::URLRequest load flags (net::LOAD_NORMAL) by default). | 132 // net::URLRequest load flags (net::LOAD_NORMAL) by default). |
| 119 int load_flags; | 133 int load_flags; |
| 120 | 134 |
| 121 // True if the request was user initiated. | 135 // True if the request was user initiated. |
| 122 bool has_user_gesture; | 136 bool has_user_gesture; |
| 137 | |
| 138 // True if the ServiceWorker should be skipped. | |
|
clamy
2015/08/24 12:27:35
In which cases is skip_service_worker set to true?
Fabrice (no longer in Chrome)
2015/08/26 13:23:24
There are a few cases:
-The request was fallbacked
kinuko
2015/08/27 01:37:44
I think your understanding is correct. Fallback ha
| |
| 139 bool skip_service_worker; | |
| 140 | |
| 141 // The request mode passed to the ServiceWorker. | |
| 142 FetchRequestMode fetch_request_mode; | |
| 143 | |
| 144 // The credentials mode passed to the ServiceWorker. | |
| 145 FetchCredentialsMode fetch_credentials_mode; | |
| 146 | |
| 147 // The redirect mode used in Fetch API. | |
| 148 FetchRedirectMode fetch_redirect_mode; | |
| 149 | |
| 150 // Indicates if the current request is the main frame load, a sub-frame | |
| 151 // load, or a sub objects load. | |
| 152 RequestContextType request_context_type; | |
| 153 RequestContextFrameType frame_type; | |
| 123 }; | 154 }; |
| 124 | 155 |
| 125 // Provided by the browser ----------------------------------------------------- | 156 // Provided by the browser ----------------------------------------------------- |
| 126 // | 157 // |
| 127 // These structs are sent by the browser to the renderer to start/commit a | 158 // These structs are sent by the browser to the renderer to start/commit a |
| 128 // navigation depending on whether browser-side navigation is enabled. | 159 // navigation depending on whether browser-side navigation is enabled. |
| 129 // Parameters used both in the current architecture and PlzNavigate should be | 160 // Parameters used both in the current architecture and PlzNavigate should be |
| 130 // put in RequestNavigationParams. Parameters only used by the current | 161 // put in RequestNavigationParams. Parameters only used by the current |
| 131 // architecture should go in StartNavigationParams. | 162 // architecture should go in StartNavigationParams. |
| 132 | 163 |
| (...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 268 ~NavigationParams(); | 299 ~NavigationParams(); |
| 269 | 300 |
| 270 CommonNavigationParams common_params; | 301 CommonNavigationParams common_params; |
| 271 StartNavigationParams start_params; | 302 StartNavigationParams start_params; |
| 272 RequestNavigationParams request_params; | 303 RequestNavigationParams request_params; |
| 273 }; | 304 }; |
| 274 | 305 |
| 275 } // namespace content | 306 } // namespace content |
| 276 | 307 |
| 277 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ | 308 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| OLD | NEW |