... |
... |
@@ -155,12 +155,28 @@ class GeckoEngineSession( |
155
|
155
|
return
|
156
|
156
|
}
|
157
|
157
|
|
|
158
|
+ // Bug 40070: Temporarily redirect DW's v2 address to their new v3 address
|
|
159
|
+ val currentHost = Uri.parse(url).host
|
|
160
|
+ logger.error("loadUrl: url: " + url)
|
|
161
|
+ logger.error("loadUrl: URL hostname: " + currentHost)
|
|
162
|
+ logger.error("loadUrl: V2_DW hostname: " + V2_DW_ADDRESS)
|
|
163
|
+
|
|
164
|
+ val newUrl = if (currentHost != null && currentHost.endsWith(V2_DW_ADDRESS)) {
|
|
165
|
+ logger.error("loadUrl: Found DW v2 address")
|
|
166
|
+ val newHost = currentHost.replace(V2_DW_ADDRESS, V3_DW_ADDRESS)
|
|
167
|
+ url.replaceFirst(currentHost, newHost)
|
|
168
|
+ } else {
|
|
169
|
+ url
|
|
170
|
+ }
|
|
171
|
+
|
|
172
|
+ logger.error("loadUrl: new url: " + newUrl)
|
|
173
|
+
|
158
|
174
|
if (initialLoad) {
|
159
|
|
- initialLoadRequest = LoadRequest(url, parent, flags, additionalHeaders)
|
|
175
|
+ initialLoadRequest = LoadRequest(newUrl, parent, flags, additionalHeaders)
|
160
|
176
|
}
|
161
|
177
|
|
162
|
178
|
val loader = GeckoSession.Loader()
|
163
|
|
- .uri(url)
|
|
179
|
+ .uri(newUrl)
|
164
|
180
|
.flags(flags.value)
|
165
|
181
|
|
166
|
182
|
if (additionalHeaders != null) {
|
... |
... |
@@ -1092,6 +1108,8 @@ class GeckoEngineSession( |
1092
|
1108
|
internal const val MOZ_NULL_PRINCIPAL = "moz-nullprincipal:"
|
1093
|
1109
|
internal const val ABOUT_BLANK = "about:blank"
|
1094
|
1110
|
internal val BLOCKED_SCHEMES = listOf("content", "file", "resource") // See 1684761 and 1684947
|
|
1111
|
+ internal const val V2_DW_ADDRESS = "dwnewsvdyyiamwnp.onion"
|
|
1112
|
+ internal const val V3_DW_ADDRESS = "dwnewsgngmhlplxy6o2twtfgjnrnjxbegbwqx6wnotdhkzt562tszfid.onion"
|
1095
|
1113
|
|
1096
|
1114
|
/**
|
1097
|
1115
|
* Provides an ErrorType corresponding to the error code provided.
|