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 #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 Loading... | |
| 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 |
| OLD | NEW |