| 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 <stdint.h> | 8 #include <stdint.h> |
| 9 | 9 |
| 10 #include <string> | 10 #include <string> |
| 11 | 11 |
| 12 #include "base/memory/ref_counted.h" |
| 12 #include "base/time/time.h" | 13 #include "base/time/time.h" |
| 13 #include "build/build_config.h" | 14 #include "build/build_config.h" |
| 14 #include "content/common/content_export.h" | 15 #include "content/common/content_export.h" |
| 15 #include "content/common/frame_message_enums.h" | 16 #include "content/common/frame_message_enums.h" |
| 17 #include "content/common/resource_request_body.h" |
| 16 #include "content/public/common/page_state.h" | 18 #include "content/public/common/page_state.h" |
| 17 #include "content/public/common/referrer.h" | 19 #include "content/public/common/referrer.h" |
| 18 #include "content/public/common/request_context_type.h" | 20 #include "content/public/common/request_context_type.h" |
| 19 #include "ui/base/page_transition_types.h" | 21 #include "ui/base/page_transition_types.h" |
| 20 #include "url/gurl.h" | 22 #include "url/gurl.h" |
| 21 | 23 |
| 22 namespace content { | 24 namespace content { |
| 23 | 25 |
| 24 // The LoFi state which determines whether to add the Lo-Fi header. | 26 // The LoFi state which determines whether to add the Lo-Fi header. |
| 25 enum LoFiState { | 27 enum LoFiState { |
| (...skipping 27 matching lines...) Expand all Loading... |
| 53 ui::PageTransition transition, | 55 ui::PageTransition transition, |
| 54 FrameMsg_Navigate_Type::Value navigation_type, | 56 FrameMsg_Navigate_Type::Value navigation_type, |
| 55 bool allow_download, | 57 bool allow_download, |
| 56 bool should_replace_current_entry, | 58 bool should_replace_current_entry, |
| 57 base::TimeTicks ui_timestamp, | 59 base::TimeTicks ui_timestamp, |
| 58 FrameMsg_UILoadMetricsReportType::Value report_type, | 60 FrameMsg_UILoadMetricsReportType::Value report_type, |
| 59 const GURL& base_url_for_data_url, | 61 const GURL& base_url_for_data_url, |
| 60 const GURL& history_url_for_data_url, | 62 const GURL& history_url_for_data_url, |
| 61 LoFiState lofi_state, | 63 LoFiState lofi_state, |
| 62 const base::TimeTicks& navigation_start, | 64 const base::TimeTicks& navigation_start, |
| 63 std::string method); | 65 std::string method, |
| 66 const scoped_refptr<ResourceRequestBody>& post_data); |
| 64 CommonNavigationParams(const CommonNavigationParams& other); | 67 CommonNavigationParams(const CommonNavigationParams& other); |
| 65 ~CommonNavigationParams(); | 68 ~CommonNavigationParams(); |
| 66 | 69 |
| 67 // The URL to navigate to. | 70 // The URL to navigate to. |
| 68 // PlzNavigate: May be modified when the navigation is ready to commit. | 71 // PlzNavigate: May be modified when the navigation is ready to commit. |
| 69 GURL url; | 72 GURL url; |
| 70 | 73 |
| 71 // The URL to send in the "Referer" header field. Can be empty if there is | 74 // The URL to send in the "Referer" header field. Can be empty if there is |
| 72 // no referrer. | 75 // no referrer. |
| 73 Referrer referrer; | 76 Referrer referrer; |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 | 114 |
| 112 // The navigationStart time exposed through the Navigation Timing API to JS. | 115 // The navigationStart time exposed through the Navigation Timing API to JS. |
| 113 // If this is for a browser-initiated navigation, this can override the | 116 // If this is for a browser-initiated navigation, this can override the |
| 114 // navigation_start value in Blink. | 117 // navigation_start value in Blink. |
| 115 // PlzNavigate: For renderer initiated navigations, this will be set on the | 118 // PlzNavigate: For renderer initiated navigations, this will be set on the |
| 116 // renderer side and sent with FrameHostMsg_BeginNavigation. | 119 // renderer side and sent with FrameHostMsg_BeginNavigation. |
| 117 base::TimeTicks navigation_start; | 120 base::TimeTicks navigation_start; |
| 118 | 121 |
| 119 // The request method: GET, POST, etc. | 122 // The request method: GET, POST, etc. |
| 120 std::string method; | 123 std::string method; |
| 124 |
| 125 // Body of HTTP POST request. |
| 126 scoped_refptr<ResourceRequestBody> post_data; |
| 121 }; | 127 }; |
| 122 | 128 |
| 123 // Provided by the renderer ---------------------------------------------------- | 129 // Provided by the renderer ---------------------------------------------------- |
| 124 // | 130 // |
| 125 // This struct holds parameters sent by the renderer to the browser. It is only | 131 // This struct holds parameters sent by the renderer to the browser. It is only |
| 126 // used in PlzNavigate (since in the current architecture, the renderer does not | 132 // used in PlzNavigate (since in the current architecture, the renderer does not |
| 127 // inform the browser of navigations until they commit). | 133 // inform the browser of navigations until they commit). |
| 128 | 134 |
| 129 // This struct is not used outside of the PlzNavigate project. | 135 // This struct is not used outside of the PlzNavigate project. |
| 130 // PlzNavigate: parameters needed to start a navigation on the IO thread, | 136 // PlzNavigate: parameters needed to start a navigation on the IO thread, |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 165 // architecture should go in StartNavigationParams. | 171 // architecture should go in StartNavigationParams. |
| 166 | 172 |
| 167 // Used by FrameMsg_Navigate. Holds the parameters needed by the renderer to | 173 // Used by FrameMsg_Navigate. Holds the parameters needed by the renderer to |
| 168 // start a browser-initiated navigation besides those in CommonNavigationParams. | 174 // start a browser-initiated navigation besides those in CommonNavigationParams. |
| 169 // The difference with the RequestNavigationParams below is that they are only | 175 // The difference with the RequestNavigationParams below is that they are only |
| 170 // used in the current architecture of navigation, and will not be used by | 176 // used in the current architecture of navigation, and will not be used by |
| 171 // PlzNavigate. | 177 // PlzNavigate. |
| 172 // PlzNavigate: These are not used. | 178 // PlzNavigate: These are not used. |
| 173 struct CONTENT_EXPORT StartNavigationParams { | 179 struct CONTENT_EXPORT StartNavigationParams { |
| 174 StartNavigationParams(); | 180 StartNavigationParams(); |
| 175 StartNavigationParams( | 181 StartNavigationParams(const std::string& extra_headers, |
| 176 const std::string& extra_headers, | |
| 177 const std::vector<unsigned char>& browser_initiated_post_data, | |
| 178 #if defined(OS_ANDROID) | 182 #if defined(OS_ANDROID) |
| 179 bool has_user_gesture, | 183 bool has_user_gesture, |
| 180 #endif | 184 #endif |
| 181 int transferred_request_child_id, | 185 int transferred_request_child_id, |
| 182 int transferred_request_request_id); | 186 int transferred_request_request_id); |
| 183 StartNavigationParams(const StartNavigationParams& other); | 187 StartNavigationParams(const StartNavigationParams& other); |
| 184 ~StartNavigationParams(); | 188 ~StartNavigationParams(); |
| 185 | 189 |
| 186 // Extra headers (separated by \n) to send during the request. | 190 // Extra headers (separated by \n) to send during the request. |
| 187 std::string extra_headers; | 191 std::string extra_headers; |
| 188 | 192 |
| 189 // If is_post is true, holds the post_data information from browser. Empty | |
| 190 // otherwise. | |
| 191 std::vector<unsigned char> browser_initiated_post_data; | |
| 192 | |
| 193 #if defined(OS_ANDROID) | 193 #if defined(OS_ANDROID) |
| 194 bool has_user_gesture; | 194 bool has_user_gesture; |
| 195 #endif | 195 #endif |
| 196 | 196 |
| 197 // The following two members identify a previous request that has been | 197 // The following two members identify a previous request that has been |
| 198 // created before this navigation is being transferred to a new render view. | 198 // created before this navigation is being transferred to a new render view. |
| 199 // This serves the purpose of recycling the old request. | 199 // This serves the purpose of recycling the old request. |
| 200 // Unless this refers to a transferred navigation, these values are -1 and -1. | 200 // Unless this refers to a transferred navigation, these values are -1 and -1. |
| 201 int transferred_request_child_id; | 201 int transferred_request_child_id; |
| 202 int transferred_request_request_id; | 202 int transferred_request_request_id; |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 322 ~NavigationParams(); | 322 ~NavigationParams(); |
| 323 | 323 |
| 324 CommonNavigationParams common_params; | 324 CommonNavigationParams common_params; |
| 325 StartNavigationParams start_params; | 325 StartNavigationParams start_params; |
| 326 RequestNavigationParams request_params; | 326 RequestNavigationParams request_params; |
| 327 }; | 327 }; |
| 328 | 328 |
| 329 } // namespace content | 329 } // namespace content |
| 330 | 330 |
| 331 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ | 331 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| OLD | NEW |