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

Side by Side Diff: components/sessions/ios/ios_serialized_navigation_driver.cc

Issue 869613006: Move referrer policy to a different field when serializing. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 10 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 #include "components/sessions/ios/ios_serialized_navigation_driver.h" 5 #include "components/sessions/ios/ios_serialized_navigation_driver.h"
6 6
7 #include "base/memory/singleton.h" 7 #include "base/memory/singleton.h"
8 #include "components/sessions/serialized_navigation_entry.h" 8 #include "components/sessions/serialized_navigation_entry.h"
9 #include "ios/web/public/referrer.h" 9 #include "ios/web/public/referrer.h"
10 10
(...skipping 14 matching lines...) Expand all
25 IOSSerializedNavigationDriver::IOSSerializedNavigationDriver() { 25 IOSSerializedNavigationDriver::IOSSerializedNavigationDriver() {
26 } 26 }
27 27
28 IOSSerializedNavigationDriver::~IOSSerializedNavigationDriver() { 28 IOSSerializedNavigationDriver::~IOSSerializedNavigationDriver() {
29 } 29 }
30 30
31 int IOSSerializedNavigationDriver::GetDefaultReferrerPolicy() const { 31 int IOSSerializedNavigationDriver::GetDefaultReferrerPolicy() const {
32 return web::ReferrerPolicyDefault; 32 return web::ReferrerPolicyDefault;
33 } 33 }
34 34
35 bool ContentSerializedNavigationDriver::MapReferrerPolicyToOldValues(
marja 2015/01/29 10:54:20 Why does this code have to be in both drivers - is
jochen (gone - plz use gerrit) 2015/01/29 10:59:30 it's not! One uses web::ReferrerPolicy*, the othe
36 int referrer_policy,
37 int* mapped_referrer_policy) const {
38 // "always" and "default" are the same value in all versions.
39 if (referrer_policy == web::ReferrerPolicyAlways ||
40 referrer_policy == web::ReferrerPolicyDefault) {
41 *mapped_referrer_policy = referrer_policy;
42 return true;
43 }
44
45 // "origin" exists in the old encoding.
46 if (referrer_policy == web::ReferrerPolicyOrigin) {
47 *mapped_referrer_policy = 3;
48 return true;
49 }
50
51 // Everything else is mapped to never.
52 *mapped_referrer_policy = 2;
53 return false;
54 }
55
56 bool ContentSerializedNavigationDriver::MapReferrerPolicyToNewValues(
57 int referrer_policy,
58 int* mapped_referrer_policy) const {
59 // "always" and "default" are the same value in all versions.
60 if (referrer_policy == 0 || referrer_policy == 1) {
61 *mapped_referrer_policy = referrer_policy;
62 return true;
63 }
64
65 // Since we don't know what encoding was used, we map the rest to "never".
66 *mapped_referrer_policy = web::ReferrerPolicyNever;
67 return false;
68 }
69
35 std::string 70 std::string
36 IOSSerializedNavigationDriver::GetSanitizedPageStateForPickle( 71 IOSSerializedNavigationDriver::GetSanitizedPageStateForPickle(
37 const SerializedNavigationEntry* navigation) const { 72 const SerializedNavigationEntry* navigation) const {
38 return std::string(); 73 return std::string();
39 } 74 }
40 75
41 void IOSSerializedNavigationDriver::Sanitize( 76 void IOSSerializedNavigationDriver::Sanitize(
42 SerializedNavigationEntry* navigation) const { 77 SerializedNavigationEntry* navigation) const {
43 web::Referrer referrer( 78 web::Referrer referrer(
44 navigation->referrer_url_, 79 navigation->referrer_url_,
45 static_cast<web::ReferrerPolicy>(navigation->referrer_policy_)); 80 static_cast<web::ReferrerPolicy>(navigation->referrer_policy_));
46 81
47 if (!navigation->virtual_url_.SchemeIsHTTPOrHTTPS() || 82 if (!navigation->virtual_url_.SchemeIsHTTPOrHTTPS() ||
48 !referrer.url.SchemeIsHTTPOrHTTPS()) { 83 !referrer.url.SchemeIsHTTPOrHTTPS()) {
49 referrer.url = GURL(); 84 referrer.url = GURL();
50 } else { 85 } else {
86 if (referrer.policy < 0 || referrer.policy > web::ReferrerPolicyLast) {
87 NOTREACHED();
88 referrer.policy = web::ReferrerPolicyNever;
89 }
90 bool is_downgrade = referrer.url.SchemeIsSecure() &&
91 !navigation->virtual_url_.SchemeIsSecure();
51 switch (referrer.policy) { 92 switch (referrer.policy) {
52 case web::ReferrerPolicyDefault: 93 case web::ReferrerPolicyDefault:
53 if (referrer.url.SchemeIsSecure() && 94 if (is_downgrade)
54 !navigation->virtual_url_.SchemeIsSecure()) {
55 referrer.url = GURL(); 95 referrer.url = GURL();
56 }
57 break; 96 break;
97 case web::ReferrerPolicyNoReferrerWhenDowngrade:
98 if (is_downgrade)
99 referrer.url = GURL();
58 case web::ReferrerPolicyAlways: 100 case web::ReferrerPolicyAlways:
59 break; 101 break;
60 case web::ReferrerPolicyNever: 102 case web::ReferrerPolicyNever:
61 referrer.url = GURL(); 103 referrer.url = GURL();
62 break; 104 break;
63 case web::ReferrerPolicyOrigin: 105 case web::ReferrerPolicyOrigin:
64 referrer.url = referrer.url.GetOrigin(); 106 referrer.url = referrer.url.GetOrigin();
65 break; 107 break;
66 default: 108 case web::ReferrerPolicyOriginWhenCrossOrigin:
marja 2015/01/29 10:54:20 Why no default case anymore?
jochen (gone - plz use gerrit) 2015/01/29 10:59:30 so the compiler catches the case when an enum valu
67 NOTREACHED(); 109 if (navigation.virtual_url_.GetOrigin() != referrer.url.GetOrigin())
110 referrer.url = referrer.url.GetOrigin();
68 break; 111 break;
69 } 112 }
70 } 113 }
71 114
72 // Reset the referrer if it has changed. 115 // Reset the referrer if it has changed.
73 if (navigation->referrer_url_ != referrer.url) { 116 if (navigation->referrer_url_ != referrer.url) {
74 navigation->referrer_url_ = GURL(); 117 navigation->referrer_url_ = GURL();
75 navigation->referrer_policy_ = GetDefaultReferrerPolicy(); 118 navigation->referrer_policy_ = GetDefaultReferrerPolicy();
76 } 119 }
77 } 120 }
78 121
79 } // namespace sessions 122 } // namespace sessions
OLDNEW
« no previous file with comments | « components/sessions/ios/ios_serialized_navigation_driver.h ('k') | components/sessions/serialized_navigation_entry.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698